1<?xml version="1.0" encoding="utf-8" ?>
2<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
3<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
4<head>
5<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
6<title>Magick++ API: Install Magick++</title>
7<link rel="stylesheet" href="http://nextgen.imagemagick.org/Magick++/magick.css" type="text/css" />
8</head>
9<body>
10<div class="doc-section">
11<h1 align="center">Installing Magick++</h1>
12<h3>General</h3>
13<p>In order to compile Magick++ you must have access to a standard C++ implementation. The author uses <a href="http://gcc.gnu.org/index.html">gcc 3.4 (GNU C++)</a> which is available under UNIX and under the <a href="http://www.cygwin.com/">Cygwin UNIX-emulation environment</a> for Windows. Standards compliant commercial C++ compilers should also work fine. Most modern C++ compilers for Microsoft Windows or the Mac should work (project files are provided for Microsoft Visual C++ 8.0).</p>
14<p>It was decided that Magick++ will be around for the long-haul, so its API definition depends on valuable C++ features which should be common in all current and future C++ compilers. The compiler must support the following C++ standard features:</p>
15<ul>
16<li>
17<p style="margin-bottom: 0cm">templates</p></li>
18<li>
19<p style="margin-bottom: 0cm">static constructors</p></li>
20<li>
21<p style="margin-bottom: 0cm">C++-style casts (e.g. static_cast)</p></li>
22<li>
23<p style="margin-bottom: 0cm">bool type</p></li>
24<li>
25<p style="margin-bottom: 0cm">string class (<tt>&lt;string&gt;</tt>)</p></li>
26<li>
27<p style="margin-bottom: 0cm">exceptions (<tt>&lt;exception&gt;</tt>)</p></li>
28<li>
29<p style="margin-bottom: 0cm">namespaces</p></li>
30<li>
31<p>Standard Template Library (STL) (e.g. <tt>&lt;list&gt;</tt>, <tt>&lt;vector&gt;</tt>)</p></li></ul>
32<p style="margin-bottom: 0cm">The author has personally verified that Magick++ compiles and runs using the following compiler/platform combinations:</p>
33<br />
34<p align="center" style="margin-bottom: 0cm"><b>Tested Configurations</b></p>
35<table width="100%" border="1" cellpadding="2" cellspacing="3">
36<tr>
37<td>
38<p align="center"><b>Operating System</b></p></td>
39<td>
40<p align="center"><b>Architecture</b></p></td>
41<td>
42<p align="center"><b>Compiler</b></p></td></tr>
43<tr>
44<td>
45<p><font size="2">SunOS 5.6, 5.7, 5.8 ("Solaris 2.6, 7, &amp; 8)</font></p></td>
46<td>
47<p><font size="2">SPARC</font></p></td>
48<td>
49<p><font size="2">GCC 3.0.4</font></p></td></tr>
50<tr>
51<td>
52<p><font size="2">SunOS 5.7 ("Solaris 7")</font></p></td>
53<td>
54<p><font size="2">SPARC</font></p></td>
55<td>
56<p><font size="2">Sun Workshop 5.0 C++</font></p></td></tr>
57<tr>
58<td>
59<p><font size="2">SunOS 5.8 ("Solaris 8")</font></p></td>
60<td>
61<p><font size="2">SPARC</font></p></td>
62<td>
63<p><font size="2">Sun WorkShop 6 update 2 C++ 5.3</font></p></td></tr>
64<tr>
65<td>
66<p><font size="2">FreeBSD 4.0</font></p></td>
67<td>
68<p><font size="2">Intel Pentium II</font></p></td>
69<td>
70<p><font size="2">GCC 2.95</font></p></td></tr>
71<tr>
72<td>
73<p><font size="2">Windows NT 4.0 SP6a</font></p></td>
74<td>
75<p><font size="2">Intel Pentium II</font></p></td>
76<td>
77<p><font size="2">Visual C++ 8.0 Standard Edition</font></p></td></tr>
78<tr>
79<td>
80<p><font size="2">Windows XP</font></p></td>
81<td>
82<p><font size="2">Intel Pentium IV</font></p></td>
83<td>
84<p><font size="2">Visual C++ 8.0 Standard Edition Service Pack 5</font></p></td></tr>
85<tr>
86<td>
87<p><font size="2">Windows '98 + <a href="http://www.cygwin.com/">Cygwin</a> 1.3.10</font></p></td>
88<td>
89<p><font size="2">Intel Pentium III</font></p></td>
90<td>
91<p><font size="2">GCC 2.95.3-5</font></p></td></tr>
92<tr>
93<td>
94<p><font size="2">Windows NT 4.0 SP6a</font></p></td>
95<td>
96<p><font size="2">Intel Pentium II</font></p></td>
97<td>
98<p><font size="2">GCC 2.95.3-5</font></p></td></tr>
99<tr>
100<td>
101<p><font size="2">Windows XP + <a href="http://www.cygwin.com/">Cygwin</a> 1.3.10</font></p></td>
102<td>
103<p><font size="2">Intel Pentium IV</font></p></td>
104<td>
105<p><font size="2">GCC 2.95.3-5</font></p></td></tr></table>
106<p style="margin-bottom: 0cm">Users of Magick++ have reported that the following configurations work with Magick++:</p>
107<br />
108<p align="center" style="margin-bottom: 0cm"><b>Other Known Working Configurations</b></p>
109<table width="100%" border="1" cellpadding="2" cellspacing="2">
110<tr>
111<td>
112<p align="center"><b>Operating System</b></p></td>
113<td>
114<p align="center"><b>Architecture</b></p></td>
115<td>
116<p align="center"><b>Compiler</b></p></td>
117<td>
118<p><b>Reported By</b></p></td></tr>
119<tr valign="top">
120<td>
121<p><font size="2">Red Hat Linux 8.0</font></p></td>
122<td>
123<p><font size="2">i386 &amp; alpha</font></p></td>
124<td>
125<p><font size="2">EGCS 1.1.2</font></p></td>
126<td>
127<p><font size="2">Dr. Alexander Zimmermann &lt;Alexander.Zimmermann@fmi.uni-passau.de&gt;</font></p></td></tr>
128<tr valign="top">
129<td>
130<p><font size="2">Red Hat Linux 7.0</font></p></td>
131<td>
132<p><font size="2">i386</font></p></td>
133<td>
134<p><font size="2">GCC 2.95.2</font></p></td>
135<td>
136<p><font size="2">Dr. Alexander Zimmermann &lt;Alexander.Zimmermann@fmi.uni-passau.de&gt;</font></p></td></tr>
137<tr valign="top">
138<td>
139<p><font size="2">Red Hat Linux 7.0</font></p></td>
140<td>
141<p><font size="2">i386</font></p></td>
142<td>
143<p><font size="2">GCC "2.96" snapshot</font></p></td>
144<td>
145<p><font size="2">???</font></p></td></tr>
146<tr>
147<td>
148<p><font size="2">Red Hat Linux 7.X</font></p></td>
149<td>
150<p><font size="2">i386 &amp; alpha</font></p></td>
151<td>
152<p><font size="2">GCC 3.0</font></p></td>
153<td>
154<p><font size="2">Dr. Alexander Zimmermann &lt;Alexander.Zimmermann@fmi.uni-passau.de&gt;</font></p></td></tr>
155<tr valign="top">
156<td>
157<p><font size="2">SGI IRIX 6.2, 6.5</font></p></td>
158<td>
159<p><font size="2">MIPS</font></p></td>
160<td>
161<p><font size="2">IRIX C++ 7.3.1.2m</font></p></td>
162<td>
163<p><font size="2">Albert Chin-A-Young &lt;china@thewrittenword.com&gt;</font></p></td></tr>
164<tr>
165<td>
166<p><font size="2">SunOS 5.5.1</font></p></td>
167<td>
168<p><font size="2">SPARC</font></p></td>
169<td>
170<p><font size="2">Sun WorkShop CC 5.0</font></p></td>
171<td>
172<p><font size="2">Albert Chin-A-Young &lt;china@thewrittenword.com&gt;</font></p></td></tr>
173<tr>
174<td>
175<p><font size="2">SunOS 5.6, 5.7, 5.8</font></p></td>
176<td>
177<p><font size="2">SPARC</font></p></td>
178<td>
179<p><font size="2">Sun Forte CC 5.3</font></p></td>
180<td>
181<p><font size="2">Albert Chin-A-Young &lt;china@thewrittenword.com&gt;</font></p></td></tr>
182<tr valign="top">
183<td>
184<p><font size="2">HP-UX 11.00</font></p></td>
185<td>
186<p><font size="2">PA-RISC</font></p></td>
187<td>
188<p><font size="2">HP-UX aCC A.03.30</font></p></td>
189<td>
190<p><font size="2">Albert Chin-A-Young &lt;china@thewrittenword.com&gt;</font></p></td></tr>
191<tr valign="top">
192<td>
193<p><font size="2">Mac OS 9</font></p></td>
194<td>
195<p><font size="2">PowerPC</font></p></td>
196<td>
197<p><font size="2">CodeWarrior Professional Release 6</font></p></td>
198<td>
199<p><font size="2">Leonard Rosenthol &lt;leonardr@digapp.com&gt;</font></p></td></tr>
200<tr>
201<td>
202<p><font size="2">Mac OS X 10.1 "Darwin"</font></p></td>
203<td>
204<p><font size="2">PowerPC</font></p></td>
205<td>
206<p><font size="2">GCC 2.95.2 (apple gcc -926)</font></p></td>
207<td>
208<p><font size="2">Cristy</font></p></td></tr></table>
209<p>Please let me know if you have successfully built and executed Magick++ using a different configuration so that I can add to the table of verified configurations.</p>
210<hr />
211<h3 align="center">Unix/Linux</h3>
212<h4>Building From Source</h4>
213<p>Magick++ is now built using the ImageMagick configure script and Makefiles. Please follow the installation instructions provided by its README.txt file. The following instructions pertain to the Magick++ specific configuration and build options.</p>
214<p>To install ImageMagick plus Magick++ under Unix, installation should be similar to</p>
215<p><tt>./configure [ --prefix=/prefix ]</tt><br />
216<tt>make</tt><br />
217<tt>make install</tt></p>
218<p>The library is currently named similar to 'libMagick++.a' (and/or libMagick++.so.5.0.39) and is installed under prefix/lib while the headers are installed with Magick++.h being installed in prefix/include and the remaining headers in prefix/include/Magick++.</p>
219<p>To influence the options the configure script chooses, you may specify 'make' option variables when running the configure script. For example, the command</p>
220<blockquote><tt>./configure CXX=CC CXXFLAGS=-O2 LIBS=-lposix</tt></blockquote>
221<p style="margin-bottom: 0cm"><br />
222specifies additional options to the configure script. The following table shows the available options.</p>
223<br />
224<p align="center" style="margin-bottom: 0cm">Environment Variables That Effect Configure</p>
225<table width="100%" border="1" cellpadding="2" cellspacing="3">
226<col width="40*" />
227<col width="216*" />
228<tr>
229<td width="16%">
230<p align="center"><b>Make Option Variable</b></p></td>
231<td width="84%">
232<p align="center"><b>Description</b></p></td></tr>
233<tr>
234<td width="16%">
235<p align="center">CXX</p></td>
236<td width="84%">
237<p>Name of C++ compiler (e.g. 'CC -Xa') to use compiler 'CC -Xa'</p></td></tr>
238<tr>
239<td width="16%">
240<p align="center">CXXFLAGS</p></td>
241<td width="84%">
242<p>Compiler flags (e.g. '-g -O2') to compile with</p></td></tr>
243<tr>
244<td width="16%">
245<p align="center">CPPFLAGS</p></td>
246<td width="84%">
247<p>Include paths (-I/somedir) to look for header files</p></td></tr>
248<tr>
249<td width="16%">
250<p align="center">LDFLAGS</p></td>
251<td width="84%">
252<p>Library paths (-L/somedir) to look for libraries. Systems that support the notion of a library run-path may additionally require -R/somedir or '-rpath /somedir' in order to find shared libraries at run time.</p></td></tr>
253<tr>
254<td width="16%">
255<p align="center">LIBS</p></td>
256<td width="84%">
257<p>Extra libraries (-lsomelib) required to link</p></td></tr></table>
258<h4>Installing Linux RPMs</h4>
259<p style="margin-bottom: 0cm">Linux RPMs of ImageMagick and Magick++ can be downloaded from <a href="ftp://ftp.imagemagick.org/pub/ImageMagick/linux//">ftp://ftp.imagemagick.org/pub/ImageMagick/linux/</a>.</p>
260<hr />
261<h3 align="center">Windows '9X, NT, 2003, 2008, XP, &amp; Windows 7</h3>
262<h4>Visual C++</h4>
263<p>Windows NT through Windows Vista are supported by the ImageMagick source package for NT available in the 'win2k' subdirectory of the ImageMagick ftp site (and mirrors). The ImageMagick source package for NT provides sources to ImageMagick, Magick++, add-on libraries (e.g. JPEG), and a ready-made Visual C++ 8.0 build environment. Please read the configuration and build instructions in README.txt (under the heading "Windows Win2K/XP VISUAL C++ 8.0 COMPILATION") in order to build Magick++.</p>
264<h4>Cygwin &amp; GCC</h4>
265<p>It is possible to build both ImageMagick and Magick++ under the Cygwin Unix-emulation environment for Windows NT. Obtain and install Cgywin from <a href="http://www.cygwin.com/">http://www.cygwin.com/</a> . An X11R6 environment for Cygwin is available from <a href="http://www.cygwin.com/xfree/">http://www.cygwin.com/xfree/</a> .To build using Cygwin and GCC, follow the instructions for building under Unix.</p>
266</div>
267</body>
268</html>
269