Difference between revisions of "Template:Code/doc"
m |
m |
||
Line 1: | Line 1: | ||
== Usage == | == Usage == | ||
+ | |||
Wraps a short span of text in <code><nowiki><syntaxhighlight></nowiki></code> tags (see [[mw:Extension:SyntaxHighlight|Extension SyntaxHighlight]]). This template should be used for short samples; longer content should use {{tag|pre}} or {{tag|syntaxhighlight}}. See [[wikipedia:Help:Wiki markup|Help:Wiki markup]] for an explanation of what the various tags do. | Wraps a short span of text in <code><nowiki><syntaxhighlight></nowiki></code> tags (see [[mw:Extension:SyntaxHighlight|Extension SyntaxHighlight]]). This template should be used for short samples; longer content should use {{tag|pre}} or {{tag|syntaxhighlight}}. See [[wikipedia:Help:Wiki markup|Help:Wiki markup]] for an explanation of what the various tags do. | ||
− | If the content includes an equals sign | + | If the content includes an equals sign “=”, you must specify the parameter explicitly: <code><nowiki>{{code|1=date=30 Feb 2010}}</nowiki></code>. |
− | The template uses the <code><nowiki><syntaxhighlight></nowiki></code> tag with the attribute <code>inline=1</code>. This works like the combination of the <code><nowiki><code></nowiki></code> and <code><nowiki><nowiki></nowiki></code> tags, applied to the expanded wikitext. For example, <code><nowiki>{{code|some '''wiki''' text}}</nowiki></code> will {{em|{{strong|not}}}} render the word | + | The template uses the <code><nowiki><syntaxhighlight></nowiki></code> tag with the attribute <code>inline=1</code>. This works like the combination of the <code><nowiki><code></nowiki></code> and <code><nowiki><nowiki></nowiki></code> tags, applied to the expanded wikitext. For example, <code><nowiki>{{code|some '''wiki''' text}}</nowiki></code> will {{em|{{strong|not}}}} render the word “wiki” in bold, and will render the tripled‐single quotes: |
: {{code|some '''wiki''' text}} | : {{code|some '''wiki''' text}} | ||
Line 24: | Line 25: | ||
which is going to be visually confusing for many: | which is going to be visually confusing for many: | ||
: foo {{code|bar baz}} quux. | : foo {{code|bar baz}} quux. | ||
− | because | + | because “foo” and “{{code|bar}}” will seem more closely associated than “{{code|bar}}” and “{{code|baz}}”; the width of the space character in a monospaced font is almost always larger than in a proportional font. |
Use parameter {{{2}}} (unnamed, as {{para|2}}, or more explicitly as {{para|lang}}) to specify a language for [[mw:Extension:SyntaxHighlight|Extension:SyntaxHighlight]]. This option defaults to plain-text, i.e. no highlighting. There is no highlighting option for wikitext as a markup language, though {{code|html4strict}} and {{code|html5}} are valid values, as are {{code|php}}, {{code|perl}}, {{code|css}}, {{code|javascript}}, {{code|mysql}} and many others. Attempting to use an invalid one causes a list of valid ones to be displayed in place of the template output, when the page is previewed or saved. | Use parameter {{{2}}} (unnamed, as {{para|2}}, or more explicitly as {{para|lang}}) to specify a language for [[mw:Extension:SyntaxHighlight|Extension:SyntaxHighlight]]. This option defaults to plain-text, i.e. no highlighting. There is no highlighting option for wikitext as a markup language, though {{code|html4strict}} and {{code|html5}} are valid values, as are {{code|php}}, {{code|perl}}, {{code|css}}, {{code|javascript}}, {{code|mysql}} and many others. Attempting to use an invalid one causes a list of valid ones to be displayed in place of the template output, when the page is previewed or saved. | ||
Line 32: | Line 33: | ||
=== Examples === | === Examples === | ||
− | {|class=wikitable style="width: 100%;" | + | {|class=wikitable style="width:100%;" |
! Markup | ! Markup | ||
! Renders as | ! Renders as | ||
Line 48: | Line 49: | ||
=== Included templates === | === Included templates === | ||
− | Embedded templates do not function as expected inside {{tl|code}}; for longer, | + | Embedded templates do not function as expected inside {{tl|code}}; for longer, free‐form blocks of code, which can contain templates such as {{tl|var}} and {{tl|samp}}, use {{tag|code}} as a wrapper instead of this template. |
Templates used inside {{tl|code}} expose the rendered HTML - this can be useful. | Templates used inside {{tl|code}} expose the rendered HTML - this can be useful. |
Revision as of 18:44, 10 July 2020
Usage
Wraps a short span of text in <syntaxhighlight>
tags (see Extension SyntaxHighlight). This template should be used for short samples; longer content should use <pre>…</pre>
or <syntaxhighlight>…</syntaxhighlight>
. See Help:Wiki markup for an explanation of what the various tags do.
If the content includes an equals sign “=”, you must specify the parameter explicitly: {{code|1=date=30 Feb 2010}}
.
The template uses the <syntaxhighlight>
tag with the attribute inline=1
. This works like the combination of the <code>
and <nowiki>
tags, applied to the expanded wikitext. For example, {{code|some '''wiki''' text}}
will not render the word “wiki” in bold, and will render the tripled‐single quotes:
some '''wiki''' text
However, {{code|a {{template}} call}}
will still invoke the template:
a {{[[Template:Code/doc|Template:Code/doc]]}} call
Use <nowiki>…</nowiki>
around the template name to avoid this problem:
a '"`UNIQ--nowiki-00000009-QINU`"' call
When used inline with regular text, Template:Tnull generally looks best and is easiest to read when it is explicitly spaced apart from the regular text:
foo '"`UNIQ--nowiki-0000000B-QINU`"' quux.
is well spaced:
- foo
bar baz
quux.
versus:
foo '"`UNIQ--nowiki-0000000E-QINU`"' quux.
which is going to be visually confusing for many:
- foo
bar baz
quux.
because “foo” and “bar
” will seem more closely associated than “bar
” and “baz
”; the width of the space character in a monospaced font is almost always larger than in a proportional font.
Use parameter {{{2}}} (unnamed, as |2=
, or more explicitly as |lang=
) to specify a language for Extension:SyntaxHighlight. This option defaults to plain-text, i.e. no highlighting. There is no highlighting option for wikitext as a markup language, though html4strict
and html5
are valid values, as are php
, perl
, css
, javascript
, mysql
and many others. Attempting to use an invalid one causes a list of valid ones to be displayed in place of the template output, when the page is previewed or saved.
This template does not need to be substituted.
Examples
Markup | Renders as |
---|---|
Lorem {{code|ipsum '''dolor'''}} sit amet
|
Lorem ipsum '''dolor''' sit amet
|
The declaration {{code |lang=cpp |int foo(const std::string& bar, const std::vector<long double*>& baz);}} is the prototype for a function defined later.
|
The declaration int foo(const std::string& bar, const std::vector<long double*>& baz); is the prototype for a function defined later.
|
If the code contains an equals sign, such as {{code |lang=javascript |code=var img = document.getElementsByTagName("img");}}, you must identify the first parameter explicitly as {{{1}}} or {{{code}}}.
|
If the code contains an equals sign, such as var img = document.getElementsByTagName("img"); , you must identify the first parameter explicitly as {{{1}}} or {{{code}}}.
|
Included templates
Embedded templates do not function as expected inside Template:Tl; for longer, free‐form blocks of code, which can contain templates such as Template:Tl and Template:Tl, use <code>…</code>
as a wrapper instead of this template.
Templates used inside Template:Tl expose the rendered HTML - this can be useful.