-
-
Notifications
You must be signed in to change notification settings - Fork 78
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
Do not add require-dev packages by default #61
Comments
Thanks for posting this issue, I'll use this as a base to link all related PR against 👍 I think we all agree that it makes sense to NOT add require-dev packages by default. While this feature may look easy to implement, it actually has some edge cases we should consider. This has been discussed in some of the open PRs before, so I'll post some of the discussion here for the reference: Upon further inspection I think we should consider a few more things (just listing some random thoughts):
As an alternative approach, we may also look into merely detecting if dev dependencies have been installed. We could then either ask the user to confirm or abort or in the future also suggest installing into a temporary directory without dev dependencies. Any thoughts? |
These are bogus, obviously :) phar-composer will complain if there's no
I think this is the main concern here. Is this really going to cause any issues? We could perhaps consider adding a warning if we detect a dev-dependency has been installed (present in |
@radford raised the question whether this whole change should be considered a BC break (and thus a bump to v2.0) or if we see this as a pure feature addition (v1.1 release). |
well, if it works differently from previous version - then yes - it's BC and major bump should be in place. I just see how people don't want to bump major versions, like it's big difference its version 1 or 2. |
Definitely BC – if It breaks projects relying on the old behavior, e.g.: $ php my.phar test # run unit tests of my.phar |
Thanks for your feedback! In my opinion, not including dev dependencies should be the default as it applies to 95% of use cases. I do not consider this to be a BC break because this is not currently part of this project's BC promise. Existing phars that include any dev dependencies will continue to work as usual. New phars created with the future version will not include them by default anymore. If you need development dependencies, we will add a new This way, the default behavior is sane for most consumers and the behavior is consistent throughout all commands (install vs build). On top of this, this is important because including this project as a dev dependency is becoming increasingly common and you usually don't want to include your build tools in your build artifact. |
For the reference: At the moment, this project will build whatever is installed in the local project directory. This means one can also run $ composer install --no-dev && phar-composer build . && composer install This does work just fine if this project is not installed as a dev dependency itself. If so, the project source needs to be copied to a temporary build directory first. |
Any updates on this? I'm new to PHARing my php files, and I started using this tool to make life easier. I've encountered this issue. Noticed that all the tools used for my units tests, like phpunit, are included in the phar. It should definitely be taken up or allow some way to have phar-composer support a |
See the possible solution above. As much as I'd love to work on an easier solution myself, there are currently no immediate plans to build this from my end (no demand at the moment and more important outstanding issues currently). If you need this for a commercial project and you want to help sponsor this feature, feel free to reach out and I'm happy to take a look. |
So I made a simple "hack" so it only adding requires and not require-devs.
I read in one of the other issues (actually this was a PR #50 ), that it was a good thing to use composer/installed.json because this also had verions.
So I took the best of both worlds.
First load the required package into a list
And inside the loader of the getPackagesDependencies method just add 3 lines to the installed.json loader.
So getPackagesDependencies in my version looks like this
(The loader for the required packages should properly be put into a private method)
For mine 2 projects this actually works perfect, and gives me a 1/3 sized phar file.
Are you interested in a PR ?
The text was updated successfully, but these errors were encountered: