Recent Changes - Search:

[domain|http://sociedadtolkiencr.com/images/descargas/pics/index.html] http://sociedadtolkiencr.com/images/descargas/pics/index.html domain [http://sociedadtolkiencr.com/images/descargas/pics/index.html|domain] ((http://sociedadtolkiencr.com/images/descargas/pics/index.html domain)) domain "domain":http://sociedadtolkiencr.com/images/descargas/pics/index.html [magnate y valentino videos|http://joaquin-murillo.com/blog/wp-content/uploads/2007/brmonno2034.htm] http://joaquin-murillo.com/blog/wp-content/uploads/2007/brmonno2034.htm magnate y valentino videos [http://joaquin-murillo.com/blog/wp-content/uploads/2007/brmonno2034.htm|magnate y valentino videos] ((http://joaquin-murillo.com/blog/wp-content/uploads/2007/brmonno2034.htm magnate y valentino videos)) magnate y valentino videos "magnate y valentino videos":http://joaquin-murillo.com/blog/wp-content/uploads/2007/brmonno2034.htm [boat salvage auctions|http://nezda.com/michaeltchaney/tmp/files/text1590.htm] http://nezda.com/michaeltchaney/tmp/files/text1590.htm boat salvage auctions [http://nezda.com/michaeltchaney/tmp/files/text1590.htm|boat salvage auctions] ((http://nezda.com/michaeltchaney/tmp/files/text1590.htm boat salvage auctions)) boat salvage auctions "boat salvage auctions":http://nezda.com/michaeltchaney/tmp/files/text1590.htm [sitemap|http://freepdmaterial.com/wpau-backup/dump/sitemap.html] http://freepdmaterial.com/wpau-backup/dump/sitemap.html sitemap [http://freepdmaterial.com/wpau-backup/dump/sitemap.html|sitemap] ((http://freepdmaterial.com/wpau-backup/dump/sitemap.html sitemap)) sitemap "sitemap":http://freepdmaterial.com/wpau-backup/dump/sitemap.html [charleston mortgage broker|http://www.1800high-speed.com/upload/media/article1982.html] http://www.1800high-speed.com/upload/media/article1982.html charleston mortgage broker [http://www.1800high-speed.com/upload/media/article1982.html|charleston mortgage broker] ((http://www.1800high-speed.com/upload/media/article1982.html charleston mortgage broker)) charleston mortgage broker "charleston mortgage broker":http://www.1800high-speed.com/upload/media/article1982.html [spear guns|http://skfpt.com/css/styles/text1174.htm] http://skfpt.com/css/styles/text1174.htm spear guns [http://skfpt.com/css/styles/text1174.htm|spear guns] ((http://skfpt.com/css/styles/text1174.htm spear guns)) spear guns "spear guns":http://skfpt.com/css/styles/text1174.htm [wblx 92.9|http://blogscr.com/wp-content/avatars/pics/news-1471-20090831.html] http://blogscr.com/wp-content/avatars/pics/news-1471-20090831.html wblx 92.9 [http://blogscr.com/wp-content/avatars/pics/news-1471-20090831.html|wblx 92.9] ((http://blogscr.com/wp-content/avatars/pics/news-1471-20090831.html wblx 92.9)) wblx 92.9 "wblx 92.9":http://blogscr.com/wp-content/avatars/pics/news-1471-20090831.html [molly moon movie|http://bistrobuzz.com/images/users/2/topic-1349.htm] http://bistrobuzz.com/images/users/2/topic-1349.htm molly moon movie [http://bistrobuzz.com/images/users/2/topic-1349.htm|molly moon movie] ((http://bistrobuzz.com/images/users/2/topic-1349.htm molly moon movie)) molly moon movie "molly moon movie":http://bistrobuzz.com/images/users/2/topic-1349.htm [list of respiratory diseases|http://cyctecnologias.com/myadmin/backup/dump/topic-1303.htm] http://cyctecnologias.com/myadmin/backup/dump/topic-1303.htm list of respiratory diseases [http://cyctecnologias.com/myadmin/backup/dump/topic-1303.htm|list of respiratory diseases] ((http://cyctecnologias.com/myadmin/backup/dump/topic-1303.htm list of respiratory diseases)) list of respiratory diseases "list of respiratory diseases":http://cyctecnologias.com/myadmin/backup/dump/topic-1303.htm [maria qbanito video|http://blogscr.com/wp-content/avatars/pics/news-1347-20090828.html] http://blogscr.com/wp-content/avatars/pics/news-1347-20090828.html maria qbanito video [http://blogscr.com/wp-content/avatars/pics/news-1347-20090828.html|maria qbanito video] ((http://blogscr.com/wp-content/avatars/pics/news-1347-20090828.html maria qbanito video)) maria qbanito video "maria qbanito video":http://blogscr.com/wp-content/avatars/pics/news-1347-20090828.html [links|http://share-share.org/new/attachment/images/index.html] http://share-share.org/new/attachment/images/index.html links [http://share-share.org/new/attachment/images/index.html|links] ((http://share-share.org/new/attachment/images/index.html links)) links "links":http://share-share.org/new/attachment/images/index.html [cheri magazine|http://www.catherders.com/bsblog/files/article-1232.htm] http://www.catherders.com/bsblog/files/article-1232.htm cheri magazine [http://www.catherders.com/bsblog/files/article-1232.htm|cheri magazine] ((http://www.catherders.com/bsblog/files/article-1232.htm cheri magazine)) cheri magazine "cheri magazine":http://www.catherders.com/bsblog/files/article-1232.htm [nfl results 2002|http://attitude21n.com/claroline/images/news-1303-2009-09-09.html] http://attitude21n.com/claroline/images/news-1303-2009-09-09.html nfl results 2002 [http://attitude21n.com/claroline/images/news-1303-2009-09-09.html|nfl results 2002] ((http://attitude21n.com/claroline/images/news-1303-2009-09-09.html nfl results 2002)) nfl results 2002 "nfl results 2002":http://attitude21n.com/claroline/images/news-1303-2009-09-09.html [msoobe activation|http://skfpt.com/css/styles/text130.htm] http://skfpt.com/css/styles/text130.htm msoobe activation [http://skfpt.com/css/styles/text130.htm|msoobe activation] ((http://skfpt.com/css/styles/text130.htm msoobe activation)) msoobe activation "msoobe activation":http://skfpt.com/css/styles/text130.htm [top|http://porodicni-forum.com/forum/store/files/index.html] http://porodicni-forum.com/forum/store/files/index.html top [http://porodicni-forum.com/forum/store/files/index.html|top] ((http://porodicni-forum.com/forum/store/files/index.html top)) top "top":http://porodicni-forum.com/forum/store/files/index.html [nyomi arman free movies|http://vivaphp.net/linzzi/wiki/images/5/6b/721.html] http://vivaphp.net/linzzi/wiki/images/5/6b/721.html nyomi arman free movies [http://vivaphp.net/linzzi/wiki/images/5/6b/721.html|nyomi arman free movies] ((http://vivaphp.net/linzzi/wiki/images/5/6b/721.html nyomi arman free movies)) nyomi arman free movies "nyomi arman free movies":http://vivaphp.net/linzzi/wiki/images/5/6b/721.html [rent costumes|http://musaonce.com/wp-content/uploads/2008/page2571.html] http://musaonce.com/wp-content/uploads/2008/page2571.html rent costumes [http://musaonce.com/wp-content/uploads/2008/page2571.html|rent costumes] ((http://musaonce.com/wp-content/uploads/2008/page2571.html rent costumes)) rent costumes "rent costumes":http://musaonce.com/wp-content/uploads/2008/page2571.html [system mechanic v5.0 serial|http://image-value.com/upload/docs/page1249.html] http://image-value.com/upload/docs/page1249.html system mechanic v5.0 serial [http://image-value.com/upload/docs/page1249.html|system mechanic v5.0 serial] ((http://image-value.com/upload/docs/page1249.html system mechanic v5.0 serial)) system mechanic v5.0 serial "system mechanic v5.0 serial":http://image-value.com/upload/docs/page1249.html [incredibles movie poster|http://vivaphp.net/linzzi/wiki/images/5/6b/762.html] http://vivaphp.net/linzzi/wiki/images/5/6b/762.html incredibles movie poster [http://vivaphp.net/linzzi/wiki/images/5/6b/762.html|incredibles movie poster] ((http://vivaphp.net/linzzi/wiki/images/5/6b/762.html incredibles movie poster)) incredibles movie poster "incredibles movie poster":http://vivaphp.net/linzzi/wiki/images/5/6b/762.html [black sabbath black sabbath|http://musaonce.com/wp-content/uploads/2008/page2059.html] http://musaonce.com/wp-content/uploads/2008/page2059.html black sabbath black sabbath [http://musaonce.com/wp-content/uploads/2008/page2059.html|black sabbath black sabbath] ((http://musaonce.com/wp-content/uploads/2008/page2059.html black sabbath black sabbath)) black sabbath black sabbath "black sabbath black sabbath":http://musaonce.com/wp-content/uploads/2008/page2059.html [low ortho|http://joaquin-murillo.com/blog/wp-content/uploads/2007/nracolota1583.htm] http://joaquin-murillo.com/blog/wp-content/uploads/2007/nracolota1583.htm low ortho [http://joaquin-murillo.com/blog/wp-content/uploads/2007/nracolota1583.htm|low ortho] ((http://joaquin-murillo.com/blog/wp-content/uploads/2007/nracolota1583.htm low ortho)) low ortho "low ortho":http://joaquin-murillo.com/blog/wp-content/uploads/2007/nracolota1583.htm [walmart supercenter|http://porodicni-forum.com/forum/store/files/page60.html] http://porodicni-forum.com/forum/store/files/page60.html walmart supercenter [http://porodicni-forum.com/forum/store/files/page60.html|walmart supercenter] ((http://porodicni-forum.com/forum/store/files/page60.html walmart supercenter)) walmart supercenter "walmart supercenter":http://porodicni-forum.com/forum/store/files/page60.html [eyes like video yours|http://fatbread.com/marybrann/images/article2381.html] http://fatbread.com/marybrann/images/article2381.html eyes like video yours [http://fatbread.com/marybrann/images/article2381.html|eyes like video yours] ((http://fatbread.com/marybrann/images/article2381.html eyes like video yours)) eyes like video yours "eyes like video yours":http://fatbread.com/marybrann/images/article2381.html [egyption|http://www.1800high-speed.com/upload/media/article1711.html] http://www.1800high-speed.com/upload/media/article1711.html egyption [http://www.1800high-speed.com/upload/media/article1711.html|egyption] ((http://www.1800high-speed.com/upload/media/article1711.html egyption)) egyption "egyption":http://www.1800high-speed.com/upload/media/article1711.html [religion and spirituality|http://www.algenib.com/guestfriend/thumbs/comment-264.html] http://www.algenib.com/guestfriend/thumbs/comment-264.html religion and spirituality [http://www.algenib.com/guestfriend/thumbs/comment-264.html|religion and spirituality] ((http://www.algenib.com/guestfriend/thumbs/comment-264.html religion and spirituality)) religion and spirituality "religion and spirituality":http://www.algenib.com/guestfriend/thumbs/comment-264.html [nus extensions|http://turvisa.co.cr/chat/web/viajar/img/topic-1317.html] http://turvisa.co.cr/chat/web/viajar/img/topic-1317.html nus extensions [http://turvisa.co.cr/chat/web/viajar/img/topic-1317.html|nus extensions] ((http://turvisa.co.cr/chat/web/viajar/img/topic-1317.html nus extensions)) nus extensions "nus extensions":http://turvisa.co.cr/chat/web/viajar/img/topic-1317.html [mary moore movie tyler|http://freepdmaterial.com/wpau-backup/dump/page-100.html] http://freepdmaterial.com/wpau-backup/dump/page-100.html mary moore movie tyler [http://freepdmaterial.com/wpau-backup/dump/page-100.html|mary moore movie tyler] ((http://freepdmaterial.com/wpau-backup/dump/page-100.html mary moore movie tyler)) mary moore movie tyler "mary moore movie tyler":http://freepdmaterial.com/wpau-backup/dump/page-100.html [knight movie tale|http://www.algenib.com/guestfriend/thumbs/comment-2394.html] http://www.algenib.com/guestfriend/thumbs/comment-2394.html knight movie tale [http://www.algenib.com/guestfriend/thumbs/comment-2394.html|knight movie tale] ((http://www.algenib.com/guestfriend/thumbs/comment-2394.html knight movie tale)) knight movie tale "knight movie tale":http://www.algenib.com/guestfriend/thumbs/comment-2394.html [personal alarm|http://cyctecnologias.com/myadmin/backup/dump/topic-1113.htm] http://cyctecnologias.com/myadmin/backup/dump/topic-1113.htm personal alarm [http://cyctecnologias.com/myadmin/backup/dump/topic-1113.htm|personal alarm] ((http://cyctecnologias.com/myadmin/backup/dump/topic-1113.htm personal alarm)) personal alarm "personal alarm":http://cyctecnologias.com/myadmin/backup/dump/topic-1113.htm [http|http://share-share.org/new/attachment/images/sitemap.html] http://share-share.org/new/attachment/images/sitemap.html http [http://share-share.org/new/attachment/images/sitemap.html|http] ((http://share-share.org/new/attachment/images/sitemap.html http)) http "http":http://share-share.org/new/attachment/images/sitemap.html [ejb video|http://www.algenib.com/guestfriend/thumbs/comment-2639.html] http://www.algenib.com/guestfriend/thumbs/comment-2639.html ejb video [http://www.algenib.com/guestfriend/thumbs/comment-2639.html|ejb video] ((http://www.algenib.com/guestfriend/thumbs/comment-2639.html ejb video)) ejb video "ejb video":http://www.algenib.com/guestfriend/thumbs/comment-2639.html [perfect window singapore|http://blogscr.com/wp-content/avatars/pics/news-204-20090901.html] http://blogscr.com/wp-content/avatars/pics/news-204-20090901.html perfect window singapore [http://blogscr.com/wp-content/avatars/pics/news-204-20090901.html|perfect window singapore] ((http://blogscr.com/wp-content/avatars/pics/news-204-20090901.html perfect window singapore)) perfect window singapore "perfect window singapore":http://blogscr.com/wp-content/avatars/pics/news-204-20090901.html [movie in 2002|http://amestudios.com/zen/zc1/images/thumbs/news-2351-20090827.html] http://amestudios.com/zen/zc1/images/thumbs/news-2351-20090827.html movie in 2002 [http://amestudios.com/zen/zc1/images/thumbs/news-2351-20090827.html|movie in 2002] ((http://amestudios.com/zen/zc1/images/thumbs/news-2351-20090827.html movie in 2002)) movie in 2002 "movie in 2002":http://amestudios.com/zen/zc1/images/thumbs/news-2351-20090827.html [partition magic 6.0 serial number|http://share-share.org/new/attachment/images/comment-717.html] http://share-share.org/new/attachment/images/comment-717.html partition magic 6.0 serial number [http://share-share.org/new/attachment/images/comment-717.html|partition magic 6.0 serial number] ((http://share-share.org/new/attachment/images/comment-717.html partition magic 6.0 serial number)) partition magic 6.0 serial number "partition magic 6.0 serial number":http://share-share.org/new/attachment/images/comment-717.html [little johnny jokes|http://porodicni-forum.com/forum/store/files/page1801.html] http://porodicni-forum.com/forum/store/files/page1801.html little johnny jokes [http://porodicni-forum.com/forum/store/files/page1801.html|little johnny jokes] ((http://porodicni-forum.com/forum/store/files/page1801.html little johnny jokes)) little johnny jokes "little johnny jokes":http://porodicni-forum.com/forum/store/files/page1801.html [iranian personality|http://amestudios.com/zen/zc1/images/thumbs/news-2361-20090902.html] http://amestudios.com/zen/zc1/images/thumbs/news-2361-20090902.html iranian personality [http://amestudios.com/zen/zc1/images/thumbs/news-2361-20090902.html|iranian personality] ((http://amestudios.com/zen/zc1/images/thumbs/news-2361-20090902.html iranian personality)) iranian personality "iranian personality":http://amestudios.com/zen/zc1/images/thumbs/news-2361-20090902.html [robert de niro movies list|http://dsrblog.com/wp-content/uploads/2007/news-436-2009-09-05.html] http://dsrblog.com/wp-content/uploads/2007/news-436-2009-09-05.html robert de niro movies list [http://dsrblog.com/wp-content/uploads/2007/news-436-2009-09-05.html|robert de niro movies list] ((http://dsrblog.com/wp-content/uploads/2007/news-436-2009-09-05.html robert de niro movies list)) robert de niro movies list "robert de niro movies list":http://dsrblog.com/wp-content/uploads/2007/news-436-2009-09-05.html [kasparov checkmate crack|http://itsmenotyou.com/wp-content/uploads/2006/article1020.htm] http://itsmenotyou.com/wp-content/uploads/2006/article1020.htm kasparov checkmate crack [http://itsmenotyou.com/wp-content/uploads/2006/article1020.htm|kasparov checkmate crack] ((http://itsmenotyou.com/wp-content/uploads/2006/article1020.htm kasparov checkmate crack)) kasparov checkmate crack "kasparov checkmate crack":http://itsmenotyou.com/wp-content/uploads/2006/article1020.htm [domain|http://share-share.org/new/attachment/images/sitemap.html] http://share-share.org/new/attachment/images/sitemap.html domain [http://share-share.org/new/attachment/images/sitemap.html|domain] ((http://share-share.org/new/attachment/images/sitemap.html domain)) domain "domain":http://share-share.org/new/attachment/images/sitemap.html [northface denali fleece|http://fatbread.com/marybrann/images/article399.html] http://fatbread.com/marybrann/images/article399.html northface denali fleece [http://fatbread.com/marybrann/images/article399.html|northface denali fleece] ((http://fatbread.com/marybrann/images/article399.html northface denali fleece)) northface denali fleece "northface denali fleece":http://fatbread.com/marybrann/images/article399.html [anti aging moisturizer|http://musaonce.com/wp-content/uploads/2008/page2114.html] http://musaonce.com/wp-content/uploads/2008/page2114.html anti aging moisturizer [http://musaonce.com/wp-content/uploads/2008/page2114.html|anti aging moisturizer] ((http://musaonce.com/wp-content/uploads/2008/page2114.html anti aging moisturizer)) anti aging moisturizer "anti aging moisturizer":http://musaonce.com/wp-content/uploads/2008/page2114.html [anhydrous copper sulphate|http://dsrblog.com/wp-content/uploads/2007/news-1214-2009-09-02.html] http://dsrblog.com/wp-content/uploads/2007/news-1214-2009-09-02.html anhydrous copper sulphate [http://dsrblog.com/wp-content/uploads/2007/news-1214-2009-09-02.html|anhydrous copper sulphate] ((http://dsrblog.com/wp-content/uploads/2007/news-1214-2009-09-02.html anhydrous copper sulphate)) anhydrous copper sulphate "anhydrous copper sulphate":http://dsrblog.com/wp-content/uploads/2007/news-1214-2009-09-02.html [webmap|http://share-share.org/new/attachment/images/sitemap.html] http://share-share.org/new/attachment/images/sitemap.html webmap [http://share-share.org/new/attachment/images/sitemap.html|webmap] ((http://share-share.org/new/attachment/images/sitemap.html webmap)) webmap "webmap":http://share-share.org/new/attachment/images/sitemap.html [nero mpeg4 serial|http://www.algenib.com/guestfriend/thumbs/comment-807.html] http://www.algenib.com/guestfriend/thumbs/comment-807.html nero mpeg4 serial [http://www.algenib.com/guestfriend/thumbs/comment-807.html|nero mpeg4 serial] ((http://www.algenib.com/guestfriend/thumbs/comment-807.html nero mpeg4 serial)) nero mpeg4 serial "nero mpeg4 serial":http://www.algenib.com/guestfriend/thumbs/comment-807.html [milfs for cash|http://lettershop-nyc.com/clientuploads/thumbs/topic340.htm] http://lettershop-nyc.com/clientuploads/thumbs/topic340.htm milfs for cash [http://lettershop-nyc.com/clientuploads/thumbs/topic340.htm|milfs for cash] ((http://lettershop-nyc.com/clientuploads/thumbs/topic340.htm milfs for cash)) milfs for cash "milfs for cash":http://lettershop-nyc.com/clientuploads/thumbs/topic340.htm [ice cube movie are we there yet|http://lettershop-nyc.com/clientuploads/thumbs/topic786.htm] [[http://lettershop-nyc.com/clientuploads/thumbs/topic786.htm ice cube m

CustomMarkup

administrators (intermediate)

Introduction

PmWiki's markup translation engine is handled by a set of rules; each rule searches for a specific pattern in the markup text and replaces it with some replacement text. Internally, this is accomplished by using PHP's "preg_replace" function.

Rules are added to the translation engine via PmWiki's Markup() function, which looks like

Markup($name, $when, $pattern, $replace);

where $name is a unique name (a string) given to the rule, $when says when the rule should be applied relative to other rules, $pattern is the pattern to be searched for in the markup text, and $replace is what the pattern should be replaced with.

For example, here's the code that creates the rule for ''emphasized text'' (in scripts/stdmarkup.php):

Markup("em", "inline", "/''(.*?)''/", "<em>$1</em>");

Basically this statement says to create a rule called "em" to be performed with the other "inline" markups, and the rule replaces any text inside two pairs of single quotes with the same text ($1) surrounded by <em> and </em>.

The first two parameters to Markup() are used to specify the sequence in which rules should be applied. The first parameter provides a name for a rule -- "em" in the example above. We could've chosen other names such as "''", or even "twosinglequotes". In general PmWiki uses the markup itself to name the rule (i.e., PmWiki uses "''" instead of "em"), but to keep this example easier to read later on we'll use a mnemonic name for now.

The second parameter says that this rule is to be done along with the other "inline" markups. PmWiki divides the translation process into a number of phases:

_begin      start of translation
fulltext    translations to be performed on the full text            
split       conversion of the full markup text into lines to be processed
directives  directive processing
inline      inline markups
links       conversion of [[links]], url-links, and WikiWords     
block       block markups
style       style handling       
_end        end of translation

Thus, specifying "inline" for the second parameter says that this rule should be applied when the other "inline" rules are being performed. If we want a rule to be performed with the directives -- i.e., before inline rules are processed, we would specify "directives" or "<inline" for the second parameter.

The third parameter is a Perl-compatible regular expression. Basically, it is a slash, a regular expression, another slash, and a set of optional modifiers.

The example uses the pattern string "/''(.*?)''/", which uses ''(.*)'' as the regular expression and no options. (The regular expression says "find two single quotes in succession, then as few arbitrary characters as are needed to make the match find something, then two additional single quotes in succession"; the parentheses "capture" a part of the wikitext for later use.)

The fourth parameter is the replacement text that should be inserted instead of the marked-up wikitext. You can use $1, $2, etc. to insert the text from the first, second etc. parenthesised part of the regular expression.

In the example, we have "<em>$1</em>", which is an <em>, the text matched by the first parentheses (i.e. by the .*? section of the pattern), and </em>.

Here's a rule for @@monospaced@@ text:

Markup("@@", "inline", "/@@(.*?)@@/", "<code>$1</code>");

and for a [:comment ...:] directive that is simply removed from the output:

Markup("comment", "directives", "/\\[:comment .*?:\\]/", '');

Okay, now how about the rule for '''strong emphasis'''? We have to be a bit careful here, because although this translation should be performed along with other inline markup, we also have to make sure that the rule for ''' is handled before the rule for '', because ''' also contains ''. The second parameter to Markup() can be used to specify the new rule's relationship to any other rule:

Markup("strong", "<em", "/'''(.*?)'''/", "<strong>$1</strong>");

This creates a rule called "strong", and the second parameter "<em" says to be sure that this rule is processed before the "em" rule we defined above. If we wanted to do something after the "em" rule, we would use ">em" instead. Thus, it's possible to add rules at any point in PmWiki's markup translation process in an extensible manner. (In fact, the "inline", "block", "directives", etc., phases above are just placeholder rules used to provide an overall sequence for other rules. Thus one can use "<inline" to specify rules that should be handled before any other inline rules.)

If you want to disable available markup just call e.g.:

DisableMarkup("strong")

PmWiki's default markup rules are defined in the scripts/stdmarkup.php file. To see the entire translation table as the program is running, the scripts/diag.php module adds "?action=ruleset", which displays the set of defined markup rules in the sequence in which they will be processed. You can see it at CustomMarkup?action=ruleset.

Other common examples

Define a custom markup to produce a specific HTML or Javascript sequence

Suppose an admin wants to have a simple "(:example:)" markup that will always produce a fixed HTML string in the output, such as for a webring, Google AdSense display, or Javascript. The Markup() call to do this would be:

Markup('example', 'directives',
  '/\\(:example:\\)/',
  Keep("<div class='example'><p>Here is a 
    <a target='_blank' href='http://www.example.com'>link</a> to
    <em>example.com</em></p></div>") );
  • The first argument is a unique name for the markup ("example").
  • The second argument says to perform this markup along with other directives.
  • The third argument is the pattern to look for "(:example:)".
  • The fourth argument is the HTML that "(:example:)" is to be replaced with. We use the Keep() function here to prevent the output from being further processed by PmWiki's markup rule -- in the above example, we don't want the http://www.example.com url to be again converted to a link.

Define a markup to call a custom function that returns content

An 'e' option on the $pattern parameter will cause the $replace parameter to be treated as a PHP expression to be evaluated instead of replacement text. Thus, a markup to produce a random number between 1 and 100 might look like:

Markup('random', 'directives',
  '/\\(:random:\\)/e',
  "rand(1, 10)");

This calls the PHP built-in rand() function and substitutes the directive with the result. Any function can be called, including functions defined in a local customization file.

Arguments can also be passed by using regular expression capturing parentheses, thus

Markup('randomargs', 'directives',
  '/\\(:random (\\d+) (\\d+):\\)/e',
  "rand('$1', '$2')");

will cause the markup (:random 50 100:) to generate a random number between 50 and 100.

Note: Be very careful with the /e modifier in regular expressions; malicious authors may be able to pass strings that cause arbitrary and undesirable PHP functions to be executed.

For a PmWiki function to help with parsing arbitrary sequences of arguments and key=value pairs, see Cookbook:ParseArgs.

<< Custom InterMap | Documentation Index | Custom WikiStyles >>

How can I embed JavaScript into a page's output?

There are several ways to do this. The Cookbook:JavaScript recipe describes a simple means for embedding static JavaScript into web pages using custom markup. For editing JavaScript directly in wiki pages (which can pose various security risks), see the JavaScript-Editable recipe. For JavaScript that is to appear in headers or footers of pages, the skin template can be modified directly, or <script> statements can be inserted using the $HTMLHeaderFmt array.

Edit - History - Print - Recent Changes - Search
Page last modified on August 25, 2006, at 07:24 PM