It does exist a command to generate the composer.lock from a composer.json?
Something similar ruby's bundler : $ bundle lock
Now, when you are installing dependencies for the first time and once all the dependencies are resolved successfully, Composer will automatically generate a composer. lock file along with it.
Don't commit the composer. lock file if you are working on a library or package that is intended to be used only as a dependency for other projects, usually in very different projects.
lock file prevents you from automatically getting the latest versions of your dependencies. To update to the latest versions, use the update command. This will fetch the latest matching versions (according to your composer. json file) and update the lock file with the new versions.
composer.lock The answer is "no", you have to generate the lock file using:
composer install Installing Without composer.lock
If you have never run the command before and there is also no composer.lock file present, Composer simply resolves all dependencies listed in your composer.json file and downloads the latest version of their files into the vendor directory in your project.
Source: getcomposer.org
NB Potential Issue: Without the lock file Composer will use the latest version of the dependencies.
composer.lock If you already have a composer.lock and Composer is complaining about it being out of sync, you'll see this warning:
Warning: The lock file is not up to date with the latest changes in composer.json. You may be getting outdated dependencies. Run update to update them.
To fix this you can update the lock file itself, without updating the dependencies. This will only update the content-hash in the lock file:
composer update --lock From the Composer manual:
--lock Only updates the lock file hash to suppress warning about the lock file being out of date.
In v1 running composer update would update lock file and install, there was no option to only write the lock file. Composer v2 has separated the two so composer update will update the lock file but does not download anything.
NB: composer update in v2 will create an updated composer.lock of course, so if you failed to save your composer.lock file from earlier there is still no way of recreating that state, you still have a problem.
Composer v2 Upgrade notes
Writing lock file composer.lock without download packages:
composer update --no-install Composer version 2.2.5
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With