|  | # | 
|  | #//===----------------------------------------------------------------------===// | 
|  | #// | 
|  | #// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. | 
|  | #// See https://llvm.org/LICENSE.txt for license information. | 
|  | #// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception | 
|  | #// | 
|  | #//===----------------------------------------------------------------------===// | 
|  | # | 
|  |  | 
|  | # void libomp_say(string message_to_user); | 
|  | # - prints out message_to_user | 
|  | macro(libomp_say message_to_user) | 
|  | message(STATUS "LIBOMP: ${message_to_user}") | 
|  | endmacro() | 
|  |  | 
|  | # void libomp_warning_say(string message_to_user); | 
|  | # - prints out message_to_user with a warning | 
|  | macro(libomp_warning_say message_to_user) | 
|  | message(WARNING "LIBOMP: ${message_to_user}") | 
|  | endmacro() | 
|  |  | 
|  | # void libomp_error_say(string message_to_user); | 
|  | # - prints out message_to_user with an error and exits cmake | 
|  | macro(libomp_error_say message_to_user) | 
|  | message(FATAL_ERROR "LIBOMP: ${message_to_user}") | 
|  | endmacro() | 
|  |  | 
|  | # libomp_append(<flag> <flags_list> [(IF_TRUE | IF_FALSE | IF_TRUE_1_0 ) BOOLEAN]) | 
|  | # | 
|  | # libomp_append(<flag> <flags_list>) | 
|  | #   - unconditionally appends <flag> to the list of definitions | 
|  | # | 
|  | # libomp_append(<flag> <flags_list> <BOOLEAN>) | 
|  | #   - appends <flag> to the list of definitions if BOOLEAN is true | 
|  | # | 
|  | # libomp_append(<flag> <flags_list> IF_TRUE <BOOLEAN>) | 
|  | #   - appends <flag> to the list of definitions if BOOLEAN is true | 
|  | # | 
|  | # libomp_append(<flag> <flags_list> IF_FALSE <BOOLEAN>) | 
|  | #   - appends <flag> to the list of definitions if BOOLEAN is false | 
|  | # | 
|  | # libomp_append(<flag> <flags_list> IF_DEFINED <VARIABLE>) | 
|  | #   - appends <flag> to the list of definitions if VARIABLE is defined | 
|  | # | 
|  | # libomp_append(<flag> <flags_list> IF_TRUE_1_0 <BOOLEAN>) | 
|  | #   - appends <flag>=1 to the list of definitions if <BOOLEAN> is true, <flag>=0 otherwise | 
|  | # e.g., libomp_append("-D USE_FEATURE" IF_TRUE_1_0 HAVE_FEATURE) | 
|  | #     appends "-D USE_FEATURE=1" if HAVE_FEATURE is true | 
|  | #     or "-D USE_FEATURE=0" if HAVE_FEATURE is false | 
|  | macro(libomp_append flags flag) | 
|  | if(NOT (${ARGC} EQUAL 2 OR ${ARGC} EQUAL 3 OR ${ARGC} EQUAL 4)) | 
|  | libomp_error_say("libomp_append: takes 2, 3, or 4 arguments") | 
|  | endif() | 
|  | if(${ARGC} EQUAL 2) | 
|  | list(APPEND ${flags} "${flag}") | 
|  | elseif(${ARGC} EQUAL 3) | 
|  | if(${ARGV2}) | 
|  | list(APPEND ${flags} "${flag}") | 
|  | endif() | 
|  | else() | 
|  | if(${ARGV2} STREQUAL "IF_TRUE") | 
|  | if(${ARGV3}) | 
|  | list(APPEND ${flags} "${flag}") | 
|  | endif() | 
|  | elseif(${ARGV2} STREQUAL "IF_FALSE") | 
|  | if(NOT ${ARGV3}) | 
|  | list(APPEND ${flags} "${flag}") | 
|  | endif() | 
|  | elseif(${ARGV2} STREQUAL "IF_DEFINED") | 
|  | if(DEFINED ${ARGV3}) | 
|  | list(APPEND ${flags} "${flag}") | 
|  | endif() | 
|  | elseif(${ARGV2} STREQUAL "IF_TRUE_1_0") | 
|  | if(${ARGV3}) | 
|  | list(APPEND ${flags} "${flag}=1") | 
|  | else() | 
|  | list(APPEND ${flags} "${flag}=0") | 
|  | endif() | 
|  | else() | 
|  | libomp_error_say("libomp_append: third argument must be one of IF_TRUE, IF_FALSE, IF_DEFINED, IF_TRUE_1_0") | 
|  | endif() | 
|  | endif() | 
|  | endmacro() | 
|  |  | 
|  | # void libomp_get_legal_arch(string* return_arch_string); | 
|  | # - returns (through return_arch_string) the formal architecture | 
|  | #   string or warns user of unknown architecture | 
|  | function(libomp_get_legal_arch return_arch_string) | 
|  | if(${IA32}) | 
|  | set(${return_arch_string} "IA-32" PARENT_SCOPE) | 
|  | elseif(${INTEL64}) | 
|  | set(${return_arch_string} "Intel(R) 64" PARENT_SCOPE) | 
|  | elseif(${MIC}) | 
|  | set(${return_arch_string} "Intel(R) Many Integrated Core Architecture" PARENT_SCOPE) | 
|  | elseif(${ARM}) | 
|  | set(${return_arch_string} "ARM" PARENT_SCOPE) | 
|  | elseif(${PPC64BE}) | 
|  | set(${return_arch_string} "PPC64BE" PARENT_SCOPE) | 
|  | elseif(${PPC64LE}) | 
|  | set(${return_arch_string} "PPC64LE" PARENT_SCOPE) | 
|  | elseif(${AARCH64}) | 
|  | set(${return_arch_string} "AARCH64" PARENT_SCOPE) | 
|  | elseif(${MIPS}) | 
|  | set(${return_arch_string} "MIPS" PARENT_SCOPE) | 
|  | elseif(${MIPS64}) | 
|  | set(${return_arch_string} "MIPS64" PARENT_SCOPE) | 
|  | elseif(${RISCV64}) | 
|  | set(${return_arch_string} "RISCV64" PARENT_SCOPE) | 
|  | else() | 
|  | set(${return_arch_string} "${LIBOMP_ARCH}" PARENT_SCOPE) | 
|  | libomp_warning_say("libomp_get_legal_arch(): Warning: Unknown architecture: Using ${LIBOMP_ARCH}") | 
|  | endif() | 
|  | endfunction() | 
|  |  | 
|  | # void libomp_check_variable(string var, ...); | 
|  | # - runs through all values checking if ${var} == value | 
|  | # - uppercase and lowercase do not matter | 
|  | # - if the var is found, then just print it out | 
|  | # - if the var is not found, then error out | 
|  | function(libomp_check_variable var) | 
|  | set(valid_flag 0) | 
|  | string(TOLOWER "${${var}}" var_lower) | 
|  | foreach(value IN LISTS ARGN) | 
|  | string(TOLOWER "${value}" value_lower) | 
|  | if("${var_lower}" STREQUAL "${value_lower}") | 
|  | set(valid_flag 1) | 
|  | set(the_value "${value}") | 
|  | endif() | 
|  | endforeach() | 
|  | if(${valid_flag} EQUAL 0) | 
|  | libomp_error_say("libomp_check_variable(): ${var} = ${${var}} is unknown") | 
|  | endif() | 
|  | endfunction() | 
|  |  | 
|  | # void libomp_get_build_number(string src_dir, string* return_build_number); | 
|  | # - grab the eight digit build number (or 00000000) from kmp_version.cpp | 
|  | function(libomp_get_build_number src_dir return_build_number) | 
|  | # sets file_lines_list to a list of all lines in kmp_version.cpp | 
|  | file(STRINGS "${src_dir}/src/kmp_version.cpp" file_lines_list) | 
|  |  | 
|  | # runs through each line in kmp_version.cpp | 
|  | foreach(line IN LISTS file_lines_list) | 
|  | # if the line begins with "#define KMP_VERSION_BUILD" then we take not of the build number | 
|  | string(REGEX MATCH "^[ \t]*#define[ \t]+KMP_VERSION_BUILD" valid "${line}") | 
|  | if(NOT "${valid}" STREQUAL "") # if we matched "#define KMP_VERSION_BUILD", then grab the build number | 
|  | string(REGEX REPLACE "^[ \t]*#define[ \t]+KMP_VERSION_BUILD[ \t]+([0-9]+)" "\\1" | 
|  | build_number "${line}" | 
|  | ) | 
|  | endif() | 
|  | endforeach() | 
|  | set(${return_build_number} "${build_number}" PARENT_SCOPE) # return build number | 
|  | endfunction() | 
|  |  | 
|  | # void libomp_get_legal_type(string* return_legal_type); | 
|  | # - set the legal type name Performance/Profiling/Stub | 
|  | function(libomp_get_legal_type return_legal_type) | 
|  | if(${NORMAL_LIBRARY}) | 
|  | set(${return_legal_type} "Performance" PARENT_SCOPE) | 
|  | elseif(${PROFILE_LIBRARY}) | 
|  | set(${return_legal_type} "Profiling" PARENT_SCOPE) | 
|  | elseif(${STUBS_LIBRARY}) | 
|  | set(${return_legal_type} "Stub" PARENT_SCOPE) | 
|  | endif() | 
|  | endfunction() | 
|  |  | 
|  | # void libomp_add_suffix(string suffix, list<string>* list_of_items); | 
|  | # - returns list_of_items with suffix appended to all items | 
|  | # - original list is modified | 
|  | function(libomp_add_suffix suffix list_of_items) | 
|  | set(local_list "") | 
|  | foreach(item IN LISTS "${list_of_items}") | 
|  | if(NOT "${item}" STREQUAL "") | 
|  | list(APPEND local_list "${item}${suffix}") | 
|  | endif() | 
|  | endforeach() | 
|  | set(${list_of_items} "${local_list}" PARENT_SCOPE) | 
|  | endfunction() | 
|  |  | 
|  | # void libomp_list_to_string(list<string> list_of_things, string* return_string); | 
|  | # - converts a list to a space separated string | 
|  | function(libomp_list_to_string list_of_things return_string) | 
|  | string(REPLACE ";" " " output_variable "${list_of_things}") | 
|  | set(${return_string} "${output_variable}" PARENT_SCOPE) | 
|  | endfunction() | 
|  |  | 
|  | # void libomp_string_to_list(string str, list<string>* return_list); | 
|  | # - converts a string to a semicolon separated list | 
|  | # - what it really does is just string_replace all running whitespace to a semicolon | 
|  | # - in cmake, a list is strings separated by semicolons: i.e., list of four items, list = "item1;item2;item3;item4" | 
|  | function(libomp_string_to_list str return_list) | 
|  | set(outstr) | 
|  | string(REGEX REPLACE "[ \t]+" ";" outstr "${str}") | 
|  | set(${return_list} "${outstr}" PARENT_SCOPE) | 
|  | endfunction() | 
|  |  |