Provided by: librsvg2-bin_2.59.2+dfsg-1_amd64 bug

NAME

       rsvg-convert - Render SVG documents to PNG images, or convert them to PDF or PS.

SYNOPSIS

       Convert an SVG to PNG at its "natural size" and write it to standard output:
          rsvg-convert input.svg > output.png

       Specify an output filename; the input filename must be the last argument:
          rsvg-convert --output=output.png input.svg

       Configure  dots-per-inch  (DPI)  for SVGs that have physical units, as in <svg width="5cm"
       height="3cm"> - the default is 96 DPI:
          rsvg-convert --dpi-x=300 --dpi-y=300 input.svg > output.png

       Render an SVG at a specific pixel size, scaled proportionally:
          rsvg-convert --width=1024 --height=768 --keep-aspect-ratio input.svg > output.png

DESCRIPTION

       rsvg-convert renders SVG documents into PNG raster images, or converts them to PDF  or  PS
       as  vector  objects.  By  default rsvg-convert will render an SVG document to a raster PNG
       image and write it to standard output:
          rsvg-convert input.svg > output.png

       To select another format, use the --format option:
          rsvg-convert --format=pdf input.svg > output.pdf

       You can use rsvg-convert as part of a pipeline; without an argument for the input filename
       it will read the document from standard input:
          cat input.svg | rsvg-convert > output.png

   SPECIFYING THE RENDERED SIZE
       You can use the --width and --height options to specify the size of the output image. Most
       of the time you should specify --keep-aspect-ratio to scale the image proportionally;  for
       compatibility with old versions this is not the default.
          rsvg-convert --width=100 --height=200 --keep-aspect-ratio input.svg > output.png

       You  can  also  specify  dimensions  as  CSS  lengths, for example 10px or 8.5in. The unit
       specifiers supported are as follows:

                                  ┌───┬──────────────────────────────────┐
                                  │px │ pixels (the unit  specifier  can │
                                  │   │ be omitted)                      │
                                  ├───┼──────────────────────────────────┤
                                  │in │ inches                           │
                                  ├───┼──────────────────────────────────┤
                                  │cm │ centimeters                      │
                                  ├───┼──────────────────────────────────┤
                                  │mm │ millimeters                      │
                                  ├───┼──────────────────────────────────┤
                                  │pt │ points, 1/72 inch                │
                                  ├───┼──────────────────────────────────┤
                                  │pc │ picas, 1/6 inch                  │
                                  └───┴──────────────────────────────────┘
       The following will create a 600*900 pixel PNG, or 2*3 inches at 300 dots-per-inch:
          rsvg-convert   --width=2in  --height=3in  --keep-aspect-ratio  --dpi-x=300  --dpi-y=300
          input.svg > output.png

       This will scale an SVG document to fit in an A4 page and convert it to PDF:
          rsvg-convert --format=pdf --width=210mm --height=297mm --keep-aspect-ratio input.svg  >
          output.pdf

   SPECIFYING A PAGE SIZE
       By  default  the  size  of the output comes from the rendered size, which can be specified
       with the --width and --height options, but you can specify a page  size  independently  of
       the  rendered  size with --page-width and --page-height, together with --top and --left to
       control the position of the rendered image within the page.  In short:

       • --page-width and --page-height together - set the page size.

       • --top and --left - set the margins.

       • --width and --height - set the rendered size.

       This will create a PDF with a landscape A4 page, by scaling an SVG document to  10*10  cm,
       and  placing  it with its top-left corner 5 cm away from the top and 8 cm from the left of
       the page:
          rsvg-convert   --format=pdf   --page-width=297mm    --page-height=210mm    --width=10cm
          --height=10cm --keep-aspect-ratio --top=5cm --left=8cm input.svg > output.pdf

   SPECIFYING A SCALE FACTOR INSTEAD OF A RENDERED SIZE
       The  --zoom  option  lets  you  scale the natural size of an SVG document. For example, if
       input.svg is a document with a declared size of 100*200 pixels, then the following command
       will render it at 250*500 pixels (zoom 2.5):
          rsvg-convert --zoom=2.5 input.svg > output.png

       You  can  limit  the  maximum  scaled  size by specifying the --width and --height options
       together with --zoom.  Here, the image will be scaled 10x, but limited to 1000*1000 pixels
       at the most:
          rsvg-convert --zoom=10 --width=1000 --height=1000 input.svg > output.png

       If  you  need  different scale factors for the horizontal and vertical dimensions, use the
       --x-zoom and --y-zoom options instead of --zoom.

   CREATING A MULTI-PAGE DOCUMENT
       The "pdf", "ps", and "eps" output formats support multiple pages. These can be created  by
       combining multiple input SVG files. For example, this PDF file will have three pages:
          rsvg-convert --format=pdf page1.svg page2.svg page3.svg > out.pdf

       The  size  of  each  page will be computed, separately, as described in the DEFAULT OUTPUT
       SIZE section. This may result in a PDF being produced with differently-sized pages. If you
       need  to  produce  a PDF with all pages set to exactly the same size, use the --page-width
       and --page-height options.

       For example, the following command creates a three-page PDF out of  three  SVG  documents.
       All the pages are portrait US Letter, and each SVG is scaled to fit so that there is a 1in
       margin around each page (hence the width of 6.5in and  height  of  9in  for  the  rendered
       size).
          rsvg-convert    --format=pdf    --page-width=8.5in   --page-height=11in   --width=6.5in
          --height=9in --keep-aspect-ratio --top=1in --left=1in pg1.svg pg2.svg pg3.svg > out.pdf

   CONVERSION OF PIXELS BASED ON THE DOTS-PER-INCH
       rsvg-convert uses the --dpi-x and --dpi-y options to configure the dots-per-inch (DPI)  by
       which  pixels  will  be  converted  to/from physical units like inches or centimeters. The
       default for both options is 96 DPI.

       Consider this example SVG, which is nominally declared to be 2*3 inches in size:

          <svg xmlns="http://www.w3.org/2000/svg" width="2in" height="3in">
            <!-- graphical objects here -->
          </svg>

       The following commands create PNGs of different sizes for the example SVG above:
          rsvg-convert two-by-three.svg > output.png #### creates a 192*288 pixel PNG

          rsvg-convert --dpi-x=300 --dpi-y=300  two-by-three.svg  >  output.png  ####  creates  a
          600*900 pixel PNG

       Note  that  the  final  pixel  dimensions  are  rounded  up to the nearest pixel, to avoid
       clipping off the right/bottom edges. In the following example, rsvg-convert will  generate
       a PNG 300x300 pixels in size:
          rsvg-convert  --width=299.5  --height=299.4 input.svg > output.png #### outputs 300x300
          pixel PNG with a fractionally-scaled image

       If you specify dimensions in physical units, they will be multiplied by the  dots-per-inch
       (DPI)  value to obtain dimensions in pixels. For example, this will generate a 96x96 pixel
       PNG, since it is 1x1 inch at the default 96 DPI:
          rsvg-convert --width=1in --height=1in input.svg > output.png #### outputs  96x96  pixel
          PNG

       Correspondingly, this will generate a 300x300 pixel PNG, since it is 1x1 inch at 300 DPI:
          rsvg-convert  --width=1in  --height=1in  --dpi-x=300 --dpi-y=300 input.svg > output.png
          #### outputs 300x300 pixel PNG

   DEFAULT OUTPUT SIZE
       If you do not specify --width or --height options for the output size,  rsvg-convert  will
       figure out a "natural size" for the SVG as follows:

       • SVG with width and height in pixel units (px): <svg width="96px" height="192px"> For PNG
         output, those same dimensions in pixels are used. For PDF/PS/EPS,  that  pixel  size  is
         converted  to  physical  units  based  on  the  DPI  value  (see the --dpi-x and --dpi-y
         options),

       • SVG with width and height in physical units:  <svg  width="1in"  height="2in">  For  PNG
         output,  the width and height attributes get converted to pixels, based on the DPI value
         (see the --dpi-x and --dpi-y  options).  For  PDF/PS/EPS  output,  the  width/height  in
         physical  units define the size of the PDF unless you specify options for the page size;
         see SPECIFYING A PAGE SIZE above.

       • SVG with viewBox only: <svg viewBox="0 0 20 30"> The size of the viewBox attribute  gets
         used for the pixel size of the image as in the first case above.

       • SVG  with  width and height in percentages: <svg width="100%" height="100%" viewBox="0 0
         20 30"> Percentages are meaningless unless you specify a viewport size with the  --width
         and  --height  options.  In  their  absence,  rsvg-convert will just use the size of the
         viewBox for the pixel size, as described above.

       • SVG with no width, height, or viewBox: rsvg-convert will  measure  the  extents  of  all
         graphical objects in the SVG document and render them at 1:1 scale (1 pixel for each CSS
         px unit). It is strongly recommended that you give SVG documents an explicit  size  with
         the width, height, or viewBox attributes.

   BACKGROUND COLOR
       You  can  use the --background-color option (-b for short) to specify the background color
       that will appear in parts of the image that would otherwise be  transparent.  This  option
       accepts  the  same syntax as the CSS color property, so you can use #rrggbb syntax, or CSS
       named colors like white, or rgba().
          rsvg-convert --background-color=white input.svg > output.png #### opaque white
          rsvg-convert -b '#ff000080' input.svg > output.png #### translucent  red  -  use  shell
          quotes so the # is not interpreted as a comment

   SELECTING A LANGUAGE FOR MULTI-LANGUAGE SVG
       An  SVG  document  can  use  the  <switch>  element  and  children with the systemLanguage
       attribute to provide different content depending on the user's language. For example:

          <svg xmlns="http://www.w3.org/2000/svg" width="200" height="100">
            <rect width="200" height="100" fill="white"/>
            <g transform="translate(30, 30)" font-size="20">
              <switch allowReorder="yes">
                <text systemLanguage="es">Español</text>
                <text systemLanguage="de">Deutsch</text>
                <text systemLanguage="fr">Français</text>
                <text>English fallback</text>
              </switch>
            </g>
          </svg>

       You can use the --accept-language option to select which language to use  when  rendering.
       This  option  accepts  strings  formatted  like an HTTP Accept-Language header, which is a
       comma-separated list of BCP47 language tags:  <https://www.rfc-editor.org/info/bcp47>
          rsvg-convert  --accept-language=es-MX  input.svg  >  output.png  ####  selects  Mexican
          Spanish; renders "Español".

   USER STYLESHEET
       You can include an extra CSS stylesheet to be used when rendering an SVG document with the
       --stylesheet option. The stylesheet will have the CSS user origin, while  styles  declared
       in the SVG document will have the CSS author origin.
          rsvg-convert --stylesheet=extra-styles.css input.svg > output.png

       Please  note  that  per the cascading rules of CSS, a user stylesheet does not necessarily
       override the styles defined in an SVG document.  To override them reliably,  you  need  to
       set your extra styles to !important.

       According           to          the          CSS          Cascading          specification
       (https://www.w3.org/TR/css-cascade-4/#cascade-sort), style declarations have the following
       precedence.   Declarations  from  origins  later  in  the  list win over declarations from
       earlier origins:

       • Normal user agent declarations (librsvg's own stylesheets).

       • Normal user declarations (from your user stylesheet).

       • Normal author declarations (from the SVG document).

       • !important author declarations (from the SVG document).

       • !important user declarations (from your user stylesheet).

       • !important user agent declarations (librsvg's own stylesheets).

       After that, the CSS specificity and order of appearance of  declarations  get  taken  into
       account.

       Consider   the  following  input.svg;  notice  how  the  rectangle  has  fill="red"  as  a
       presentation attribute, and a recolorable class:

          <svg xmlns="http://www.w3.org/2000/svg" width="100" height="100">
            <rect width="200" height="100" fill="white"/>

            <rect class="recolorable" x="10" y="10" width="50" height="50" fill="red"/>

            <text x="10" y="80" font-size="20" fill="red">Hello</text>
          </svg>

       And this is extra-styles.css:

          .recolorable { fill: blue !important; }

          text { fill: green !important; }

       Then the PNG created by the command above will have these elements:

       • A blue square instead of a red one, because of the  selector  for  the  the  recolorable
         class.   The  fill:  blue  !important; declaration takes precendence over the fill="red"
         presentation attribute.

       • Text in green, since its fill="red" gets overriden with fill: green !important.

OPTIONS

   GENERAL OPTIONS
       -f format, --format=[png, pdf, pdf1.4, pdf1.5, pdf1.6. pdf1.7, ps, eps, svg]
              Output format for the rendered document. Default is  png.   See  the  section  "PDF
              VERSIONS" for more detail on what each one allows.

       -o filename, --output filename
              Specify the output filename. If unspecified, outputs to standard output.

       -v, --version
              Display what version of rsvg-convert you are running.

       --help Display a summary of usage and options.

   SIZE AND POSITION
       In   the   following,  <length>  values  must  be  specified  with  CSS  <length>  syntax:
       <https://developer.mozilla.org/en-US/docs/Web/CSS/length> .  For example, 640px or 25cm.

       --page-width <length> --page-height <length>
              Page size of the output document; both options must be used together.  The  default
              is to use the image's width and height as modified by the options below.

       --top <length>
              Distance between top edge of the page and the rendered image. Default is 0.

       --left <length>
              Distance between left edge of the page and the rendered image.  Default is 0.

       -w <length>, --width <length>
              Width of the rendered image. If unspecified, the natural width of the image is used
              as the default. See the section "SPECIFYING DIMENSIONS" above for details.

       -h <length>, --height <length>
              Height of the rendered image. If unspecified, the natural height of  the  image  is
              used as the default. See the section "SPECIFYING DIMENSIONS" above for details.

       -a, --keep-aspect-ratio
              Specify  that  the  aspect  ratio  is  to  be  preserved,  i.e. the image is scaled
              proportionally to fit in the --width and --height. If not specified,  aspect  ratio
              will not be preserved.

       -d number, --dpi-x number
              Set the X resolution of the image in pixels per inch. Default is 96 DPI.

       -p number, --dpi-y number
              Set the Y resolution of the image in pixels per inch. Default is 96 DPI.

       -x number, --x-zoom number
              Horizontal scaling factor. Default is 1.0.

       -y number, --y-zoom number
              Vertical factor factor. Default is 1.0.

       -z number, --zoom number
              Horizontal and vertical scaling factor. Default is 1.0.

   CONTROLLING THE RENDERED APPEARANCE
       -b <color>, --background-color [black, white, #abccee, #aaa...]
              Specify  the  background  color.  If unspecified, none is used as the default; this
              will create transparent PNGs, or PDF/PS/EPS  without  a  special  background.   The
              <color>      must      be      specified      in      CSS      <color>      syntax:
              <https://developer.mozilla.org/en-US/docs/Web/CSS/color_value>  .    For   example,
              black, #ff0000, rgba(0.0, 1.0, 0.0, 1.0).

       -s filename.css, --stylesheet filename.css
              Filename of a custom CSS stylesheet.

       -l language-tag, --accept-language [es-MX,fr,en]
              Specify which languages will be used for SVG documents with multiple languages. The
              string is formatted like an HTTP Accept-Language header, which is a comma-separated
              list of BCP47 language tags:
               <https://www.rfc-editor.org/info/bcp47>  .  The  default  is  to  use the language
              specified by environment variables; see the section "ENVIRONMENT VARIABLES" below.

   OPTIONS SPECIFIC TO PDF/PS/EPS OUTPUT
       --keep-image-data
              For SVG documents  that  reference  PNG  or  JPEG  images,  include  the  original,
              compressed  images  in the final output, rather than uncompressed RGB data. This is
              the default behavior for PDF and (E)PS output.

       --no-keep-image-data
              Do not include the original, compressed images but instead embed  uncompressed  RGB
              date  in PDF or (E)PS output. This will most likely result in larger documents that
              are slower to read.

   MISCELLANEOUS
       -i object-id, --export-id object-id
              Allows to specify an SVG object that  should  be  exported  based  on  its  XML  id
              attribute. If not specified, all objects will be exported.

       -u, --unlimited
              The XML parser has some guards designed to mitigate large CPU or memory consumption
              in the face of malicious documents. It may also refuse to resolve data:  URIs  used
              to  embed  image  data  in  SVG documents. If you are running into such issues when
              converting a SVG, this option allows to turn off these guards.

       --testing
              For developers only: render images for librsvg's test suite.

       --completion shell-name
              Generate a script for a shell's Tab completion.  You can use  bash,  elvish,  fish,
              powershell,  and zsh for the shell's name.  Rsvg-convert will then write a suitable
              script to standard output.

ENVIRONMENT VARIABLES

       SOURCE_DATE_EPOCH
              If the selected output format is PDF, this variable can  be  used  to  control  the
              CreationDate  in  the  PDF  file.  This  is  useful  for  reproducible  output. The
              environment variable must be set to  a  decimal  number  corresponding  to  a  UNIX
              timestamp,  defined  as the number of seconds, excluding leap seconds, since 01 Jan
              1970 00:00:00 UTC. The specification for this can be found at
               <https://reproducible-builds.org/specs/source-date-epoch/>

       System language
              Unless the --accept-language option  is  specified,  the  default  is  to  use  the
              system's  environment  to  detect  the user's preferred language. This consults the
              environment variables LANGUAGE, LC_ALL, LC_MESSAGES, and LANG.

PDF VERSIONS

       The --format=pdf option makes rsvg-convert output  the  latest  version  of  PDF  that  it
       supports.  Normally this is the right thing to do, except when you have tools that consume
       the resulting PDFs but only support certain versions.

       For example, LaTeX tools like pdflatex may issue a warning if you try  to  include  a  PDF
       image that uses a newer version than the surrounding document, similar to
          PDF inclusion: found PDF version <1.7> but at most version <1.5> allowed

       In  this  case,  you  may  need  to  restrict  the PDF version that rsvg-convert produces.
       Instead of --format=pdf, you can use the following:

       --format=pdf1.4
              Does not use PDF object streams; files  may  be  bigger  as  they  allow  for  less
              compression.

       --format=pdf1.5
              Allows creating PDFs where text can be selected and searched.

       --format=pdf1.6
              No special behavior.

       --format=pdf1.7
              Allows including UTF-8 filenames in link objects reliably.

       If you are using LaTeX tooling, you may want to research options like \pdfminorversion=6.

MORE INFORMATION

       Librsvg source repository and bug tracker:  <https://gitlab.gnome.org/GNOME/librsvg>

       Wiki project page:  <https://wiki.gnome.org/Projects/LibRsvg>

       SVG1.1 specification:  <http://www.w3.org/TR/SVG11/>

       SVG2 specification:  <http://www.w3.org/TR/SVG2>

       GNOME project page:  <http://www.gnome.org/>

                                                                                   RSVG-CONVERT()