zxing/cpp
smparkes@smparkes.net 124ef03ca9 Allow a few build-time arguments to the C++ build
Add DEBUG and PIC flags to scons so you can now build without debug, e.g.,
  scons DEBUG=false lib
or with -fPIC forced, e.g,.
  scons PIC=true lib

Defaults haven't changed.


git-svn-id: https://zxing.googlecode.com/svn/trunk@1550 59b500cc-1b3d-0410-9834-0bbf25fbcc57
2010-08-20 18:46:05 +00:00
..
core Fixed a bug I introduced while removing exceptions, which caused the 2010-08-18 18:31:49 +00:00
magick/src C++ port: Make sure #indef/#define/#endif's and copyright information on all header files is in a common format. 2010-08-04 13:36:20 +00:00
osx.xcodeproj Tweak svn/git ignores 2010-08-20 00:41:26 +00:00
scons Tweak svn/git ignores 2010-08-20 00:41:26 +00:00
.gitignore Tweak svn/git ignores 2010-08-20 00:41:26 +00:00
.svnignore C++ port: 2009-12-08 21:16:43 +00:00
astyle-options Many changes to the C++ port. 2009-11-01 17:30:30 +00:00
blackboxtest.sh C++: binarizer updates 2010-07-19 20:56:17 +00:00
format Many changes to the C++ port. 2009-11-01 17:30:30 +00:00
README Tweak svn/git ignores 2010-08-20 00:41:26 +00:00
SConscript Allow a few build-time arguments to the C++ build 2010-08-20 18:46:05 +00:00
SConstruct Many changes to the C++ port. 2009-11-01 17:30:30 +00:00

This is only tested on Linux. With some trouble, it might work on Windows as well.

The build process uses scons, a build tool written in python. You'll
need to have python installed, but scons installation is optional: a
runtime copy of scons (called scons-local) is included with zxing. To
use the included copy of scons-local, where the instructons says enter
"scons", enter "python scons/scons.py" instead. For example, to build
the library only, you'd use "python scons/scons.py lib" instead of
"scons lib".

To build the library only:
- Run "scons lib" in this folder (cpp)

To build the unit tests:
- Install cppunit (libcppunit-dev on Ubuntu)
- Run "scons tests"
- Run "testrunner" in the build folder

To build the test utility:
- Install Magick++ (libmagick++-dev on Ubuntu)
- Run "scons zxing"

An simple example application is now also included, but no compilation instructions yet.

To clean:
- Run "scons -c all"

To use the test utility:
- Basic usage:
  - "mkdir testout"
  - "zxing testout *.jpg > report.html"
- With the zxing test data, from the cpp folder:
  - "mkdir testout"
  - "build/zxing testout ../core/test/data/blackbox/qrcode-*/* > report.html"

To format the code:
 - Install astyle
 - Run ./format

To profile the code (very useful to optimize the code):
 - Install valgrind
 - "valgrind --tool=callgrind build/zxing - path/to/test/data/*.jpg > report.html"
 - kcachegrind is a very nice tool to analize the output