You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Daniel Zucchetto cb5135f772 Add test for Canon M100 ModelID 7 years ago
ci [travis] Move travis scripts to ci/ folder 7 years ago
config [cmake] Add -Wdouble-promotion & -Wcomma only for certain clang versions 7 years ago
contrib Remove obsolete svn revision 8 years ago
doc Remove obsolete svn revision 8 years ago
include/exiv2 Simplify usage of strerror_r. 7 years ago
msvc Trivial Documentation Update 7 years ago
po Fix typos in Polish translation 8 years ago
samples Whitespace cleanup 7 years ago
src Support Canon M100 7 years ago
test Add test for Canon M100 ModelID 7 years ago
tests Add test for Canon M100 ModelID 7 years ago
unitTests Replaced way to check buffer after calling DateValue::copy 7 years ago
xmpsdk Remove HAVE_STDLIB_H check and replace stdlib.h by cstdlib 7 years ago
.clang-format Add .clang-format file 8 years ago
.gitignore Ignore build* folders and project file generated by QtCreator 8 years ago
.gitlab-ci.yml [GitLab] Add .gitlab-ci.yml 7 years ago
.travis.yml [travis] Move travis scripts to ci/ folder 7 years ago
ABOUT-NLS Merged revisions 907:999 from gettext branch into trunk 19 years ago
AUTHORS Refer to doc/ChangeLog for authors and other contributors. 15 years ago
CMakeLists.txt Export all symbols when running unit tests. Add dummy test for private code. 8 years ago
CODING_GUIDELINES.md CONTRUBUTING.md updates (#234) 7 years ago
CONTRIBUTING.md Clarified the workflow description (after input from piponazo). 7 years ago
COPYING Updated copyright and fsf address 20 years ago
COPYING-CMAKE-SCRIPTS use dedicated licence file for CMake Script, as it done into KDE project. 13 years ago
Makefile Remove obsolete svn revision 8 years ago
README-CMAKE New documentation about how to use Conan 7 years ago
README-CONAN.md New documentation about how to use Conan 7 years ago
README.md Add gitlab pipeline status badge to README.md 7 years ago
TODO-CMAKE Documentation update to withdraw support for MinGW. The code-base has not been modified and will probably build with MinGW. However Team Exiv2 will not support this platform. 8 years ago
WORK-IN-PROGRESS Documentation update for Michal. 8 years ago
appveyor.yml [conan] Update to conan 1.1.1 and recipes in which we depend on 7 years ago
bootstrap.linux Remove EXIV2_ENABLE_LIBXMP variable, always build static XMP library, remove cmake OBJECT library 8 years ago
bootstrap.macports Remove EXIV2_ENABLE_LIBXMP variable, always build static XMP library, remove cmake OBJECT library 8 years ago
bootstrap.mxe add support of MXE xrosscompiling for Windows, based on MinGW. 9 years ago
conanfile.py Install conan-dependencies DLLs into install/bin. 7 years ago

README.md

Build Status Build status pipeline status


    @@@Marco@@@@@b                   ;mm                       /##Gilles###\
    j@@@#Robin",                     Brad                     /@@@Thomas@@@@Q
     @@@#       \                     ##                     @@@b     |@@@b
     @@@#          .;;;;,     ,;;;, ,;;;;  ,;;;p      .;;;   7@@      ]Alan
     @@@#           j@@@@,   ]@@#/  '@@@#  j@@@#      ]@@^           ;@@@"
     @@@Andreas@C     "@@@p @@@"     @@@b   j@@@p     @@b           @@@#/
     @@@#^7"7%#\       ^@@@@@#~      Benb    1@@@    {@#          s@@@#
     @@@#                Niels       @@@b     @@@Q  ]@#         ;@@@#/
     @@@#              ,@@##@@m      @@@b      @@@p @@C        #@@#C
     @@@#       ,/    s@@#  @@@@     @@@b       Volker       @Tuan@
    ]@@@Abhinav@@\   /@@@\    \@@@Q  @@@Q       %@@@#      /@@@@Mahesh@@#
   /@@Raphael@@@@@\ /@@@@@\     C++  Metadata  Library    /@Sridhar@@@v0.26\

Exiv2

Welcome to Exiv2, a C++ library and a command line utility to read and write Exif, IPTC and XMP image metadata. The homepage of Exiv2 is:

http://www.exiv2.org/

See doc/ChangeLog for a list of recent changes to Exiv2.

