Provided by: dvisvgm_3.4.2+ds-1_amd64 bug

NAME

       dvisvgm - converts DVI, EPS, and PDF files to the XML-based SVG format

SYNOPSIS

       dvisvgm [options] file[.dvi]

       dvisvgm --eps [options] file1[.eps] file2[.eps] ...

       dvisvgm --pdf [options] file[.pdf]

DESCRIPTION

       The command-line utility dvisvgm converts DVI files, as generated by TeX/LaTeX, to the
       XML-based scalable vector graphics format SVG. It supports the classic DVI version 2 as
       well as version 3 (created by pTeX in vertical mode), and the XeTeX versions 5 to 7 which
       are also known as XDV. Besides the basic DVI commands, dvisvgm also evaluates many
       so-called specials which heavily extend the capabilities of the plain DVI format. For a
       more detailed overview, see section Supported Specials below.

       Since the current SVG standard 1.1 doesn’t specify multi-page graphics, dvisvgm creates
       separate SVG files for each DVI page. Because of compatibility reasons, only the first
       page is converted by default. In order to select a different page or arbitrary page
       sequences, use option -p which is described below.

       SVG is a vector-based graphics format and therefore dvisvgm tries to convert the glyph
       outlines of all fonts referenced in a DVI page section to scalable path descriptions. The
       fastest way to achieve this is to extract the path information from vector-based font
       files available in PFB, TTF, or OTF format. If dvisvgm is able to find such a file, it
       extracts all necessary outline information about the glyphs from it.

       However, TeX’s main source for font descriptions is Metafont, which produces bitmap output
       (GF files). That’s why not all obtainable TeX fonts are available in a scalable format. In
       these cases, dvisvgm tries to vectorize Metafont’s output by tracing the glyph bitmaps.
       The results are not as perfect as most (manually optimized) PFB or OTF counterparts, but
       are nonetheless really nice in most cases.

       When running dvisvgm without option --no-fonts, it creates font elements
       (<font>...</font>) to embed the font data into the SVG files. Unfortunately, only few SVG
       renderers support these elements yet. Most web browsers and vector graphics applications
       don’t evaluate them properly so that the text components of the resulting graphics might
       look strange. In order to create more compatible SVG files, command-line option --no-fonts
       can be given to replace the font elements by plain graphics paths. Most web browsers (but
       only few external SVG renderers) also support WOFF and WOFF2 fonts that can be used
       instead of the default SVG fonts. Option --font-format offers the functionality to change
       the format applied to the fonts being embedded. This, however, only works when converting
       DVI files. Text present in PDF and PostScript files is always converted to path elements.

