[Piglit] [PATCH] cmake: Require Mako >= 0.7

Chad Versace chad.versace at linux.intel.com
Wed Jun 25 20:47:24 PDT 2014


Piglit began requiring Mako 0.7 as of commit ac1f382 "dispatch:
Generate piglit-dispatch from Khronos XML".

Piglit has required Mako for a long time, and CMake did check for Mako.
But CMake didn't check the version. This patch fixes CMake to require
Mako >= 0.7 and to provide the below hint on failure:

  Hint: Try installing Mako with `pip install --user --upgrade Mako`

Reported-by: Tom Stellard <thomas.stellard at amd.com>
Signed-off-by: Chad Versace <chad.versace at linux.intel.com>
---
 CMakeLists.txt                     | 13 ++----
 cmake/Modules/PiglitFindMako.cmake | 93 ++++++++++++++++++++++++++++++++++++++
 2 files changed, 96 insertions(+), 10 deletions(-)
 create mode 100644 cmake/Modules/PiglitFindMako.cmake

diff --git a/CMakeLists.txt b/CMakeLists.txt
index f875f5b..0b20084 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -183,8 +183,9 @@ if(NOT DEFINED python)
 	message(FATAL_ERROR "python version 2.x (where x >= 6) required")
 endif(NOT DEFINED python)
 
-# Check for the presence of several python packages, which are needed to build
-# generated tests.
+include(PiglitFindMako)
+
+# Require numpy
 execute_process(
 	COMMAND ${python} -c "import numpy"
 	OUTPUT_QUIET
@@ -193,14 +194,6 @@ execute_process(
 if(NOT import_numpy_error_code EQUAL 0)
 	message(FATAL_ERROR "numpy python module not found")
 endif(NOT import_numpy_error_code EQUAL 0)
-execute_process(
-	COMMAND ${python} -c "from mako.template import Template"
-	OUTPUT_QUIET
-	ERROR_QUIET
-	RESULT_VARIABLE import_mako_error_code)
-if(NOT import_mako_error_code EQUAL 0)
-	message(FATAL_ERROR "mako.template python module not found")
-endif(NOT import_mako_error_code EQUAL 0)
 
 # Default to compiling with debug information (`gcc -g`):
 if(NOT CMAKE_BUILD_TYPE)
diff --git a/cmake/Modules/PiglitFindMako.cmake b/cmake/Modules/PiglitFindMako.cmake
new file mode 100644
index 0000000..4b1fcf9
--- /dev/null
+++ b/cmake/Modules/PiglitFindMako.cmake
@@ -0,0 +1,93 @@
+# Copyright 2014 Intel Corporation
+#
+# Permission is hereby granted, free of charge, to any person obtaining a
+# copy of this software and associated documentation files (the "Software"),
+# to deal in the Software without restriction, including without limitation
+# the rights to use, copy, modify, merge, publish, distribute, sublicense,
+# and/or sell copies of the Software, and to permit persons to whom the
+# Software is furnished to do so, subject to the following conditions:
+#
+# The above copyright notice and this permission notice (including the next
+# paragraph) shall be included in all copies or substantial portions of the
+# Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
+# IN THE SOFTWARE.
+
+# This module sets the following variables:
+#
+#   MAKO_REQUIRED_VERSION
+#
+#   MAKO_FOUND (CACHE)
+#       True if and only if the installed Mako version is at least
+#       MAKO_REQUIRED_VERSION.
+#
+#    MAKO_VERSION (CACHE)
+#       If MAKO_FOUND, then this is the installed Mako's full version string,
+#       given by the Python value ``mako.__version__``. Otherwise,
+#       "MAKO_VERSION-NOTFOUND".
+#
+# This module avoids checking the installed Mako version when not needed, by
+# performing the check the check only if the cached MAKO_VERSION does not
+# satisfy the current value of MAKO_REQUIRED_VERSION.
+
+set(MAKO_REQUIRED_VERSION "0.7")
+
+set(__MAKO_CHECK_VERSION_PY "
+try:
+	import mako
+except ImportError as err:
+	import sys
+	sys.exit(err)
+else:
+	print(mako.__version__)
+")
+
+set(__MAKO_INSTALL_HINT "Hint: Try installing Mako with `pip install --user --upgrade Mako`")
+
+if(MAKO_VERSION VERSION_LESS MAKO_REQUIRED_VERSION)
+	message(STATUS "Looking for Mako >= ${MAKO_REQUIRED_VERSION}")
+
+	set(MAKO_FOUND false)
+	set(MAKO_VERSION "MAKO_VERSION-NOTFOUND")
+
+	execute_process(
+		COMMAND ${python} -c "${__MAKO_CHECK_VERSION_PY}"
+		OUTPUT_VARIABLE __MAKO_ACTUAL_VERSION
+		OUTPUT_STRIP_TRAILING_WHITESPACE
+		ERROR_VARIABLE __MAKO_STDERR
+		ERROR_STRIP_TRAILING_WHITESPACE
+		RESULT_VARIABLE __MAKO_EXIT_STATUS
+	)
+
+	if(NOT __MAKO_EXIT_STATUS EQUAL 0)
+		message(SEND_ERROR
+			"  Failed to find Mako\n"
+			"  ${__MAKO_INSTALL_HINT}\n")
+	elseif(__MAKO_ACTUAL_VERSION VERSION_LESS MAKO_REQUIRED_VERSION)
+		message(SEND_ERROR
+			"  Found Mako ${__MAKO_ACTUAL_VERSION}, but Mako >= ${MAKO_REQUIRED_VERSION} is required\n"
+			"  ${__MAKO_INSTALL_HINT}\n")
+	else()
+		message(STATUS "Found Mako ${__MAKO_ACTUAL_VERSION}")
+		set(MAKO_FOUND true)
+		set(MAKO_VERSION "${__MAKO_ACTUAL_VERSION}")
+	endif()
+endif()
+
+if(NOT MAKO_FOUND)
+endif()
+
+set(MAKO_FOUND "${MAKO_FOUND}"
+    CACHE INTERNAL "Was Mako >= ${MAKO_REQUIRED_VERSION} found?"
+    FORCE
+)
+set(MAKO_VERSION "${MAKO_VERSION}"
+    CACHE INTERNAL "Full version string of installed Mako, if MAKO_FOUND."
+    FORCE
+)
-- 
2.0.0.rc1



More information about the Piglit mailing list