wiki.techinc.nl/includes/libs/composer/ComposerLock.php
Bartosz Dziewoński 485f66f174 Use PHP 7 '??' operator instead of '?:' with 'isset()' where convenient
Find: /isset\(\s*([^()]+?)\s*\)\s*\?\s*\1\s*:\s*/
Replace with: '\1 ?? '

(Everywhere except includes/PHPVersionCheck.php)
(Then, manually fix some line length and indentation issues)

Then manually reviewed the replacements for cases where confusing
operator precedence would result in incorrect results
(fixing those in I478db046a1cc162c6767003ce45c9b56270f3372).

Change-Id: I33b421c8cb11cdd4ce896488c9ff5313f03a38cf
2018-05-30 18:06:13 -07:00

37 lines
842 B
PHP

<?php
/**
* Reads a composer.lock file and provides accessors to get
* its hash and what is installed
*
* @since 1.25
*/
class ComposerLock {
/**
* @param string $location
*/
public function __construct( $location ) {
$this->contents = json_decode( file_get_contents( $location ), true );
}
/**
* Dependencies currently installed according to composer.lock
*
* @return array
*/
public function getInstalledDependencies() {
$deps = [];
foreach ( $this->contents['packages'] as $installed ) {
$deps[$installed['name']] = [
'version' => ComposerJson::normalizeVersion( $installed['version'] ),
'type' => $installed['type'],
'licenses' => $installed['license'] ?? [],
'authors' => $installed['authors'] ?? [],
'description' => $installed['description'] ?? '',
];
}
return $deps;
}
}