QINU fix

See discussion and proposed patch of this issue at

Some extensions that parse WikiMarkup return strings similar to "UNIQ7dcd9aca33200a81-example-14c1dc322856b22b00000001-QINU" instead of returning what they're supposed to. This seems to be a bug with using  to access the parser. In MediaWiki 1.6.8 or above, the parser object is passed to the extension callback function. By using that object, you can solve the problem.

For example, this code may break (it seems inconsistent, or at least in my tests)

The following  function fixes the problem in most cases:

The above code will add  around your output. To disable this, just change the second to last line to:

However, this won't work with newer versions of MediaWiki (1.6.7?) if you call it more than once. Instead, instantiate a new parser altogether:

I haven't tested this with the backward-compatibility described on MediaWiki extensions FAQ, but it seems like it should work.

In general, it seems like a better idea to use the $parser than the global $wgOut object.

if you have to use UNIQ...QINU as input for you function/extension:
example

the parser hides html from wiki with the operation in an array inside the mStripeState Object and replaces it with the UNIQ...QINU string instead. when wiki goes over the code, it does not recognize it is html or anything else with importance for wiki and leaves it untouched. and some final workover process, which is definately after the parsing-hooker stuff, it will replace such UNIQ...QINU strings back with the original raw html. see also jimbos page http://jimbojw.com/wiki/index.php?title=Raw_HTML_Output_from_a_MediaWiki_Parser_Function

so if you get handed over such an UNIQ...QINU string, it is a random genereated unique key for this array. with this key you can access the corresponding raw html code like this:

where $html is the given UNIQ-string and $parser is the used parser. $html contains after this operation something like this: linktitle if return of foreign function was a link.

voila! you can easily extract everything you need from this string!