| # 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 <src>/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() |