summaryrefslogtreecommitdiff
path: root/project/config/cfgdefs.sh
diff options
context:
space:
mode:
authormidipix <writeonce@midipix.org>2018-12-15 17:22:58 -0500
committermidipix <writeonce@midipix.org>2018-12-18 20:38:39 -0500
commit8d7c97df868450dc39d376d2374a4c9dff4c842b (patch)
tree9adcdc02ddf73dcba53fc3d34a36192de72099af /project/config/cfgdefs.sh
parent80140a5721a2439d2eb8758b730124697d022d8c (diff)
downloadsbpython3-8d7c97df868450dc39d376d2374a4c9dff4c842b.tar.bz2
sbpython3-8d7c97df868450dc39d376d2374a4c9dff4c842b.tar.xz
custom config: init python's version make vars based on patchlevel.h.
Diffstat (limited to 'project/config/cfgdefs.sh')
-rw-r--r--project/config/cfgdefs.sh47
1 files changed, 47 insertions, 0 deletions
diff --git a/project/config/cfgdefs.sh b/project/config/cfgdefs.sh
index 054e536..ad5e9eb 100644
--- a/project/config/cfgdefs.sh
+++ b/project/config/cfgdefs.sh
@@ -35,6 +35,47 @@ cfgdefs_set_cfghost_flavors()
}
+cfgdefs_detect_python_version()
+{
+ mb_internal_verinfo=$(mktemp)
+
+ if [ -z "$mb_internal_verinfo" ]; then
+ exit 2
+ fi
+
+ "$mb_native_cc" -E -dM "$mb_source_dir/Include/patchlevel.h" \
+ > "$mb_internal_verinfo"
+
+ python_major=$(grep '#define PY_MAJOR_VERSION ' "$mb_internal_verinfo" | cut -d' ' -f3)
+ python_minor=$(grep '#define PY_MINOR_VERSION ' "$mb_internal_verinfo" | cut -d' ' -f3)
+ python_micro=$(grep '#define PY_MICRO_VERSION ' "$mb_internal_verinfo" | cut -d' ' -f3)
+
+ if [ -z "$python_major" ] || [ -z "$python_minor" ] || [ -z "$python_micro" ]; then
+ error_msg "Could not properly parse Python's patchlevel.h"
+ exit 2
+ fi
+
+ python_ver="$python_major.$python_minor"
+
+ [ -z "$mb_package" ] && mb_package='python'"$python_ver"
+ [ -z "$mb_nickname" ] && mb_nickname="$mb_package"
+ [ -z "$mb_pkgname" ] && mb_pkgname="$mb_package"
+ [ -z "$mb_pkgdesc" ] && mb_pkgdesc="$mb_package"
+}
+
+
+cfgdefs_output_custom_defs()
+{
+ sed \
+ -e 's/@python_ver@/'"$python_ver"'/g' \
+ -e 's/@python_major@/'"$python_major"'/g' \
+ -e 's/@python_minor@/'"$python_minor"'/g' \
+ -e 's/@python_micro@/'"$python_micro"'/g' \
+ "$mb_project_dir/project/config/cfgdefs.in" \
+ >> "$mb_pwd/cfgdefs.mk"
+}
+
+
cfgdefs_perform_target_tests()
{
# init
@@ -141,6 +182,12 @@ cfgdefs_perform_native_tests()
# cfghost
cfgdefs_set_cfghost_flavors
+# python version info
+cfgdefs_detect_python_version
+
+# cfgdefs.in --> cfgdefs.mk
+cfgdefs_output_custom_defs
+
# target-specific tests
cfgdefs_perform_target_tests