diff options
author | midipix <writeonce@midipix.org> | 2018-12-19 10:04:45 -0500 |
---|---|---|
committer | midipix <writeonce@midipix.org> | 2018-12-19 11:15:00 -0500 |
commit | e308264b99de5f754d6938c90658e7fcc512dc1e (patch) | |
tree | b592a4c602e42d5cca53186fede46a3bf95d8d4c | |
parent | 7cb7c845d31823297ea043a3b06d35ad46415ab2 (diff) | |
download | sbpython3-e308264b99de5f754d6938c90658e7fcc512dc1e.tar.bz2 sbpython3-e308264b99de5f754d6938c90658e7fcc512dc1e.tar.xz |
build system: config-time test framework: added cfgtest_decl_presence.
-rw-r--r-- | sofort/cfgtest.sh | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/sofort/cfgtest.sh b/sofort/cfgtest.sh index bd661c0..57aca7c 100644 --- a/sofort/cfgtest.sh +++ b/sofort/cfgtest.sh @@ -157,6 +157,39 @@ cfgtest_interface_presence() return 0 } + +cfgtest_decl_presence() +{ + mb_internal_cflags='' + + for mb_header in $mb_cfgtest_headers; do + mb_internal_cflags="$mb_internal_cflags --include=$mb_header" + done + + printf 'void * any = (void *)%s;' "$@" \ + | $mb_cfgtest_cc -S -xc - -o - \ + $mb_cfgtest_cflags \ + $mb_internal_cflags \ + > /dev/null 2>/dev/null \ + || return 1 + + # does the argument solely consist of the macro or enum member name? + mb_internal_str=$(printf '%s' "$@" | tr -d '[a-z][A-Z][0-9][_]') + + if [ -n "$mb_internal_str" ]; then + return 0 + fi + + mb_internal_str=$(printf '%s%s' '-DHAVE_DECL_' "$@" \ + | sed -e 's/\./_/g' \ + | tr "[:lower:]" "[:upper:]") + + cfgtest_cflags_append "$mb_internal_str" + + return 0 +} + + cfgtest_library_presence() { printf 'int main(void){return 0;}' \ |