PmWikiDe /
Seitenlistenvariablen
Autoren (Fortgeschrittene) und Administratoren
$EnablePageListProtect
- Auf 1 gesetzt (das ist der Standard), bewirkt diese Variable, dass
(:pagelist:)
und(:searchresult:)
die Seiten nicht mit auflisten, für die der Besucher aktuell kein Leserecht hat. Setzt man diese Variable auf 0, bedeutet das, dass lesegeschützte Seiten in Seitenlisten auftauchen können, sogar wenn der Besucher die Seiten gar nicht öffnen kann. In einigen Fällen kann das die Suchgeschwindigkeit erheblich heraufsetzen (weil die Seitenerlaubnisse nicht geprüft werden müssen), andererseits im Falle von WikiGruppen mit unterschiedlichen Gruppenattributen (Seitenerlaubnissen) und jede mit vielen Seiten, könnte das belassen der Voreinstellung schneller sein, da dann die individuellen Seiten von unautorisierten Seiten nicht geprüft werden. $PageListSortCmpFunction
- Die Funktion wird genutzt, um Werte für die Reihenfolge miteinander zu vergleichen, aus historischen Gründen ist die Voreinstellung 'strcasecmp' und sortiert alphabetisch und unabhängig von der Groß/Kleinschreibung. Wenn Sie regelmäßig Zahlen oder Strings mit Zahlen sortieren, können Sie diese Variable auf 'strnatcasecmp' setzen und die Liste wird gemäß einer natürlichen Reihenfolge sortiert, unabhängig von der Groß/Kleinschreibung.
$PageListSortCmpFunction = 'strnatcasecmp';# "natürliche" Sortierung von Seitenlisten
Oder Sie geben hier den Namen einer selbstgeschriebenen Sortierfunktion an. Dies ist die allgemeine Sortierfunktion, für spezielle Anforderungen können Sie spezifische Funktionen schreiben, siehe Angepasste Seitenlistenreihenfolge. $PageListVarFoldFn
- Seitenlisten- und Such-Ausdrücke, einschließlich Seitenvariablensuchausdrücke, sind für das lateinische Alphabet immer groß/kleinschreibungsunabhängig. Für internationale Zeichen waren die Seitenvariablen-Ausdrücke bis PmWiki 2.2.115 groß/kleinschreibungsabhängig und wurden groß/kleinschreibungsunabhängig ab 2.2.116 (wie beim lateinischen Alphabet). Wenn Ihre Seitenlisten auf das bisherige Verhalten angewiesen sind, können Sie hier den Namen einer Funktion setzen, die die Groß/Kleinschreibung internationaler Zeichen nicht ändert, z. B.:
$PageListVarFoldFn = 'strval';
$SearchPatterns
- Ein Array von Seitennamenmustern, die nötig sind für – oder ausgeschlossen werden sollen von – Such- und Seitenlisten-Ergebnissen. Damit eine Seite in eine Suchliste oder Seitenliste aufgenommen wird, darf sie nicht auf ein Muster mit einem Ausrufezeichen am Beginn passen, muss aber auf alle anderen Muster passen. Siehe Cookbook:SearchPatterns.
# begrenze jede Suche auf die Gruppe 'Main' $SearchPatterns['default'][] = '/^Main\\./'; # Schließe die Gruppe 'Main' von den Suchergebnissen aus $SearchPatterns['default'][] = '!^Main\\.!'; # Schließe die 'RecentChanges'-Seiten aller Gruppe und die # 'AllRecentChanges'-Seite von den Suchergebnissen aus $SearchPatterns['default'][] = '!\\.(All)?RecentChanges$!'; # Schütze Seiten davor, sich selbst zu listen $SearchPatterns['default'][] = FmtPageName('!^$FullName$!', $pagename);
Zum Beispiel
$SearchBoxOpt ['target'] = '$DefaultGroup.Search';
$SearchBoxInputType
- Das HTML "type"-Attribut für das Suchfeld. Vorgabe ist "text" und damit valides HTML4. Wenn Ihr Skin HTML5 benutzt, können Sie das auf "search" abändern:
$SearchBoxInputType
= "search";
$EnablePageIndex
- Auf 0 gesetzt, wird die Standardindizierung abgeschaltet. Standardmäßig verwaltet PmWiki einen "Link- und Wortindex" in
$PageIndexFile
, der die Behandlung von Kategorien und Rückverweise sowie die Suche erheblich beschleunigt. $PageIndexFile
- Hierin steht der Ort für die Seitenindexdatei für Seitenlisten (
(:pagelist:)
). Der Standard dafür ist$Workdir/.pageindex
. $PageListCacheDir
- enthält den Namen eines beschreibbaren Verzeichnisses, wo PmWiki Ergebnisse von
(:pagelist:)
-Direktiven zwischenspeichern kann, um schnell aufeinanderfolgende Anzeigen der gleichen Seitenliste zu beschleunigen. Die Variable ist standardmäßig leer, wodurch das Zwischenspeichern abgeschaltet ist.
# Aktiviere Seitenlisten-Caching in work.d/.pagelistcache $PageListCacheDir = 'work.d/.pagelistcache';
$PageSearchForm
- Hierin steht der Name der Seite, die benutzt wird, um die Ausgabe von Suchergebnissen zu gestalten für
?action=search
(es sei denn, die aktuelle Seite enthält selbst eine "Suchergebnis"-Direktive in sich). Diese Variable kann ein Array sein, in dem Fall wird die erste Seite aus dem Array benutzt, die gefunden wird.
# Einfacher Einsatz des Seitensuchformulars in der Standardgruppe $PageSearchForm = '$DefaultGroup.Search';
# Benutze die Suchseite der aktuellen Gruppe, falls sie existiert, # andernfalls benutze Site.Search $PageSearchForm = array('$Group.Search', '[=$[$SiteGroup/Search]=]');
$FPLTemplatePageFmt
- Hierin steht der Name der Seiten, in denen nach einer Seitenlistenvorlage gesucht wird, die durch einen
fmt=#xyz
-Parameter angegeben wurde. Voreingestellt sind die aktuelle Seite, Site.LocalTemplates und Site.PageListTemplates.
# PmWikis Standardeinstellung global $FPLTemplatePageFmt; $FPLTemplatePageFmt = array( '{$FullName}', '{$SiteGroup}.LocalTemplates', '{$SiteGroup}.PageListTemplates');
Die Variable kann angepasst werden, damit auch in anderen Seiten gesucht wird.
# Durchsuche auch eine Gruppen.Vorlagen-Seite (Group.Templates) # vor den beiden Vorlagenseiten aus der Site-Gruppe; global $FPLTemplatePageFmt; $FPLTemplatePageFmt = array( '{$FullName}', '{$Group}.Templates', '{$SiteGroup}.LocalTemplates', '{$SiteGroup}.PageListTemplates');
Oder deklariere Standards für das Vorlagen-Array:
# Durchsuche eine Gruppen.Vorlagen-Seite (Group.Templates) # vor den beiden Volagenseiten aus der Site-Gruppe; SDV($FPLTemplatePageFmt, array( '{$FullName}', '{$Group}.Templates', '{$SiteGroup}.LocalTemplates', '{$SiteGroup}.PageListTemplates') );
$EnableUndefinedTemplateVars
- Diese Variable kontrolliert, wie mit einer nicht definierten {$$Variable} umgegangen wird in includes und Seitenlistenvorlagen. Bei dem Wert 0 werden nicht definierte {$$Variable}n von dem Include-Abschnitt oder aus der Vorlage entfernt. Bei dem Wert 1 werden nicht definierte {$$Variable}n angezeigt wie sie sind, mit . ''Hinweis: PmWiki 2.2.13 und früher belassen nicht gesetzte include/template-Variablen.
-
# lösche nicht gesetzte Vorlagenvariablen$EnableUndefinedTemplateVars
= 0; -
# belasse nicht gesetzte Vorlagenvariablen und gib sie aus$EnableUndefinedTemplateVars
= 1; $PageIndexFoldFunction
- Eine vom Benutzer/Administrator definierte Funktion, die eingesetzt wird, um die Wörter der Seite zu 'falten' (vereinfachen, normalisieren), bevor sie in der wiki.d/.pageindex-Datei gespeichert werden, sowie die Suchterme, die der Benutzer eingibt. Gewöhnlich konvertiert PmWiki diese zur Kleinschreibung, hier können Sie eine Funktion definieren, die das anders behandelt (z. B. Inline-HTML-Tags herauslösen).
$PageIndexTermsFunction
- Eine Funktion, die die Seitentexte in normalisierte Suchterme zerlegt. Per Voreinstellung wird die Funktion PageIndexTerms() aufgerufen, mit dieser Variablen können Sie sie durch eine selbsterstellte Funktion überschreiben. Das könnte nützlich sein, wenn es erforderlich ist, dass Sie bestimmte Texte vom Seitenindex entfernen, z. B. Inline-HTML-Tags. Das erste und einzige Argument der Ersatzfunktion kann entweder eine Zeichenkette oder ein Array aus Zeichenketten sein.
$EnableSearchAtLeastOneTerm
- Standardmäßig wird bei der Suche nach mehreren Termen wie
term1 term2
eine Liste der Seiten ausgegeben, die alle Terme enthält. Wenn Sie diese Variable auf 1 setzen, wird die Suche veranlasst, die Seiten auszugeben, die wenigstens einen der Terme enthält (wie eine ODER-Funktion). In diesem Fall können erforderliche Terme mit einem Pluszeichen eingeleitet werden wie in+term1 +term2
. Wenn Sie diese Variable ändern, möchten Sie womöglich auch die Suchanleitung in Ihrer Search-
Seite anpassen.
Übersetzung von PmWiki.PagelistVariables, Originalseite auf PmWikiDe.PagelistVariables — Rückverweise
Zuletzt geändert: | PmWikiDe.PagelistVariables | am 20.08.2024 |
PmWiki.PagelistVariables | am 19.08.2024 |