Diese Seite beschreibt eine interne Funktion in PmWiki. 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 Variablen-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
(kleines 'v'), nicht von der übliche SV-Form {$Var}
(großes 'V').
$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):
$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.
$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,
$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 01.12.2016 |
PmWiki.FmtPageName | am 10.09.2011 |