| Themen** GO:Go/Spiele
** GO:Go/Brett selber bauen
 ! Login
 |  
       
        | 
          Basic Variables
          
 
 Where the variables are available as wiki markup they are shown as Variable value "{$VariableName}". $AsSpacedFunctionThe name of the function used to convert WikiWords into normal, spaced strings.  Defaults to 'AsSpaced'.      $AsSpacedFunction = 'MyAsSpaced';
 $Authoris currently ""
 $Author Set to the current reader, who is potentially an author (see discussion). See also $EnablePostAuthorRequired.$AuthorGroup The WikiGroup for user profiles. Defaults to 'Profiles'. This variable is implicit in the markup[[~AuthorName]]      $AuthorGroup = 'Users';$AuthId For sites using user-based authorization, tracks the "reader" or login name.
      SessionAuth($pagename);      if( isset($AuthId) ) { // this person has been authenticated$AuthPw Request for documentation, meanwhile see AuthId vs AuthPw.
      SessionAuth($pagename);      if( isset($AuthPw) ) { // this person has entered a password
 $BaseNameis currently "PmWiki.BasicVariables"
 $BaseName
$BaseNamePatternsAllows population of the {$BaseName}PageVariable.  The key to the hash is the pattern to be replaced and the value is the replacement string.      
# If {$FullName} is 'Group.Page-Draft' then {$BaseName} is 'Group.Page'
$BaseNamePatterns['/-Draft$/'] = '';
# If {$FullName} is 'Comments-Group.Page' then {$BaseName} is 'Group.Page'
$BaseNamePatterns['/^Comments-/'] = '';$CategoryGroup The WikiGroup used for categories. Defaults to 'Category'.  (See Categories). This variable is implicit in the markup[[!CategoryName]]$CookiePrefix A string prefix to be prepended to cookies set from PmWiki scripts.  It defaults to '', but can be set to a different value to avoid conflicts with similar-named cookies from other applications, or to allow multiple wikis from the same domain to store separate cookies.
      $CookiePrefix = 'pmwiki_';     # set cookie prefix to 'pmwiki_'If you have a WikiFarm, use the following in each field's config.phpto get a unique prefix for each field in the farm, thus isolating each field's cookies.
      $CookiePrefix = substr($tmp = md5(__FILE__), 0, 5).'_';
 $DefaultGroupis currently "GI"
 $DefaultGroupWikiGroup used by default (on startup) when no group is specified in the URL.  
 $DefaultNameis currently "HomePage"
 $DefaultNameName of the default HomePage of each WikiGroup.  Used when the group doesn't have a page with the same name as the group.
            Note that the behavior will differ based on whether the page exists or not. Probably you want to alter $PagePathFmtin addition to$DefaultNameif you really want it to take effect.
 Note: See comment below under  $DefaultPage re the order how this must be defined within your  (farm)config.php scripts - this must be set prior to any call of  ResolvePageName().$DefaultPageStartup page when PmWiki is called without a specified page, normally .$DefaultGroup.$DefaultName
 Note: for  $DefaultGroup,  $DefaultName and  $DefaultPage variables to work, they should be defined in the beginning of  (farm)config.php, before any call to the function  ResolvePageName(). This means, before any script from PmWiki and before any recipe that might be using this function. This also means it cannot be set in a per-page or per-group customization script -ResolvePageName()is called before these are loaded.  Please note that this variable is intended to be set in (farm)config.php, not in individual groups. Trying to use different,$DefaultNameor$DefaultPage settings in different groups will cause cross-group linking anomalies.$PagePathFmt$EnableCommonEnhancementsThis variable enables popular core functions for easier editing and review:
   $EnableCommonEnhancements= 1;  In this case, the following configuration options are enabled, unless they are already defined or disabled in config.php (click on each variable to learn more):
      # Security + review changes
     $EnableCookieHTTPOnly= 1;$EnableObfuscateEmails= 1;$EnableRCDiffBytes= 1;$EnableLocalTimes= 3;
     # Editing$EnablePreviewChanges= 1;$EnableMergeLastMinorEdit= 12*3600; # 12 hours$EnableListIncludedPages= 1;$EnablePmSyntax= 2;$EnableEditAutoText= 1;$EditAutoBrackets= array('('=>')', '['=>']', '{'=>'}', '"'=>'"');$EnableGUIButtons= 1;$EnableGuiEditFixUrl= 220; # after external link button
     # Documentation$PmTOC['Enable'] = 1;$PmTOC['EnableBacklinks'] = 1;$EnableCopyCode= 1;
     # Uploads (if enabled)$EnableUploadDrop= 1;$EnableRecentUploads= 1;$EnableUploadVersions= 1;$EnableLocalConfigAllows/disables local/config.phpcustomizations (usually for a farm's wikis).  Can be set to zero inlocal/farmconfig.phpto prevent the farm's wikis'local/config.phpfrom being loaded.      $EnableLocalConfig = 0;    # disable PmWiki's local/config$EnableStdConfigDisables scripts/stdconfig.phpand a large part of the core functionalities provided by the scripts in thepmwiki/scriptsdirectory and outlined in the core documentation, unless included by your own local configuration (notably core markup rules, page history, skins, uploads). Allows you to completely reshape the way PmWiki behaves, if you need to.      $EnableStdConfig = 0;      # disable many standard features$EnablePGCustAllows/disables per-page and per-group customizations.  Can be set to zero in any local customization file to prevent remaining page/group customizations from being loaded.
      $EnablePGCust = 0;         # turn off per-page/group configs$EnableBaseNameConfigWhen enabled, and if the page has a different base page (per $BaseNamePatterns), will include the local configuration for the base page. For example, if the page is "Group.Page-Draft", this would try to include the filelocal/Group.Page.phpin addition tolocal/Group.Page-Draft.php.      $EnableBaseNameConfig = 1;  # include basename configuration$EnableRedirectWhen enabled (default), causes page redirects to automatically be performed by the browser.  Setting $EnableRedirectto zero causes PmWiki to pause and issue a "Redirect to link" message instead.  This is sometimes useful when debugging recipes to be able to see the results of actions before page redirections occur. Not to be confused with$EnableRedirectQuiet.$EnableWikiWordsEnable WikiWord processing.
$EnableWSPreEnables a markup rule that causes lines with leading spaces to be treated as sections of preformatted text.  If set to a value greater than 1, indicates the minimum number of leading spaces required for this treatment.
      $EnableWSPre = 1;            # leading spaces are preformatted text      $EnableWSPre = 0;            # leading spaces are normal lines of text      $EnableWSPre = 4;            # 4+ spaces are preformatted text$FTimeFmtCan be used to override the default date format used by the "ftime" function.  The default$FTimeFmtis$TimeFmt.  (See Markup Expressions.)$GroupPattern The regular expression pattern used for valid WikiGroup name specifications.  Defaults to allowing any group name beginning with an uppercase letter, but can be set to limit the valid group names (see Cookbook:LimitWikiGroups).
      # limit groups to Site, SiteAdmin, PmWiki, and MyGroup      $GroupPattern = '(?:Site|SiteAdmin|PmWiki|MyGroup)';      #for case-sensitive group names, note the ?-i switch:      $GroupPattern = '(?-i:Site|SiteAdmin|PmWiki|MyGroup)';$LinkWikiWordsIf set, then bare WikiWords in a page are automatically linked to pages of the same name.  Note that this value can also be affected by the (:linkwikiwords:)and(:nolinkwikiwords:)directives.      $LinkWikiWords = 1;           # turn on WikiWord links      $LinkWikiWords = 0;           # disable WikiWord links      Note, this setting requires WikiWords to be enabled, see $EnableWikiWords.$LogoutRedirectFmt Identifies the page to which the visitor should be sent after an ?action=logout.  Defaults to the current page.      $LogoutRedirectFmt = 'Site.Logout';    # ?action=logout target$LogoutCookies An array of cookie names to be removed when ?action=logoutis invoked.$NamePattern The regular expression pattern used for valid page names.  Defaults to allowing pages beginning with an uppercase letter or digit, followed by sequences of alphanumeric characters, hyphens, and underscores.  
$pagename A variable that gives the name of the current page.
 To access inside a Markup callback function, use
 $pagename=$GLOBALS['MarkupToHTML']['pagename'];
It is also accessible via
 global $pagename;# if you use it inside a function
 $pagename = ResolvePageName($pagename);
See +  for more information, including when it's possible to use this variable.
Once you have  $pagename, page variables become accessible:
 
$page = PageVar($pagename, '$FullName'); # =$pagename
$group = PageVar($pagename, '$Group');
$name = PageVar($pagename, '$Name');
$PagePathFmt An array controlling how the default group home-page name will be determined.
  Please note that this variable is intended to be set in (farm)config.php, not in individual groups. Trying to use different,$DefaultNameor$DefaultPagesettings in different groups will cause cross-group linking anomalies.$PagePathFmt
 Default Setting:
 $PagePathFmt = array('{$Group}.$1','$1.$1','$1.{$DefaultName}');
Setting to use if you wish  $DefaultName to actually be the name of your group home-pages:
 $PagePathFmt = array('{$Group}.$1','$1.{$DefaultName}','$1.$1');
Do note that if the  Groupname.Groupname page does exist but  Groupname.Defaultname does not exist, then  Groupname.Groupname will still take precedence. You may remove the ' $1.$1' entirely to require Groupname.Defaultname to be the group homepage - that would look like this:
 $PagePathFmt = array('{$Group}.$1','$1.{$DefaultName}');
$PagePathResolveFmt This array is similar to $PagePathFmt. If defined in local customization, it will be used when the current page name is resolved instead of$PagePathFmtwhich is used when linking to pages. On wikis where both pages Main.Name and (Name.HomePage or Name.Name) exist, and the requested URL is just "example.com/Name", it will now be possible to open the Name group instead of the page Main.Name. To enable, add to config.php:$PagePathResolveFmt = array('$1.$1','$1.{$DefaultName}', '{$Group}.$1');
  By default this is not enabled, and $PagePathFmtis used to resolve the current page name.
 $SiteGroupis currently "Site"
 $SiteGroupDefault group for storing configuration and utility pages such as Site.Search, Site.EditForm, Site.PageNotFound, etc.
$SiteAdminGroupDefault group for locked administrative pages such as SiteAdmin.AuthList, SiteAdmin.AuthUser, SiteAdmin.ApprovedUrls?, etc, defaults to 'SiteAdmin'.$SkinThe name of the directory containing the skin (theme) files, default "pmwiki". See Skins.
$SpaceWikiWordsIf set, then WikiWords in pages are automatically spaced according to $AsSpacedFunction.  Note that this value can also be affected by the(:spacewikiwords:)and(:nospacewikiwords:)directives.      $SpaceWikiWords = 1;          # turn on WikiWord spacing      $SpaceWikiWords = 0;          # turn off WikiWord spacing$TimeFmt The format to use for dates and times, in strftime()format.  The default value is'%B %d, %Y at %I:%M %p', which gives dates of the form "September 8, 2005 at 10:57 PM". Formats$CurrentTimevariable.      $TimeFmt = '%B %d, %Y';        # dates as "September 8, 2005"      $TimeFmt = '%Y-%m-%d';         # dates as "2005-09-08"$EnableFTimeNew If set to 1, enables the new functions to format dates and times for PHP before 8.1. This allows you to preview the outputs of dates and times, for example in the page footer, in Recent Changes and page histories, or with the {(ftime)}markup expression. See explanation at Functions#PSFT. (For PHP 8.1, strftime() is deprecated, and the new functions are enabled by default.)
 $Versionis currently "pmwiki-2.4.4"
 $Version A string representing the release version of PmWiki.
 $VersionNumis currently "2004004"
 $VersionNum A number representing the release version of PmWiki,
with the major and minor release components padded with zeroes to
produce three digits.  Thus, release "pmwiki-2.1.40" will have $VersionNumset to 2001040.
The first digit is a 2, the next three digits are the major
release number, and the last three digits are the minor release
number. Beta releases use 900-999 for the minor release number.
Thus:
2.1.0          2001000
2.1.1          2001001
...
2.1.27         2001027
2.2.0-beta1    2001901
2.2.0-beta2    2001902
...
2.2.0-beta18   2001918
...
2.2.0          2002000
$WikiWordPattern The pattern that describes a WikiWord.
$EnableRelativePageVarsThis setting controls how Page variables in included pages are understood by PmWiki.
 $EnableRelativePageVars= 1; # PmWiki current defaultIn this case
 {$Name}displays the name of the physical page where it written. If{$Name}is in an included page, it will display the name of the included page. (This is currently PmWiki's default.) $EnableRelativePageVars= 0; # revert to previous defaultIn this case
 {$Name}displays the name of the currently browsed page. Even if{$Name}is in an included page, it will display the name of the browsed page. This was PmWiki's default in versions 2.2.8 and earlier, and changed in 2.2.9, but you can revert it back with this line in config.php.  {*$Name}with an asterisk always displays the name of the currently browsed page, regardless of$EnableRelativePageVars.
 Categories: PmWiki Developer
 
 
 |  |