Wikipedia:Wikipedia Signpost/2008-01-28/New parser

From Wikipedia, the free encyclopedia
Jump to: navigation, search
The Wikipedia Signpost


New parser preprocessor introduced

By ais523, 28 January, 2008

A new preprocessor was introduced this week (see m:Migration to the new preprocessor), after several days of testing by the community, and preceding that extensive testing by developers, to try to make sure that it would not cause problems (last week's coverage). The new parser fixes several bugs, and makes new features available; however, it caused some problems as well that were not caught by the testing.

The new preprocessor has actually existed in the software for a while (since November 20, revision r27667 of the software); however, it caused problems with strip markers (the 'UNIQ bug'; see related story) and was disabled on Wikimedia wikis until the problems could be sorted out. It was re-enabled for the English Wikipedia on January 24 (Village Pump announcement), but some unexpected problems developed, in addition to the changes that were known.

There were some changes that fit to some extent within expected behaviour; for instance, the method previously used to prevent MediaWiki:Ipbreason-dropdown expanding templates within the drop-down list stopped working, but this was easily fixed by Tim Starling (who wrote the new preprocessor) using a different method. However, there were other unexpected problems. One problem that affected certain processes like Wikipedia:Templates for deletion was that signature tildes (~~~~) inside a <!-- comment --> ended up being expanded when the page was saved under the new preprocessor; the new preprocessor was disabled for several hours while the issue was fixed, but now handles such cases correctly. Another problem was caused by the change in semantics of <onlyinclude> (which indirectly affected Portal:Current events, and possibly other pages); it now no longer removes whitespace from the same line, and therefore now behaves the same way as <includeonly> and <noinclude>. However, the change for the most part went smoothly.

Two new pieces of markup are available with the new preprocessor. The new {{#iferror:}} parser function checks to see if another parser function returned an error message, and allows a different error message or other markup instead:

* {{#expr:2+2}} {{#iferror:{{#expr:2+2}}|error}}
* {{#expr:this is an error}} {{#iferror:{{#expr:this is an error}}|error}}
  • 4 4
  • Expression error: Unrecognized word "this". error

There is also the #tag syntax, allowing magic words, template markup and similar preprocessor markup to be used inside tag-like extensions, like <ref> and <imagemap>. There is an example on the technical village pump. One less obvious but important improvement is that branches of parser functions like {{#if:}} that are not used are now not parsed, reducing the load on the server for pages which use such constructs; this means that the pages in question will not use up nearly as much of the page's template limits as before.

A large number of bugs were also fixed by the new preprocessor (see related story).




Also this week:

From the editor — 2007 in review — John Broughton interview — New parser — WikiWorld — News and notes — In the news — Tutorial — WikiProject report — Dispatches — Features and admins — Technology report — Arbitration report


Signpost archives