Exiv2 API and tag reference documentation is at http://www.exiv2.org/doc or you can build it and point your browser to doc/index.html.

For more information on XMP support in Exiv2, see doc/README-XMP.

Building and Installing

You can build the libraries in the following ways:

1 Autotools: UNIX-like systems (including GNU/Linux, MacOS-X, Cygwin (32 and 64), MinGW (32 and 64)

2 Microsoft Visual C++ solutions

  • see msvc/ReadMe.txt (32bit and 64bit builds Visual Studio 2005,08,10,12,13,15)

3 CMake (support for all platforms/compilers except MinGW)

To build a commercial version of the Exiv2 library, see also section "Commercial version" at the end of this file.

On UNIX-like systems, use the GNU configure script. Run the following commands from the top directory (containing this file) to configure, build and install the library and utility:

$ ./configure
$ make
$ sudo make install  (Cygwin/MinGW $ make install)

Caution: If you downloaded the source code from the git repository, you will have to generate the configure script:

$ make config
$ ./configure
$ make
$ sudo make install  (Cygwin/MinGW $ make install)

To build the sample applications:

$ make samples

The default install locations are /usr/local/lib for the library, /usr/local/bin for the exiv2 utility and /usr/local/include/exiv2 for the header files. Use the --prefix=directory option of the configure script to change the default. Run ./configure --help to see a list of all options.

To uninstall Exiv2 from a UNIX-like system, run:

$ sudo make uninstall

Dependencies

The following libexiv2 features are enabled by default and may require external libraries. They can be controlled through configure options. See also ./configure --help.

Feature                     Package   Configure options
--------------------------  --------  ----------------------------
PNG image support           zlib      --without-zlib
                                      --with-zlib=DIR
Native language support     gettext   --disable-nls
Characterset conversions    libiconv  --without-libiconv-prefix
                                      --with-libiconv-prefix[=DIR]
XMP support                 expat     --disable-xmp
                                      --with-expat=DIR

zlib         http://zlib.net/
gettext  *)  http://www.gnu.org/software/gettext/
libiconv *)  http://www.gnu.org/software/libiconv/
expat        http://expat.sourceforge.net/

*) Some systems have gettext and iconv in libc. The configure script (and CMake) should detect this.

On Linux, it is usually best to install the dependencies through the package management system of the distribution together with the corresponding development packages (for the header files and static libraries).

To build the sample programs in the samples/ directory (make samples), you also need to have the pkg-config program.

To generate the documentation (make doc), you will further need doxygen, graphviz, python and xsltproc.

pkg-config   http://pkg-config.freedesktop.org/wiki/
doxygen      http://www.doxygen.org/
graphviz     http://www.graphviz.org/
python       http://www.python.org/
xsltproc     http://xmlsoft.org/XSLT/
md5sum       http://www.microbrew.org/tools/md5sha1sum/

Troubleshooting

If you have problems building Exiv2 on UNIX-like systems, check the generated config/config.mk and config/config.h files. You should not need to modify any Makefile directly, in particular not src/Makefile!

Support

All project resources are accessible from the project website at http://dev.exiv2.org/projects/exiv2/wiki

Please send feedback or queries to the Exiv2 forum. For new bug reports and feature requests, please open an issue.

Linking your own code with Exiv2

A pkg-config .pc file is installed together with the library. Application developers can use pkg-config(1) to obtain correct compile and link time flags for the Exiv2 library. See samples/Makefile for an example.

If you downloaded Exiv2 directly from the git repository, and you want to build it using the GNU configure script, then you need to have GNU Autoconf installed on your system and create the configure script as the first step:

$ make config

Then run the usual ./configure; make; make install commands.

Exiv2 uses GNU Libtool in order to build shared libraries on a variety of systems. While this is very nice for making usable binaries, it can be a pain when trying to debug a program. For that reason, compilation of shared libraries can be turned off by specifying the --disable-shared option to the configure script.

License

Copyright (C) 2004-2017 Andreas Huggel ahuggel@gmx.net

Exiv2 is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.

Exiv2 is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, 5th Floor, Boston, MA 02110-1301 USA.

Commercial version

If you have a commercial license, you must disable NLS support and the conversion of Nikon lens data to readable lens names to build a commercial version of the Exiv2 library.

To do this on Windows, compile the library with the preprocessor symbol EXV_COMMERCIAL_VERSION defined in msvc\include\exv_msvc.h

On UNIX-like systems, run the configure script with the options --enable-commercial --disable-nls --disable-lensdata.

That's all Folks