Manual:Title.php/fr

La classe  du logiciel MediaWiki implemente les interfaces  et IDBAccessObject. Elle représente les titres des articles, utilisés à différentes fins, y compris :


 * comme texte du titre de l'article lisible par un humain
 * dans l'URL utilisée pour accéder à l'article
 * le lien en wikicode vers l'article
 * la clé de l'article dans la base de données

La classe est instanciée avec l'un de ces formats. Une fois instancié, le titre peut être récupéré dans d'autres formats ou interrogé pour avoir ses attributs. est prévu pour être une classe de valeur non mutable, il n'y a donc pas de fonction mutateur.

Pour instancier, appelez l'une des méthodes statiques de la fabrique :
 * - Ce n'est pas la fonction que vous désirez. Utilisez Title::newFromText.
 * - retourne un tableau d'objets Title
 * - Crée un nouvel objet Title à partir d'un index d'espace de noms et d'une clé de base de données. Retourne null en cas d'erreur.
 * - Ce n'est pas la fonction que vous désirez. Utilisez Title::newFromText.
 * - retourne un tableau d'objets Title
 * - Crée un nouvel objet Title à partir d'un index d'espace de noms et d'une clé de base de données. Retourne null en cas d'erreur.
 * - Crée un nouvel objet Title à partir d'un index d'espace de noms et d'une clé de base de données. Retourne null en cas d'erreur.

Une fois instancié, les autres méthodes non statiques des assesseurs peuvent être utilisées telles que,  ,  , etc.

Si vous avez un objet Title, vous pouvez obtenir un :


 * objet, utilisant
 * objet, utilisant

Cette classe peut récupérer différents types de données de la base de données; néanmoins, elle le fait de manière pas trop efficace. A la place, prenez plutôt un objet. TitleValue est plus léger et ne dépend pas de l'état global de la base de données.

Structure de Title
Un titre est constitué d'un préfixe Interwiki optionnel (tel que «  » pour les pages de mediawiki.org ou «   » pour les articles Wikipedia), suivi d'un espace de nom optionnel (tel que «   »), suivi du nom de la page.

Prefixes et espaces de noms Interwiki
Les prefixes Interwiki et les espaces de noms suivent les mêmes règles de contenu :


 * ils doivent commencer par une lettre
 * ils doivent se terminer par un caractère deux points ':'
 * ils ne peuvent contenir que des chiffres, des lettres, des caractères espace et des soulignés '_'
 * les espaces et les caractères souligné '_' peuvent être utilisés invariablement
 * ils ne sont pas sensibles à la casse

Les préfixes et les espaces de noms Interwiki ne sont reconnus que s'ils sont connus d'une installation de MediaWiki, soit par défaut, soit par la configuration.

Par exemple sur ce wiki, «  » est un lien vers l'article «   » de Wikipedia, parce que «   » est reconnu comme l'un des préfixes interwiki autorisés. Le titre «  » est un lien vers l'article « name » dans l'espace de noms «   » du wiki actuel, parce que «   » est un espace de noms reconnu. Les deux peuvent être présents, et si c'est le cas, l'interwiki doit se trouver en premier, par exemple, «  ».

Si un titre commence par le caractère deux points ':', les préfixes ne sont pas scannés, et ce caractère est supprimé avant que le titre ne soit traité. Grâce à cela, il est possible d'avoir des articles avec le caractère deux points ':' dans le nom. " " est un titre valide, comme l'est "Commandos: Behind Enemy Lines", parce que " " et " " ne sont pas des liens interwikis ni des espaces de noms valides.

Nom d'article
Dans le nom d'article, les espaces et les soulignés '_' sont traités de la même manière et chacun est converti en l'autre en fonction du contexte (le souligné est utilisé dans les URL et les clés de la base de données, les espaces sont utilisés dans le texte brut). Les caractères « étendus » (extended) appartiennent à l'intervalle 0x80..0xFF. Ils sont autorisés partout et sont des caractères valides. Ils sont encodés dans les URLs. Les caractères étendus (encodés URL) ne sont pas encodés lorsqu'ils sont utilisés pour le texte ou pour les clés de la base de données. Les autres caractères peuvent être des lettres ASCII, des chiffres, un trait d'union, une virgule, un point, une apostrophe, des parenthèses et des deux points. Aucun autre caractère ASCII n'est autorisé, et sera supprimé s'il est trouvé (cela entraînera probablement une mauvaise interprétation de l'URL par le navigateur).

Formes canoniques
La forme canonique d'un titre sera toujours rendue par l'objet. La canonisation implique ce qui suit :

