Pull request numbers before 2.4.2 are not linked as they refer to the now defunct Bitbucket project.
Carbon: fix long processing times on invalid input
Elpi: handle quotations (#2419)
lean: recognize expressions nested within attributes (#1817)
scdoc: improve language guessing implementation (#2402)
Transact SQL: add Pre-sorted Group keyword (#2417)
Uxntal: update for current runes (#2424)
Generic.EmphStrongtoken for bold italic markup (#2444)
(released April 18th, 2023)
(released April 10th, 2023)
AMDGPU: Add support for
attr*.*argument, as well as the
APDL: Miscellaneous improvements (#2314)
Chapel: Support attributes (#2376)
CSS: Improve lexing of numbers inside function calls (#2382, #2383)
diff: Support normal diff syntax, as opposed to unified diff syntax (#2321)
LilyPond: minor update of builtins
PHP: support attributes (#2055, #2347, #2360), fix anonymous classes without parameters (#2359), improve lexing of variable variable syntax (#2358)
Spice: Update keywords (#2336)
analyse_textmethod): Fix catastrophic backtracking (#2355)
Declare support for Python 3.11 and drop support for Python 3.6 (#2324).
nativestyle to improve contrast (#2325).
Update github-dark` style to match latest Primer style (#2401)
Revert a change that made guessing lexers based on file names slower on Python 3.10 and older (#2328).
Fix some places where a locale-dependent encoding could unintentionally be used instead of UTF-8 (#2326).
Groff formatter: sort color definitions for reproducibility (#2343)
Move project metadata to
Makefilehas been removed. Instead, all shortcuts for developing are now defined and run through tox. The
docfolder still contains a
Makefileas an alternative to
tox -e doc.
(released January 1st, 2023)
Abap: Update keywords (#2281)
Alloy: Update for Alloy 6 (#1963)
C family (C, C++ and many others):
CSound: Updated builtins (#2268)
.fsxfile extension (#2282)
gas (GNU assembler): recognize braces as punctuation (#2230)
HTTP: Add CONNECT keyword (#2242)
Inform 6: Fix lexing of properties and doubles (#2214)
INI: Allow comments that are not their own line (#2217, #2161)
Java properties: Fix issue with whitespace-delimited keys, support comments starting with ! and escapes, no longer support undocumented ; and // comments (#2241)
LilyPond: Improve heuristics, add
LLVM: Add opaque pointer type (#2269)
Macaulay2: Update keywords (#2305)
Minecraft-related lexers (SNB and Minecraft function) moved to
Nim: General improvements (#1970)
Nix: Fix single quotes inside indented strings (#2289)
Objective J: Fix catastrophic backtracking (#2225)
NASM: Add support for SSE/AVX/AVX-512 registers as well as ‘rel’ and ‘abs’ address operators (#2212)
Solidity: Add boolean operators (#2292)
enumkeyword and fix a bug regarding binary, hexadecimal and octal number tokens (#2227)
YAML: Accept colons in key names (#2277)
Fix make mapfiles when Pygments is not installed in editable mode (#2223)
Support more filetypes and compression types in autopygmentize (#2219)
Merge consecutive tokens in Autohotkey, Clay (#2248)
.nasmas a recognized file type for NASM (#2280)
*Spec.hsas a recognized file type for
*.pyi(for typing stub files) as a recognized file type for Python (#2231)
The HTML lexer no longer emits empty spans for whitespace (#2304)
IRCFormatterinserting linenumbers incorrectly (#2270)
(released August 15th, 2022)
Ada: support Ada 2022 (#2121); disable recognition of namespaces because it disturbs lexing of aspects (#2125)
Agda: allow straight quotes in module names (#2163)
C family (C, C++ and many others): allow comments between elements of function headers, e.g. between the arguments and the opening brace for the body (#1891)
Coq: Add some common keywords, improve recognition of
Setand qualified identifiers (#2158)
F*: Allow C-style comments anywhere in a line
Fortran: Fix catastrophic backtracking with backslashes in strings (#2194)
Go: add support for generics (#2167)
Inform: Update for version 6.40 (#2190)
Isabelle: recognize cartouches (#2089)
Java: support multiline strings aka. text blocks (#2132)
LilyPond: Add some missing builtins
Macaulay2: Update builtins (#2139)
Matlab session: fix traceback when a line continuation ellipsis appears in the output (#2166)
.NET: Add aliases for LibreOffice Basic, OpenOfficeBasic and StarOffice Basic (#2170)
PHP: fix "$var" inside strings (#2105)
Python: only recognize
\Uescape sequences in string literals, but not in bytes literals where they are not supported (#2204)
Terraform: Accept leading whitespace for << heredoc delimiters (#2162)
Teraterm: Various improvements (#2165)
Spice: add support for the recently added features including more builtin functions and bin, oct, hex number formats (#2206)
Pygments now tries to use the
importlib.metadatamodule to discover plugins instead of the slower
pkg_resources(#2155). In particular, this largely speeds up the
pygmentizescript when the lexer is not specified.
importlib.metadatais only available in the Python standard library since Python 3.8. For older versions, there exists an
importlib_metadatabackport on PyPI. For this reason, Pygments now defines a packaging extra
plugins, which adds a requirement on
importlib_metadataif the Python version is older than 3.8. Thus, in order to install Pygments with optimal plugin support even for old Python versions, you should do:
pip install pygments[plugins]
Pygments still falls back on
importlib_metadatais found, but it will be slower.
BrokenPipeErrorin the command-line interface (#2193).
HtmlFormatternow uses the
lineanchorsattribute is unset (#2026).
formatfunctions no longer wrongly report “argument must be a lexer/formatter instance, not a class” in some cases where this is not the actual problem (#2123).
Fix warnings in doc build (#2124).
codetagifyfilter now recognizes
FIXMEtags by default (#2150).
pygmentizecommand now recognizes if the
COLORTERMenvironment variable is set to a value indicating that true-color support is available. In that case, it uses the
TerminalTrueColorFormatterby default (#2160)
Remove redundant caches for filename patterns (#2153)
Use new non-deprecated Pillow API for text bounding box in
DeprecationWarningsas errors in the unit tests (#2196)
(released April 24th, 2022)
Agda: Update keyword list (#2017)
C family: Fix identifiers after
Clojure: Highlight ratios (#2042)
Csound: Update to 6.17 (#2064)
CSS: Update the list of properties (#2113)
Futhark: Add missing tokens (#2118)
Inform6: Update to 6.36 (#2050)
.xxx.jinja2to relevant lexers (for
xml, etc.) (#2103)
JSON: Support C comments in JSON (#2049). Note: This doesn’t mean the JSON parser now supports JSONC or JSON5 proper, just that it doesn’t error out when seeing a
//style comment. If you need proper comment handling, consider using the
PHP: Update builtin function and keyword list (#2054, #2056)
Savi: fix highlighting for underscore/private identifiers, add string interpolation (#2102); fix nested type name highlighting (#2110)
Scheme: Various improvements (#2060)
Spice: Update the keyword list, add new types (#2063, #2067)
Bump minimal Python version to 3.6 (#2059)
Fix multiple lexers marking whitespace as
Remove various redundant uses of
.resourcewith the Robot framework (#2047)
.cljcwith Clojure (#2043)
.tppwith C++ (#2031)
Remove traces of Python 2 from the documentation (#2039)
nativestyle was updated to meet the WCAG AAA contrast guidelines (#2038)
Fix various typos (#2030)
Groffformatter not inheriting token styles correctly (#2024)
Various improvements to the CI (#2036)
The Ada lexer has been moved to a separate file (#2117)
linenos=tableis used, the
<table>itself is now wrapped with a
<div class="highlight">tag instead of placing it inside the
<td class="code">cell (#632.) With this change, the output matches the documented behavior.
If you have subclassed
HtmlFormatter.wrap, you may have to adjust the logic.
(released January 6th, 2022)
Fix links to line numbers not working correctly (#2014)
Whitespacestyle in the
Terminal256formatters not backtracking correctly for custom token types, resulting in some unstyled tokens (#1986)
(released December 31st, 2021)
(released December 30th, 2021)
ABNF: Allow one-character rules (#1804)
Bibtex: Distinguish between
C family: Support unicode identifiers (#1848)
CDDL: Fix slow lexing speed (#1959)
Debian control: Add missing fields (#1946)
Devicetree: Recognize hexadecimal addresses for nodes (#1949)
voiddata type (#1948)
HTML, XML: Improve comment handling (#1896)
objdump-nasm: Improve handling of
Prolog: Support escaped
\inside quoted strings (#1479)
All of the new styles unfortunately do not conform to WCAG recommendations.
There is new infrastructure in place to improve style accessibility. The default style has been updated to conform to WCAG recommendations. All styles are now checked for sufficient contrast by default to prevent regressions. (#1919, #1937, #1938, #1940)
Clean up unused imports (#1887)
Fix multiple lexers producing repeated single-character tokens
Fix multiple lexers marking whitespace as
Text(#1237, #1905, #1908, #1914, #1911, #1923, #1939, #1957, #1978)
Remove duplicated assignments in the Paraiso style (#1934)
pygmentizesupports JSON output for the various list functions now, making it easier to consume them from scripts. (#1437, #1890)
Use the C lexer for
Update documentation (#1928)
Line anchors now link to themselves (#1973)
Add official support for Python 3.10 (#1917)
Fix several missing colors in dark styles: Gruvbox dark, Monokai, Rrt, Sas, Strata dark (#1955)
Associate more file types with
HtmlFormattercan now emit tooltips for each token to ease debugging of lexers (#1822)
f90as an alias for
(released August 15th, 2021)
C-family: Fix preprocessor token issues (#1830)
Scala: Add support for the
Fix assert statements in TNT lexer.
Token types across all lexers have been unified (using the most common token type name) (#1816, #1819)
Improve Jasmin min score analysis (#1619)
Add new alias for Go files (#1827)
Fix multi-line console highlighting (#1833)
Add a new trivial lexer which outputs everything as Text.Generic.Output (#1835, #1836)
pwshis now recognized as an alias for PowerShell (#1876)
(released May 3rd, 2021)
C/C++: Improve namespace handling (#1722, #1561, #1719, #1746)
Octave: Allow multiline and block-percent comments (#1726)
Terraform: Support 0.14 syntax (#1756)
Velocity: Detect multi-line patterns (#1776)
Add Pango formatter (#1727)
filefirst instead of
Fix links (#1716)
Fix issue with LaTeX formatter and
minted(#1734, #1735, #1736, #1737)
Improve alias order (#1780)
Fix CTag related issue (#1724)
.leexas Elixir templates
Fix incorrect variable being accessed (#1748)
Updated filename handling in HTML formatter if linenos=’table’ (#1757)
Previously the filename would be emitted within the <td> holding the code, but outside the <pre>. This would invariably break the alignment with line numbers.
Now if filename is specified, a separate <tr> is emitted before the table content which contains a single <th> with colspan=2 so it spans both the line number and code columns. The filename is still within <span class=”filename”>…</span> so any existing styles should still apply, although the CSS path may need to change.
For an example of the new output format see table_cls_step_1_start_1_special_0_noanchor_filename.html in the tests/html_linenos_expected_output/ directory.
For more details and discussion see the issue https://github.com/pygments/pygments/issues/1757
Gruvbox light+dark (#1763)
(released February 14, 2021)
C/C++ & related: Fix mishandling
Cocoa: Add builtin types (#1703)
Eiffel: Fix performance issues (#1658)
Kotlin: Improve string interpolation, modifier keyword handling, and various small issues (#1699)
LESS: Support single-line comments (#1046)
Ruby: Better method name handling (#1531)
Stata: Updated keywords (#1470)
The pygmentize script now uses argparse, all options should work as before
Add pygmentize -C option to guess a lexer from content
With this release, Pygments moves to a new internal testing system (#1649.) See
Contributing.mdfor details. The main advantage of this new change is a much better test coverage of all existing example lexers. It also makes it much easier to add new test snippets.
Make guessing prefer Python 3 lexer
Do not guess MIME or SQL without reason
Changed setuptools to use a declarative config through
setup.cfg. Building Pygments now requires setuptools 39.2+.
Add markdown to MarkdownLexer aliases (#1687)
Change line number handling
<table>based output, the
td.linenoselement will have either a
specialclass attached. Previously, only
specialline numbers got a class. This prevents styles from getting applied twice - once via
<pre>, once via
<span class="special">. This also means that
td.linenos preis no longer styled, instead, use
In the “inline” style, the DOM element order was changed. The line number is added first, then the line is wrapped is wrapped by the highlighter. This fixes lines not being fully highlighted.
The visual output for inline and non-inline line numbers & highlighting, as well as class-based and inline styling is now consistent.
Line number styles are set to
color: inheritby default. This works much better with dark styles which don’t have colors set for line numbers.
Remove “raw” alias from RawTokenLexer, so that it cannot be selected by alias.
Fix RawTokenLexer to work in Python 3 and handle exceptions.
Add prompt colors to the Solarized theme (#1529)
Image formatter supports background colors now (#1374)
Add support for anchors in conjunction with inline line numbers (#1591)
Modernize the codebase using
Add support for line numbers to the
terminal256formatter (#1674, #1653)
CBM Basic V2(#1607)
(released January 12, 2021)
Apache configurations: Improve handling of malformed tags (#1656)
SQL - Fix keywords (#1668)
Typescript: Fix incorrect punctuation handling (#1510, #1511)
Fix infinite loop in SML lexer (#1625), CVE-2021-20270
Limit recursion with nesting Ruby heredocs (#1638)
Fix a few inefficient regexes for guessing lexers
Fix the raw token lexer handling of Unicode (#1616)
Revert a private API change in the HTML formatter (#1655) – please note that private APIs remain subject to change!
Fix several exponential/cubic-complexity regexes found by Ben Caller/Doyensec (#1675)
Fix incorrect MATLAB example (#1582)
Thanks to Google’s OSS-Fuzz project for finding many of these bugs.
(released December 6, 2020)
Deprecated JsonBareObjectLexer, which is now identical to JsonLexer (#1600)
ImgFormatternow calculates the exact character width, which fixes some issues with overlapping text (#1213, #1611)
Added support for Kotlin scripts (#1587)
Removed CSS rule which forced margin to 0
(released October 24, 2020)
Fix Python console/traceback lexer problems with custom exceptions without messages (#1548)
Allow loading ttc fonts on Mac/image formatter (#1223)
analyze_textacross a variety of lexers (#1549)
Remove CSS rule which forced the vertical padding to 0 for line numbers (#1583, #1579)
regexlintcan be now run locally as part of
Add Python 3.9 as a supported version (#1554)
(released September 16, 2020)
Fixed a regression in the JSON lexer (#1544)
(released September 12, 2020)
C++ (#1350, which also fixes: #1222, #996, #906, #828, #1162, #1166, #1396)
Inform 6 (#1461)
SystemVerilog (#1436, #1452, #1454, #1460, #1462, #1463, #1464, #1471, #1496, #1504)
Added a new filter for math symbols (#1406)
The Kconfig lexer will match Kconfig derivative names now (#1458)
Improved HTML formatter output (#1500)
.markdownis now recognized as an extension for Markdown files (#1476)
Improvements to exception handling (#1478)
(released March 8, 2020)
This release fixes a packaging issue. No functional changes.
(released March 8, 2020)
Running Pygments on Python 2.x is no longer supported. (The Python 2 lexer still exists.)
The 256-color/true-color terminal formatters now support the italic attribute in styles (#1288)
Support HTTP 2/3 header (#1308)
Support missing reason in HTTP header (#1322)
Boogie/Silver: support line continuations and triggers, move contract keywords to separate category (#1299)
GAS: support C-style comments (#1291)
Fix numeric literals in Ada (#1334)
.eexfiles as Elixir (#1387)
poetrydependency & lock files (PR#1376)
Improve font search on Windows (#1247)
Remove unused script block (#1401)
(released November 29, 2019)
Fix incompatibility with some setuptools versions (PR#1316)
Fix lexing of ReST field lists (PR#1279)
Fix lexing of Matlab keywords as field names (PR#1282)
Recognize double-quoted strings in Matlab (PR#1278)
Avoid slow backtracking in Vim lexer (PR#1312)
Fix Scala highlighting of types (PR#1315)
Highlight field lists more consistently in ReST (PR#1279)
Fix highlighting Matlab keywords in field names (PR#1282)
Recognize Matlab double quoted strings (PR#1278)
Add some Terraform keywords
Update Modelica lexer to 3.4
Update Crystal examples
(released November 26, 2019)
This release fixes a packaging issue. No functional changes.
(released November 26, 2019)
PythonLexerclass is now an alias for the former
Python3Lexer. The old
PythonLexeris available as
Python2Lexer. Same change has been done for the
python3option for the
PythonConsoleLexeris now true by default.
.asmfiles (fixes #1326)
Default font in the
ImageFormatterhas been updated (#928, PR#1245)
Test suite switched to py.test, removed nose dependency (#1490)
TeraTermlexer score – it used to match nearly all languages (#1256)
Starlarkfiles as Python files (PR#1259)
Image formatter: actually respect
Add LICENSE file to wheel builds
Agda: fix lambda highlighting
FROM ... ASsyntax
Emacs Lisp: add more string functions
GAS: accept registers in directive arguments
Java: make structural punctuation (braces, parens, colon, comma)
varcontextual keyword (#1101)
Matlab: Fix recognition of
fstring prefix (#1156)
Ruby: support squiggly heredocs
Shell sessions: recognize Virtualenv prompt (PR#1266)
Velocity: support silent reference syntax
(released May 28, 2019)
Fix encoding error when guessing lexer with given
(released May 24, 2019)
MSDOS Session (PR#734)
Objective-C (PR#813, #1508)
Support CSS variables in stylesheets (PR#814, #1356)
Fix F# lexer name (PR#709)
TerminalFormatterusing bold for bright text (#1480)
(released May 8, 2019)
BBC Basic (PR#806)
Charm++ CI (PR#788)
Tera Term Language (PR#749)
Add solarized style (PR#708)
Add support for Markdown reference-style links (PR#753)
Add license information to generated HTML/CSS files (#1496)
Change ANSI color names (PR#777)
Fix catastrophic backtracking in the bash lexer (#1494)
Fix documentation failing to build using Sphinx 2.0 (#1501)
Fix incorrect links in the Lisp and R lexer documentation (PR#775)
Fix rare unicode errors on Python 2.7 (PR#798, #1492)
Fix lexers popping from an empty stack (#1506)
Updated Trove classifiers and
(released Dec 16, 2018)
Igor Pro (PR#764)
Python (PR#720, #1299, PR#715)
YAML (PR#762, PR#724)
Fix invalid string escape sequences
Fix FutureWarning introduced by regex changes in Python 3.7
(released Nov 25, 2018)
Minimum Python versions changed to 2.7 and 3.5
Added support for Python 3.7 generator changes (PR#772)
Fix incorrect token type in SCSS for single-quote strings (#1322)
Use terminal256 formatter if TERM contains 256 (PR#666)
Fix incorrect handling of GitHub style fences in Markdown (PR#741, #1389)
Fix %a not being highlighted in Python3 strings (PR#727)
(released Jan 22, 2017)
Varnish config (PR#554)
NCAR command language (PR#536)
Cap’n Proto (PR#595)
SAS, Stata (PR#593)
Added the ability to load lexer and formatter classes directly from files with the -x command line option and the lexers.load_lexer_from_file() and formatters.load_formatter_from_file() functions. (PR#559)
Added lexers.find_lexer_class_by_name(). (#1203)
Added new token types and lexing for magic methods and variables in Python and PHP.
Added a new token type for string affixes and lexing for them in Python, C++ and Postgresql lexers.
Added a new token type for heredoc (and similar) string delimiters and lexing for them in C++, Perl, PHP, Postgresql and Ruby lexers.
Styles can now define colors with ANSI colors for use in the 256-color terminal formatter. (PR#531)
Improved the CSS lexer. (#1083, #1130)
Added “Rainbow Dash” style. (PR#623)
Delay loading pkg_resources, which takes a long while to import. (PR#690)
(released Mar 2, 2016)
Fixed regression in Bash lexer (PR#563)
(released Feb 29, 2016)
Fixed Python 3 regression in image formatter (#1215)
Fixed regression in Bash lexer (PR#562)
(released Feb 14, 2016)
Fixed Jython compatibility (#1205)
Fixed HTML formatter output with leading empty lines (#1111)
Added a mapping table for LaTeX encodings and added utf8 (#1152)
Fixed image formatter font searching on Macs (#1188)
Fixed deepcopy-ing of Token instances (#1168)
Fixed Julia string interpolation (#1170)
Fixed statefulness of HttpLexer between get_tokens calls
Many smaller fixes to various lexers
(released Jan 17, 2016)
Emacs Lisp (PR#431)
Modula-2 with multi-dialect support (#1090)
Fortran fixed format (PR#213)
Archetype Definition language (PR#483)
Jcl, Easytrieve (PR#208)
Fish Shell (PR#422)
Test Anything Protocol (PR#428)
Component Pascal (PR#437)
Shell consoles (Tcsh, PowerShell, MSDOS) (PR#479)
Elm and J (PR#452)
QVT Operational (PR#204)
CAmkES Configuration (PR#462)
Algol and Algol-nu (#1090)
True color (24-bit) terminal ANSI sequences (#1142) (formatter alias: “16m”)
New “filename” option for HTML formatter (PR#527).
Improved performance of the HTML formatter for long lines (PR#504).
Updated autopygmentize script (PR#445).
Fixed style inheritance for non-standard token types in HTML output.
Added support for async/await to Python 3 lexer.
Rewrote linenos option for TerminalFormatter (it’s better, but slightly different output than before) (#1147).
Cocoa builtins updated for iOS 8.1 (PR#433).
Combined BashSessionLexer and ShellSessionLexer, new version should support the prompt styles of either.
Added option to pygmentize to show a full traceback on exceptions.
Fixed incomplete output on Windows and Python 3 (e.g. when using iPython Notebook) (#1153).
Allowed more traceback styles in Python console lexer (PR#253).
Added decorators to TypeScript (PR#509).
Fix highlighting of certain IRC logs formats (#1076).
(released Jan 20, 2015)
Fix Python tracebacks getting duplicated in the console lexer (#1068).
Backquote-delimited identifiers are now recognized in F# (#1062).
(released Nov 10, 2014)
Fix an encoding issue when using
(released Nov 9, 2014)
Default lexer encoding is now “guess”, i.e. UTF-8 / Locale / Latin1 is tried in that order.
Major update to Swift lexer (PR#410).
Multiple fixes to lexer guessing in conflicting cases:
recognize HTML5 by doctype
recognize XML by XML declaration
don’t recognize C/C++ as SystemVerilog
Simplified regexes and builtin lists.
(released Oct 16, 2014)
Dropped Python 2.4 and 2.5 compatibility. This is in favor of single-source compatibility between Python 2.6, 2.7 and 3.3+.
New website and documentation based on Sphinx (finally!)
Agda and Literate Agda (PR#203)
ColdFusion CFC (PR#283)
Cryptol and Literate Cryptol (PR#344)
Docker config files
Idris and Literate Idris (PR#210)
Igor Pro (PR#172)
Inform 6/7 (PR#281)
Intel objdump (PR#279)
Perl 6 (PR#181)
TADS 3 (PR#407)
Todo.txt todo lists
Added a helper to “optimize” regular expressions that match one of many literal words; this can save 20% and more lexing time with lexers that highlight many keywords or builtins.
New styles: “xcode” and “igor”, similar to the default highlighting of the respective IDEs.
The command-line “pygmentize” tool now tries a little harder to find the correct encoding for files and the terminal (#979).
Added “inencoding” option for lexers to override “encoding” analogous to “outencoding” (#800).
Added line-by-line “streaming” mode for pygmentize with the “-s” option. (PR#165) Only fully works for lexers that have no constructs spanning lines!
Added an “envname” option to the LaTeX formatter to select a replacement verbatim environment (PR#235).
Updated the Makefile lexer to yield a little more useful highlighting.
Lexer aliases passed to
get_lexer_by_name()are now case-insensitive.
File name matching in lexers and formatters will now use a regex cache for speed (PR#205).
Pygments will now recognize “vim” modelines when guessing the lexer for a file based on content (PR#118).
Major restructure of the
pygments.lexersmodule namespace. There are now many more modules with less lexers per module. Old modules are still around and re-export the lexers they previously contained.
The NameHighlightFilter now works with any Name.* token type (#790).
Python 3 lexer: add new exceptions from PEP 3151.
Opa lexer: add new keywords (PR#170).
Julia lexer: add keywords and underscore-separated number literals (PR#176).
Lasso lexer: fix method highlighting, update builtins. Fix guessing so that plain XML isn’t always taken as Lasso (PR#163).
Objective C/C++ lexers: allow “@” prefixing any expression (#871).
Ruby lexer: fix lexing of Name::Space tokens (#860) and of symbols in hashes (#873).
Stan lexer: update for version 2.4.0 of the language (PR#162, PR#255, PR#377).
HTTP lexer: support for PATCH method (PR#190).
Koka lexer: update to newest language spec (PR#201).
Haxe lexer: rewrite and support for Haxe 3 (PR#174).
Prolog lexer: add different kinds of numeric literals (#864).
F# lexer: rewrite with newest spec for F# 3.0 (#842), fix a bug with dotted chains (#948).
Kotlin lexer: general update (PR#271).
Rebol lexer: fix comment detection and analyse_text (PR#261).
LLVM lexer: update keywords to v3.4 (PR#258).
PHP lexer: add new keywords and binary literals (PR#222).
external/markdown-processor.py updated to newest python-markdown (PR#221).
CSS lexer: some highlighting order fixes (PR#231).
Ceylon lexer: fix parsing of nested multiline comments (#915).
C family lexers: fix parsing of indented preprocessor directives (#944).
Rust lexer: update to 0.9 language version (PR#270, PR#388).
Elixir lexer: update to 0.15 language version (PR#392).
Fix swallowing incomplete tracebacks in Python console lexer (#874).
(released Feb 3, 2013)
Dylan console (PR#149)
Shell sessions (PR#158)
Fix guessed lexers not receiving lexer options (#838).
Fix unquoted HTML attribute lexing in Opa (#841).
Fixes to the Dart lexer (PR#160).
(released Jan 9, 2013)
BUGS-like languages (PR#89)
Croc (new name for MiniD)
Lasso (PR#95, PR#113)
NSIS scripts (PR#136)
Robot Framework (PR#137)
RPM spec files (PR#124)
Smali (Dalvik assembly)
Visual FoxPro (#762)
Windows Registry (#819)
The HTML formatter now supports linking to tags using CTags files, when the python-ctags package is installed (PR#87).
The HTML formatter now has a “linespans” option that wraps every line in a <span> tag with a specific id (PR#82).
When deriving a lexer from another lexer with token definitions, definitions for states not in the child lexer are now inherited. If you override a state in the child lexer, an “inherit” keyword has been added to insert the base state at that position (PR#141).
The C family lexers now inherit token definitions from a common base class, removing code duplication (PR#141).
Use “colorama” on Windows for console color output (PR#142).
Fix Template Haskell highlighting (PR#63).
Fix some S/R lexer errors (PR#91).
Fix a bug in the Prolog lexer with names that start with ‘is’ (#810).
Rewrite Dylan lexer, add Dylan LID lexer (PR#147).
Add a Java quickstart document (PR#146).
Add a “external/autopygmentize” file that can be used as .lessfilter (#802).
(codename Zeitdilatation, released Mar 10, 2012)
Standard ML (PR#14)
HTTP sessions (PR#42)
OpenEdge ABL (PR#27)
Fix Python 3 terminal highlighting with pygmentize (#691).
In the LaTeX formatter, escape special &, < and > chars (#648).
In the LaTeX formatter, fix display problems for styles with token background colors (#670).
Enhancements to the Squid conf lexer (#664).
Several fixes to the reStructuredText lexer (#636).
Recognize methods in the ObjC lexer (#638).
Fix Lua “class” highlighting: it does not have classes (#665).
Fix degenerate regex in Scala lexer (#671) and highlighting bugs (#713, 708).
Fix number pattern order in Ocaml lexer (#647).
Fix generic type highlighting in ActionScript 3 (#666).
Fixes to the Clojure lexer (PR#9).
Fix degenerate regex in Nemerle lexer (#706).
Fix infinite looping in CoffeeScript lexer (#729).
Fix crashes and analysis with ObjectiveC lexer (#693, #696).
Add some Fortran 2003 keywords.
Fix Boo string regexes (#679).
Add “rrt” style (#727).
Fix infinite looping in Darcs Patch lexer.
Lots of misc fixes to character-eating bugs and ordering problems in many different lexers.
(codename Unschärfe, released Jan 03, 2011)
BlitzMax Basic (#478)
Java properties, split out of the INI lexer (#445)
Google Protocol Buffers
Do not fail in analyse_text methods (#618).
Performance improvements in the HTML formatter (#523).
noclassesoption in the HTML formatter, some styles present in the stylesheet were not added as inline styles.
Four fixes to the Lua lexer (#480, #481, #482, #497).
More context-sensitive Gherkin lexer with support for more i18n translations.
Support new OO keywords in Matlab lexer (#521).
Small fix in the CoffeeScript lexer (#519).
A bugfix for backslashes in ocaml strings (#499).
Fix unicode/raw docstrings in the Python lexer (#489).
Allow PIL to work without PIL.pth (#502).
Allow seconds as a unit in CSS (#496).
Support Offload C++ Extensions as keywords in the C++ lexer (#484).
Escape more characters in LaTeX output (#505).
Update Haml/Sass lexers to version 3 (#509).
Small PHP lexer string escaping fix (#515).
Support comments before preprocessor directives, and unsigned/ long long literals in C/C++ (#613, #616).
Support line continuations in the INI lexer (#494).
Fix lexing of Dylan string and char literals (#628).
Fix class/procedure name highlighting in VB.NET lexer (#624).
(bugfix release, released Mar 05, 2010)
pygmentizescript was missing from the distribution.
(codename Schneeglöckchen, released Mar 01, 2010)
ensurenllexer option, which can be used to suppress the automatic addition of a newline to the lexer input.
Haml and Sass
Enhanced reStructuredText highlighting.
Added support for PHP 5.3 namespaces in the PHP lexer.
Added a bash completion script for pygmentize, to the external/ directory (#466).
Fixed a bug in do_insertions() used for multi-lexer languages.
Fixed a Ruby regex highlighting bug (#476).
Fixed regex highlighting bugs in Perl lexer (#258).
Add small enhancements to the C lexer (#467) and Bash lexer (#469).
Small fixes for the Tcl, Debian control file, Nginx config, Smalltalk, Objective-C, Clojure, Lua lexers.
Gherkin lexer: Fixed single apostrophe bug and added new i18n keywords.
(bugfix release, released Jan 02, 2010)
Removed a backwards incompatibility in the LaTeX formatter that caused Sphinx to produce invalid commands when writing LaTeX output (#463).
Fixed a forever-backtracking regex in the BashLexer (#462).
(bugfix release, released Jan 02, 2010)
Fixed mishandling of an ellipsis in place of the frames in a Python console traceback, resulting in clobbered output.
(codename Neujahr, released Jan 01, 2010)
Dropped Python 2.3 compatibility.
Added options for rendering LaTeX in source code comments in the LaTeX formatter (#461).
Updated the Logtalk lexer.
Added line_number_start option to image formatter (#456).
Added hl_lines and hl_color options to image formatter (#457).
Fixed the HtmlFormatter’s handling of noclasses=True to not output any classes (#427).
Added the Monokai style (#453).
Fixed LLVM lexer identifier syntax and added new keywords (#442).
Fixed the PythonTracebackLexer to handle non-traceback data in header or trailer, and support more partial tracebacks that start on line 2 (#437).
Fixed the CLexer to not highlight ternary statements as labels.
Fixed lexing of some Ruby quoting peculiarities (#460).
A few ASM lexer fixes (#450).
(bugfix release, released Sep 15, 2009)
Fixed the BBCode lexer (#435).
Added support for new Jinja2 keywords.
Fixed test suite failures.
Added Gentoo-specific suffixes to Bash lexer.
(codename Brillouin, released Sep 11, 2009)
Ported Pygments to Python 3. This needed a few changes in the way encodings are handled; they may affect corner cases when used with Python 2 as well.
Antlr/Ragel, thanks to Ana Nelson
Fixed the LaTeX formatter’s output so that output generated for one style can be used with the style definitions of another (#384).
Added “anchorlinenos” and “noclobber_cssfile” (#396) options to HTML formatter.
Support multiline strings in Lua lexer.
When pygmentize is asked to highlight a file for which multiple lexers match the filename, use the analyse_text guessing engine to determine the winner (#355).
Fixed three Perl heredoc lexing bugs (#379, #400, #422).
Fixed a bug in the image formatter which misdetected lines (#380).
Fixed bugs lexing extended Ruby strings and regexes.
Fixed a bug when lexing git diffs.
Fixed a bug lexing the empty commit in the PHP lexer (#405).
Fixed a bug causing Python numbers to be mishighlighted as floats (#397).
Fixed a bug when backslashes are used in odd locations in Python (#395).
Fixed various bugs in Matlab and S-Plus lexers, thanks to Winston Chang (#410, #411, #413, #414) and fmarc (#419).
Fixed a bug in Haskell single-line comment detection (#426).
Added new-style reStructuredText directive for docutils 0.5+ (#428).
(codename Dreiundzwanzig, released Nov 23, 2008)
Don’t use join(splitlines()) when converting newlines to
\n, because that doesn’t keep all newlines at the end when the
stripnllexer option is False.
-Noption to command-line interface to get a lexer name for a given filename.
Added Tango style, written by Andre Roberge for the Crunchy project.
Added Python3TracebackLexer and
python3option to PythonConsoleLexer.
Fixed a few bugs in the Haskell lexer.
Fixed PythonTracebackLexer to be able to recognize SyntaxError and KeyboardInterrupt (#360).
Provide one formatter class per image format, so that surprises like:
pygmentize -f gif -o foo.gif foo.py
creating a PNG file are avoided.
Actually use the font_size option of the image formatter.
Fixed numpy lexer that it doesn’t listen for *.py any longer.
Fixed HTML formatter so that text options can be Unicode strings (#371).
Unified Diff lexer supports the “udiff” alias now.
Fixed a few issues in Scala lexer (#367).
RubyConsoleLexer now supports simple prompt mode (#363).
Add Applescript lexer, thanks to Andreas Amann (#330).
Make the codetags more strict about matching words (#368).
NginxConfLexer is a little more accurate on mimetypes and variables (#370).
(released Aug 24, 2008)
Fixed a Jython compatibility issue in pygments.unistring (#358).
(codename Straußenei, released Aug 23, 2008)
Many thanks go to Tim Hatch for writing or integrating most of the bug fixes and new features.
Nasm-style assembly language, thanks to delroth
YAML, thanks to Kirill Simonov
ActionScript 3, thanks to Pierre Bourdon
Cheetah/Spitfire templates, thanks to Matt Good
Lighttpd config files
Nginx config files
Gnuplot plotting scripts
POV-Ray scene files
Sqlite3 interactive console sessions
Scala source files, thanks to Krzysiek Goj
C lexer highlights standard library functions now and supports C99 types.
Bash lexer now correctly highlights heredocs without preceding whitespace.
Vim lexer now highlights hex colors properly and knows a couple more keywords.
Irc logs lexer now handles xchat’s default time format (#340) and correctly highlights lines ending in
Support more delimiters for perl regular expressions (#258).
ObjectiveC lexer now supports 2.0 features.
Added “Visual Studio” style.
Updated markdown processor to Markdown 1.7.
Support roman/sans/mono style defs and use them in the LaTeX formatter.
The RawTokenFormatter is no longer registered to
*.rawand it’s documented that tokenization with this lexer may raise exceptions.
hl_linesto HTML formatter, to highlight certain lines.
prestylesto HTML formatter.
New option -g to pygmentize, to allow lexer guessing based on filetext (can be slowish, so file extensions are still checked first).
guess_lexer()now makes its decision much faster due to a cache of whether data is xml-like (a check which is used in several versions of
analyse_text(). Several lexers also have more accurate
(codename Malzeug, released May 06, 2008)
S, S-plus, R statistics languages
In the LatexFormatter, the commandprefix option is now by default ‘PY’ instead of ‘C’, since the latter resulted in several collisions with other packages. Also, the special meaning of the arg argument to
Added ImageFormatter, to format code as PNG, JPG, GIF or BMP. (Needs the Python Imaging Library.)
Support doc comments in the PHP lexer.
Handle format specifications in the Perl lexer.
Fix comment handling in the Batch lexer.
Add more file name extensions for the C++, INI and XML lexers.
Fixes in the IRC and MuPad lexers.
Fix function and interface name highlighting in the Java lexer.
Fix at-rule handling in the CSS lexer.
Handle KeyboardInterrupts gracefully in pygmentize.
Bash lexer now correctly highlights math, does not require whitespace after semicolons, and correctly highlights boolean operators.
Makefile lexer is now capable of handling BSD and GNU make syntax.
(codename Herbstzeitlose, released Oct 14, 2007)
Various assembly languages
Debian control files
Greatly improved the Haskell and OCaml lexers.
Improved the Bash lexer’s handling of nested constructs.
The C# and Java lexers exhibited abysmal performance with some input code; this should now be fixed.
The IRC logs lexer is now able to colorize weechat logs too.
The Lua lexer now recognizes multi-line comments.
Fixed bugs in the D and MiniD lexer.
The encoding handling of the command line mode (pygmentize) was enhanced. You shouldn’t get UnicodeErrors from it anymore if you don’t give an encoding option.
-Poption to the command line mode which can be used to give options whose values contain commas or equals signs.
Added 256-color terminal formatter.
Added an experimental SVG formatter.
lineanchorsoption to the HTML formatter, thanks to Ian Charnas for the idea.
Gave the line numbers table a CSS class in the HTML formatter.
Added a Vim 7-like style.
(released Jun 27, 2007)
Fixed POD highlighting in the Ruby lexer.
Fixed Unicode class and namespace name highlighting in the C# lexer.
Fixed Unicode string prefix highlighting in the Python lexer.
Fixed a bug in the D and MiniD lexers.
Fixed the included MoinMoin parser.
(codename Maikäfer, released May 30, 2007)
Haskell, thanks to Adam Blinkinsop
Redcode, thanks to Adam Blinkinsop
D, thanks to Kirk McDonald
MuPad, thanks to Christopher Creutzig
MiniD, thanks to Jarrett Billingsley
Vim Script, by Tim Hatch
The HTML formatter now has a second line-numbers mode in which it will just integrate the numbers in the same
<pre>tag as the code.
The CSharpLexer now is Unicode-aware, which means that it has an option that can be set so that it correctly lexes Unicode identifiers allowed by the C# specs.
Added a RaiseOnErrorTokenFilter that raises an exception when the lexer generates an error token, and a VisibleWhitespaceFilter that converts whitespace (spaces, tabs, newlines) into visible characters.
Fixed the do_insertions() helper function to yield correct indices.
The ReST lexer now automatically highlights source code blocks in “.. sourcecode:: language” and “.. code:: language” directive blocks.
Improved the default style (thanks to Tiberius Teng). The old default is still available as the “emacs” style (which was an alias before).
The get_style_defs method of HTML formatters now uses the cssclass option as the default selector if it was given.
Improved the ReST and Bash lexers a bit.
Fixed a few bugs in the Makefile and Bash lexers, thanks to Tim Hatch.
Fixed a bug in the command line code that disallowed
-Ooptions when using the
Fixed a bug in the RawTokenFormatter.
(released Feb 15, 2007)
Fixed little highlighting bugs in the Python, Java, Scheme and Apache Config lexers.
Updated the included manpage.
Included a built version of the documentation in the source tarball.
(codename Faschingskrapfn, released Feb 14, 2007)
Added a MoinMoin parser that uses Pygments. With it, you get Pygments highlighting in Moin Wiki pages.
Changed the exception raised if no suitable lexer, formatter etc. is found in one of the get_*_by_* functions to a custom exception, pygments.util.ClassNotFound. It is, however, a subclass of ValueError in order to retain backwards compatibility.
Added a -H command line option which can be used to get the docstring of a lexer, formatter or filter.
Made the handling of lexers and formatters more consistent. The aliases and filename patterns of formatters are now attributes on them.
Added an OCaml lexer, thanks to Adam Blinkinsop.
Made the HTML formatter more flexible, and easily subclassable in order to make it easy to implement custom wrappers, e.g. alternate line number markup. See the documentation.
Added an outencoding option to all formatters, making it possible to override the encoding (which is used by lexers and formatters) when using the command line interface. Also, if using the terminal formatter and the output file is a terminal and has an encoding attribute, use it if no encoding is given.
Made it possible to just drop style modules into the styles subpackage of the Pygments installation.
Added a “state” keyword argument to the using helper.
Added a commandprefix option to the LatexFormatter which allows to control how the command names are constructed.
Added quite a few new lexers, thanks to Tim Hatch:
Java Server Pages
Windows batch files
Trac Wiki markup
and the Befunge esoteric programming language (yay!)
Added Mako lexers by Ben Bangert.
Added “fruity” style, another dark background originally vim-based theme.
Added sources.list lexer by Dennis Kaarsemaker.
Added token stream filters, and a pygmentize option to use them.
Changed behavior of in Operator for tokens.
Added mimetypes for all lexers.
Fixed some problems lexing Python strings.
Fixed tickets: #167, #178, #179, #180, #185, #201.
(codename Zimtstern, released Dec 20, 2006)
Added option for the HTML formatter to write the CSS to an external file in “full document” mode.
Added RTF formatter.
Added Bash and Apache configuration lexers (thanks to Tim Hatch).
Improved guessing methods for various lexers.
Added @media support to CSS lexer (thanks to Tim Hatch).
Added a Groff lexer (thanks to Tim Hatch).
License change to BSD.
Added lexers for the Myghty template language.
Added a Scheme lexer (thanks to Marek Kubica).
Added some functions to iterate over existing lexers, formatters and lexers.
The HtmlFormatter’s get_style_defs() can now take a list as an argument to generate CSS with multiple prefixes.
Support for guessing input encoding added.
Encoding support added: all processing is now done with Unicode strings, input and output are converted from and optionally to byte strings (see the
encodingoption of lexers and formatters).
Some improvements in the C(++) lexers handling comments and line continuations.
(released Oct 30, 2006)
Fixed traceback in
pygmentize -L(thanks to Piotr Ozarowski).
(codename PyKleur, released Oct 30, 2006)
Initial public release.