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
37 lines
842 B
PHP
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;
|
|
}
|
|
}
|