aboutsummaryrefslogtreecommitdiffstats
path: root/host/Modules/UHDPython.cmake
diff options
context:
space:
mode:
authorJosh Blum <josh@joshknows.com>2010-12-27 16:57:09 -0800
committerJosh Blum <josh@joshknows.com>2010-12-27 16:57:09 -0800
commit5c08896e6c4124de69f43f0765468dc4d517920b (patch)
tree47ef644eadac0e9271eb26e4e222035461f6bfae /host/Modules/UHDPython.cmake
parentbf8677c9a96c3ed7fae48a57759b9f4742cd7593 (diff)
parent7d3842dbd01175dc04cbd77e852b30af3ab5ac35 (diff)
downloaduhd-5c08896e6c4124de69f43f0765468dc4d517920b.tar.gz
uhd-5c08896e6c4124de69f43f0765468dc4d517920b.tar.bz2
uhd-5c08896e6c4124de69f43f0765468dc4d517920b.zip
Merge branch 'uhd_master' into uhd_next
Diffstat (limited to 'host/Modules/UHDPython.cmake')
-rw-r--r--host/Modules/UHDPython.cmake69
1 files changed, 69 insertions, 0 deletions
diff --git a/host/Modules/UHDPython.cmake b/host/Modules/UHDPython.cmake
new file mode 100644
index 000000000..49f74ae88
--- /dev/null
+++ b/host/Modules/UHDPython.cmake
@@ -0,0 +1,69 @@
+#
+# Copyright 2010 Ettus Research LLC
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+########################################################################
+# Setup Python
+########################################################################
+#this allows the user to override PYTHON_EXECUTABLE
+IF(PYTHON_EXECUTABLE)
+
+ SET(PYTHONINTERP_FOUND TRUE)
+
+#otherwise if not set, try to automatically find it
+ELSE(PYTHON_EXECUTABLE)
+
+ #use the built-in find script
+ FIND_PACKAGE(PythonInterp)
+
+ #and if that fails use the find program routine
+ IF(NOT PYTHONINTERP_FOUND)
+ FIND_PROGRAM(PYTHON_EXECUTABLE python)
+ IF(PYTHON_EXECUTABLE)
+ SET(PYTHONINTERP_FOUND TRUE)
+ ENDIF(PYTHON_EXECUTABLE)
+ ENDIF(NOT PYTHONINTERP_FOUND)
+
+ENDIF(PYTHON_EXECUTABLE)
+
+#make the path to the executable appear in the cmake gui
+SET(PYTHON_EXECUTABLE ${PYTHON_EXECUTABLE} CACHE PYTHON_EXECUTABLE "python interpreter")
+
+IF(NOT PYTHONINTERP_FOUND)
+ MESSAGE(FATAL_ERROR "Error: Python interpretor required by the build system.")
+ENDIF(NOT PYTHONINTERP_FOUND)
+
+MACRO(PYTHON_CHECK_MODULE desc mod cmd have)
+ MESSAGE(STATUS "")
+ MESSAGE(STATUS "Python checking for ${desc}")
+ EXECUTE_PROCESS(
+ COMMAND ${PYTHON_EXECUTABLE} -c "
+#########################################
+try: import ${mod}
+except: exit(-1)
+try: assert ${cmd}
+except: exit(-1)
+#########################################"
+ RESULT_VARIABLE ${have}
+ )
+ IF(${have} EQUAL 0)
+ MESSAGE(STATUS "Python checking for ${desc} - found")
+ SET(${have} TRUE)
+ ELSE(${have} EQUAL 0)
+ MESSAGE(STATUS "Python checking for ${desc} - not found")
+ SET(${have} FALSE)
+ ENDIF(${have} EQUAL 0)
+ENDMACRO(PYTHON_CHECK_MODULE)