Composer version constraints you must know
If you don’t know composer yet, please go to composer usage tutorialcolumn and start reading.
I've seen many people struggle with constraints on dependencies between the composer packages they use. Hopefully this article will point out the causes of some problems and provide ways to avoid them. I'll start with the worst case scenario and improve the constraints step by step.
Almighty asterisk: *
Composer has a dependency parser, so it can automatically find out what I want, right ? wrong.
Declaring a version constraint with *
is probably one of the worst practices. Because you have absolutely no control over what you get. It may be any version matching minimum-stability
and other constraints.
You're basically playing a game of Russian roulette with Composer, and it will eventually hurt you. Then you might blame the tool for disappointing you.
If you continue to be careless, please at least rely on the latest development version, usually labeled dev-master
.
The hard-coded branch name
So you are now using dev-master
. The problem is that the code pointed to by dev-master
may change. At least, what you get is always an unstable package (unstable according to the stability flag represented by composer). The bigger problem, however, is that the meaning of dev-master
can change at any time.
For example, now it represents the latest 1.0 development version. When developers say they are going to start developing version 1.1, the branch name dev-master
no longer points to the 1.0 branch, it starts pointing to the latest 1.1 development branch.
Unless you follow the development of this library closely, it won't be until you run the composer update
command that the problem will show up to you and ruin your day. Therefore, directly referencing the branch's name is not a sustainable solution. Fortunately, composer
can help when it comes to aliases.
Branch Alias
The branch alias is an attribute that package maintainers can put into their composer.json
to allow these branches Names map to versions.
Branch names like 1.0, 2.1, etc. are not necessary, Composer
has already processed these.
But a branch name like master
will produce a version named dev-master
, and you must give it an alias. Composer
The documentation has a good article about aliases, which explains how to define branch aliases:
{ "extra": { "branch-alias": { "dev-master": "1.0.x-dev" } } }
dev-master
The version will be mapped to a On the alias of 1.0.x-dev
,
this basically means you can require the package with a 1.0.*@dev
constraint. The advantage of this is that the meaning of 1.0 will be defined and will not change. It will also make switching to stable releases easier.
Warnings for branch aliases require package maintainers to put them in. If you are using libraries that don't have branch aliases, send them a pull request adding the extra
section above to their composer.json
.
Stable version
1.0.*@dev
This constraint is already very good. But the problem is that so far, there is still no stable version. There's nothing wrong with your code other than the fact that you're still running an unstable version.
But if other people's projects depend on your package, then your users need to explicitly use the @dev
flag to allow Composer to install unstable versions, or simply reduce the project's minimum-stability Level
, which means they will get unstable versions of all dependent packages.
The best way to avoid instability in the development version is to label it with a release tag (referring to releasing a stable version). If you are using a library that is not tagged release
, alert its maintainer until it is tagged. Do it now!
As a member of the Composer community, we must be responsible. We must release stable versions and should maintain a CHANGELOG (change log). It won’t be easy, but it will make a huge difference to the entire ecosystem. Remember to label things truthfully and semantically.
When you release a stable version, you can remove the @dev
identifier and change your constraints to 1.0.*
.
The next major version
If every release node of the package you depend on adheres to the rules of semantic versioning and is strictly backwards compatible, then you You can gradually increase the constraints.
Now 1.0.* The
version has some potential compatibility issues and a 1.1
version will be released soon. If your constraint is 1.0
, but someone else needs the new features of the 1.1
version (remember backwards compatibility?), they can't install the 1.1
version. So you need to rewrite your constraints, like: 1.*
.
Great, unless you start relying on the new features of the 1.1
version, you don't have to modify the constraint and it will still match 1.0
This version has no new features .
Next, you modify the constraints to >=1.1,<2.0
, but this way of writing is more troublesome. Using the tilde operator allows you to express the above expression in a concise way: ~1.1
. This means any 1.* version above 1.1. Now you know that semantic versions are encouraged to use the tilde operator and maximize package compatibility.
TLDR
Use branch-alias
.
Label publishing to make publishing more reliable and semantic.
Use the ~
operator.
The above is the detailed content of Composer version constraints you must know. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Laravel is a PHP framework for easy building of web applications. It provides a range of powerful features including: Installation: Install the Laravel CLI globally with Composer and create applications in the project directory. Routing: Define the relationship between the URL and the handler in routes/web.php. View: Create a view in resources/views to render the application's interface. Database Integration: Provides out-of-the-box integration with databases such as MySQL and uses migration to create and modify tables. Model and Controller: The model represents the database entity and the controller processes HTTP requests.

When developing an e-commerce website, I encountered a difficult problem: how to provide users with personalized product recommendations. Initially, I tried some simple recommendation algorithms, but the results were not ideal, and user satisfaction was also affected. In order to improve the accuracy and efficiency of the recommendation system, I decided to adopt a more professional solution. Finally, I installed andres-montanez/recommendations-bundle through Composer, which not only solved my problem, but also greatly improved the performance of the recommendation system. You can learn composer through the following address:

When developing websites using CraftCMS, you often encounter resource file caching problems, especially when you frequently update CSS and JavaScript files, old versions of files may still be cached by the browser, causing users to not see the latest changes in time. This problem not only affects the user experience, but also increases the difficulty of development and debugging. Recently, I encountered similar troubles in my project, and after some exploration, I found the plugin wiejeben/craft-laravel-mix, which perfectly solved my caching problem.

I'm having a tricky problem when doing a mail marketing campaign: how to efficiently create and send mail in HTML format. The traditional approach is to write code manually and send emails using an SMTP server, but this is not only time consuming, but also error-prone. After trying multiple solutions, I discovered DUWA.io, a simple and easy-to-use RESTAPI that helps me create and send HTML mail quickly. To further simplify the development process, I decided to use Composer to install and manage DUWA.io's PHP library - captaindoe/duwa.

I had a tough problem when working on a project with a large number of Doctrine entities: Every time the entity is serialized and deserialized, the performance becomes very inefficient, resulting in a significant increase in system response time. I've tried multiple optimization methods, but it doesn't work well. Fortunately, by using sidus/doctrine-serializer-bundle, I successfully solved this problem, significantly improving the performance of the project.

Article summary: This article provides detailed step-by-step instructions to guide readers on how to easily install the Laravel framework. Laravel is a powerful PHP framework that speeds up the development process of web applications. This tutorial covers the installation process from system requirements to configuring databases and setting up routing. By following these steps, readers can quickly and efficiently lay a solid foundation for their Laravel project.

To install Laravel, follow these steps in sequence: Install Composer (for macOS/Linux and Windows) Install Laravel Installer Create a new project Start Service Access Application (URL: http://127.0.0.1:8000) Set up the database connection (if required)

When developing an e-commerce platform, it is crucial to choose the right framework and tools. Recently, when I was trying to build a feature-rich e-commerce website, I encountered a difficult problem: how to quickly build a scalable and fully functional e-commerce platform. I tried multiple solutions and ended up choosing Fecmall's advanced project template (fecmall/fbbcbase-app-advanced). By using Composer, this process becomes very simple and efficient. Composer can be learned through the following address: Learning address
