PHP的依赖管理--composer源码

till 23902023e5 fix namespace 13 jaren geleden
bin 26e909a1a0 Apply nested-autoload support to all relevant files 13 jaren geleden
doc 1ee715ead5 updated intro and basic-usage to reflect new --install-dir option 13 jaren geleden
res 7ceca9b789 Suppress relaxed schema and build it on the fly in php, refs #151 13 jaren geleden
src ae6de4be60 Merge pull request #377 from till/svn-auth 13 jaren geleden
tests 23902023e5 fix namespace 13 jaren geleden
.gitignore 92410f997a Added bonus: ignore phpunit.xml 13 jaren geleden
.travis.yml fdef6bfca2 Add 5.3.2 to travis runs 13 jaren geleden
CHANGELOG.md c81a776279 Update changelog 13 jaren geleden
LICENSE 7ea2fd6c93 Fix author/copyright 14 jaren geleden
PORTING_INFO 933cc6179b Import initial partial port of the libzypp satsolver. 14 jaren geleden
README.md e4143f98c5 [docs] mention coding standards 13 jaren geleden
composer.json bd54e43d37 Rework JsonFile API slightly, avoid tokenizing in php if the syntax is valid 13 jaren geleden
composer.lock e63d24e438 Update vendors 13 jaren geleden
phpunit.xml.dist 8b1b4527bd Fix code coverage report, fixes #205 13 jaren geleden

README.md

Composer - Package Management for PHP

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

See the about page on packagist.org for more information.

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.

Configuration

Additional options for composer can be configured in composer.json by using the config section.

{
    "config": {
        "vendor-dir": "custom/path/for/vendor"
    }
}
  • vendor-dir: The location to install vendor packages. The location can be supplied as an absolute or relative path but must be within the current working directory.

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.