[gdal-dev] GDAL trunk compilation broken by r19335 / minizip /
libkml
Even Rouault
even.rouault at mines-paris.org
Wed Apr 7 15:36:31 EDT 2010
Harsh,
The telascience (Linux) slavebot fails building latest trunk with :
kmlsuperoverlaydataset.cpp:12:17: error: zip.h: No such file or directory
kmlsuperoverlaydataset.cpp: In function 'bool
...
Full log here :
http://buildbot.osgeo.org:8500/builders/telascience-quick/builds/358/steps/make/logs/stdio
I guess this is because the new driver has a dependency to minizip ? For the
time being, it should probably be removed from GDALmake.opt.in to avoid build
failures.
For the long term solution, I'm not sure what the best option is. In the past,
I had 'imported' the unzip part of minizip in GDAL port subdirectory to add
support for a /vsizip virtual file system. To avoid issues for applications
that would link both GDAL and minizip (see (1)), I had renamed the symbols of
the imported files with cpl_ prefix. I choosed this because as far as I
remember, minizip didn't come as a nicely & standard packaged library (it was
some tool/demonstration code living in the contrib directory from the 'zip'
project) and so it didn't seem practical to add support for its detection
in ./configure (see (2)). Perhaps this has changed now and minizip is a more
standard library dependency. A bit of googling shows
http://groups.google.com/group/linux.debian.bugs.dist/browse_thread/thread/c82c7d7ead3ec189?tvc=2
which reveals that the issue still seems up-to-date. Fedora has apparently
minizip packaged as a library, but Debian not.
The issue with minizip will also arise with the new KML driver that Brian Case
is developping that uses libkml, and minizip is a dependency of libkml. I'm
not sure how libkml is supposed to be packaged : are minizip symbols
statically linked in libkml (if it is the case, are the minizip symbols
exported in the windows/linux builds ?) or is minizip a dependency as a
shared library ?
Actually, another bit of googling shows that Debian has packaged libkml
(http://packages.debian.org/squeeze/libkml0) and that a libminizip.so is part
of the package. But the -dev package doesn't seem to include the headers of
minizip, so it is probably only seen as an internal dependency.
The situation is quite confusing, isn't it ? Any thought anyone on the best
approach to use minizip ?
Best regards,
Even
(1) : This can be a problem. For example some applications use GDAL built with
its internal libtiff (libtiff 4.x based) and also link with the system
libtiff (in most cases still libtiff 3.x), directly or indirectly (for
example GTK+-2.0 links with libtiff). So a guy linking its app with GDAL and
GTK can end up pulling 2 libtiff versions... Because of the ABI changes
between libtiff 3.x and 4.x, this is known to cause crashes on Linux in some
circumstances. We probably want to avoid such situation with minizip in case
various software packages depend on incompatible minizip versions (although
note (2) shows that they've managed to avoid ABI clashes, so this is just a
theoretical problem for now)
(2) : It also enabled me to experiment with adding support for ZIP64
unzipping. Very recently (15 march 2010) upstream zlib has incorporated back
the changes in minizip 1.1 (and in zlib124 package) in a cleaner & backward
compatible way by adding new symbols with 64 prefix. So if latest minizip was
a dependency, we could drop the cpl_minizip files from GDAL source and use
upstream version instead. The ZIP64 issue isn't terribly important to me so
this would certainly not be a show-stopper for moving to another solution
that would only require using the old minizip interfaces. And the
cpl_vsil_gzip.cpp code could certainly be adapted to work with classic or
zip64 symbols according to what is available.
More information about the gdal-dev
mailing list