forked from discourse/wp-discourse
-
Notifications
You must be signed in to change notification settings - Fork 0
/
scoper.inc.php
132 lines (112 loc) · 5.51 KB
/
scoper.inc.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
<?php
declare(strict_types=1);
use Isolated\Symfony\Component\Finder\Finder;
return [
// The prefix configuration. If a non null value will be used, a random prefix will be generated.
'prefix' => 'WPDiscourse',
// By default when running php-scoper add-prefix, it will prefix all relevant code found in the current working
// directory. You can however define which files should be scoped by defining a collection of Finders in the
// following configuration key.
//
// For more see: https://github.com/humbug/php-scoper#finders-and-paths
'finders' => [
Finder::create()
->files()
->ignoreVCS(true)
->in('vendor')
->path([
'Monolog/Formatter/FormatterInterface.php',
'Monolog/Formatter/NormalizerFormatter.php',
'Monolog/Formatter/LineFormatter.php',
'Monolog/Handler/AbstractHandler.php',
'Monolog/Handler/AbstractProcessingHandler.php',
'Monolog/Handler/HandlerInterface.php',
'Monolog/Handler/NullHandler.php',
'Monolog/Handler/StreamHandler.php',
'Monolog/ResettableInterface.php',
'Monolog/Logger.php',
'Monolog/Utils.php',
'monolog/LICENSE'
]),
Finder::create()
->files()
->ignoreVCS(true)
->notName('/.*\\.md|.*\\.dist|Makefile|composer\\.json|composer\\.lock/')
->exclude([
'doc',
'test',
'test_old',
'Test',
'tests',
'Tests',
'vendor-bin',
])
->in('vendor')
->path('/^psr/')
],
// Whitelists a list of files. Unlike the other whitelist related features, this one is about completely leaving
// a file untouched.
// Paths are relative to the configuration file unless if they are already absolute
'files-whitelist' => [],
// When scoping PHP files, there will be scenarios where some of the code being scoped indirectly references the
// original namespace. These will include, for example, strings or string manipulations. PHP-Scoper has limited
// support for prefixing such strings. To circumvent that, you can define patchers to manipulate the file to your
// heart contents.
//
// For more see: https://github.com/humbug/php-scoper#patchers
'patchers' => [
function (string $filePath, string $prefix, string $contents) {
$lines = explode( "\n", $contents );
foreach ( $lines as $index => $line ) {
// Ensure functions do not have return type declarations, which are not supported in PHP 5.*.
// See further https://github.com/Seldaek/monolog/issues/1537.
if ( preg_match( '/\h(function)\h/', $line ) && ltrim($line)[0] !== '*' ) {
$last_bracket_index = strripos( $line, ')' );
if ( $last_bracket_index ) {
$new_line = substr( $line, 0, $last_bracket_index );
$new_line .= ")";
$line_without_args = preg_replace( '/\(([^()]*+|(?R))*\)/', '', $line );
if ( strpos( $line_without_args, "{" ) !== false ) {
$new_line .= " {";
}
if ( substr( $line, -1 ) == ";" ) {
$new_line .= ";";
}
$lines[ $index ] = $new_line;
}
}
// Remove strict_type declarations
if ( preg_match( '/strict_types/', $line ) && ltrim($line)[0] !== '*' ) {
unset( $lines[ $index ] );
}
}
return implode( "\n", $lines );
},
],
// PHP-Scoper's goal is to make sure that all code for a project lies in a distinct PHP namespace. However, you
// may want to share a common API between the bundled code of your PHAR and the consumer code. For example if
// you have a PHPUnit PHAR with isolated code, you still want the PHAR to be able to understand the
// PHPUnit\Framework\TestCase class.
//
// A way to achieve this is by specifying a list of classes to not prefix with the following configuration key. Note
// that this does not work with functions or constants neither with classes belonging to the global namespace.
//
// Fore more see https://github.com/humbug/php-scoper#whitelist
'whitelist' => [
// 'PHPUnit\Framework\TestCase', // A specific class
// 'PHPUnit\Framework\*', // The whole namespace
// '*', // Everything
],
// If `true` then the user defined constants belonging to the global namespace will not be prefixed.
//
// For more see https://github.com/humbug/php-scoper#constants--constants--functions-from-the-global-namespace
'whitelist-global-constants' => true,
// If `true` then the user defined classes belonging to the global namespace will not be prefixed.
//
// For more see https://github.com/humbug/php-scoper#constants--constants--functions-from-the-global-namespace
'whitelist-global-classes' => true,
// If `true` then the user defined functions belonging to the global namespace will not be prefixed.
//
// For more see https://github.com/humbug/php-scoper#constants--constants--functions-from-the-global-namespace
'whitelist-global-functions' => true,
];