Extension:SyntaxHighlight/zh

SyntaxHighlight扩展（语法高亮扩展），原先被称作SyntaxHighlight_GeSHi，使用 扩展标签对源代码提供了丰富的格式. 它是由Pygments库提供支持的，并支持数百种不同的编程语言和文件格式.

就像 和 标签，文本将按照输入的内容准确呈现且保留所有空格.

用法
当您安装本扩展后，您就可以在你的wiki使用“syntaxhighlight”标签. 举个例子，

这是实现上面内容的维基代码：

在MediaWiki 1.16之前，这个扩展使用的是 标签. 它现在仍然可以使用，不过 也许可以帮助你获取比 更准确的结果（例如XML语言）.

样式
如果您觉得标签里面的预览文字太大，您可以调整它通过把下面的代码拷贝到您wiki的 MediaWiki:Common.css 中 （创建它如果不存在的话）：

代码块的外框可以通过在上方代码中插入一行 实现. 控制使用的字体也可以通过添加 到上面的代码中.

语法高亮错误分类
该扩展将添加在 或 标签中有错误 属性的页面到一个追踪分类. 消息文字MediaWiki:syntaxhighlight-error-category决定了分类的名字，在本维基上为Category:.

导致页面被此类别标记的最常见错误是 或 标记，根本没有 属性，因为此扩展的旧版本支持“$wgSyntaxHighlightDefaultLang”的定义. 这些通常既可以替换为 ，也可以将 或 添加到标签.

第二普遍的错误是使用 或 等不受支持的 参数. 这些可以通过 或 替换.

语言
属性定义了应使用什么词法分析器. 该语言会影响扩展如何高亮显示源代码. pygments解析器区分大小写，所有语言都至少有一个大写字母（小写字母名称保留给gtags）. 参阅支持的语言这一章节获得关于受支持语言的详细内容.

指定了一个无效的或未知的语言名称，则该页面会被加入跟踪分类. 参阅语法高亮错误分类章节获取详细信息.

行号
属性启用行号.

开始位置
属性（与 相配合）定义了代码块的第一行行号. 例如， 将会使行号从55开始.

高亮
属性将指定一行或多行将被标记（通过对指定的行显示不同的背景色）. 您可以指定多个行的数字通过逗号分隔（例如， ）或使用一个连字符和两个数字表示范围（例如， ）. 注意，行的数字将忽略任何 属性的重新标号.

上面为下方代码的输出结果：

内联
该属性表示源代码将作为段落的一部分内联（而不是自己的块）. 该选项在MediaWiki 1.26 版本开始可用. 为了保持向后兼容， 也会有同样效果.

注意，换行符可以在标签开始和结束之间的任何空格处出现，若源代码带有 （在那些受支持的维基；见下方）或 则是不换行的.

例如：

是在Python的Lambda 表达式.

是下方的结果：

是在Python的Lambda 表达式.

class样式
当使用了 时，指定 （在那些受到支持的维基上，而不是MediaWiki本身）不应在代码块内的空格处出现换行符.

例如：

没有 ：

xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx With : xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx

style样式
属性允许CSS属性被直接包含. 这相当于将块封装在 标签（不是 标签）中. 属性不能够通过这种方式指定. 它需要 标签封装，像下方高级段落中描述的样子.

例如：

是下方的结果：

支持的语言
Pygments库为数百种计算机语言和文件格式提供支持. 简要的语言列表如下：

AppleScript, Assembly, Asymptote, Awk, bash, Befunge, Boo, BrainFuck, C, C++, C#, Clojure, CoffeeScript, ColdFusion, Common Lisp, Coq, Cryptol, Crystal, Cython, D, Dart, Delphi, Dylan, Elm, Erlang, Ezhil, Factor, Fancy, Fortran, F#, Gambas, GAP, Gherkin, GL shaders, Groovy, Haskell, IDL, Io, Java, JavaScript, Lasso, LLVM, Logtalk, Lua, Matlab, MiniD, Modelica, Modula-2, MuPad, Nemerle, Nimrod, Objective-C, Objective-J, Octave, OCaml, PHP, Perl, PovRay, PostScript, PowerShell, Prolog, Python 2.x and 3.x (incl. console sessions and tracebacks), R, REBOL, Red, Redcode, Ruby, Rust, S, S-Plus, Scala, Scheme, Scilab, Smalltalk, SNOBOL, Tcl, Vala, Verilog, VHDL, Visual Basic.NET, Visual FoxPro, XQuery, Zephir

