2004-02-18 02:15:00 +00:00
|
|
|
<?php
|
2004-09-02 23:28:24 +00:00
|
|
|
/**
|
|
|
|
|
* Provide things related to namespaces
|
2004-09-03 23:00:01 +00:00
|
|
|
* @package MediaWiki
|
2004-09-02 23:28:24 +00:00
|
|
|
*/
|
2005-08-02 13:35:19 +00:00
|
|
|
|
2004-09-02 23:28:24 +00:00
|
|
|
/**
|
|
|
|
|
* Definitions of the NS_ constants are in Defines.php
|
2006-06-10 18:28:50 +00:00
|
|
|
* @private
|
2004-09-02 23:28:24 +00:00
|
|
|
*/
|
|
|
|
|
$wgCanonicalNamespaceNames = array(
|
2004-08-22 17:24:50 +00:00
|
|
|
NS_MEDIA => 'Media',
|
|
|
|
|
NS_SPECIAL => 'Special',
|
|
|
|
|
NS_TALK => 'Talk',
|
|
|
|
|
NS_USER => 'User',
|
|
|
|
|
NS_USER_TALK => 'User_talk',
|
2004-08-28 17:53:12 +00:00
|
|
|
NS_PROJECT => 'Project',
|
|
|
|
|
NS_PROJECT_TALK => 'Project_talk',
|
2004-08-22 17:24:50 +00:00
|
|
|
NS_IMAGE => 'Image',
|
|
|
|
|
NS_IMAGE_TALK => 'Image_talk',
|
|
|
|
|
NS_MEDIAWIKI => 'MediaWiki',
|
|
|
|
|
NS_MEDIAWIKI_TALK => 'MediaWiki_talk',
|
|
|
|
|
NS_TEMPLATE => 'Template',
|
|
|
|
|
NS_TEMPLATE_TALK => 'Template_talk',
|
|
|
|
|
NS_HELP => 'Help',
|
|
|
|
|
NS_HELP_TALK => 'Help_talk',
|
2006-03-06 13:52:21 +00:00
|
|
|
NS_CATEGORY => 'Category',
|
2004-12-21 15:04:40 +00:00
|
|
|
NS_CATEGORY_TALK => 'Category_talk',
|
2004-04-05 10:38:40 +00:00
|
|
|
);
|
|
|
|
|
|
2005-06-24 06:08:53 +00:00
|
|
|
if( is_array( $wgExtraNamespaces ) ) {
|
2004-09-09 06:12:04 +00:00
|
|
|
$wgCanonicalNamespaceNames = $wgCanonicalNamespaceNames + $wgExtraNamespaces;
|
2004-08-31 10:23:55 +00:00
|
|
|
}
|
|
|
|
|
|
2004-09-02 23:28:24 +00:00
|
|
|
/**
|
|
|
|
|
* This is a utility class with only static functions
|
|
|
|
|
* for dealing with namespaces that encodes all the
|
|
|
|
|
* "magic" behaviors of them based on index. The textual
|
|
|
|
|
* names of the namespaces are handled by Language.php.
|
|
|
|
|
*
|
|
|
|
|
* These are synonyms for the names given in the language file
|
|
|
|
|
* Users and translators should not change them
|
2004-09-03 23:00:01 +00:00
|
|
|
*
|
|
|
|
|
* @package MediaWiki
|
|
|
|
|
*/
|
2003-04-14 23:10:40 +00:00
|
|
|
class Namespace {
|
|
|
|
|
|
2004-09-02 23:28:24 +00:00
|
|
|
/**
|
|
|
|
|
* Check if the given namespace might be moved
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
2006-07-10 18:53:15 +00:00
|
|
|
static function isMovable( $index ) {
|
2005-12-21 02:35:20 +00:00
|
|
|
return !( $index < NS_MAIN || $index == NS_IMAGE || $index == NS_CATEGORY );
|
2003-04-14 23:10:40 +00:00
|
|
|
}
|
|
|
|
|
|
2005-11-03 01:29:02 +00:00
|
|
|
/**
|
|
|
|
|
* Check if the given namespace is not a talk page
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
2006-07-10 18:53:15 +00:00
|
|
|
static function isMain( $index ) {
|
2005-11-03 01:29:02 +00:00
|
|
|
return ! Namespace::isTalk( $index );
|
|
|
|
|
}
|
|
|
|
|
|
2004-09-02 23:28:24 +00:00
|
|
|
/**
|
|
|
|
|
* Check if the give namespace is a talk page
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
2006-07-10 15:41:30 +00:00
|
|
|
static function isTalk( $index ) {
|
2005-12-21 02:35:20 +00:00
|
|
|
return ($index > NS_MAIN) // Special namespaces are negative
|
2005-08-28 23:39:18 +00:00
|
|
|
&& ($index % 2); // Talk namespaces are odd-numbered
|
2003-04-14 23:10:40 +00:00
|
|
|
}
|
|
|
|
|
|
2004-09-02 23:28:24 +00:00
|
|
|
/**
|
|
|
|
|
* Get the talk namespace corresponding to the given index
|
|
|
|
|
*/
|
2006-07-10 18:53:15 +00:00
|
|
|
static function getTalk( $index ) {
|
2003-04-14 23:10:40 +00:00
|
|
|
if ( Namespace::isTalk( $index ) ) {
|
|
|
|
|
return $index;
|
|
|
|
|
} else {
|
2003-11-15 12:53:17 +00:00
|
|
|
# FIXME
|
2003-04-14 23:10:40 +00:00
|
|
|
return $index + 1;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2006-07-10 18:53:15 +00:00
|
|
|
static function getSubject( $index ) {
|
2003-04-14 23:10:40 +00:00
|
|
|
if ( Namespace::isTalk( $index ) ) {
|
|
|
|
|
return $index - 1;
|
|
|
|
|
} else {
|
|
|
|
|
return $index;
|
|
|
|
|
}
|
|
|
|
|
}
|
2004-04-05 10:38:40 +00:00
|
|
|
|
2004-09-02 23:28:24 +00:00
|
|
|
/**
|
|
|
|
|
* Returns the canonical (English Wikipedia) name for a given index
|
|
|
|
|
*/
|
2006-07-10 18:53:15 +00:00
|
|
|
static function getCanonicalName( $index ) {
|
2004-04-05 10:38:40 +00:00
|
|
|
global $wgCanonicalNamespaceNames;
|
|
|
|
|
return $wgCanonicalNamespaceNames[$index];
|
|
|
|
|
}
|
|
|
|
|
|
2004-09-02 23:28:24 +00:00
|
|
|
/**
|
|
|
|
|
* Returns the index for a given canonical name, or NULL
|
|
|
|
|
* The input *must* be converted to lower case first
|
|
|
|
|
*/
|
2006-07-10 18:53:15 +00:00
|
|
|
static function getCanonicalIndex( $name ) {
|
2004-04-05 10:38:40 +00:00
|
|
|
global $wgCanonicalNamespaceNames;
|
|
|
|
|
static $xNamespaces = false;
|
|
|
|
|
if ( $xNamespaces === false ) {
|
|
|
|
|
$xNamespaces = array();
|
|
|
|
|
foreach ( $wgCanonicalNamespaceNames as $i => $text ) {
|
|
|
|
|
$xNamespaces[strtolower($text)] = $i;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if ( array_key_exists( $name, $xNamespaces ) ) {
|
|
|
|
|
return $xNamespaces[$name];
|
|
|
|
|
} else {
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
}
|
2006-04-12 15:38:17 +00:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Can this namespace ever have a talk namespace?
|
|
|
|
|
* @param $index Namespace index
|
|
|
|
|
*/
|
2006-07-10 18:53:15 +00:00
|
|
|
static function canTalk( $index ) {
|
2006-04-12 15:38:17 +00:00
|
|
|
return( $index >= NS_MAIN );
|
|
|
|
|
}
|
2003-04-14 23:10:40 +00:00
|
|
|
}
|
|
|
|
|
?>
|