1
0
Fork 0
Go to file
Nils Adermann 7c7cac61b6 Merge remote-tracking branch 'github-seldaek/stability'
* github-seldaek/stability:
  Add stability docs
  Add test for Pool handling and refactor a couple things
  Add support for stabilities in lock file
  Infer stability flags for requirements that have an explicit version required of a lower stability
  Add InstalledArrayRepository to make sure the root package is not purged by the Pool because of a lower stability
  Basic handling of stability flags
  Add list of stabilities to base package
  Add minimum-stability flag on root package to filter packages by stability
  Add CompositeRepo::getRepositories
  Add package stability
2012-05-12 18:28:32 +02:00
bin Fix CS & simplify code 2012-05-12 17:10:28 +02:00
doc Merge remote-tracking branch 'github-seldaek/stability' 2012-05-12 18:28:32 +02:00
res Merge remote-tracking branch 'github-seldaek/stability' 2012-05-12 18:28:32 +02:00
src Merge remote-tracking branch 'github-seldaek/stability' 2012-05-12 18:28:32 +02:00
tests Merge remote-tracking branch 'github-seldaek/stability' 2012-05-12 18:28:32 +02:00
.gitignore * ignore vagrant related 2012-03-22 17:17:11 +01:00
.travis.yml Drop 5.3.2 since symfony2 can not run against it anymore 2012-05-12 09:54:40 +02:00
CHANGELOG.md Refactor validate command to offer more flexibility in adding validation 2012-05-12 17:32:13 +02:00
LICENSE Fix author/copyright 2011-04-17 21:39:53 +02:00
PORTING_INFO Import initial partial port of the libzypp satsolver. 2011-04-05 17:37:19 +02:00
README.md Update README 2012-04-12 09:57:52 +02:00
composer.json Fix wording 2012-04-15 23:04:42 +02:00
composer.lock Update vendors 2012-05-12 09:44:22 +02:00
phpunit.xml.dist Add slow tests to slow group, excluded by default except for travis 2012-05-06 15:10:13 +02:00

README.md

Composer - Package Management for PHP

Composer is a package manager tracking local dependencies of your projects and libraries.

See http://getcomposer.org/ for more information and documentation.

Build Status

Installation / Usage

  1. Download the composer.phar executable or use the installer.

    $ curl -s http://getcomposer.org/installer | php
    
  2. Create a composer.json defining your dependencies. Note that this example is a short version for applications that are not meant to be published as packages themselves. To create libraries/packages please read the guidelines.

    {
        "require": {
            "monolog/monolog": ">=1.0.0"
        }
    }
    
  3. Run Composer: php composer.phar install

  4. Browse for more packages on Packagist.

Installation from Source

To run tests, or develop Composer itself, you must use the sources and not the phar file as described above.

  1. Run git clone https://github.com/composer/composer.git
  2. Download the composer.phar executable
  3. Run Composer to get the dependencies: php composer.phar install

Global installation of Composer (manual)

Since Composer works with the current working directory it is possible to install it in a system wide way.

  1. Change into a directory in your path like cd /usr/local/bin
  2. Get Composer curl -s http://getcomposer.org/installer | php
  3. Make the phar executeable chmod a+x composer.phar
  4. Change into a project directory cd /path/to/my/project
  5. Use Composer as you normally would composer.phar install
  6. Optionally you can rename the composer.phar to composer to make it easier

Global installation of Composer (via homebrew)

Installing via this homebrew formula will always get you the latest Composer version.

  1. run brew uninstall composer ; brew install --HEAD https://raw.github.com/gist/1574469/composer.rb
  2. Change into a project directory cd /path/to/my/project
  3. Use Composer as you normally would composer.phar install

You will see a warning "Warning: Cannot verify package integrity"; however, this is benign and expected.

Updating Composer

Running php composer.phar self-update or equivalent will update a phar install with the latest version.

Contributing

All code contributions - including those of people having commit access - must go through a pull request and approved by a core developer before being merged. This is to ensure proper review of all the code.

Fork the project, create a feature branch, and send us a pull request.

To ensure a consistent code base, you should make sure the code follows the Coding Standards which we borrowed from Symfony.

If you would like to help take a look at the list of issues.

Community

The developer mailing list is on google groups IRC channels are available for discussion as well, on irc.freenode.org #composer for users and #composer-dev for development.

Requirements

PHP 5.3+

Authors

Nils Adermann - naderman@naderman.de - http://twitter.com/naderman - http://www.naderman.de
Jordi Boggiano - j.boggiano@seld.be - http://twitter.com/seldaek - http://seld.be

See also the list of contributors who participated in this project.

License

Composer is licensed under the MIT License - see the LICENSE file for details

Acknowledgments

This project's Solver started out as a PHP port of openSUSE's Libzypp satsolver.