Diese Seite beschreibt eine interne Funktion in PmWiki, die FmtPageName() heißt. Diese Seite ist nicht für Leute mit einem schwachen Herzen bestimmt ;-)
Siehe auch Funktionen
FmtPageName($fmt, $pagename)
Die Funktion gibt $fmt wieder zurück, nachdem darin $variable-Ersetzungen und Internationalisierung durchgeführt worden sind unter der Vorgabe, dass der Name der Seite $pagename ist.
Dabei wird die Regel angewandt, dass zuerst die Variablen behandelt werden, deren Namen auf 'Fmt' endet (wie $GroupFooterFmt), aber auch solche Strings, die eine Interpolation erfordern, insbesondere die Seitenvorlagendatei (.tmpl).
Siehe Variablen wegen einer (unvollständigen) Liste von zur Verfügung stehenden Variablen und Internationalisierungen wegen der Internationalisierung.
Die Funktion FmtPageName() wendet Internationalisierungs- und Variablen-Ersetzungen auf den String $fmt an unter der Vorgabe, der Name der aktuellen Seite sei .
$pagename
Das Ersetzen geht so:
$XyzFmt durch den zugehörenden Wert einer globalen Variable.
$[...] Phrasen (Internationalisierte Phrasen) mit Hilfe der aktuell geladenen Übersetzungstabelle.
{$ScriptUrl} durch $ScriptUrl (um die Abarbeitung der URI-Bearbeitungs-Phase hinauszuschieben).
{*$FullName} ersetzt (siehe ReleaseNotes). Beachten Sie, dass SVs der Form {Group.Page$Var} nicht ersetzt werden. Wenn es keine weiteren $-Sequenzen gibt, gib den formatierten String zurück und beende die Funktion.
$FmtP (P=pattern/Muster) durch. Typischerweise wird das verwendet, um Dinge wie $Name und $Group etc., die spezifisch für die aktuelle Seite sind, zu behandeln. Das scheint eingesetzt zu werden in robot.php, um Seitenverweise mit einer Aktion (z. B. Seite?action=edit) so umzuwandeln, dass ein Suchroboter ihnen nicht folgt (der Roboter wird gezielt hinters Licht geführt, siehe Sonstige Variablen).
$Var , nicht von der übliche SV-Form {$Var}.
$EnablePathInfo nicht gesetzt ist, wandle URIs um in die Schreibweise $ScriptUrl?n=<Group>.<Name> anstelle von $ScriptUrl/<Group>/<Name>. Ersetze $ScriptUrl in beiden Fällen durch seinen Wert. Gibt es keine weiteren $-Sequenzen, gib den formatierten String zurück und beende damit die Funktion.
$FmtV.
Anmerkung: FmtPageName() erkennt alle globalen Variablen automatisch. Allerdings existiert das Array $FmtV, weil globale Variablen zu ändern aufwändig ist. So wird das ständige Wiederaufbauen des Variablenzwischenspeichers für sich häufig ändernde Variablen vermieden.
PM zufolge ist es generell unklug, die Funktion FmtPageName() für Strings aufzurufen, die aus Seiten-Markups stammen, denn das eröffnet Jemandem die Möglichkeit, Variablenwerte zu sehen, die er vielleicht nicht hätte sehen sollen. Das ist auch der Grund, warum Seiten-Variablen (die aus Markups stammen) PageVar() und PageTextVar() verwenden und nicht durch FmtpageName() gehen.
Um ganz präzise zu sein, das schreibt PM in Bezug auf verschiedene Wege, eine Variable zu definieren, die von FmtPageName verwendet werden kann (wenn es einen String formatiert):
FmtPageName() führt automatisch Ersetzungen durch für alle globalen Variablen, die keine Arrays sind. Wenn aber die Variable ihren Wert während wiederholter Aufrufe von FmtPageName() verändern wird, ist es möglicherweise besser, $FmtV zu verwenden wie im nächsten Punkt.
$FmtV-Array ein. $FmtV['$MyVariable']='something' bedeutet, ersetze alle Vorkommen von '$MyVariable' durch 'something'. Verwenden sie dies für Variablen, die ihren Wert während wiederholter Aufrufe von FmtPageName() verändern werden, es ist möglicherweise besser, $FmtV wie im nächsten Punkt zu benutzen.
$FmtP-Array ein. Dies wird normalerweise für Ersetzungen gemacht, die dynamisch sein müssen, weil sie in gewisser Weise auf dem referenzierten Seitennamen basieren, so wie '$Title', '$Group', '$Name', $PageUrl', etc.
Siehe auch Cookbook:Functions#FmtPageName
Schließlich gibt es hier noch etwas, das PM geschrieben hat, was sich auf diese Funktion bezieht und erklärt, wozu wir sie haben:
$ScriptUrl/$Group/$Name in $ScriptUrl?n=$Group.$Name für Sites, die keine PATH_INFO-Urls handhaben können,
FmtPageName()-Funktion zusammen. Weil einige Dinge extrem dynamisch sind, solche wie die Url oder die Gruppe für eine beliebige Seite, die nicht die aktuell angezeigte ist, können diese Dinge nicht einfach globale Variablen sein. Oder wenn sie doch globale Variablen würden, wären sie Variablen, die nicht zuverlässig Werte für eine lange Zeit behielten, weile einige andere Routinen (die gerade einen String einer anderen Seite formatieren) daherkommen und den Wert auf etwas setzen, was sie gerade brauchen.
FmtPageName()-Funktion. Der vollständige Satz dieser speziellen Variablen ist $Group, $Name, $FullName, $PageUrl, $Title, $Titlespaced, $Namespaced, $Groupspaced, $LastModifiedBy, $LastModifiedHost und $LastModified. Diese Dinge können nicht einfach PHP-Standardvariablen sein, weil sich PmWiki oft den URL, den Namen, den Titel etc. einer anderen Seite besorgen muss als jenen der aktuell im Browser betrachteten Seite.
$page = ReadPage($pagename);
PCache($pagename, $page);
$ptitle = FmtPageName('$Title', $pagename);
$pauthor = FmtPageName('$LastModifiedBy', $pagename);
Übersetzung von PmWiki.FmtPageName, Originalseite auf PmWikiDe.FmtPageName — Backlinks
| Zuletzt geändert: | PmWikiDe.FmtPageName | am 20.11.2022 |
| PmWiki.FmtPageName | am 18.11.2022 |