Variables
Contents
Predefined Variables
The following variables are substituted when a page is saved. Note that they will appear unreplaced in the preview!
Variable |
Description |
Example – markup |
Example – render |
@``PAGE@ |
Name of the page (useful for template pages) |
||
@``TIMESTAMP@ |
Raw time stamp |
`2004-08-30T06:38:05Z` |
2004-08-30T06:38:05Z |
@``DATE@ |
Current date in the system's format |
`2004-08-30` |
2004-08-30 |
@``TIME@ |
Current date and time in the user's format |
`2004-08-30 06:38:05` |
2004-08-30 06:38:05 |
@``ME@ |
Just the user's name |
||
@``USERNAME@ |
Just the user's name (or his domain/IP) |
||
@``USER@ |
Signature "-- loginname" |
`-- TheAnarcat` |
-- TheAnarcat |
@``SIG@ |
Dated Signature "-- loginname date time" |
`-- TheAnarcat 2004-08-30 06:38:05` |
-- TheAnarcat 2004-08-30 06:38:05 |
@``EMAIL@ |
Replaced with `<<MailTo: execution failed [You need to give an (obfuscated) email address] (see also the log)>>` macro with editor's obfuscated email address |
`<<MailTo(testuser AT example DOT com)` |
Testuser@example.com |
@MAILTO@ || Replaced with `<<MailTo()>>` macro with editor's email address||`<<MailTo(Testuser@example.com)` ||Testuser@example.com – no obfuscation, better to use @EMAIL@ on public sites |
Defining New Variables
If the builtin variables are not enough, you can define new variables by creating a sub-page of your home page with a dictionary of variables in it. For example, if your username is JohnDoe, you would create page `JohnDoe/MyDict` with the content like:
VAR1:: some random text VAR2:: use ''any'' wiki markup
Then, whenever you edit a page, you can use `@VAR1@` or `@VAR2@` to expand to the text in that dictionary. (Note that the lines in a dictionary must start with exactly one space.)
Getting Variables
At Every Page Refresh
You can use these values using the `GetVal` macro:
<<GetVal(WikiDict,var1)>> <<GetVal(WikiDict,var2)>> <<GetVal(WikiDict,var3)>>
Renders as:
When Saving the Page
If the variables are set on UserName/MyDict (UserName must of course be replaced as appropriate), you can get the variables when saving any page with @var1@, @var2@, ...etc. instead of the GetVal macro.
Note that data in dict pages is cached and does not require opening and parsing the page file for each access to the value. In CGI, the value is fetched from a pickle, in long running process, the pickle is loaded once and then the value is accessed from memory.
Note that saving template pages and using preview does not expand variables. Other than that, variable expansion is very global and happens anywhere on the page, including code displays, comments, processing instructions and other "special" areas of a page you might think are excluded.