forked from SemanticMediaWiki/SemanticMediaWiki
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathload.php
167 lines (138 loc) · 4.52 KB
/
load.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
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
<?php
use SMW\NamespaceManager;
use SMW\ApplicationFactory;
use SMW\Setup;
if ( !defined( 'MEDIAWIKI' ) ) {
die( 'Not an entry point.' );
}
/**
* ExtensionRegistry only maps classes and functions after all extensions have
* been queued from the LocalSettings.php resulting in DefaultSettings not being
* loaded in-time.
*
* When changing the load order, please ensure that this function is run either
* via Composer's autoloading or as part of your internal registration.
*/
SemanticMediaWiki::load();
/**
* @codeCoverageIgnore
*/
class SemanticMediaWiki {
/**
* @since 2.5
*
* @note It is expected that this function is loaded before LocalSettings.php
* to ensure that settings and global functions are available by the time
* the extension is activated.
*/
public static function load() {
if ( is_readable( __DIR__ . '/vendor/autoload.php' ) ) {
include_once __DIR__ . '/vendor/autoload.php';
}
include_once __DIR__ . '/src/Aliases.php';
include_once __DIR__ . '/src/Defines.php';
include_once __DIR__ . '/src/GlobalFunctions.php';
foreach ( include __DIR__ . '/DefaultSettings.php' as $key => $value ) {
if ( !isset( $GLOBALS[$key] ) ) {
$GLOBALS[$key] = $value;
}
}
// In case extension.json is being used, the the succeeding steps will
// be handled by the ExtensionRegistry
self::initExtension();
$GLOBALS['wgExtensionFunctions'][] = function() {
self::onExtensionFunction();
};
}
/**
* @since 2.4
*/
public static function initExtension() {
define( 'SMW_VERSION', '2.5.7' );
// Registration of the extension credits, see Special:Version.
$GLOBALS['wgExtensionCredits']['semantic'][] = array(
'path' => __FILE__,
'name' => 'Semantic MediaWiki',
'version' => SMW_VERSION,
'author' => array(
'[http://korrekt.org Markus Krötzsch]',
'[https://www.mediawiki.org/wiki/User:Jeroen_De_Dauw Jeroen De Dauw]',
'James Hong Kong',
'[https://www.semantic-mediawiki.org/wiki/Contributors ...]'
),
'url' => 'https://www.semantic-mediawiki.org',
'descriptionmsg' => 'smw-desc',
'license-name' => 'GPL-2.0-or-later'
);
// A flag used to indicate SMW defines a semantic extension type for extension credits.
// @deprecated, removal in SMW 3.0
define( 'SEMANTIC_EXTENSION_TYPE', true );
$GLOBALS['wgMessagesDirs']['SemanticMediaWiki'] = $GLOBALS['smwgIP'] . 'i18n';
$GLOBALS['wgExtensionMessagesFiles']['SemanticMediaWikiAlias'] = $GLOBALS['smwgIP'] . 'i18n/extra/SemanticMediaWiki.alias.php';
$GLOBALS['wgExtensionMessagesFiles']['SemanticMediaWikiMagic'] = $GLOBALS['smwgIP'] . 'i18n/extra/SemanticMediaWiki.magic.php';
self::onCanonicalNamespaces();
}
/**
* CanonicalNamespaces initialization
*
* @note According to T104954 registration via wgExtensionFunctions can be
* too late and should happen before that in case RequestContext::getLanguage
* invokes Language::getNamespaces before the `wgExtensionFunctions` execution.
*
* @see https://phabricator.wikimedia.org/T104954#2391291
* @see https://www.mediawiki.org/wiki/Manual:Hooks/CanonicalNamespaces
* @Bug 34383
*
* @since 2.5
*/
public static function onCanonicalNamespaces() {
$GLOBALS['wgHooks']['CanonicalNamespaces'][] = 'SMW\NamespaceManager::initCanonicalNamespaces';
}
/**
* Setup and initialization
*
* @note $wgExtensionFunctions variable is an array that stores
* functions to be called after most of MediaWiki initialization
* has finalized
*
* @see https://www.mediawiki.org/wiki/Manual:$wgExtensionFunctions
*
* @since 1.9
*/
public static function onExtensionFunction() {
// 3.x reverse the order to ensure that smwgMainCacheType is used
// as main and smwgCacheType being deprecated with 3.x
$GLOBALS['smwgMainCacheType'] = $GLOBALS['smwgCacheType'];
$applicationFactory = ApplicationFactory::getInstance();
$namespace = new NamespaceManager( $GLOBALS );
$namespace->init();
$setup = new Setup( $applicationFactory, $GLOBALS, __DIR__ );
$setup->run();
}
/**
* @since 2.4
*
* @return string|null
*/
public static function getVersion() {
return SMW_VERSION;
}
/**
* @since 2.4
*
* @return array
*/
public static function getEnvironment() {
$store = '';
if ( isset( $GLOBALS['smwgDefaultStore'] ) ) {
$store = $GLOBALS['smwgDefaultStore'];
};
if ( strpos( strtolower( $store ), 'sparql' ) ) {
$store .= '::' . strtolower( $GLOBALS['smwgSparqlDatabaseConnector'] );
}
return array(
'store' => $store,
'db' => isset( $GLOBALS['wgDBtype'] ) ? $GLOBALS['wgDBtype'] : 'N/A'
);
}
}