Syntax Highlighting Filters

There are several highlighting filters in the filters subdirectory. These all are programs that read a file, usually from the standard input, and write to the standard output. Vile invokes these, uses the marked-up text to display highlighting.

Except for the manpage filter (a special case) all of these can be (and most are) implemented using lex.


Each filter reads one or more keyword files, which list specific keywords and their highlighting attributes, as well as classes of keywords.

The filters search for these files in the current, $HOME, $HOME/vile and startup directories. On Unix, the keyword files in the current and $HOME directories are hidden using a "." prefix. Except for MS-DOS, the suffix is ".keywords"; on that platform it is ".key". In the source distribution, these files are ".key", to keep them compatible with MS-DOS 8.3 filename lengths.

You can specify the root name to search, otherwise they search for "vile" and the compiled-in filter name. The locations checked are:

For example (referring to the last as $VILE_STARTUP_PATH), on a Unix host, the C filter (vile-c-filt) searches first here:


and then here:


In each case, vile-c-filt stops as soon as it finds the desired file. On a non-Unix host, the search looks like this:



The vile.keywords file contains color information for the most common classes. The c.keywords file contains the actual keywords to be highlighted, referenced to the classes which are in turn colored. You can see the search for keyword files by running the filter with a -v option, repeating the option (-vv) to obtain more verbose traces. Note that filters may be compiled-into vile. In that case (vile calls the filter using the attribute-directly command), you can still get a trace by adding the -v option to the filtername line of the majormode. The trace will go to the message line, but also if you have

set popup-msgs

specified, to the [Messages] buffer.

Predefined keyword classes include (but may not necessarily be used in specific filters):


A few filters, e.g., cweb, latex, diff, use additional classes. The predefined classes are a guideline, to implement a common style across the different filters.

Each line in the keyword file consists of two strings separated by a colon (:). If the first string is empty, the line is treated as a comment. The second string is interpreted as follows:

The keyword file reader supports a limited include facility. In each case, the parameter of the include is the root name of the keyword file, e.g., "c" for "c.key".

Specify abbreviations using a '*' character, e.g.,


to match any of vi, vil, vile. You can change the '*' character using the ".abbrev" directive. A special case is provided for languages such as SQL*PLUS, using the '?' character, e.g.,


Use ".brief" to alter the special character '?'.

For either ".abbrev" or ".brief", omitting the parameter disables the feature.

Use the ".default" directive to change the default class. The parameter must be the name of a class which has already been defined. Omit the parameter to reset the default back to "Keyword".

You can change the characters assigned to ':' and '.' using ".equals" and ".meta" directives, respectively.

Some of the filters match case-independent keywords (e.g., the DOS batchfiles). The keywords file must give these names in lowercase, since the filtered text is converted to lowercase when matching.

You can modify the behavior slightly, by giving an absolute pathname with the -k option, but otherwise the filters search for both "vile" and the specific language keywords, if any.


A few options are common to all filters:

is recognized when the filters have been compiled with "DEBUG" defined. This is used in the more complicated filters such as perl, ruby and sql to show the parsing.
is used (in all except for html, imake and make) to tell vile to ignore case when matching keywords. It is ignored in the few instances mentioned because those filters contain logic to distinguish between caseless and case-sensitive syntax.
specifies the keyword file to use.
exits the filter before writing the marked-up output. This happens after processing the class definitions, so it is useful in combination with the -v option to simply obtain the class information.
is like "-q", but also writes to stderr (or [Filter Messages]) the resulting keyword information.
holds the tabstop setting, which can be used in a filter for column computations.
verbose, turns on extra output which can be used for troubleshooting configuration problems.

The C syntax filter recognizes additional options to customize it for Java, JavaScript and Objective-C:

Extend name- and literal-syntax to include Java.
Allow '@' in names, for directives.
Disallow preprocessor lines.
for JavaScript (to support jsmode). This controls whether to allow regular expressions in certain cases.
support C# verbatim string literals

The HTML filter recognizes a "-a" option to customize it for "asp" files, as well as a "-j" option to customize for JavaScript script-tags.

The keyword filter recognizes a "-c" option to tell it to highlight color codes with the corresponding color rather than the "Action" color.

The MAN filter recognizes a "-8" option which tells it to use 8-bit approximations for some common UTF-8 equivalents such as hyphen.

The Ruby filter recognizes a "-e" option to customize it for "ERB" files.