OPTIONS

       dvisvgm provides a POSIX-compliant command-line interface with short and long option
       names. They may be given before and/or after the name of the file to be converted. Also,
       the order of specifying the options is not significant, i.e. you can add them in any order
       without changing dvisvgm’s behavior. Certain options accept or require additional
       parameters which are directly appended to or separated by whitespace from a short option
       (e.g. -v0 or -v 0). Long options require an additional equals sign (=) between option name
       and argument but without any surrounding whitespace (e.g. --verbosity=0). Multiple short
       options that don’t expect a further parameter can be combined after a single dash (e.g.
       -ejs rather than -e -j -s).

       Long option names may also be shortened by omitting trailing characters. As long as the
       shortened name is unambiguous, it’s recognized and applied. For example, option
       --exact-bbox can be shortened to --exact, --exa, or --ex. In case of an ambiguous
       abbreviation, dvisvgm prints an error message together with all matching option names.

       -b, --bbox=fmt
           Sets the bounding box of the generated SVG graphic to the specified format. This
           option only affects the conversion of DVI files. SVG documents generated from PDF and
           PostScript always inherit the bounding boxes of the input files.

           Parameter fmt takes either one of the format specifiers listed below, or a sequence of
           four comma- or whitespace-separated length values x1, y1, x2 and y2. The latter define
           the absolute coordinates of two diagonal corners of the bounding box. Each length
           value consists of a floating point number and an optional length unit (pt, bp, cm, mm,
           in, pc, dd, cc, or sp). If the unit is omitted, TeX points (pt) are assumed.

           It’s also possible to give only one length value l. In this case, the minimal bounding
           box is computed and enlarged by adding (-l,-l) to the upper left and (l,l) to the
           lower right corner.

           Additionally, dvisvgm also supports the following format specifiers:

           International DIN/ISO paper sizes
               An, Bn, Cn, Dn, where n is a non-negative integer, e.g. A4 or a4 for DIN/ISO A4
               format (210mm × 297mm).

           North American paper sizes
               invoice, executive, legal, letter, ledger

           Special bounding box sizes

               dvi         page size stored in the DVI file
               min         computes the minimal/tightest bounding box
               none        no bounding box is assigned
               papersize   box sizes specified by papersize specials present in the DVI file
               preview     bounding box data computed by the preview package (if present in the
                           DVI file)

           Page orientation
               The default page orientation for DIN/ISO and American paper sizes is portrait,
               i.e.  width < height. Appending -landscape or simply -l to the format string
               switches to landscape mode (width > height). For symmetry reasons you can also
               explicitly add -portrait or -p to indicate the default portrait format. Note that
               these suffixes are part of the size string and not separate options. Thus, they
               must directly follow the size specifier without additional blanks. Furthermore,
               the orientation suffixes can’t be used with dvi, min, and none.

                   Note
                   Option -b, --bbox only affects the bounding box and does not transform the
                   page content. Hence, if you choose a landscape format, the page won’t be
                   rotated.

       -B, --bitmap-format=fmt
           This option sets the image format used to embed bitmaps extracted from PostScript or
           PDF data. By default, dvisvgm embeds all bitmaps as JPEG images because it’s the most
           compact of the two formats supported by SVG. To select the alternative lossless PNG
           format, --bitmap-format=png can be used. There are some more format variants dvisvgm
           currently supports even though jpeg and png should be sufficient in most cases. The
           following list gives an overview of the known format names which correspond to names
           of Ghostscript output devices.

           none       disable processing of bitmap images
           jpeg       color JPEG format
           jpeggray   grayscale JPEG format
           png        grayscale or 24-bit color PNG format depending on current color space
           pnggray    grayscale PNG format
           pngmono    black-and-white PNG format
           pngmonod   dithered black-and-white PNG format
           png16      4-bit color PNG format

           png256     8-bit color PNG format
           png16m     24-bit color PNG format

           Since the collection of supported output devices can vary among local Ghostscript
           installations, not all formats may be available in some environments. dvisvgm quits
           with a PostScript error message if the selected output format requires a locally
           unsupported output device.

           The two JPEG format specifiers accept an optional parameter to set the IJG quality
           level which must directly follow the format specifier separated by a colon, e.g.
           --bitmap-format=jpeg:50. The quality value is an integer between 0 and 100. Higher
           values result in better image quality but lower compression rates and therefore larger
           files. The default quality level is 75 which is applied if no quality parameter is
           given or if it’s set to 0.

       -C, --cache[=dir]
           To speed up the conversion process of bitmap fonts, dvisvgm saves intermediate
           conversion information in cache files. By default, these files are stored in
           $XDG_CACHE_HOME/dvisvgm/ or $HOME/.cache/dvisvgm if XDG_CACHE_HOME is not set. If you
           prefer a different location, use option --cache to overwrite the default. Furthermore,
           it is also possible to disable the font caching mechanism completely with option
           --cache=none. If argument dir is omitted, dvisvgm prints the path of the default cache
           directory together with further information about the stored fonts. Additionally,
           outdated and corrupted cache files are removed.

       -j, --clipjoin
           This option tells dvisvgm to compute all intersections of clipping paths itself rather
           than delegating this task to the SVG renderer. The resulting SVG files are more
           portable because some SVG viewers don’t support intersecting clipping paths which are
           defined by clipPath elements containing a clip-path attribute.

       --color
           Enables colorization of messages printed during the conversion process. The colors can
           be customized via environment variable DVISVGM_COLORS. See the Environment section
           below for further information.

       --colornames
           By default, dvisvgm exclusively uses RGB values of the form #RRGGBB or #RGB to
           represent colors in the SVG file. The latter is a short form for colors whose RGB
           components each consist of two identical hex digits, e.g.  #123 equals #112233.
           According to the SVG standard, it’s also possible to use color names (like black and
           darkblue) for a limited number of predefined colors
           (https://www.w3.org/TR/SVG11/types.html#ColorKeywords). In order to apply these color
           names rather than their RGB values, call dvisvgm with option --colornames. All colors
           without an SVG color name will still be represented by RGB values.

       --comments
           Adds comments with further information about selected data to the SVG file. Currently,
           only font elements and font CSS rules related to native fonts are annotated.

       --currentcolor[=color]
           This option tells dvisvgm to replace the specified color with CSS variable
           currentColor which holds the current foreground color set by CSS property color. This
           way an application or website can change the color via CSS without the need to modify
           the SVG code.

           The optional argument of --currentcolor specifies the RGB color value to be replaced
           and must be given as either six or three digit hex color value
           (https://www.w3.org/TR/css-color/#typedef-hex-color) preceded by character #, e.g.
           #0000ff or #00f for blue. If the optional argument is omitted, black is assumed.

       --embed-bitmaps
           Embeds the contents of bitmap files into the generated SVG files instead of adding
           file references. Because of the base64-encoded data, the SVG files are usually much
           bigger but at the same time more portable because they don’t rely on external bitmap
           files.

           This option only affects bitmaps referenced in DVI/XDV files, e.g. by \includegraphics
           or special command dvisvgm:img (see below). Bitmaps present in PostScript or PDF files
           are always embedded. Also see option bitmap-format.

       -E, --eps
           If this option is given, dvisvgm does not expect a DVI but a single or multiple EPS
           input files, and tries to convert them to SVG. In order to do so, a single psfile
           special command is created and forwarded to the PostScript special handler. This
           option is only available if dvisvgm was built with PostScript support enabled, and
           requires Ghostscript to be available. See option --libgs for further information.

       -e, --exact-bbox
           This option tells dvisvgm to compute the precise bounding box of each character. By
           default, the values stored in a font’s TFM file are used to determine a glyph’s
           extent. As these values are intended to implement optimal character placements and are
           not designed to represent the exact dimensions, they don’t necessarily correspond with
           the bounds of the visual glyphs. Thus, width and/or height of some glyphs may be
           larger (or smaller) than the respective TFM values. As a result, this can lead to
           clipped characters at the bounds of the SVG graphics. With option --exact-bbox given,
           dvisvgm analyzes the actual shape of each character and derives a usually tight
           bounding box.

           This option only affects the processing of DVI files. When converting EPS or PDF
           files, the bounding box information stored in these files are used to derive the SVG
           bounding box.

       -f, --font-format=format
           Selects the file format used to embed font data into the generated SVG output when
           converting DVI or PDF files. The latter require the new mutool-based PDF handler
           introduced with dvisvgm 3.0 (also see option --pdf). Option --font-format has no
           effect when converting PDF or PostScript files using Ghostscript. Text fragments
           present in these files are then always converted to path elements.

           Following formats are supported: SVG (that’s the default), TTF (TrueType), WOFF, and
           WOFF2 (Web Open Font Format version 1 and 2). By default, dvisvgm creates unhinted
           fonts that might look bad on low-resolution devices. In order to improve the display
           quality, the generated TrueType, WOFF, or WOFF2 fonts can be autohinted. The
           autohinter is enabled by appending ,autohint or ,ah to the font format, e.g.
           --font-format=woff,autohint or --fwoff,ah. This functionality requires the ttfautohint
           library (https://freetype.org/ttfautohint). If it’s not available or can’t be found,
           dvisvgm issues a corresponding warning message.

           Option --font-format is only available if dvisvgm was built with WOFF support enabled.

       -m, --fontmap=filenames
           Loads and evaluates a single font map file or a sequence of font map files. These
           files are required to resolve font file names and encodings. dvisvgm does not provide
           its own map files but tries to read available ones coming with dvips or dvipdfm. If
           option --fontmap is omitted, dvisvgm looks for the default map files dvisvgm.map,
           ps2pk.map, pdftex.map, dvipdfm.map, and psfonts.map (in this order). Otherwise, the
           files given as option arguments are evaluated in the given order. Multiple filenames
           must be separated by commas without leading and/or trailing whitespace.

           By default, redefined mappings do not replace previous ones. However, each filename
           can be preceded by an optional mode specifier (+, -, or =) to change this behavior:

           +mapfile
               Only those entries in the given map file that don’t redefine a font mapping are
               applied, i.e. fonts already mapped keep untouched. That’s also the default mode if
               no mode specifier is given.

           -mapfile
               Ensures that none of the font mappings defined in the given map file are used,
               i.e. previously defined mappings for the specified fonts are removed.

           =mapfile
               All mappings defined in the map file are applied. Previously defined settings for
               the same fonts are replaced.

               If the first filename in the filename sequence is preceded by a mode specifier,
               dvisvgm loads the default font map (see above) and applies the other map files
               afterwards. Otherwise, none of default map files will be loaded automatically.

               Examples: --fontmap=myfile1.map,+myfile2.map loads myfile1.map followed by
               myfile2.map where all redefinitions of myfile2.map are ignored.
               --fontmap==myfile1.map,-myfile2.map loads the default map file followed by
               myfile1.map and myfile2.map where all redefinitions of myfile1.map replace
               previous entries. Afterwards, all definitions for the fonts given in myfile2.map
               are removed from the font map tree.

               For further information about the map file formats and the mode specifiers, see
               the manuals of dvips (https://tug.org/texinfohtml/dvips.html) and dvipdfm
               (https://ctan.org/tex-archive/dviware/dvipdfm).

               dvisvgm supports both the dvips and the dvipdfm map file formats. It extends both
               variants by two include statements that allow for loading other map files inside a
               map file. The syntax is as follows:

                   #include [<modechar>] <filename|filepath>
                   #includefirst [<modechar>] <filename|filepath>

               They must be placed on a separate line and start at the first column of that line.
               Otherwise, they are ignored. While the first variant always tries to include the
               specified file, #includefirst is only executed once, i.e. once a file was
               successfully included by this statement, all subsequent #includefirst lines are
               skipped. This can be used to include one of several alternative files, whereby the
               first one found is loaded and all others are ignored.

               The optional parameter <modechar> (which can be +, -, or =) determines how to
               integrate the data read from the included file into the already present mapping
               data. They work the same way as the mode specifiers described above. If <modechar>
               parameter is omitted, it defaults to +.

               The following filename or file path specifies the file to include. In case of
               plain filenames (without path indicators), the files are looked up using the TeX
               file search functionality, i.e. files in the TeX directory tree can easily be
               added. Relative paths are relative to the location of the file containing the
               #include statement. Path components must be separated by forward slashes (/), also
               on Windows systems.

               Examples: #include pdftex.map looks for pdftex.map in the current working
               directory and in the TeX directory tree.  #include ./pdftex.map, on the other
               hand, looks for pdftex.map only in the directory where the including file is
               located.

       --grad-overlap
           Tells dvisvgm to create overlapping grid segments when approximating color gradient
           fills (also see option --grad-segments below). By default, adjacent segments don’t
           overlap but only touch each other like separate tiles. However, this alignment can
           lead to visible gaps between the segments because the background color usually
           influences the color at the boundary of the segments if the SVG renderer uses
           anti-aliasing to create smooth contours. One way to avoid this and to create
           seamlessly touching color regions is to enlarge the segments so that they extend into
           the area of their right and bottom neighbors. Since the latter are drawn on top of the
           overlapping parts, the visible size of all segments keeps unchanged. Just the former
           gaps disappear as the background is now completely covered by the correct colors.
           Currently, dvisvgm computes the overlapping segments separately for each patch of the
           mesh (a patch mesh may consist of multiple patches of the same type). Therefore, there
           still might be visible gaps at the seam of two adjacent patches.

       --grad-segments=number
           Determines the maximum number of segments per column and row used to approximate
           gradient color fills. Since SVG 1.1 only supports a small subset of the shading
           algorithms available in PostScript, dvisvgm approximates some of them by subdividing
           the area to be filled into smaller, monochromatic segments. Each of these segments
           gets the average color of the region it covers. Thus, increasing the number of
           segments leads to smaller monochromatic areas and therefore a better approximation of
           the actual color gradient. As a drawback, more segments imply bigger SVG files because
           every segment is represented by a separate path element.

           Currently, dvisvgm supports free- and lattice-form triangular patch meshes as well as
           Coons and tensor-product patch meshes. They are approximated by subdividing the area
           of each patch into a n×n grid of smaller segments. The maximum number of segments per
           column and row can be changed with option --grad-segments.

       --grad-simplify=delta
           If the size of the segments created to approximate gradient color fills falls below
           the given delta value, dvisvgm reduces their level of detail. For example, Bézier
           curves are replaced by straight lines, and triangular segments are combined to
           tetragons. For a small delta, these simplifications are usually not noticeable but
           reduce the size of the generated SVG files significantly.

       -h, --help[=mode]
           Prints a short summary of all available command-line options. The optional mode
           parameter is an integer value between 0 and 2. It selects the display variant of the
           help text. Mode 0 lists all options divided into categories with section headers. This
           is also the default if dvisvgm is called without parameters. Mode 1 lists all options
           ordered by the short option names, while mode 2 sorts the lines by the long option
           names.

           A values in brackets after the description text indicate the default parameter of the
           option. They are applied if an option with a mandatory parameter is not used or if an
           optional parameter is omitted. For example, option --bbox requires a size parameter
           which defaults to min if --bbox is not used. Option --zip, which isn’t applied by
           default, accepts an optional compression level parameter. If it’s omitted, the stated
           default value 9 is used.

       --keep
           Disables the removal of temporary files as created by Metafont (usually .gf, .tfm, and
           .log files) or the TrueType/WOFF module.

       --libgs=path
           This option is only available if the Ghostscript library is not directly linked to
           dvisvgm and if PostScript support was not completely disabled during compilation. In
           this case, dvisvgm tries to load the shared GS library dynamically during runtime. By
           default, it expects the library’s name to be libgs.so.X (on Unix-like systems, where X
           is the ABI version of the library) or gsdll32.dll/gsdll64.dll (Windows). If dvisvgm
           doesn’t find the library, option --libgs can be used to specify the correct path and
           filename, e.g.  --libgs=/usr/local/lib/libgs.so.9 or
           --libgs=\gs\gs9.25\bin\gsdll64.dll.

           Alternatively, it’s also possible to assign the path to environment variable LIBGS,
           e.g.  export LIBGS=/usr/local/lib/libgs.so.9 or set LIBGS=\gs\gs9.25\bin\gsdll63.dll.
           LIBGS has less precedence than the command-line option, i.e. dvisvgm ignores variable
           LIBGS if --libgs is given.

       -L, --linkmark=style
           Selects the method how to mark hyperlinked areas. The style argument can take one of
           the values none, box, and line, where box is the default, i.e. a rectangle is drawn
           around the linked region if option --linkmark is omitted. Style argument line just
           draws the lower edge of the bounding rectangle, and none tells dvisvgm not to add any
           visible objects to hyperlinks. The lines and boxes get the current text color
           selected. In order to apply a different, constant color, a colon followed by a color
           specifier can be appended to the style string. A color specifier is either a
           hexadecimal RGB value of the form #RRGGBB, or a dvips color name
           (https://en.wikibooks.org/wiki/LaTeX/Colors#The_68_standard_colors_known_to_dvips).

           Moreover, argument style can take a single color specifier to highlight the linked
           region by a frameless box filled with that color. An optional second color specifier
           separated by a colon selects the frame color.

           Examples: box:red or box:#ff0000 draws red boxes around the linked areas.  yellow:blue
           creates yellow filled rectangles with blue frames.

       -l, --list-specials
           Prints a list of registered special handlers and exits. Each handler processes a set
           of special statements belonging to the same category. In most cases, these categories
           are identified by the prefix of the special statements which is usually a leading
           string followed by a colon or a blank, e.g.  color or ps. The listed handler names,
           however, don’t need to match these prefixes, e.g. if there is no common prefix or if
           functionality is split into separate handlers in order to allow them to be disabled
           separately using option --no-specials. All special statements not covered by one of
           the special handlers are silently ignored.

       -M, --mag=factor
           Sets the magnification factor applied in conjunction with Metafont calls prior tracing
           the glyphs. The larger this value, the better the tracing results. Nevertheless, large
           magnification values can cause Metafont arithmetic errors due to number overflows. So,
           use this option with care. The default setting usually produces nice results.

       --message=text
           Prints a given message to the console after an SVG file has been written. Argument
           text may consist of static text as well as the macros listed below in the description
           of special command dvisvgm:raw. For example, --message="page {?pageno} written to
           {?svgfile}" prints the message with the macros expanded after the conversion of each
           page of a DVI or PDF file or after processing an EPS file.

           The output of option --message is not affected by a specified verbosity level, i.e.
           dvisvgm prints the text even with --verbosity=0.

       --no-merge
           Puts every single character in a separate text element with corresponding x and y
           attributes. By default, new text or tspan elements are only created if a string starts
           at a location that differs from the regular position defined by the characters'
           advance values.

       --no-mktexmf
           Suppresses the generation of missing font files. If dvisvgm can’t find a font file
           through the kpathsea lookup mechanism, it calls the external tools mktextfm or
           mktexmf. This option disables these calls.

       -n, --no-fonts[=variant]
           If this option is given, dvisvgm doesn’t create SVG font elements but uses paths
           instead. The resulting SVG files tend to be larger but are concurrently more
           compatible with most applications that don’t support SVG fonts. The optional argument
           variant selects the method how to substitute fonts by paths. Variant 0 creates path
           and use elements in order to avoid lengthy duplicates. Variant 1 creates path elements
           only. Option --no-fonts implies --no-styles.

       -c, --scale=sx[,sy]
           Scales the page content horizontally by sx and vertically by sy. This option is
           equivalent to -TSsx,sy.

       -S, --no-specials[=names]
           Disable processing of special commands embedded in the DVI file. If no further
           parameter is given, all specials are ignored. To disable a selected set of specials,
           an optional comma-separated list of names can be appended to this option. A name is
           the unique identifier referencing the intended special handler as listed by option
           --list-specials.

       --no-styles
           By default, dvisvgm creates CSS styles and class attributes to reference fonts. This
           variant is more compact than adding the complete font information to each text element
           over and over again. However, if you prefer direct font references, the default
           behavior can be disabled with option --no-styles.

       -O, --optimize[=modules]
           Applies several optimizations on the generated SVG tree to reduce the file size. The
           optimizations are performed by running separate optimizer modules specified by
           optional argument modules. It may consist of a single module name or a comma-separated
           list of several module names. The corresponding modules are executed one by one in the
           given order and thus transform the XML tree gradually. A leading hyphen (-) can be
           used to exclude a module from processing. For example -Oall,-collapse-groups performs
           all optimizations except collapse-groups. If the first module name in the list starts
           with a hyphen, dvisvgm automatically inserts all at the beginning, i.e.
           -O-collapse-groups is identical to -Oall,-collapse-groups.

           The following list describes the currently available optimizer modules.

           list
               Lists all available optimizer modules and exits.

           none
               If this argument is given, dvisvgm doesn’t apply any optimization.  none can’t be
               combined with other module names.

           all
               Performs all optimizations listed below. This is also the default if option
               --optimize is used without any arguments. The modules are executed in a predefined
               order that usually leads to the best results.  all must be the only or the first
               entry in the list of module names.

           collapse-groups
               Combines nested group elements (<g>...</g>) that contain only a single group each.
               If possible, the group attributes are moved to the outermost element of the
               processed subtree. This module also unwraps group elements that have no attributes
               at all.

           group-attributes
               Creates groups (<g>...</g>) for common attributes around adjacent elements. Each
               attribute is moved to a separate group so that multiple common attributes lead to
               nested groups. They can be combined by applying optimizer module collapse-groups
               afterwards. The algorithm only takes inheritable properties, such as fill or
               stroke-width, into account and only removes them from an element if none of the
               other attributes, like id, prevents this.

           reassign-clippaths
               Collects all clipPath elements that differ only by their IDs. Afterwards, the
               duplicates are removed so that only one remains. All clip-path attributes
               referencing one of the duplicates are updated accordingly.

           remove-clippaths
               Removes all redundant clipPath elements. This optimization was already present in
               former versions of dvisvgm and was always applied by default. This behavior is
               retained, i.e. dvisvgm executes this module even if option --optimize is not
               given. You can use argument none to prevent that.

           simplify-text
               If a text element only contains whitespace nodes and tspan elements, all common
               inheritable attributes of the latter are moved to the enclosing text element. All
               tspan elements without further attributes are unwrapped.

           simplify-transform
               Tries to shorten all transform attributes. This module combines the transformation
               commands of each attribute and decomposes the resulting transformation matrix into
               a sequence of basic transformations, i.e. translation, scaling, rotation, and
               skewing. If this sequence is shorter than the equivalent matrix expression, it’s
               assigned to the attribute. Otherwise, the matrix expression is used.

       -o, --output=pattern
           Sets the pattern that determines the names of the generated SVG files, optionally
           including the file path. The required parameter pattern may consist of an arbitrary
           sequence of characters which make up the filenames or file paths relative to the
           current working directory. With the exception of the following mentioned variables and
           expressions, all characters are treated as static parts of the filenames/folders and
           are therefore identical for all pages processed during a run of dvisvgm. The strings
           %f, %p, %P, %n, %N, %hd, %ho, and %hc are variables that can be used as part of the
           pattern.  %f expands to the base name of the DVI file, i.e. the filename without
           suffix, %p is the current page number, and %P the total number of pages in the DVI
           file. The variables %n and %N expand to the number of the current file being converted
           (starting at 1) and the total number of files given, respectively.

           An optional number (0-9) specified directly after the percent sign of a variable
           holding a numeric value denotes the minimal number of digits to be created. If a
           particular value consists of less digits, the number is padded with leading zeros.
           Example: %3p enforces 3 digits for the current page number (001, 002, etc.). Without
           an explicit width specifier, %p gets the same number of digits as %P.

           If you need more control over the numbering, you can use arithmetic expressions as
           part of the pattern. The syntax is %(expr) where expr may contain additions,
           subtractions, multiplications, and integer divisions with common precedence. The
           variables p and P contain the current page number and the total number of pages,
           respectively. For example, --output="%f-%(p-1)" creates filenames where the numbering
           starts with 0 rather than 1.

           The variables %hX contain different hash values computed from the DVI page data and
           the options given on the command-line.  %hd and %hc are only set if option
           --page-hashes is present. Otherwise, they are empty. For further information, see the
           description of option --page-hashes below.

           The default pattern is %f-%p.svg if the DVI file consists of more than one page, and
           %f.svg otherwise. That means, a DVI file foo.dvi is converted to foo.svg if foo.dvi is
           a single-page document. Otherwise, multiple SVG files foo-01.svg, foo-02.svg, etc. are
           produced. In Windows environments, the percent sign indicates dereferenced environment
           variables, and must therefore be protected by a second percent sign, e.g.
           --output=%%f-%%p.

       -p, --page=ranges
           This option selects the pages to be processed. Parameter ranges consists of a
           comma-separated list of single page numbers and/or page ranges. A page range is a pair
           of numbers separated by a hyphen, e.g. 5-12. Thus, a page sequence might look like
           this: 2-4,6,9-12,15. It doesn’t matter if a page is given more than once or if page
           ranges overlap. dvisvgm always extracts the page numbers in ascending order and
           converts them only once.

           In order to stay compatible with previous versions, the default page sequence is 1.
           dvisvgm therefore converts only the first page and not the whole document if option
           --page is omitted. Usually, page ranges consist of two numbers denoting the first and
           last page to be converted. If the conversion should start at page 1, or if it should
           continue up to the last DVI page, the first or second range number can be omitted,
           respectively. Example: --page=-10 converts all pages up to page 10, --page=10-
           converts all pages starting with page 10. Please consider that the page values don’t
           refer to the page numbers printed on the corresponding page. Instead, the physical
           page count is expected, where the first page always gets number 1.

           At the end of the range sequence an optional filter specifier can be appended in order
           to remove certain page numbers from the sequence. Currently, the two filters :even and
           :odd are supported which restrict the preceding values to even and odd numbers,
           respectively. For example, --page=1-11,20:even is equivalent to --page=2,4,6,8,10,20.

       -H, --page-hashes[=params]
           If this option is given, dvisvgm computes hash values of all pages to be processed. As
           long as the page contents don’t change, the hash value of that page stays the same.
           This property can be used to determine whether a DVI page must be converted again or
           can be skipped in consecutive runs of dvisvgm. This is done by propagating the hash
           value to variable %hd which can be accessed in the output pattern (see option
           --output). By default, dvisvgm changes the output pattern to %f-%hd if option
           --page-hashes is given. As a result, all SVG file names contain the hash value instead
           of the page number. When calling dvisvgm again with option --page-hashes with the same
           output pattern, it checks the existence of the SVG file to be created and skips the
           conversion if it’s already present. This also applies for consecutive calls of dvisvgm
           with different command-line parameters. If you want to force another conversion of a
           DVI file that hasn’t changed, you must remove the corresponding SVG files beforehand
           or add the parameter replace (see below). If you manually set the output pattern to
           not contain a hash value, the conversion won’t be skipped.

           Alternatively, the output pattern may contain the variables %ho and %hc.  %ho expands
           to a 32-bit hash representing the given command-line options that affect the generated
           SVG output, like --no-fonts and --precision. Different combinations of options and
           parameters lead to different hashes. Thus pattern %f-%hd-%ho creates filenames that
           change depending on the DVI data and the given command-line options. Variable %hc
           provides a combined hash computed from the DVI data and the command-line options. It
           has the same length as %hd.

           Since the page number isn’t part of the file name by default, different DVI pages with
           identical contents get the same file name. Therefore, only the first one is converted
           while the others are skipped. To create separate files for each page, you can add the
           page number to the output pattern, e.g.  --output="%f-%p-%hc".

           By default, dvisvgm uses the fast XXH64 hash algorithm to compute the values provided
           through %hd and %hc. 64-bit hashes should be sufficient for most documents with an
           average size of pages. Alternatively, XXH32 and MD5 can be used as well. The desired
           algorithm is specified by argument params of option --page-hashes. It takes one of the
           strings MD5, XXH32, and XXH64, where the names can be given in lower case too, like
           --page-hashes=md5. Since version 0.7.1, xxHash provides an experimental 128-bit hash
           function whose algorithm has been stabilized as of version 0.8. When using a version
           prior to 0.8, the 128-bit hash values can vary depending on the used xxHash version.
           If the corresponding API is available, dvisvgm supports the new hash function, and
           option --page-hashes additionally accepts the algorithm specifier XXH128.

           Finally, option --page-hashes can take a second argument that must be separated by a
           comma. Currently, only the two parameters list and replace are evaluated, e.g.
           --page-hashes=md5,list or --page-hashes=replace. When list is present, dvisvgm doesn’t
           perform any conversion but just lists the hash values %hd and %hc of the pages
           specified by option --page. Parameter replace forces dvisvgm to convert a DVI page
           even if a file with the target name already exists.

       -P, --pdf
           If this option is given, dvisvgm does not expect a DVI but a PDF input file, and tries
           to convert it to SVG. Similar to the conversion of DVI files, only the first page is
           processed by default. Option --page can be used to select different pages, page
           ranges, and/or page sequences.

           If a Ghostcript version < 10.01.0 is found, dvisvgm uses Ghostscript to process the
           PDF file. In this case, the conversion is realized by creating a single pdffile
           special command which is forwarded to dvisvgm’s PostScript special handler. Therefore,
           this option is only available if dvisvgm was built with PostScript support enabled,
           and requires Ghostscript to be accessible. See option --libgs for further information.

           As of Ghostscript 10.01.0, this will no longer work due to the introduction of a new
           PDF interpreter. Therefore, an alternative conversion module based on mutool, a
           utility which is part of the MuPDF (https://mupdf.com) package, has been introduced.
           It’s automatically invoked if Ghostscript can’t be used and if a working mutool
           executable is present in a directory which is part of the system’s search path.

           Alternatively, environment variable DVISVGM_PDF_PROC can be used to select the PDF
           processor. The currently supported values are gs and mutool.

       -d, --precision=digits
           Specifies the maximum number of decimal places applied to floating-point attribute
           values. All attribute values written to the generated SVG file(s) are rounded
           accordingly. The parameter digits accepts integer values from 0 to 6, where 0 enables
           the automatic selection of significant decimal places. This is also the default value
           if dvisvgm is called without option --precision.

       --progress[=delay]
           Enables a simple progress indicator shown when time-consuming operations like
           PostScript specials are processed. The indicator doesn’t appear before the given delay
           (in seconds) has elapsed. The default delay value is 0.5 seconds.

       -r, --rotate=angle
           Rotates the page content clockwise by angle degrees around the page center. This
           option is equivalent to -TRangle.

       -R, --relative
           SVG allows you to define graphics paths by a sequence of absolute and/or relative path
           commands, i.e. each command expects either absolute coordinates or coordinates
           relative to the current drawing position. By default, dvisvgm creates paths made up of
           absolute commands. If option --relative is given, relative commands are created
           instead. This slightly reduces the size of the SVG files in most cases.

       --stdin
           Tells dvisvgm to read the DVI or EPS input data from stdin instead from a file.
           Alternatively to option --stdin, a single dash (-) can be given. The default name of
           the generated SVG file is stdin.svg which can be changed with option --output.

       -s, --stdout
           Don’t write the SVG output to a file but redirect it to stdout.

       --tmpdir[=path]
           In some cases, dvisvgm needs to create temporary files to work properly. These files
           go to the system’s temporary folder by default, e.g.  /tmp on Linux systems. Option
           --tmpdir can be used to specify a different location. Please note that dvisvgm does
           not create this folder if it doesn’t exist. Therefore, you must ensure that it’s
           actually present before running dvisvgm.

           In order to prevent colliding files caused by parallel calls of dvisvgm, the program
           doesn’t write the files directly in the specified directory but furthermore creates a
           uniquely named subfolder in there, where the temporary files will be placed. This can
           be prevented by appending // or \\ (on Windows) to the specified directory name. For
           example, --tmpdir=.// creates the temporary files directly in the current working
           directory, while --tmpdir=.  places them in a dedicated subfolder of the current
           working directory.

           If the optional parameter path of option --tmpdir is omitted, dvisvgm prints the
           location of the system’s temp folder and exits.

       -a, --trace-all=[retrace]
           This option forces dvisvgm to vectorize not only the glyphs actually required to
           render the SVG file correctly – which is the default –, but processes all glyphs of
           all fonts referenced in the DVI file. Because dvisvgm stores the tracing results in a
           font cache, all following conversions of these fonts will speed up significantly. The
           boolean option retrace determines how to handle glyphs already stored in the cache. By
           default, these glyphs are skipped. Setting argument retrace to yes or true forces
           dvisvgm to retrace the corresponding bitmaps again.

               Note
               This option only takes effect if font caching is active. Therefore, --trace-all
               cannot be combined with option --cache=none.

       -T, --transform=commands
           Applies a sequence of transformations to the SVG content. Each transformation is
           described by a command beginning with a capital letter followed by a list of
           comma-separated parameters. Following transformation commands are supported:

           T tx[,ty]
               Translates (moves/shifts) the page in direction of vector (tx,ty). If ty is
               omitted, ty=0 is assumed. The expected unit length of tx and ty are TeX points
               (1pt = 1/72.27in). However, there are several constants defined to simplify the
               unit conversion (see below).

           S sx[,sy]
               Scales the page horizontally by sx and vertically by sy. If sy is omitted, sy=sx
               is assumed.

           R angle[,x,y]
               Rotates the page clockwise by angle degrees around point (x,y). If the optional
               arguments x and y are omitted, the page will be rotated around its center
               depending on the chosen page format. When option -bnone is given, the rotation
               center is origin (0,0).

           KX angle
               Skews the page along the x-axis by angle degrees. Argument angle can take any
               value except 90+180k, where k is an integer.

           KY angle
               Skews the page along the y-axis by angle degrees. Argument angle can take any
               value except 90+180k, where k is an integer.

           FH [y]
               Mirrors (flips) the page at the horizontal line through point (0,y). Omitting the
               optional argument leads to y=h/2, where h denotes the page height (see pre-defined
               constants below).

           FV [x]
               Mirrors (flips) the page at the vertical line through point (x,0). Omitting the
               optional argument leads to x=w/2, where w denotes the page width (see pre-defined
               constants below).

           M m1,...,m6
               Applies a transformation described by the 3×3 matrix
               ((m1,m2,m3),(m4,m5,m6),(0,0,1)), where the inner triples denote the rows.

                   Note
                   All transformation commands of option -T, --transform are applied in the order
                   of their appearance. Multiple commands can optionally be separated by spaces.
                   In this case the whole transformation string has to be enclosed in double
                   quotes to keep them together. All parameters are expressions of floating point
                   type. You can either give plain numbers or arithmetic terms combined by the
                   operators + (addition), - (subtraction), * (multiplication), / (division) or %
                   (modulo) with common associativity and precedence rules. Parentheses may be
                   used as well.

                   Additionally, some pre-defined constants are provided:

                   ux   horizontal position of upper left page corner in TeX point units
                   uy   vertical position of upper left page corner in TeX point units
                   h    page height in TeX point units (0 in case of -bnone)
                   w    page width in TeX point units (0 in case of -bnone)

                   Furthermore, you can use the 9 length constants pt, bp, cm, mm, in, pc, dd,
                   cc, and sp, e.g.  2cm or 1.6in. Thus, option -TT1in,0R45 moves the page
                   content 1 inch to the right and rotates it by 45 degrees around the page
                   center afterwards.

                   For single transformations, there are also the short-hand options -c, -t and
                   -r available. In contrast to the --transform commands, the order of these
                   options is not significant, so that it’s not possible to describe
                   transformation sequences with them.

       -t, --translate=tx[,ty]
           Translates (moves) the page content in direction of vector (tx,ty). This option is
           equivalent to -TTtx,ty.

       -v, --verbosity=level
           Controls the type of messages printed during a dvisvgm run:

           0   no message output at all
           1   error messages only
           2   warning messages only
           4   informational messages only
           8   user messages only (e.g. created by special dvisvgm:message)

               Note
               By adding these values you can combine the categories. The default level is 15,
               i.e. all messages are printed.

       -V, --version[=extended]
           Prints the version of dvisvgm and exits. If the optional argument is set to yes, the
           version numbers of the linked libraries are printed as well.

       -z, --zip[=level]
           Creates a compressed SVG file with suffix .svgz. The optional argument specifies the
           compression level. Valid values are in the range of 1 to 9 (default value is 9).
           Larger values cause better compression results but may take slightly more computation
           time.

       -Z, --zoom=factor
           Multiplies the values of the width and height attributes of the SVG root element by
           argument factor while the coordinate system of the graphic content is retained. As a
           result, most SVG viewers zoom the graphics accordingly. If a negative zoom factor is
           given, the width and height attributes are omitted.

SUPPORTED SPECIALS

       dvisvgm supports several special commands that enrich the DVI command set with additional
       instructions for features, like color, graphics, and hyperlinks. The term special command,
       or just special, originates from the TeX command \special{...} which does almost nothing.
       TeX only forwards the argument of this command to the DVI file using the corresponding xxx
       opcode, thus delegating its execution to the DVI driver. The driver can then decide to
       either process or ignore it, depending on the supported statements. The parameter of TeX’s
       \special command is given in curly braces and may consist of an arbitrary character
       sequence representing the actual instruction, for example color Red.

       It might be worth mentioning that specials are only evaluated when processing DVI files.
       PS/EPS and PDF don’t know anything about the concept of specials and therefore don’t
       provide means to represent them.

       In order to evaluate the special commands, dvisvgm implements several dedicated handlers.
       Each handler is responsible for all special statements belonging to the same command set,
       i.e. commands usually – but not necessarily – beginning with a common prefix. For example,
       all PDF specials start with the prefix pdf:, while the TPIC special set consists of 13
       different commands without common identifier. The PDF specials are processed by dvisvgm’s
       pdf handler, the TPIC ones by the tpic handler. To get a list of the actually provided
       special handlers, use option --list-specials (see above). The following list gives an
       overview of the special sets currently supported. The names of the handlers can also be
       used to disable the processing of individual sets of specials. For further information on
       this, see option --no-specials.

       bgcolor
           Special statements for changing the background/page color. Currently, dvisvgm only
           supports the background statement as specified in the dvips manual
           (https://tug.org/texinfohtml/dvips.html#Color-specifications). Since SVG 1.1 doesn’t
           support background colors, dvisvgm inserts a rectangle of the chosen color into the
           generated SVG document. This rectangle always gets the same size as the selected or
           computed bounding box. This background color command is part of the color special set
           but is handled separately in order to let the user turn it off.

       color
           Statements of this command set provide instructions to change the text/paint color.
           For an overview of the exact syntax, see the documentation of dvips, for instance.

           dvisvgm extends the dvips syntax of the color specials by two optional modifiers to
           enable the differentiation between fill and stroke colors, i.e. colors used to fill
           enclosed areas and to draw lines, respectively. If one of the color specifiers, like a
           color name or a color model followed by a sequence of color components, is preceded by
           fill or stroke, only the corresponding color is changed. Without these modifiers both
           colors are affected. Example: color push fill rgb 1 0 1 pushes a new color pair onto
           the color stack whereby the fill color is set to magenta and the stroke color retains
           its current value.  color push rgb 1 0 1 pushes a color pair with both colors set to
           magenta.

           Additionally, the new special color set is introduced. Its syntax is the same as the
           one of color push including the optional fill and stroke modifiers. Instead of pushing
           a new color pair it modifies the topmost one on the stack. If the color stack is
           empty, the default (black) fill/stroke color is changed.

       dvisvgm
           The following list gives a brief overview of dvisvgm’s own set of currently supported
           specials.

           dvisvgm:raw text
               Adds an arbitrary sequence of XML nodes to the page section of the SVG document.
               dvisvgm checks syntax and proper nesting of the inserted elements but does not
               perform any validation, thus the user has to ensure that the resulting SVG is
               still valid. Opening and closing tags may be distributed among different raw
               specials. The tags themselves can also be split but must be continued with the
               immediately following raw special. Both syntactically incorrect and wrongly nested
               tags lead to error messages.

               Parameter text may also contain the expressions {?x}, {?y}, {?color},
               {?fillcolor}, {?strokecolor}, {?matrix}, {?pageno}, {?svgfile}, and {?svgpath}
               that respectively expand to the current x and y coordinate, an RGB hex string of
               the current active fill and stroke color, the current transformation matrix, the
               current page number, and the relative and absolute path of the SVG file being
               created.  {?color} expands to the same string as {?fillcolor} and is still
               available for compatibility with older dvisvgm versions that didn’t distinguish
               between fill and stroke colors (see information about color specials below).

               As SVG doesn’t support CMYK colors, for example in fill and stroke attributes,
               dvisvgm provides macro {?cmyk(c,m,y,k)} to create an RGB hex string from a CMYK
               color. It can be used instead of a combination of color/PostScript specials and
               color macros to directly insert a CMYK color value.

               Character sequence {?nl} expands to a newline character. Finally, constructions of
               the form {?(expr)} enable the evaluation of mathematical expressions which may
               consist of basic arithmetic operations including modulo. As above, the variables x
               and y represent the current coordinates. Invalid operations, like divisions by
               zero, lead to an error message on the console. Example: {?(-10*(x+2y)-5)} is a
               valid expresssion and expands to the corresponding numeric string.

           dvisvgm:rawdef text
               This command is similar to dvisvgm:raw, but puts the XML nodes into the <defs>
               section of the SVG document currently being generated.

           dvisvgm:rawset name ... dvisvgm:endrawset
               This pair of specials marks the begin and end of a definition of a named raw SVG
               fragment. All dvisvgm:raw and dvisvgm:rawdef specials enclosed by dvisvgm:rawset
               and dvisvgm:endrawset are not evaluated immediately but stored together under the
               given name for later use. Once defined, the named fragment can be referenced
               throughout the DVI file by dvisvgm:rawput (see below). The two commands
               dvisvgm:rawset and dvisvgm:endrawset must not be nested, i.e. each call of
               dvisvgm:rawset has to be followed by a corresponding call of dvisvgm:endrawset
               before another dvisvgm:rawset may occur. Also, the identifier name must be unique
               throughout the DVI file. Using dvisvgm:rawset multiple times together with the
               same name leads to warning messages.

           dvisvgm:rawput name
               Inserts raw SVG fragments previously stored under the given name. dvisvgm
               distinguishes between fragments that were specified with dvisvgm:raw or
               dvisvgm:rawdef, and handles them differently: It inserts all dvisvgm:raw parts
               every time dvisvgm:rawput is called, whereas the dvisvgm:rawdef portions go to the
               <defs> section of the current SVG document only once.

           dvisvgm:img width height file
               Creates an image element using the current graphic position, transformation
               matrix, the specified extents, and the given filename. This special command also
               updates the bounding box of the resulting SVG to entirely enclose the transformed
               image. The image itself is positioned such that the lower left corner of the
               untransformed image lies at the current graphic position. The length width and
               height specify the extents of the untransformed image. For a list of supported
               length units see option --bbox. Plain numbers without an appended unit specifier
               imply TeX points (1in = 72.27pt).

               Parameter file can be a plain filename or a relative or absolute path of a file.
               By default, dvisvgm just creates links referencing the image file so that the SVG
               renderer will evaluate the filename or path relative to the location of the
               generated SVG file. If option --embed-bitmaps is given, JPEG and PNG images are
               embedded into the SVG document. As this requires base64-encoding of the image
               data, the resulting SVG files can become quite big.

           dvisvgm:bbox lock
               Locks the bounding box of the current page and prevents it from further updating,
               i.e. graphics elements added after calling this special are not taken into account
               in determining the extent of the bounding box.

           dvisvgm:bbox unlock
               Unlocks the previously locked bounding box of the current page so that it gets
               updated again when adding graphics elements to the page.

           dvisvgm:bbox n[ew] name
               Defines or resets a local bounding box called name. The name may consist of
               letters and digits. While processing a DVI page, dvisvgm continuously updates the
               (global) bounding box of the current page in order to determine the minimal
               rectangle containing all visible page components (characters, images, drawing
               elements etc.) Additionally to the global bounding box, the user can request an
               arbitrary number of named local bounding boxes. Once defined, these boxes are
               updated together with the global bounding box starting with the first character
               that follows the definition. Thus, the local boxes can be used to compute the
               extent of parts of the page. This is useful for scenarios where the generated SVG
               file is post-processed.

               In conjunction with special dvisvgm:raw, the macro {?bbox name} expands to the
               four values x, y, w, and h (separated by spaces) specifying the coordinates of the
               upper left corner, width, and height of the local box name. If box name wasn’t
               previously defined, all four values equal to zero.

           dvisvgm:bbox width height [depth] [transform]
               Updates the bounding box of the current page by embedding a virtual rectangle (x,
               y, width, height) where the lower left corner is located at the current DVI
               drawing position (x,y). If the optional parameter depth is specified, dvisvgm
               embeds a second rectangle (x, y, width, -depth). The lengths width, height, and
               depth can be given together with a unit specifier (see option --bbox) or as plain
               floating point numbers. In the latter case, TeX point units are assumed (1in =
               72.27pt). Depending on size and position of the virtual rectangle, this command
               either enlarges the overall bounding box or leaves it as is. So, it’s not possible
               to reduce its extent.

               This special is supposed to be used together with dvisvgm:raw in order to update
               the viewport of the page properly. By default, the box extents are assigned
               unchanged and, in particular, are not altered by transformation commands. In order
               to apply the current transformation matrix, the optional modifier transform can be
               added at the end of the special statement.

           dvisvgm:bbox a[bs] x1 y1 x2 y2 [transform]
               This variant of the bbox special updates the bounding box by embedding a virtual
               rectangle (x1,y1,x2,y2). The points (x1,y1) and (x2,y2) denote the absolute
               coordinates of two diagonal corners of the rectangle. As with the relative special
               variant described above, the optional modifier transform allows for applying the
               current transformation matrix to the bounding box.

           dvisvgm:bbox f[ix] x1 y1 x2 y2 [transform]
               This variant of the bbox special assigns an absolute (final) bounding box to the
               resulting SVG. After executing this command, dvisvgm doesn’t further alter the
               bounding box coordinates, except this special is called again later. The points
               (x1,y1) and (x2,y2) denote the absolute coordinates of two diagonal corners of the
               rectangle. As with the relative special variant described above, the optional
               modifier transform allows for applying the current transformation matrix to the
               bounding box.

               The following TeX snippet adds two raw SVG elements to the output and updates the
               bounding box accordingly:

                   \special{dvisvgm:raw <circle cx='{?x}' cy='{?y}' r='10' stroke='black' fill='red'/>}%
                   \special{dvisvgm:bbox 10bp 10bp 10bp transform}%
                   \special{dvisvgm:bbox -10bp 10bp 10bp transform}

                   \special{dvisvgm:raw <path d='M50 200 L10 250 H100 Z' stroke='black' fill='blue'/>}%
                   \special{dvisvgm:bbox abs 10bp 200bp 100bp 250bp transform}

           dvisvgm:currentcolor [on|off]
               This special works similar to option --currentcolor but doesn’t require an
               explicit color argument. Instead, it takes the currently active color and replaces
               it with currentColor. Therefore, the result depends on both the placement of the
               special and the preceding color changes. Argument on – which activates the
               currentColor functionality – can be omitted. When called with argument off, the
               functionality is deactivated again.

           dvisvgm:message msg
               Prints the given text msg to the console. Besides static text it may also contain
               the macros {?...} mentioned in the description of dvisvgm:raw. The messages
               created by this special can be suppressed with option --verbosity (see above).

       em
           These specials were introduced with the emTeX distribution by Eberhard Mattes. They
           provide line drawing statements, instructions for embedding MSP, PCX, and BMP image
           files, as well as two PCL commands. dvisvgm supports only the line drawing statements
           and ignores all other em specials silently. A description of the command syntax can be
           found in the DVI driver documentation coming with emTeX (https://ctan.org/pkg/emtex).

       html
           The hyperref specification defines several variants on how to mark hyperlinked areas
           in a DVI file. dvisvgm supports the plain HyperTeX special constructs as created with
           hyperref package option hypertex. By default, all linked areas of the document are
           marked by a rectangle. Option --linkmark allows you to change this behavior. See above
           for further details. Information on syntax and semantics of the HyperTeX specials can
           be found in the hyperref manual (https://ctan.org/pkg/hyperref).

       papersize
           The papersize special, which is an extension introduced by dvips, can be used to
           specify the widths and heights of the pages in the DVI file. It affects the page it
           appears on as well as all following pages until another papersize special is found. If
           there is more than one papersize special present on a page, dvisvgm applies the last
           one. However, in order to stay compatible with previous versions of dvisvgm that did
           not evaluate these specials, their processing must be explicitly enabled by adding
           option --bbox=papersize on the command-line. Otherwise, dvisvgm ignores them and
           computes tight bounding boxes.

       pdf
           pdfTeX and dvipdfmx introduced several special commands related to the generation of
           PDF files. Currently, only pdf:mapfile, pdf:mapline, pdf:pagesize, and PDF hyperlink
           specials are supported by dvisvgm. The latter are the PDF pendants to the HTML
           HyperTeX specials generated by the hyperref package in PDF mode.

           pdf:pagesize is similar to the papersize special (see above) which specifies the size
           of the current and all following pages. In order to actually apply the extents to the
           generated SVG files, option --bbox=papersize must be given.

           pdf:mapfile and pdf:mapline allow for modifying the font map tree while processing the
           DVI file. They are used by CTeX, for example. dvisvgm supports both, the dvips and
           dvipdfm font map format. For further information on the command syntax and semantics,
           see the documentation of \pdfmapfile in the pdfTeX user manual
           (https://ctan.org/pkg/pdftex).

       ps
           The famous DVI driver dvips (https://www.tug.org/texinfohtml/dvips.html) introduced
           its own set of specials in order to embed PostScript code into DVI files, which
           greatly improves the capabilities of DVI documents. One aim of dvisvgm is to
           completely evaluate all PostScript fragments and to convert as many of them as
           possible to SVG. In contrast to dvips, dvisvgm uses floating point arithmetics to
           compute the precise position of each graphic element, i.e. it doesn’t round the
           coordinates. Therefore, the relative locations of the graphic elements may slightly
           differ from those computed by dvips.

           Since PostScript is a rather complex language, dvisvgm does not implement its own
           PostScript interpreter but relies on Ghostscript (https://ghostscript.com) instead. If
           the Ghostscript library was not linked to the dvisvgm binary, it is looked up and
           loaded dynamically during runtime. In this case, dvisvgm looks for libgs.so.X on
           Unix-like systems (supported ABI versions: 7,8,9), for libgs.X.dylib on macOS, and for
           gsdll32.dll or gsdll64.dll on Windows. You can override the default file names with
           environment variable LIBGS or the command-line option --libgs. The library must be
           reachable through the ld search path (*nix) or the PATH environment variable
           (Windows). Alternatively, the absolute file path can be specified. If the library
           cannot be found, dvisvgm disables the processing of PostScript specials and prints a
           warning message. Use option --list-specials to check whether PostScript support is
           available, i.e. entry ps is present.

           The PostScript handler also recognizes and evaluates bounding box data generated by
           the preview package (https://ctan.org/pkg/preview) with option tightpage. If such data
           is present in the DVI file and if dvisvgm is called with option --bbox=preview,
           dvisvgm sets the width and total height of the SVG file to the values derived from the
           preview data. Additionally, it prints a message showing the width, height, and depth
           of the box in TeX point units to the console. Especially, the depth value can be read
           by a post-processor to vertically align the SVG graphics with the baseline of
           surrounding text in HTML or XSL-FO documents, for example. Please note that SVG
           bounding boxes are defined by a width and (total) height. In contrast to TeX, SVG
           provides no means to differentiate between height and depth, i.e. the vertical extents
           above and below the baseline, respectively. Therefore, it is generally not possible to
           retrieve the depth value from the SVG file itself.

           If you call dvisvgm with option --bbox=min (the default) and preview data is present
           in the DVI file, dvisvgm doesn’t apply the preview extents but computes a bounding box
           that tightly encloses the page contents. The height, depth and width values written to
           console are adapted accordingly.

       tpic
           The TPIC special set defines instructions for drawing simple geometric objects. Some
           LaTeX packages, like eepic and tplot, use these specials to describe graphics.

EXAMPLES

       dvisvgm file
           Converts the first page of file.dvi to file.svg.

       dvisvgm -p1-5 file
           Converts the first five pages of file.dvi to file-1.svg,...,file-5.svg.

       dvisvgm -p1- file
           Converts all pages of file.dvi to separate SVG files.

       dvisvgm -p1,3 -O file
           Converts the first and third page of file.dvi to optimized SVG files.

       dvisvgm - < file.dvi
           Converts the first page of file.dvi to stdin.svg where the contents of file.dvi is
           read from stdin.

       dvisvgm -z file
           Converts the first page of file.dvi to file.svgz with default compression level 9.

       dvisvgm -p5 -z3 -ba4-l -o newfile file
           Converts the fifth page of file.dvi to newfile.svgz with compression level 3. The
           bounding box is set to DIN/ISO A4 in landscape format.

       dvisvgm --transform="R20,w/3,2h/5 T1cm,1cm S2,3" file
           Converts the first page of file.dvi to file.svg where three transformations are
           applied.

ENVIRONMENT

       dvisvgm uses the kpathsea library for locating the files that it opens. Hence, the
       environment variables described in the library’s documentation influence the converter.

       If dvisvgm was linked without the Ghostscript library, and if PostScript support has not
       been disabled, the shared Ghostscript library is looked up during runtime via dlopen().
       The environment variable LIBGS can be used to specify path and file name of the library.

       The pre-compiled Windows versions of dvisvgm require a working installation of MiKTeX 2.9
       or above. dvisvgm does not work together with the portable edition of MiKTeX because it
       relies on MiKTeX’s COM interface that is only accessible in a local installation. To
       enable the evaluation of PostScript specials, the original Ghostscript DLL gsdll32.dll
       must be present and reachable through the search path. 64-bit Windows builds require the
       64-bit Ghostscript DLL gsdll64.dll. Both DLLs come with the corresponding Ghostscript
       installers available from https://ghostscript.com.

       The environment variable DVISVGM_COLORS specifies the colors used to highlight various
       parts of dvisvgm’s message output. It is only evaluated if option --color is given. The
       value of DVISVGM_COLORS is a list of colon-separated entries of the form gg=BF, where gg
       denotes one of the color group indicators listed below, and BF are two hexadecimal digits
       specifying the background (first digit) and foreground/text color (second digit). The
       color values are defined as follows: 0=black, 1=red, 2=green, 3=yellow, 4=blue, 5=magenta,
       6=cyan, 7=gray, 8=bright red, 9=bright green, A=bright yellow, B=bright blue, C=bright
       magenta, D=bright cyan, E=bright gray, F=white. Depending on the terminal, the colors may
       differ. Rather than changing both the text and background color, it’s also possible to
       change only one of them: An asterisk (*) in place of a hexadecimal digit indicates the
       default text or background color of the terminal.

       All malformed entries in the list are silently ignored.

       er   error messages

       wn   warning messages

       pn   messages about page numbers

       ps   page size messages

       fw   information about the files written

       sm   state messages

       tr   messages of the glyph tracer

       pi   progress indicator

       Example: er=01:pi=*5 sets the colors of error messages (er) to red (1) on black (0), and
       those of progress indicators (pi) to cyan (5) on default background (*).

       Variable DVISVGM_PDF_PROC allows you to select the desired PDF processor. dvisvgm requires
       either Ghostscript (version < 10.01.0) or mutool to process PDF files. IF DVISVGM_PDF_PROC
       is not set, dvisvgm tries to detect the available processors. See option --pdf for further
       information. To select a specific PDF processor, you can set DVISVGM_PDF_PROC to gs or
       mutool which forces the use of Ghostscript and mutool respectively.

FILES

       The location of the following files is determined by the kpathsea library. To check the
       actual kpathsea configuration you can use the kpsewhich utility.

       *.enc   Font encoding files

       *.fgd   Font glyph data files (cache files created by dvisvgm)

       *.map   Font map files

       *.mf    Metafont input files

       *.pfb   PostScript Type 1 font files

       *.pro   PostScript header/prologue files

       *.tfm   TeX font metric files

       *.ttf   TrueType font files

       *.vf    Virtual font files

SEE ALSO

       tex(1), mf(1), mktexmf(1), grodvi(1), potrace(1), and the kpathsea library info
       documentation.

RESOURCES

       Project home page
           https://dvisvgm.de

       Code repository
           https://github.com/mgieseki/dvisvgm

BUGS

       Please report bugs using the bug tracker at GitHub
       (https://github.com/mgieseki/dvisvgm/issues).

AUTHOR

       Written by Martin Gieseking <martin.gieseking@uos.de>

COPYING

       Copyright © 2005-2024 Martin Gieseking. Free use of this software is granted under the
       terms of the GNU General Public License (GPL) version 3 or, (at your option) any later
       version.