Add one option to generate the PDF from CMake at build time
Make sure pygmentize is installed
Change-Id: I068ba45c33a8e96acc906a464b12d10d58b3e231
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 29834d1..117e86b 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -583,3 +583,15 @@
ADD_SUBDIRECTORY(internal/ceres)
ADD_SUBDIRECTORY(examples)
+
+OPTION(BUILD_DOCUMENTATION
+ "Build User's Guide (pdf)"
+ OFF)
+
+IF (${BUILD_DOCUMENTATION})
+ MESSAGE("-- Documentation building is enabled")
+
+ # Generate the User's Guide (pdf).
+ # The corresponding target is UserGuide, but is included in ALL.
+ ADD_SUBDIRECTORY(docs)
+ENDIF (${BUILD_DOCUMENTATION})
diff --git a/docs/CMakeLists.txt b/docs/CMakeLists.txt
new file mode 100644
index 0000000..cd98662
--- /dev/null
+++ b/docs/CMakeLists.txt
@@ -0,0 +1,63 @@
+# Ceres Solver - A fast non-linear least squares minimizer
+# Copyright 2012 Google Inc. All rights reserved.
+# http://code.google.com/p/ceres-solver/
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions are met:
+#
+# * Redistributions of source code must retain the above copyright notice,
+# this list of conditions and the following disclaimer.
+# * Redistributions in binary form must reproduce the above copyright notice,
+# this list of conditions and the following disclaimer in the documentation
+# and/or other materials provided with the distribution.
+# * Neither the name of Google Inc. nor the names of its contributors may be
+# used to endorse or promote products derived from this software without
+# specific prior written permission.
+#
+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
+# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+#
+# Author: arnaudgelas@gmail.com (Arnaud Gelas)
+
+FIND_PROGRAM(PYGMENTIZE NAMES pygmentize
+ PATHS
+ /usr/bin
+ /usr/local/bin
+ /opt/bin
+ /opt/local/bin)
+
+IF (${PYGMENTIZE} MATCHES PYGMENTIZE-NOTFOUND)
+ MESSAGE(SEND_ERROR "Pygmentize is not installed")
+ENDIF (${PYGMENTIZE} MATCHES PYGMENTIZE-NOTFOUND)
+
+FIND_PACKAGE(LATEX REQUIRED)
+
+FILE(DOWNLOAD http://minted.googlecode.com/files/minted.sty
+ ${CMAKE_BINARY_DIR}/docs/minted.sty
+ SHOW_PROGRESS)
+
+ADD_CUSTOM_TARGET(UserGuide ALL
+ COMMAND ${CMAKE_COMMAND} -E copy_directory
+ ${CMAKE_SOURCE_DIR}/docs ${CMAKE_BINARY_DIR}/docs
+ COMMAND ${PDFLATEX_COMPILER}
+ -shell-escape ${CMAKE_BINARY_DIR}/docs/ceres-solver.tex
+ -output-directory ${CMAKE_BINARY_DIR}/docs
+ WORKING_DIRECTORY ${CMAKE_BINARY_DIR}/docs
+ COMMAND ${BIBTEX_COMPILER} ${CMAKE_BINARY_DIR}/docs/ceres-solver.aux
+ COMMAND ${PDFLATEX_COMPILER}
+ -shell-escape ${CMAKE_BINARY_DIR}/docs/ceres-solver.tex
+ -output-directory ${CMAKE_BINARY_DIR}/docs
+ WORKING_DIRECTORY ${CMAKE_BINARY_DIR}/docs
+ COMMAND ${PDFLATEX_COMPILER}
+ -shell-escape ${CMAKE_BINARY_DIR}/docs/ceres-solver.tex
+ -output-directory ${CMAKE_BINARY_DIR}/docs
+ WORKING_DIRECTORY ${CMAKE_BINARY_DIR}/docs)