Les suites consécutives de certains espaces sont réduites à un caractère ' ' unique (formulaires textuels). Ils sont supprimés s'ils se trouvent au début et/ou à la fin du titre, ou le l'espace de noms, ou du préfixe interwiki.
 * Certains caractères directionnels Unicode (marque de gauche à droite, etc.) sont supprimés, car ils résultent généralement d'un copier-coller erroné.
 * À partir de  tout est supprimé, car cela est utilisé pour les liens de section.
 * La répétition du caractère souligné '_' est réduite à un seul '_' (format des URL et des clés de base de données des formulaires).
 * Les préfixes interwiki reconnus sont mis sous forme canonique, ce qui signifie qu'ils sont tous en minuscules.
 * Les noms des espaces de noms reconnus sont mis sous forme canonique, ce qui signifie que le premier caractère est en majuscule, les autres étant des minuscules. (néanmoins, ceci n'est pas fait pour les liens interwiki).
 * En fonction du wiki et de l'espace de noms, le premier caractère du titre peut être en majuscule. (Néanmoins, ceci n'est pas fait pour les liens interwiki).
 * Pour les liens vers les pages utilisateur des utilisateurs anonymes, l'adresse IP est mise sous forme canonique.
 * Le processus de mise sous forme canonique inclut aussi une logique de validation afin de rejeter les titres non valides (comme ceux qui sont trop longs, ou qui contiennent des caractères illégaux).

Diagrammes de la classe MediaWikiTitleCodec
Codec pour les titres de page MediaWiki : &#x5B;code link&#x5D;

Exemple
Pour vérifier et voir qu'une page donnée existe déjà : Créez un nouvel objet Title à partir du texte, tel qu'on pourrait le trouver dans un lien. Décodez toutes les entités HTML du texte. Sont acceptés : les espaces, les préfixes et le ':' initial qui identifie l'espace de noms principal. Notez que si la page n'existe pas, ceci ne va pas la créer. Voir pour cela Manual:Article.php.

Fonctions
Beaucoup de ces fonctions sont utilisées par Manual:CoreParserFunctions.php pour générer les mots magiques.

getArticleID
Fournit l'ID de l'article pour le titre correspondant à partir du cache lié, en l'ajoutant si nécessaire. Pour les articles « internes », revoie le champ  si l'article existe, sinon retourne 0. Retourne 0 pour tous les articles externes. Les IDs de toutes les instances Title créées durant une requête sont mis en cache, afin d'être recherchés rapidement lors de la génération du wikicode ayant de multiples liens internes.

getBaseText
Fournit le nom de base de la page, c'est à dire la partie la plus à gauche, hors espace de noms, et jusqu'au premier slash (s'il y en a), sans convertir les espaces en soulignés '_'. Voir les mots magiques et.

getText
Fournit la forme textuelle (espaces et pas les soulignés '_') de la partie principale, c'est à dire le titre sans l'espace de noms, mais avec les slashes et ce qu'il y a après. Voir le mot magique.

getDBKey
Fournit la partie principale (c'est à dire le titre sans l'espace de noms) avec les caractères souligné '_'.

getPrefixedDBKey
Fournit la forme préfixée de la clé de la base de données avec les caractères soulignés '_'.

getFragment
Fournit le fragment du titre Title (c'est à dire le morceau qui suit le '#') sous forme textuelle.

getFullText
Fournit le titre préfixé avec des espaces, avec tout fragment (partie commençant avec '#').

getPartialURL
Fournit la forme encodée d'URL pour la partie principale. Voir le mot magique.

getFullURL
Fournit une URL réelle pointant vers ce titre, sous la forme d'un lien interwiki et d'un fragment.

getLocalURL
Fournit une URL sans fragment ni nom de serveur.

getPrefixedText
Fournit le titre préfixé avec les espaces. Ceci est la forme généralement utilisée pour l'affichage. Voir le mot magique.

getPrefixedUrl
Fournit une orme encodée d'URL pour le titre (pas l'URL actuelle) incluant le préfixe innterwiki. Voir le mot magique.

getSubjectNsText
Fournit le texte de l'espace de noms de la page du sujet (plutôt que celui de la page de discussion). Voir les mots magiques et.

getSubjectPage
Fournit un objet Title associé à la page du sujet de cette page de discussion. Voir le mot magique.

getSubpageText
Fournit le nom de la sous-page de plus bas niveau, c'est à dire la partie la plus à droite après le dernier slash. Voir le mot magique.

getSubpageUrlForm
Fournit une forme encodée d'URL pour le texte de la sous-page. Voir le mot magique.

getTalkNsText
Fournit le texte de l'espace de noms de la page de discussion. Voir les mots magiques et.

getTalkPage
Fournit un objet Title associé à la page de discussion de cet article. Voir et.

getNamespace
Fournit l'index de l'espace de noms. Voir.