Composer,最小稳定性和依赖关系的依赖关系

时间:2012-12-20 10:42:05

标签: symfony dependency-management composer-php

我在使用作曲家的新项目和Symfony 2依赖项时非常挑剔。

首先,我使用composer安装symfony / framework-standard-edition v2.1.5。这会产生一个具有这些要求且没有最小稳定性节点的composer文件。

"require": {
  "php": ">=5.3.3",
  "symfony/symfony": "2.1.*",
  "doctrine/orm": ">=2.2.3,<2.4-dev",
  "doctrine/doctrine-bundle": "1.0.*",
  "twig/extensions": "1.0.*@dev",
  "symfony/assetic-bundle": "2.1.*",
  "symfony/swiftmailer-bundle": "2.1.*",
  "symfony/monolog-bundle": "2.1.*",
  "sensio/distribution-bundle": "2.1.*",
  "sensio/framework-extra-bundle": "2.1.*",
  "sensio/generator-bundle": "2.1.*",
  "jms/security-extra-bundle": "1.2.*",
  "jms/di-extra-bundle": "1.1.*",
  "kriswallsmith/assetic": "1.1.*@dev"
},

这很好用,它会安装所有最新的稳定版本,就像它应该的那样。

接下来,我添加一个包 - &gt; https://packagist.org/packages/kunstmaan/admin-bundle

"require": {
  "php": ">=5.3.3",
  "symfony/symfony": "2.1.*",
  "doctrine/orm": ">=2.2.3,<2.4-dev",
  "doctrine/doctrine-bundle": "1.0.*",
  "twig/extensions": "1.0.*@dev",
  "symfony/assetic-bundle": "2.1.*",
  "symfony/swiftmailer-bundle": "2.1.*",
  "symfony/monolog-bundle": "2.1.*",
  "sensio/distribution-bundle": "2.1.*",
  "sensio/framework-extra-bundle": "2.1.*",
  "sensio/generator-bundle": "2.1.*",
  "jms/security-extra-bundle": "1.2.*",
  "jms/di-extra-bundle": "1.1.*",
  "kriswallsmith/assetic": "1.1.*@dev",
  "kunstmaan/admin-bundle": "dev-master"
},

此捆绑包取决于“dev-master”中的“doctrine / doctrine-fixtures-bundle”(https://packagist.org/packages/doctrine/doctrine-fixtures-bundle

该捆绑包依赖于带有*(https://packagist.org/packages/doctrine/data-fixtures

的教义/数据夹具

现在,当我在项目中运行composer update时,它告诉我没有什么可以满足doctrine / data-fixtures依赖。可能是名称中的拼写错误,也可能没有“稳定”版本,因为最小稳定性默认为稳定。

它确实想要在“dev”稳定性中安装doctrine-fixtures-bundle,因为put-master会自动将这种依赖性置于“dev”稳定性中。但这对于这个版本的代表没有任何作用,他们一直希望安装稳定,因为这是我的最小稳定性。

此时我可以通过在项目中将doctrine / data-fixture:dev-master或@dev添加到我的composer.json中来解决这个问题。

但由于这只是一个例子(knpmenubundle,fosuserbundle等等),我将不得不手动去添加所有不安装到我自己的作曲家文件的deps。

另一个解决方案是将我的项目的最小稳定性降低到dev,但那时我所有的deps,包括像Symfony2这样的稳定​​版本,都会安装他们的dev版本,而不是标记版本。

1 个答案:

答案 0 :(得分:13)

只有一个好方法:唠叨人们,以便他们标记更多的版本。如果你真的需要使用不稳定的东西,那么将所有内容列入白名单"@dev"是最好的替代IMO。如果你有比稳定更不稳定的东西,那么你总是可以标记@stable并将最小稳定性设置为dev。在大多数情况下,仍然有锁文件来保存你的屁股;)