The SH filter recognizes a "-K" option to turn on Korn shell's syntax for dotted variable names. The ksh93 "vnames" allow a dotted name such as "$" to be defined it is root ("$foo") is already defined. That affects portability of scripts because other sh-like programs do not behave this way.

The XML filter recognizes "-A" and "-M" options to recognize Ant and Maven macrodef and property tags, respectively.


The following are implemented:

vile-ada-filt (Ada95)
vile-as-filt (GNU assembler (x86))
vile-asm-filt (Microsoft ASM (x86))
vile-au3-filt (AutoIt 3)
vile-awk-filt (awk)
vile-basic-filt (BASIC)
vile-bat-filt (DOS batchfiles)
vile-bnf-filt (BNF)
vile-c-filt (C language)
vile-cfg-filt (Lynx configure file)
vile-conf-filt (General config-files)
vile-css-filt (Cascading Style Sheets)
vile-cweb-filt (CWEBx)
vile-dcl-filt (VMS DCL batchfiles)
vile-def-filt (Windows linker definition files)
vile-diff-filt (diff/patch files)
vile-ecl-filt (Prolog/ECLiPSe)
vile-esql-filt (embedded SQL with C/C++)
vile-est-filt (Enscript syntax-descriptions)
vile-fdl-filt (Forms definition language)
vile-html-filt (HTML with embedded JavaScript)
vile-imake-filt (imake)
vile-info-filt (GNU info files)
vile-ini-filt (ini, desktop)
vile-iss-filt (Inno Setup)
vile-json-filt (json)
vile-key-filt (Vile keyword files)
vile-latex-filt (LaTeX or TeX)
vile-lex-filt (lex)
vile-lisp-filt (Lisp)
vile-lua-filt (Lua)
vile-m4-filt (m4)
vile-mail-filt (mail folders)
vile-make-filt (make)
vile-manfilt (manual-page)
vile-mcrl-filt (mCRL(2) specification)
vile-midl-filt (Microsoft Interface Definition Language)
vile-mms-filt (VMS makefiles)
vile-nr-filt (nroff)
vile-pas-filt (Pascal)
vile-perl-filt (Perl, in C)
vile-php-filt (PHP)
vile-pl-filt (Perl, in lex)
vile-pot-filt (gettext (.po) files)
vile-ps-filt (PostScript)
vile-ps1-filt (PowerShell)
vile-py-filt (Python)
vile-rb-filt (Ruby)
vile-rc-filt (Windows resource files)
vile-rcs-filt (RCS archives)
vile-rexx-filt (REXX)
vile-rpm-filt (RPM ".spec" files)
vile-rtf-filt (Rich Text Format)
vile-ruby-filt (Ruby)
vile-sccs-filt (SCCS archives)
vile-sed-filt (sed scripts)
vile-sh-filt (sh/ksh/csh)
vile-sml-filt (Standard ML)
vile-spell-filt (ispell highlights misspelled words)
vile-sql-filt (SQL scripts)
vile-tags-filt (ctags tags files)
vile-tbl-filt (Vile's mktbl format)
vile-tc-filt (termcap)
vile-tcl-filt (TCL/TK)
vile-texi-filt (texinfo)
vile-ti-filt (terminfo)
vile-txt-filt (plain text files, such as vile.hlp)
vile-vile-filt (Vile's macros)
vile-vlog-filt (Verilog)
vile-wbt-filt (WinBatch)
vile-xml-filt (XML)
vile-xres-filt (X Window resources)
vile-xs-filt (Perl extension)
vile-yacc-filt (yacc)

Not all majormodes require a special filter for highlighting, since they use the same syntax as other majormodes:

cppmode C++ uses C filter
cshmode C-shell uses shell filter
csmode C# uses C filter
csvmode CSV uses text filter
delphimode Delphi uses Pascal filter
desktopmode Desktop uses INI filter
docbookmode Docbook uses XML filter
imakemode Imake uses C filter
javamode Java uses C filter
jsmode JavaScript uses C filter
jspmode JSP uses HTML filter
nmakemode nmake uses make filter
nsismode nsis uses def filter
pcmode printcap uses termcap filter
texmode TeX uses latex filter
vbmode Visual Basic uses basic filter
vbsmode Visual Basic Scripting uses basic filter
xpmmode XPM uses C filter


The lex filters have been well tested only with flex, which treats newlines differently. Older versions of lex may not support the %x states.