# Ceres Solver - A fast non-linear least squares minimizer # Copyright 2023 Google Inc. All rights reserved. # http://ceres-solver.org/ # # 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: alexs.mac@gmail.com (Alex Stewart) # This must take place outside of CONFIGURE_CERES_CONFIG() in order that # we can determine where *this* file is, and thus the relative path to # config.h.in. Inside of CONFIGURE_CERES_CONFIG(), CMAKE_CURRENT_LIST_DIR # refers to the caller of CONFIGURE_CERES_CONFIG(), not this file. set(CERES_CONFIG_IN_FILE "${CMAKE_CURRENT_LIST_DIR}/config.h.in") # CreateCeresConfig.cmake - Create the config.h for Ceres. # # This function configures the Ceres config.h file based on the current # compile options and copies it into the specified location. It should be # called before Ceres is built so that the correct config.h is used when # Ceres is compiled. # # INPUTS: # CURRENT_CERES_COMPILE_OPTIONS: List of currently enabled Ceres compile # options. These are compared against the # full list of valid options, which are read # from config.h.in. Any options present # which are not part of the valid set will # invoke an error. Any valid option present # will be enabled in the resulting config.h, # all other options will be disabled. # # CERES_CONFIG_OUTPUT_DIRECTORY: Path to output directory in which to save # the configured config.h. Typically this # will be /include/ceres/internal. function(CREATE_CERES_CONFIG CURRENT_CERES_COMPILE_OPTIONS CERES_CONFIG_OUTPUT_DIRECTORY) # Create the specified output directory if it does not exist. if (NOT EXISTS "${CERES_CONFIG_OUTPUT_DIRECTORY}") message(STATUS "Creating configured Ceres config.h output directory: " "${CERES_CONFIG_OUTPUT_DIRECTORY}") file(MAKE_DIRECTORY "${CERES_CONFIG_OUTPUT_DIRECTORY}") endif() if (EXISTS "${CERES_CONFIG_OUTPUT_DIRECTORY}" AND NOT IS_DIRECTORY "${CERES_CONFIG_OUTPUT_DIRECTORY}") message(FATAL_ERROR "Ceres Bug: Specified CERES_CONFIG_OUTPUT_DIRECTORY: " "${CERES_CONFIG_OUTPUT_DIRECTORY} exists, but is not a directory.") endif() # Read all possible configurable compile options from config.h.in, this avoids # us having to hard-code in this file what the valid options are. file(READ ${CERES_CONFIG_IN_FILE} CERES_CONFIG_IN_CONTENTS) string(REGEX MATCHALL "@[^@ $]+@" ALL_CONFIGURABLE_CERES_OPTIONS "${CERES_CONFIG_IN_CONTENTS}") # Removing @ symbols at beginning and end of each option. string(REPLACE "@" "" ALL_CONFIGURABLE_CERES_OPTIONS "${ALL_CONFIGURABLE_CERES_OPTIONS}") # Ensure that there are no repetitions in the current compile options. list(REMOVE_DUPLICATES CURRENT_CERES_COMPILE_OPTIONS) foreach (CERES_OPTION ${ALL_CONFIGURABLE_CERES_OPTIONS}) # Try and find the option in the list of current compile options, if it # is present, then the option is enabled, otherwise it is disabled. list(FIND CURRENT_CERES_COMPILE_OPTIONS ${CERES_OPTION} OPTION_ENABLED) # list(FIND ..) returns -1 if the element was not in the list, but CMake # interprets if (VAR) to be true if VAR is any non-zero number, even # negative ones, hence we have to explicitly check for >= 0. if (OPTION_ENABLED GREATER -1) message(STATUS "Enabling ${CERES_OPTION} in Ceres config.h") set(${CERES_OPTION} "#define ${CERES_OPTION}") # Remove the item from the list of current options so that we can identify # any options that were in CURRENT_CERES_COMPILE_OPTIONS, but not in # ALL_CONFIGURABLE_CERES_OPTIONS (which is an error). list(REMOVE_ITEM CURRENT_CERES_COMPILE_OPTIONS ${CERES_OPTION}) else() set(${CERES_OPTION} "// #define ${CERES_OPTION}") endif() endforeach() # CURRENT_CERES_COMPILE_OPTIONS should now be an empty list, any elements # remaining were not present in ALL_CONFIGURABLE_CERES_OPTIONS read from # config.h.in. if (CURRENT_CERES_COMPILE_OPTIONS) message(FATAL_ERROR "Ceres Bug: CURRENT_CERES_COMPILE_OPTIONS contained " "the following options which were not present in config.h.in: " "${CURRENT_CERES_COMPILE_OPTIONS}") endif() configure_file(${CERES_CONFIG_IN_FILE} "${CERES_CONFIG_OUTPUT_DIRECTORY}/config.h" @ONLY) endfunction()