This repository has been archived on 2023-11-11. You can view files and clone it, but cannot push or open issues or pull requests.
libpng/INSTALL

227 lines
9.1 KiB
Plaintext
Raw Normal View History

1998-03-07 06:06:55 -06:00
2007-01-31 07:22:52 -06:00
Installing libpng version 1.2.16 - January 31, 2007
1998-03-07 06:06:55 -06:00
2006-02-22 09:19:25 -06:00
On Unix/Linux and similar systems, you can simply type
2006-12-07 19:21:29 -06:00
./configure [--prefix=/path]
2006-02-22 09:19:25 -06:00
make check
make install
and ignore the rest of this document.
2006-06-14 13:59:43 -05:00
If configure does not work on your system and you have a reasonably
up-to-date set of tools, running ./autogen.sh before running ./configure
may fix the problem. You can also run the individual commands in
autogen.sh with the --force option, if supported by your version of
the tools. If you run 'libtoolize --force', though, this will replace
the distributed, patched, version of ltmain.sh with an unpatched version
and your shared library builds may fail to produce libraries with the
correct version numbers.
Instead, you can use one of the custom-built makefiles in the
2006-02-22 09:19:25 -06:00
"scripts" directory
cp scripts/makefile.system makefile
make test
make install
Or you can use one of the "projects" in the "projects" directory.
2006-12-07 19:21:29 -06:00
If you want to use "cmake" (see www.cmake.org), copy CMakeLists.txt
from the "scripts" directory to this directory and type
2006-12-21 09:04:13 -06:00
cmake . [-DPNG_MMX=YES] -DCMAKE_INSTALL_PREFIX=/path
2006-12-07 19:21:29 -06:00
make
make install
2006-02-22 09:19:25 -06:00
Before installing libpng, you must first install zlib, if it
is not already on your system. zlib can usually be found
wherever you got libpng. zlib can be placed in another directory,
at the same level as libpng.
If your system already has a preinstalled zlib you will still need
to have access to the zlib.h and zconf.h include files that
correspond to the version of zlib that's installed.
1998-03-07 06:06:55 -06:00
You can rename the directories that you downloaded (they
2007-01-31 07:22:52 -06:00
might be called "libpng-1.2.16" or "lpng109" and "zlib-1.2.1"
2006-02-20 22:09:05 -06:00
or "zlib121") so that you have directories called "zlib" and "libpng".
1998-03-07 06:06:55 -06:00
Your directory structure should look like this:
.. (the parent directory)
libpng (this directory)
INSTALL (this file)
README
*.h
*.c
1999-10-14 07:43:10 -05:00
contrib
gregbook
1999-10-23 08:39:18 -05:00
pngminus
pngsuite
2000-06-23 21:38:16 -05:00
visupng
2001-01-15 22:01:20 -06:00
projects
2001-05-07 14:52:45 -05:00
beos
2006-02-20 22:09:05 -06:00
c5builder (Borland)
visualc6 (msvc)
2001-06-23 08:03:17 -05:00
netware.txt
wince.txt
1998-03-07 06:06:55 -06:00
scripts
makefile.*
pngtest.png
etc.
zlib
README
*.h
*.c
contrib
etc.
2000-02-04 23:40:16 -06:00
If the line endings in the files look funny, you may wish to get the other
distribution of libpng. It is available in both tar.gz (UNIX style line
endings) and zip (DOS style line endings) formats.
2006-02-20 22:09:05 -06:00
If you are building libpng with MSVC, you can enter the
libpng projects\visualc6 directory and follow the instructions in
projects\visualc6\README.txt.
You can build libpng for WindowsCE by downloading and installing
the projects\wince directory as instructed in the projects\wince.txt file, and
2001-06-23 08:03:17 -05:00
then following the instructions in the README* files. Similarly, you can
2006-02-20 22:09:05 -06:00
build libpng for Netware or Beos as instructed in projects\netware.txt
or projects\beos.
2000-06-04 14:29:29 -05:00
2000-06-23 21:38:16 -05:00
Else enter the zlib directory and follow the instructions in zlib/README,
2006-02-22 09:19:25 -06:00
then come back here and run "configure" or choose the appropriate
makefile.sys in the scripts directory.
2000-06-23 21:38:16 -05:00
1998-03-07 06:06:55 -06:00
The files that are presently available in the scripts directory
include
2006-12-07 19:21:29 -06:00
CMakeLists.txt => "cmake" script
2000-03-21 05:13:06 -06:00
makefile.std => Generic UNIX makefile (cc, creates static libpng.a)
2006-02-20 22:09:05 -06:00
makefile.elf => Linux/ELF makefile symbol versioning,
2007-01-31 07:22:52 -06:00
gcc, creates libpng12.so.0.1.2.16)
2006-02-20 22:09:05 -06:00
makefile.linux => Linux/ELF makefile
2007-01-31 07:22:52 -06:00
(gcc, creates libpng12.so.0.1.2.16)
2006-02-20 22:09:05 -06:00
makefile.gcmmx => Linux/ELF makefile
2007-01-31 07:22:52 -06:00
(gcc, creates libpng12.so.0.1.2.16,
2000-03-21 05:13:06 -06:00
uses assembler code tuned for Intel MMX platform)
2006-12-21 09:04:13 -06:00
makefile.nommx => Linux/ELF makefile
2007-01-31 07:22:52 -06:00
(gcc, creates libpng12.so.0.1.2.16
2006-12-21 09:04:13 -06:00
does not use Intel MMX assembler code)
2000-03-21 05:13:06 -06:00
makefile.gcc => Generic makefile (gcc, creates static libpng.a)
1999-10-14 07:43:10 -05:00
makefile.knr => Archaic UNIX Makefile that converts files with
ansi2knr (Requires ansi2knr.c from
ftp://ftp.cs.wisc.edu/ghost)
2002-10-03 06:32:37 -05:00
makefile.aix => AIX/gcc makefile
2000-11-10 12:26:19 -06:00
makefile.cygwin => Cygwin/gcc makefile
2006-02-20 22:09:05 -06:00
makefile.darwin => Darwin makefile, can use on MacosX
1999-10-14 07:43:10 -05:00
makefile.dec => DEC Alpha UNIX makefile
2006-02-20 22:09:05 -06:00
makefile.freebsd => FreeBSD makefile
2001-05-07 14:52:45 -05:00
makefile.hpgcc => HPUX makefile using gcc
1999-10-14 07:43:10 -05:00
makefile.hpux => HPUX (10.20 and 11.00) makefile
2006-02-20 22:09:05 -06:00
makefile.hp64 => HPUX (10.20 and 11.00) makefile, 64-bit
2000-04-01 21:10:05 -06:00
makefile.ibmc => IBM C/C++ version 3.x for Win32 and OS/2 (static)
2000-05-16 06:17:36 -05:00
makefile.intel => Intel C/C++ version 4.0 and later
2000-04-01 21:10:05 -06:00
libpng.icc => Project file for IBM VisualAge/C++ version 4.0 or later
2002-04-15 09:25:51 -05:00
makefile.netbsd => NetBSD/cc makefile, uses PNGGCCRD, makes libpng.so.
2006-02-20 22:09:05 -06:00
makefile.ne12bsd => NetBSD/cc makefile, uses PNGGCCRD,
makes libpng12.so
2002-03-06 22:08:00 -06:00
makefile.openbsd => OpenBSD makefile
2000-03-21 05:13:06 -06:00
makefile.sgi => Silicon Graphics IRIX makefile (cc, creates static lib)
2006-02-20 22:09:05 -06:00
makefile.sggcc => Silicon Graphics (gcc,
2007-01-31 07:22:52 -06:00
creates libpng12.so.0.1.2.16)
1999-10-14 07:43:10 -05:00
makefile.sunos => Sun makefile
2006-02-20 22:09:05 -06:00
makefile.solaris => Solaris 2.X makefile (gcc,
2007-01-31 07:22:52 -06:00
creates libpng12.so.0.1.2.16)
2006-02-20 22:09:05 -06:00
makefile.so9 => Solaris 9 makefile (gcc,
2007-01-31 07:22:52 -06:00
creates libpng12.so.0.1.2.16)
2002-03-06 22:08:00 -06:00
makefile.32sunu => Sun Ultra 32-bit makefile
makefile.64sunu => Sun Ultra 64-bit makefile
1999-10-14 07:43:10 -05:00
makefile.sco => For SCO OSr5 ELF and Unixware 7 with Native cc
makefile.mips => MIPS makefile
makefile.acorn => Acorn makefile
makefile.amiga => Amiga makefile
smakefile.ppc => AMIGA smakefile for SAS C V6.58/7.00 PPC compiler
(Requires SCOPTIONS, copied from scripts/SCOPTIONS.ppc)
makefile.atari => Atari makefile
makefile.beos => BEOS makefile for X86
2000-03-21 05:13:06 -06:00
makefile.bor => Borland makefile (uses bcc)
makefile.bc32 => 32-bit Borland C++ (all modules compiled in C mode)
makefile.tc3 => Turbo C 3.0 makefile
1999-10-14 07:43:10 -05:00
makefile.dj2 => DJGPP 2 makefile
makefile.msc => Microsoft C makefile
makefile.vcawin32 => makefile for Microsoft Visual C++ 5.0 and later (uses
2000-02-04 23:40:16 -06:00
assembler code tuned for Intel MMX platform)
1999-10-14 07:43:10 -05:00
makefile.vcwin32 => makefile for Microsoft Visual C++ 4.0 and later (does
not use assembler code)
makefile.os2 => OS/2 Makefile (gcc and emx, requires pngos2.def)
pngos2.def => OS/2 module definition file used by makefile.os2
makefile.watcom => Watcom 10a+ Makefile, 32-bit flat memory model
makevms.com => VMS build script
2000-03-21 05:13:06 -06:00
descrip.mms => VMS makefile for MMS or MMK
1999-10-14 07:43:10 -05:00
SCOPTIONS.ppc => Used with smakefile.ppc
1998-03-07 06:06:55 -06:00
Copy the file (or files) that you need from the
scripts directory into this directory, for example
1999-10-14 07:43:10 -05:00
MSDOS example: copy scripts\makefile.msc makefile
1998-03-07 06:06:55 -06:00
UNIX example: cp scripts/makefile.std makefile
Read the makefile to see if you need to change any source or
target directories to match your preferences.
Then read pngconf.h to see if you want to make any configuration
changes.
2006-02-20 22:09:05 -06:00
Then just run "make" which will create the libpng library in
this directory and "make test" which will run a quick test that reads
the "pngtest.png" file and writes a "pngout.png" file that should be
identical to it. Look for "9782 zero samples" in the output of the
test. For more confidence, you can run another test by typing
"pngtest pngnow.png" and looking for "289 zero samples" in the output.
Also, you can run "pngtest -m contrib/pngsuite/*.png" and compare
1999-10-23 08:39:18 -05:00
your output with the result shown in contrib/pngsuite/README.
1998-03-07 06:06:55 -06:00
Most of the makefiles will allow you to run "make install" to
put the library in its final resting place (if you want to
do that, run "make install" in the zlib directory first if necessary).
2002-06-20 06:54:34 -05:00
Some also allow you to run "make test-installed" after you have
2002-10-03 06:32:37 -05:00
run "make install".
1998-03-07 06:06:55 -06:00
2006-02-20 22:09:05 -06:00
If you encounter a compiler error message complaining about the
lines
__png.h__ already includes setjmp.h;
__dont__ include it again.;
This means you have compiled another module that includes setjmp.h,
which is hazardous because the two modules might not include exactly
the same setjmp.h. If you are sure that you know what you are doing
and that they are exactly the same, then you can comment out or
delete the two lines. Better yet, use the cexcept interface
instead, as demonstrated in contrib/visupng of the libpng distribution.
2004-11-01 14:13:40 -06:00
Further information can be found in the README and libpng.txt
2006-02-20 22:09:05 -06:00
files, in the individual makefiles, in png.h, and the manual pages
libpng.3 and png.5.
2004-12-02 18:14:51 -06:00
Using the ./configure script -- 16 December 2002.
=================================================
The ./configure script should work compatibly with what scripts/makefile.*
did, however there are some options you need to add to configure explicitly,
which previously was done semi-automatically (if you didn't edit
scripts/makefile.* yourself, that is)
CFLAGS="-Wall -O3 -funroll-loops \
-malign-loops=2 -malign-functions=2" ./configure --prefix=/usr/include \
--with-pkgconfigdir=/usr/lib/pkgconfig --includedir=/usr/include
You can alternatively specify --includedir=/usr/include, /usr/local/include,
/usr/include/png12, or whatever.