| # Copied from http://www.itk.org/Wiki/CMakeMacroParseArguments under |
| # http://creativecommons.org/licenses/by/2.5/. |
| # |
| # The PARSE_ARGUMENTS macro will take the arguments of another macro and define |
| # several variables. The first argument to PARSE_ARGUMENTS is a prefix to put on |
| # all variables it creates. The second argument is a list of names, and the |
| # third argument is a list of options. Both of these lists should be quoted. The |
| # rest of PARSE_ARGUMENTS are arguments from another macro to be parsed. |
| # |
| # PARSE_ARGUMENTS(prefix arg_names options arg1 arg2...) |
| # |
| # For each item in options, PARSE_ARGUMENTS will create a variable with that |
| # name, prefixed with prefix_. So, for example, if prefix is MY_MACRO and |
| # options is OPTION1;OPTION2, then PARSE_ARGUMENTS will create the variables |
| # MY_MACRO_OPTION1 and MY_MACRO_OPTION2. These variables will be set to true if |
| # the option exists in the command line or false otherwise. |
| # |
| #For each item in arg_names, PARSE_ARGUMENTS will create a variable with that |
| #name, prefixed with prefix_. Each variable will be filled with the arguments |
| #that occur after the given arg_name is encountered up to the next arg_name or |
| #the end of the arguments. All options are removed from these |
| #lists. PARSE_ARGUMENTS also creates a prefix_DEFAULT_ARGS variable containing |
| #the list of all arguments up to the first arg_name encountered. |
| # |
| #Here is a simple, albeit impractical, example of using PARSE_ARGUMENTS that |
| #demonstrates its behavior. |
| # |
| # SET(arguments |
| # hello OPTION3 world |
| # LIST3 foo bar |
| # OPTION2 |
| # LIST1 fuz baz |
| # ) |
| # |
| # PARSE_ARGUMENTS(ARG "LIST1;LIST2;LIST3" "OPTION1;OPTION2;OPTION3" ${arguments}) |
| # |
| # PARSE_ARGUMENTS creates 7 variables and sets them as follows: |
| # ARG_DEFAULT_ARGS: hello;world |
| # ARG_LIST1: fuz;baz |
| # ARG_LIST2: |
| # ARG_LIST3: foo;bar |
| # ARG_OPTION1: FALSE |
| # ARG_OPTION2: TRUE |
| # ARG_OPTION3: TRUE |
| # |
| # If you don't have any options, use an empty string in its place. |
| # PARSE_ARGUMENTS(ARG "LIST1;LIST2;LIST3" "" ${arguments}) |
| # Likewise if you have no lists. |
| # PARSE_ARGUMENTS(ARG "" "OPTION1;OPTION2;OPTION3" ${arguments}) |
| |
| MACRO(PARSE_ARGUMENTS prefix arg_names option_names) |
| SET(DEFAULT_ARGS) |
| FOREACH(arg_name ${arg_names}) |
| SET(${prefix}_${arg_name}) |
| ENDFOREACH(arg_name) |
| FOREACH(option ${option_names}) |
| SET(${prefix}_${option} FALSE) |
| ENDFOREACH(option) |
| |
| SET(current_arg_name DEFAULT_ARGS) |
| SET(current_arg_list) |
| FOREACH(arg ${ARGN}) |
| SET(larg_names ${arg_names}) |
| LIST(FIND larg_names "${arg}" is_arg_name) |
| IF (is_arg_name GREATER -1) |
| SET(${prefix}_${current_arg_name} ${current_arg_list}) |
| SET(current_arg_name ${arg}) |
| SET(current_arg_list) |
| ELSE (is_arg_name GREATER -1) |
| SET(loption_names ${option_names}) |
| LIST(FIND loption_names "${arg}" is_option) |
| IF (is_option GREATER -1) |
| SET(${prefix}_${arg} TRUE) |
| ELSE (is_option GREATER -1) |
| SET(current_arg_list ${current_arg_list} ${arg}) |
| ENDIF (is_option GREATER -1) |
| ENDIF (is_arg_name GREATER -1) |
| ENDFOREACH(arg) |
| SET(${prefix}_${current_arg_name} ${current_arg_list}) |
| ENDMACRO(PARSE_ARGUMENTS) |