-
Notifications
You must be signed in to change notification settings - Fork 96
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Improved detection logic for package manager #171
base: main
Are you sure you want to change the base?
Conversation
b7bab1d
to
5dd3185
Compare
55e6f72
to
ae8ee6c
Compare
lib/install/helpers.rb
Outdated
|
||
helper.run %(#{helper.bundler_run_cmd} #{name}) if run_script | ||
end | ||
}.freeze |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is interesting, but too complicated.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I get what you mean, i commited a new version a bit more simpler to read.
ae8ee6c
to
27e8fd8
Compare
lib/install/helpers.rb
Outdated
when File.exist?("yarn.lock") then :yarn | ||
when File.exist?("bun.lockb") then :bun | ||
when File.exist?("bun.lock") then :bun |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The Bun lockfiles should come before yarn.lock
, since Bun optionally generates a yarn.lock
file.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good catch, i update
…rates a yarn.lock file
Lets review it again, so we fixed #169 |
rails/jsbundling-rails#213 (comment)
Summary
This PR enhances the CSS Bundling Rails gem by implementing comprehensive support for multiple JavaScript package managers (Yarn, Bun, PNPM, and NPM) with improved detection logic and consistent behavior.
Changes
Technical Details
TOOLS_COMMANDS
constant mapping each package manager to its specific commandsSCRIPT_STRATEGIES
to handle package.json script modifications per package managertool_determined_by_config_file
andtool_determined_by_executable
This change enhances developer experience by providing better support for their preferred package manager while maintaining backward compatibility.