Menu

Tree [c927e2] default tip /
 History

Read Only access


File Date Author Commit
 BCBMagick unknown
 Magick++ 2025-05-13 Bob Friesenhahn Bob Friesenhahn [6deb3c] Retreat from use of C'99 printf macros. Remove ...
 PerlMagick 2025-01-04 Bob Friesenhahn Bob Friesenhahn [f1e61f] Update copyright year and rotate ChangeLog
 TclMagick 2025-02-11 Bob Friesenhahn Bob Friesenhahn [608941] TclMagick/README: Autoconf/Automake seems to do...
 VisualMagick 4 days ago Bob Friesenhahn Bob Friesenhahn [d00098] coders/png.c WriteOnePNGImage(): Cache the outp...
 bzlib unknown
 coders 4 days ago Bob Friesenhahn Bob Friesenhahn [d00098] coders/png.c WriteOnePNGImage(): Cache the outp...
 config 6 days ago Bob Friesenhahn Bob Friesenhahn [be8e48] First pass at depending on a C'99 compliant bui...
 contrib unknown
 dcraw unknown
 design 2021-12-12 Bob Friesenhahn Bob Friesenhahn [0ff371] Merge changes for the 1.3.37 release.
 doc 2025-06-10 Bob Friesenhahn Bob Friesenhahn [d1c159] Document that adding '!' to the geometry specif...
 filters unknown
 fuzzing 2025-06-04 Bob Friesenhahn Bob Friesenhahn [0a4fdc] coders/wpg.c: Fix improper usage of MagickReall...
 hp2xx unknown
 iOS unknown
 images unknown
 jbig 2019-12-24 Bob Friesenhahn Bob Friesenhahn [6d6500] Merge changes for 1.3.34 release into GraphicsM...
 jp2 2023-08-05 Bob Friesenhahn Bob Friesenhahn [b69b1c] jasper/jas_types.h: Always provide the _PFX_PTR...
 jpeg 2024-02-18 Jaroslav Fojtik Jaroslav Fojtik [b82b1b] jpeg/* Update JPEG builtin library to 9f.
 lcms unknown
 libxml unknown
 licenses unknown
 locale 2025-06-13 Bob Friesenhahn Bob Friesenhahn [c66af3] magick/colorspace.c TransformRGBImage(): Valida...
 logo unknown
 m4 5 days ago Bob Friesenhahn Bob Friesenhahn [66ee6b] Build and documentation updates related to C'99...
 magick 4 days ago Bob Friesenhahn Bob Friesenhahn [c927e2] magick/attribute.c: Capture more EXIF tags, and...
 patches unknown
 png unknown
 profiles unknown
 ralcgm unknown
 scenes unknown
 scripts 2025-05-19 Bob Friesenhahn Bob Friesenhahn [a2b78a] scripts/format_c_api_doc.py: Fix regular expres...
 tests 2025-02-09 Bob Friesenhahn Bob Friesenhahn [9e6fb2] Visual Studio prior to 2015 does not support C'...
 tiff 2024-03-22 Bob Friesenhahn Bob Friesenhahn [8f02b3] Merge changes for the 1.3.43 release
 ttf unknown
 utilities 2025-06-10 Bob Friesenhahn Bob Friesenhahn [d1c159] Document that adding '!' to the geometry specif...
 wand 2025-05-13 Bob Friesenhahn Bob Friesenhahn [6deb3c] Retreat from use of C'99 printf macros. Remove ...
 webp 2023-08-20 Jaroslav Fojtik Jaroslav Fojtik [6ea7e0] MSVC2010 does not have stdbool.h nor inttypes.h
 win2k unknown
 wmf unknown
 www 4 days ago Bob Friesenhahn Bob Friesenhahn [c927e2] magick/attribute.c: Capture more EXIF tags, and...
 xlib unknown
 zlib 2024-06-23 Jaroslav Fojtik Jaroslav Fojtik [6d885d] zlib/contrib/minizip/unzip.c unzip.h Expose unz...
 .cvsignore unknown
 .gdbinit unknown
 .hgignore 2024-09-26 Bob Friesenhahn Bob Friesenhahn [21a6c1] m4, TclMagick/unix/m4: Update to libtool 2.5.3
 .hgtags 2025-01-14 Bob Friesenhahn Bob Friesenhahn [a131be] Added tag GraphicsMagick-1_3_42 for changeset 6...
 ChangeLog 4 days ago Bob Friesenhahn Bob Friesenhahn [c927e2] magick/attribute.c: Capture more EXIF tags, and...
 ChangeLog.2001 unknown
 ChangeLog.2002 unknown
 ChangeLog.2003 unknown
 ChangeLog.2004 unknown
 ChangeLog.2005 unknown
 ChangeLog.2006 unknown
 ChangeLog.2007 unknown
 ChangeLog.2008 2022-10-01 Bob Friesenhahn Bob Friesenhahn [dfd44d] Replaced rst2htmldeco.py with rst2html5.py as w...
 ChangeLog.2009 unknown
 ChangeLog.2010 unknown
 ChangeLog.2011 unknown
 ChangeLog.2012 2022-10-01 Bob Friesenhahn Bob Friesenhahn [dfd44d] Replaced rst2htmldeco.py with rst2html5.py as w...
 ChangeLog.2013 unknown
 ChangeLog.2014 unknown
 ChangeLog.2015 unknown
 ChangeLog.2016 unknown
 ChangeLog.2017 unknown
 ChangeLog.2018 unknown
 ChangeLog.2019 unknown
 ChangeLog.2020 unknown
 ChangeLog.2021 unknown
 ChangeLog.2022 2024-01-28 Bob Friesenhahn Bob Friesenhahn [034ad7] ChangeLog tidying and update the news.
 ChangeLog.2023 2024-01-28 Bob Friesenhahn Bob Friesenhahn [034ad7] ChangeLog tidying and update the news.
 ChangeLog.2024 2025-01-04 Bob Friesenhahn Bob Friesenhahn [f1e61f] Update copyright year and rotate ChangeLog
 Copyright.txt 2025-01-04 Bob Friesenhahn Bob Friesenhahn [f1e61f] Update copyright year and rotate ChangeLog
 GraphicsMagick.spec.in unknown
 LICENSE 2023-11-16 Bob Friesenhahn Bob Friesenhahn [1a7804] Updates due to switching from OSDN to foss.hept...
 Makefile.am 2025-06-12 Bob Friesenhahn Bob Friesenhahn [63f04e] Makefile.am: Add a 'coverity-build' target, whi...
 Makefile.in 5 days ago Bob Friesenhahn Bob Friesenhahn [66ee6b] Build and documentation updates related to C'99...
 NEWS.txt 6 days ago Bob Friesenhahn Bob Friesenhahn [68eebb] Update the news
 README.txt 2025-03-01 Bob Friesenhahn Bob Friesenhahn [9927dc] README.txt: Refresh README text.
 TODO.txt unknown
 acinclude.m4 unknown
 aclocal.m4 5 days ago Bob Friesenhahn Bob Friesenhahn [66ee6b] Build and documentation updates related to C'99...
 bootstrap unknown
 common.shi.in unknown
 configure 5 days ago Bob Friesenhahn Bob Friesenhahn [66ee6b] Build and documentation updates related to C'99...
 configure.ac 5 days ago Bob Friesenhahn Bob Friesenhahn [66ee6b] Build and documentation updates related to C'99...
 cscope.files 2024-10-24 Bob Friesenhahn Bob Friesenhahn [8c40f4] Magick++: Add InitializeMagickSentinel and upda...
 lndir.sh unknown
 mkinstalldirs unknown
 rungm.sh.in unknown
 version.sh 2024-08-27 Bob Friesenhahn Bob Friesenhahn [96f765] Merge changes for the 1.3.45 release
 winpath.sh unknown

Read Me

.. -*- mode: rst -*-
.. This text is in reStucturedText format, so it may look a bit odd.
.. See http://docutils.sourceforge.net/rst.html for details.

=========================
Installing GraphicsMagick
=========================

.. contents::
  :local:

Introduction
------------

GraphicsMagick provides a comprehensive collection of utilities,
programming interfaces, and GUIs, to support file format conversion,
image processing, and 2D vector rendering.

GraphicsMagick is originally based on ImageMagick from ImageMagick
Studio (which was originally written by John Cristy at Dupont), but
forking from it in late 2002, and becoming independent from it, while
retaining the MIT-style license. The goal of GraphicsMagick is to
provide the highest quality product possible while encouraging open
and active participation from all interested developers.  The
GraphicsMagick usage license is designed to allow it to be used for
any application, including proprietary or GPLed applications. Please
see the file `Copyright.txt <Copyright.html>`_ for the GraphicsMagick
licence.

Availability
------------

GraphicsMagick release files may be downloaded from SourceForge
at http://sourceforge.net/projects/graphicsmagick/files/.

GraphicsMagick is a continual work in progress. The very latest code
is available via the Mercurial distributed source control management
tool (https://www.mercurial-scm.org/). GraphicsMagick may be retrieved
from foss.heptapod.net or SourceForge via one of the following commands:

  hg clone https://foss.heptapod.net/graphicsmagick/graphicsmagick GM

  hg clone http://hg.code.sf.net/p/graphicsmagick/code/ GM

Mercurial provides a complete stand-alone repository which contains
the full history of the GraphicsMagick project.  You may use the
cloned repository for your own purposes related to GraphicsMagick
(e.g. manage local GraphicsMagick changes), and can easily pull
updates from the main repository whenever you like.

Documentation
-------------

  Open the file index.html in a web browser, or refer to the gm(1) manual
  page. Also read the GraphicsMagick frequently asked questions in the
  file `www/FAQ.html <FAQ.html>`_.

Installation
------------

  GraphicsMagick may be compiled from source code for virtually any
  modern Unix system (including Linux and MacOS X) and Microsoft Windows.
  Installation instructions may be found in the following files (or their
  HTML equivalents):

  * Unix / Linux / \*BSD / MacOS-X / Cygwin / MinGW:

    `Installation on Unix-like systems <INSTALL-unix.html>`_

  * Microsoft Windows (Via "setup" style installer or from source code):

    `Installation on Microsoft Windows <INSTALL-windows.html>`_

Add-On Libraries & Programs
---------------------------

To further enhance the capabilities of GraphicsMagick, you may want to
get these programs or libraries. Note that these packages are already
integrated into the GraphicsMagick Mercurial repository for use when
building under Microsoft Windows:

* GraphicsMagick requires the BZLIB library from

    http://www.sourceware.org/bzip2/

  to read and write BZip compressed MIFF images.

* GraphicsMagick requires 'ralcgm' from

    http://www.agocg.ac.uk/train/cgm/ralcgm.htm

  to read the Computer Graphics Metafile (CGM) image format. You also
  need Ghostscript and Ghostscript/URW Fonts (see below).

* GraphicsMagick requires 'dcraw' (version 8.95 or later) from

    https://www.dechifro.org/dcraw/

  to read raw images from digital cameras.  Dcraw is invoked
  automatically when used to read files using a common RAW file format
  extension.

* GraphicsMagick requires 'fig2dev' provided in the transfig package
  from

    http://mcj.sourceforge.net/

  to read the Fig image format. Ghostscript and Ghostscript/URW Fonts (see
  below) are also required.

* GraphicsMagick requires the FreeType software, version 2.0 or above,
  available as

    http://www.freetype.org/

  to annotate with TrueType, OpenType, and Postscript Type 1 fonts.

* GraphicsMagick requires Ghostscript software available from

    https://ghostscript.com/releases/index.html

  to read the Postscript or the Portable Document Format (PDF).

  Ghostscript Fonts (also known as "URW Standard postscript fonts
  (cyrillicized)") are available from

    https://sourceforge.net/projects/gs-fonts/

  Ghostscript has historically been observed to have severe security
  issues when reading untrusted Postscript files (does not apply to
  PDF).  Examples of these severe security issues are being tricked
  into reading or writing arbitrary files when executing in "-dSAFER"
  mode, which which is supposed to prevent such access.  Users of
  Ghostscript who may encounter untrusted Postscript files are
  recommended to assure that all security patches have been applied
  and it might be necessary to use the latest upstream release.

  Ghostscript is available for use under both free (GPL) and
  commercial licenses.  We are not lawyers so we can not provide
  advice as to when the commercial license from Artifex is required.
  Please make sure that you are aware of Ghostscript licencing and
  usage terms if you plan to use it in some sort of commercial
  situation.

  Ghostscript is used as an external program under Unix-like systems,
  but is used via its DLL in the Microsoft Windows Visual Studio
  build.

* GraphicsMagick requires hp2xx available from

     http://www.gnu.org/software/hp2xx/hp2xx.html

  to read the HP-GL image format. Note that HPGL is a plotter file
  format. HP printers usually accept PCL format rather than HPGL
  format.  Ghostscript (see above) is also required.

* GraphicsMagick requires the lcms library (2.0 or later) available
  from

     http://www.littlecms.com/

  to perform ICC CMS color management.

* GraphicsMagick requires Graphviz available from

     http://www.graphviz.org/

  to read Graphvis 'dot' digraph files (with extension dot).
  Ghostscript (see above) is also required.

* GraphicsMagick requires html2ps available from

     https://sourceforge.net/projects/html2ps/

  to rasterize HTML files.  Ghostscript (see above) is also required.

* GraphicsMagick requires the JBIG-Kit software available via
  HTTP from

     http://www.cl.cam.ac.uk/~mgk25/jbigkit/

  to read and write the JBIG image format.

* GraphicsMagick requires the WebP library version 0.1.99 (or later)
  available via HTTPS from

     https://developers.google.com/speed/webp/

  to read and write the WebP image format.

* GraphicsMagick requires the Independent JPEG Group's software
  available from

     http://www.ijg.org/

  or libjpeg-turbo available from

     https://libjpeg-turbo.org/ or https://github.com/libjpeg-turbo/libjpeg-turbo

  to read and write the JPEG v1 image format.  The 'turbo' releases
  are much faster than the IJG releases on certain targets (due to
  using assembly code and other optimizations), but lack the
  SmartScale JPEG extension introduced in IJG JPEG v8, and the
  lossless coding mode JPEG extension introduced in IJG JPEG v9 (which
  is not compatible with standard lossless JPEG!).

  GraphicsMagick supports 8-bit, 12-bit, and 16-bit JPEG, provided a
  JPEG library (e.g. libjpeg-turbo) which supports those depths.

* GraphicsMagick requires the JasPer Project's JasPer library from
  https://jasper-software.github.io/jasper/ to read and write the
  JPEG-2000 format.  Due to security concerns, using the latest
  version of JasPer is always recommended.  Note that modern JasPer
  requires C'11 (2011) language support.

* On Unix-type systems, Windows/MinGW, and Windows/Cygwin,
  GraphicsMagick requires libltdl from libtool in order to support
  building GraphicsMagick with dynamically loadable modules.  Libtool
  is available via anonymous FTP from

     ftp://ftp.gnu.org/pub/gnu/libtool/

* GraphicsMagick requires the MPEG utilities
  (`mpeg2vidcodec_v12.tar.gz`) from the MPEG Software Simulation Group
  in order to read or write the MPEG image format.

* GraphicsMagick requires the LIBPNG library, version 1.0 or above, from

     http://www.libpng.org/pub/png/pngcode.html

  to read or write the PNG, MNG, or JNG image formats.  LIBPNG depends
  upon the ZLIB library (see below).

* GraphicsMagick requires Sam Leffler's TIFF software available via
  HTTPS at

     https://libtiff.gitlab.io/libtiff/

  to read the TIFF image format. It in turn optionally requires the
  JBIG, JPEG, LERC, Deflate, LZMA, ZSTD, WebP, and ZLIB libraries.
  Libtiff 3.9.7 or later is required, but a recent release is always
  recommended.

* GraphicsMagick requires libzip available via HTTPS at

     https://libzip.org/

  in in order to read the ORA format.  It in turn optionally requires
  ZLIB, BZip2, LZMA (xz), ZSTD, and a crypto library (Common Crypto,
  GnuTLS, mbed TLS, OpenSSL, or Windows Cryptography).

* GraphicsMagick may optionally use the TRIO library from

     http://sourceforge.net/projects/ctrio/

  to substitute for the vsnprintf function when the operating system
  does not provide one. Older operating systems (e.g. Solaris 2.5) may
  not provide a vsnprintf function. If vsnprintf (or the TRIO
  replacement) is not used, then vsprintf is used instead, which
  decreases the security of GraphicsMagick due to possible buffer
  overrun exploits.  It is highly unlikely that TRIO is useful on any
  modern system.

* GraphicsMagick may optionally use the 'tcmalloc' library provided as
  part of Google gperftools available from

     https://github.com/gperftools/gperftools

  to provide enhanced versions of the standard memory allocation
  facilities.  Use of tcmalloc may improve performance for both
  single-threaded and multi-threaded programs.  Benchmarking under
  Linux shows a doubling of performance with tcmalloc over the default
  glibc malloc when images are repeatedly allocated, cleared, and
  de-allocated.

* GraphicsMagick may optionally use the umem memory allocation library
  which is included in Sun's Solaris operating system, and
  OpenSolaris/Illumos derivatives, to provide enhanced versions of the
  standard memory allocation facilities. Use of umem may improve
  performance for multi-threaded programs and provides access to
  debugging features that detect memory leaks, buffer overruns,
  multiple frees, use of uninitialized data, use of freed data, and
  many other common programming errors.

* GraphicsMagick requires libwmflite from libwmf 0.2.5 (or later) from

     http://sourceforge.net/projects/wvware/

  to render files in the Windows Meta File (WMF) metafile format
  (16-bit WMF files only, not 32-bit "EMF"). This is the format
  commonly used for Windows clipart (available on CD at your local
  computer or technical book store). WMF support requires the FreeType
  2 library in order to render TrueType, OpenType, and Postscript
  fonts.

  While GraphicsMagick uses the libwmflite (parser) component of the
  libwmf package which does not depend on any special libraries, the
  libwmf package as a whole depends on FreeType 2 and either the
  xmlsoft libxml, or expat libraries. Since GraphicsMagick already uses
  libxml (for reading SVG and to retrieve files via HTTP or FTP), it is
  recommended that the options '--without-expat --with-xml' be supplied
  to libwmf's configure script.  If the other features of libwmf are
  not needed, then the '--disable-heavy' option may be used to only
  build libwmflite.

  GraphicsMagick's WMF renderer provides some of the finest WMF
  rendering available due its use of antialiased drawing algorithms.
  You may select a background color or texture image to render on. For
  example, "-background '#ffffffff'" renders on a transparent
  background while "-texture plasma:fractal" renders on a fractal image.

   A free set of Microsoft Windows fonts may be retrieved from
   http://sourceforge.net/projects/corefonts/. Note that the license
   for these fonts requires that they be distributed in the original
   .exe form, but the Linux folks have found ways to deal with that on
   non-Windows systems.

* GraphicsMagick requires an X server for the 'display', 'animate', and
  'import' functions to work properly. Unix systems usually provide an X
  server as part of their standard installation. For MacOS-X, X11 is a
  system install time option.

  A free X server for Microsoft Windows is included as part of
  Cygwin and may be selected from the Cygwin installer. Cygwin is
  available from

     http://www.cygwin.com/

* GraphicsMagick requires libxml2 available from

     http://xmlsoft.org/

  to read the SVG image format and to retrieve files from over a
  network via FTP and HTTP.

* GraphicsMagick requires the liblzma library from XZ Utils available from

     https://www.tukaani.org/xz/

  to support TIFF with LZMA compression and future LZMA-compression
  features (yet to be developed).  The utilities from this package are
  also necessary in order to decompress GraphicsMagick packages
  distributed with ".xz" or ".lzma" extensions.

* GraphicsMagick requires the ZLIB library from

     http://www.zlib.net/

  to read or write the PNG or Zip compressed MIFF images.

* GraphicsMagick requires the Zstandard (Zstd) library from

    https://facebook.github.io/zstd/

      or

    https://github.com/facebook/zstd/releases

  to read or write Zstd compressed TIFF images.  In the future it is
  likely that other purposes will be found for Zstd.

* GraphicsMagick may require the deflate library to link with libtiff.

  Libtiff may optionally depend on the libdeflate library (from
  https://github.com/ebiggers/libdeflate).  Linking with this library
  may be necessary for builds where libtiff depends on libdeflate.

* GraphicsMagick requires the heif library from

    https://github.com/strukturag/libheif

    and the libde265 library from

    https://github.com/strukturag/libde265

  to read HEIF/h.265 files and HEIF/AVIF files. Libheif makes use of
  libde265 for h.265/HEVC decoding and libx265 for encoding.
  GraphicsMagick does not itself provide any h.265/HEVC algoriths and
  it does not currently support encoding.

  The HEVC codec is covered by a huge number of patents (the MPEG LA
  HEVC patent list is 164 pages long!).  While GraphicsMagick is
  unable to grant any patent usage rights to users or offer legal
  advice, HEVC patents are normally paid for "per device" and so it is
  possible and even likely that the user's modern "device" is already
  covered.  For example, users of Windows 10, Apple's OS-X, or popular
  video cards may already be entitled to use the HEVC codec since the
  vendor has already paid for it.  Some countries do not support
  software patents.  The user is responsible for assuring that some
  entity has paid to allow use of any applicable HEVC patents on their
  device, or that the patents do not apply in their country.

* GraphicsMagick requires the JPEG XL (JXL) library (release 0.7.0 or
  later) from https://github.com/libjxl/libjxl to read and write JPEG
  XL files.
Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.