Composer.php 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283
  1. <?php
  2. /*
  3. * This file is part of Composer.
  4. *
  5. * (c) Nils Adermann <naderman@naderman.de>
  6. * Jordi Boggiano <j.boggiano@seld.be>
  7. *
  8. * For the full copyright and license information, please view the LICENSE
  9. * file that was distributed with this source code.
  10. */
  11. namespace Composer;
  12. use Composer\Package\RootPackageInterface;
  13. use Composer\Package\Locker;
  14. use Composer\Repository\RepositoryManager;
  15. use Composer\Installer\InstallationManager;
  16. use Composer\Plugin\PluginManager;
  17. use Composer\Downloader\DownloadManager;
  18. use Composer\EventDispatcher\EventDispatcher;
  19. use Composer\Autoload\AutoloadGenerator;
  20. use Composer\Package\Archiver\ArchiveManager;
  21. /**
  22. * @author Jordi Boggiano <j.boggiano@seld.be>
  23. * @author Konstantin Kudryashiv <ever.zet@gmail.com>
  24. * @author Nils Adermann <naderman@naderman.de>
  25. */
  26. class Composer
  27. {
  28. /*
  29. * Examples of the following constants in the various configurations they can be in
  30. *
  31. * releases (phar):
  32. * const VERSION = '1.8.2';
  33. * const BRANCH_ALIAS_VERSION = '';
  34. * const RELEASE_DATE = '2019-01-29 15:00:53';
  35. * const SOURCE_VERSION = '';
  36. *
  37. * snapshot builds (phar):
  38. * const VERSION = 'd3873a05650e168251067d9648845c220c50e2d7';
  39. * const BRANCH_ALIAS_VERSION = '1.9-dev';
  40. * const RELEASE_DATE = '2019-02-20 07:43:56';
  41. * const SOURCE_VERSION = '';
  42. *
  43. * source (git clone):
  44. * const VERSION = '1.10.3';
  45. * const BRANCH_ALIAS_VERSION = '';
  46. * const RELEASE_DATE = '2020-04-09 16:26:35';
  47. * const SOURCE_VERSION = '1.8-dev+source';
  48. */
  49. const VERSION = '1.10.3';
  50. const BRANCH_ALIAS_VERSION = '';
  51. const RELEASE_DATE = '2020-04-09 16:26:35';
  52. const SOURCE_VERSION = '1.10-dev+source';
  53. public static function getVersion()
  54. {
  55. // no replacement done, this must be a source checkout
  56. if (self::VERSION === '@package_version'.'@') {
  57. return self::SOURCE_VERSION;
  58. }
  59. // we have a branch alias and version is a commit id, this must be a snapshot build
  60. if (self::BRANCH_ALIAS_VERSION !== '' && preg_match('{^[a-f0-9]{40}$}', self::VERSION)) {
  61. return self::BRANCH_ALIAS_VERSION.'+'.self::VERSION;
  62. }
  63. return self::VERSION;
  64. }
  65. /**
  66. * @var Package\RootPackageInterface
  67. */
  68. private $package;
  69. /**
  70. * @var Locker
  71. */
  72. private $locker;
  73. /**
  74. * @var Repository\RepositoryManager
  75. */
  76. private $repositoryManager;
  77. /**
  78. * @var Downloader\DownloadManager
  79. */
  80. private $downloadManager;
  81. /**
  82. * @var Installer\InstallationManager
  83. */
  84. private $installationManager;
  85. /**
  86. * @var Plugin\PluginManager
  87. */
  88. private $pluginManager;
  89. /**
  90. * @var Config
  91. */
  92. private $config;
  93. /**
  94. * @var EventDispatcher
  95. */
  96. private $eventDispatcher;
  97. /**
  98. * @var Autoload\AutoloadGenerator
  99. */
  100. private $autoloadGenerator;
  101. /**
  102. * @var ArchiveManager
  103. */
  104. private $archiveManager;
  105. /**
  106. * @param Package\RootPackageInterface $package
  107. * @return void
  108. */
  109. public function setPackage(RootPackageInterface $package)
  110. {
  111. $this->package = $package;
  112. }
  113. /**
  114. * @return Package\RootPackageInterface
  115. */
  116. public function getPackage()
  117. {
  118. return $this->package;
  119. }
  120. /**
  121. * @param Config $config
  122. */
  123. public function setConfig(Config $config)
  124. {
  125. $this->config = $config;
  126. }
  127. /**
  128. * @return Config
  129. */
  130. public function getConfig()
  131. {
  132. return $this->config;
  133. }
  134. /**
  135. * @param Package\Locker $locker
  136. */
  137. public function setLocker(Locker $locker)
  138. {
  139. $this->locker = $locker;
  140. }
  141. /**
  142. * @return Package\Locker
  143. */
  144. public function getLocker()
  145. {
  146. return $this->locker;
  147. }
  148. /**
  149. * @param Repository\RepositoryManager $manager
  150. */
  151. public function setRepositoryManager(RepositoryManager $manager)
  152. {
  153. $this->repositoryManager = $manager;
  154. }
  155. /**
  156. * @return Repository\RepositoryManager
  157. */
  158. public function getRepositoryManager()
  159. {
  160. return $this->repositoryManager;
  161. }
  162. /**
  163. * @param Downloader\DownloadManager $manager
  164. */
  165. public function setDownloadManager(DownloadManager $manager)
  166. {
  167. $this->downloadManager = $manager;
  168. }
  169. /**
  170. * @return Downloader\DownloadManager
  171. */
  172. public function getDownloadManager()
  173. {
  174. return $this->downloadManager;
  175. }
  176. /**
  177. * @param ArchiveManager $manager
  178. */
  179. public function setArchiveManager(ArchiveManager $manager)
  180. {
  181. $this->archiveManager = $manager;
  182. }
  183. /**
  184. * @return ArchiveManager
  185. */
  186. public function getArchiveManager()
  187. {
  188. return $this->archiveManager;
  189. }
  190. /**
  191. * @param Installer\InstallationManager $manager
  192. */
  193. public function setInstallationManager(InstallationManager $manager)
  194. {
  195. $this->installationManager = $manager;
  196. }
  197. /**
  198. * @return Installer\InstallationManager
  199. */
  200. public function getInstallationManager()
  201. {
  202. return $this->installationManager;
  203. }
  204. /**
  205. * @param Plugin\PluginManager $manager
  206. */
  207. public function setPluginManager(PluginManager $manager)
  208. {
  209. $this->pluginManager = $manager;
  210. }
  211. /**
  212. * @return Plugin\PluginManager
  213. */
  214. public function getPluginManager()
  215. {
  216. return $this->pluginManager;
  217. }
  218. /**
  219. * @param EventDispatcher $eventDispatcher
  220. */
  221. public function setEventDispatcher(EventDispatcher $eventDispatcher)
  222. {
  223. $this->eventDispatcher = $eventDispatcher;
  224. }
  225. /**
  226. * @return EventDispatcher
  227. */
  228. public function getEventDispatcher()
  229. {
  230. return $this->eventDispatcher;
  231. }
  232. /**
  233. * @param Autoload\AutoloadGenerator $autoloadGenerator
  234. */
  235. public function setAutoloadGenerator(AutoloadGenerator $autoloadGenerator)
  236. {
  237. $this->autoloadGenerator = $autoloadGenerator;
  238. }
  239. /**
  240. * @return Autoload\AutoloadGenerator
  241. */
  242. public function getAutoloadGenerator()
  243. {
  244. return $this->autoloadGenerator;
  245. }
  246. }