（完整列表和[$pypments 文档中的http://pygments.org/docs/lexers/完整详细信息]）并且GeSHi支持某些语言名称的映射（完整列表）.

以下是GeSHi可以高亮显示的部分语言清单，在切换到Pygments之后不再支持语言的被用横线删去.

配置

 * Linux:


 * （可选）：Pygments包中pygmentize的绝对路径. 默认情况下，扩展中附带了Pygments包， 指向默认了Pygments包，但如果需要，您可以指向不同的版本.  例如：.
 * ：对一些维基页面配置默认的语法分析器. 默认情况下它会高亮显示javascript和css页面.  额外的内容模型可以通过扩展名配置（例如：Lua、JSON等）.


 * Windows:


 * 若您在一台Windows主机上运行MediaWiki，您需要设置Pygmentize.exe的位置.
 * 若没有 ，从命令行运行在 目录中的 来生成文件.

若您在使用附带的pygmentize二进制文件（extensions/SyntaxHighlight_GeSHi/pygments/pygmentize），确保您的网络服务器允许执行它. 若您的主机商不允许添加可执行文件到站点目录，安装python-pygments并添加 到LocalSettings.php中.


 * 问题排除:

找升级到MediaWiki 1.26 版本及其以后，一些用户开始报告与这个扩展的问题. There could be cases, when some languages, such as Lua might not get highlighted and by turning on debugging, MediaWiki would throw out the error,.


 * 尝试在LocalSettings.php指定 为外部pygmentize二进制文件.
 * In shared hosting environments with cPanel, this can be done by setting up a new Python application through the "Setup Python App" menu, and activating the virtual environment for the app through SSH . After this, the Pygments module can be added to the Python app, for which navigate to the virtual environment path, download and install Pygments and then activate the module by adding "Pygments" under the "Existing applications" section of the "Setup Python App" menu. This will create the required file at path:


 * 获取更多建议和信息，请参见phabricator task.

可视化编辑器集成
该插件可以使用可视化编辑器直接编辑. 一个对话框会被打开，当一个用户想要编辑 或 段落. 要使其工作，可视化编辑器必须被安装且从最新git版本被配置，与Parsoid相同. 该功能在较老的Parsoid版本中随机地无法使用. See Extension:SyntaxHighlight/VisualEditor for details

高级
不像 和 标签，HTML字符实体（例如$nbsp）不需要 字符转意为 2. Like the  tag but unlike the   tag, tags within the range (other than its own closing tag) need not have the   symbol escaped as , nor does wikitext need to be escaped with a   tag.

Furthermore, while  assumes tab stops every 8 characters and renders tabs using actual spaces when the rendered text is copied,   uses 4-space tab stops (except Internet Explorer, which uses 8) and preserves the tab characters in the rendered text; the latter may be changed using an enclosing   tag (not , and not using its own   attribute). The  prefix is required for Firefox (from version 4.0), and the   prefix is required for Opera (from version 10.60 to version 15). (Note that the wiki editing box assumes 8-space tabs.) This applies only to actual saved pages; previews generated through an edit box or Special:ExpandTemplates may differ.

另请参阅

 * Pygments – Python syntax highlighter
 * 相关扩展：
 * – 使用谷歌代码美化库的语法高亮扩展.
 * – 使用SyntaxHighlighter库的语法高亮扩展.
 * – 一个依赖于这个扩展的扩展，支持通过一个特殊页面查看文件的高亮文本.