[GRASS-SVN] r37989 - in grass/trunk/macosx: . app pkg/resources

svn_grass at osgeo.org svn_grass at osgeo.org
Sat Jun 20 00:38:38 EDT 2009


Author: kyngchaos
Date: 2009-06-20 00:38:38 -0400 (Sat, 20 Jun 2009)
New Revision: 37989

Modified:
   grass/trunk/macosx/Makefile
   grass/trunk/macosx/app/Makefile
   grass/trunk/macosx/app/grass.sh.in
   grass/trunk/macosx/pkg/resources/postflight.in
Log:
precompile python scripts for bindist package install as user may not have perms at runtime (from dev6 r37987)

Modified: grass/trunk/macosx/Makefile
===================================================================
--- grass/trunk/macosx/Makefile	2009-06-20 04:30:29 UTC (rev 37988)
+++ grass/trunk/macosx/Makefile	2009-06-20 04:38:38 UTC (rev 37989)
@@ -19,6 +19,8 @@
 MAKE_DIR_CMD = mkdir -p -m 755
 LN = /bin/ln -sf
 LN_DIR = /bin/ln -sfh
+# get python version - use python in path, should be config'd python
+PYVER = `python -V 2>&1 | cut -d \  -f 2 | cut -d . -f 1,2`
 
 # packagemaker location, options and behaviour changed in xcode 3
 ifeq ($(findstring darwin9,$(ARCH)),darwin9)
@@ -95,7 +97,7 @@
 	${MAKE} bundle-macosx
 	@# pkg resources
 	${MAKE_DIR_CMD} dist/resources
-	-sed -e "s#@INST_DIR@#${INST_DIR}#g" -e "s#@MACOSX_SUPPDIR@#${MACOSX_SUPPDIR}#g" -e "s#@GRASS_VER@#${GRASS_VERSION_MAJOR}.${GRASS_VERSION_MINOR}#g" pkg/resources/postflight.in > dist/resources/postflight
+	-sed -e "s#@INST_DIR@#${INST_DIR}#g" -e "s#@MACOSX_SUPPDIR@#${MACOSX_SUPPDIR}#g" -e "s#@GRASS_VER@#${GRASS_VERSION_MAJOR}.${GRASS_VERSION_MINOR}#g" -e "s#@PYVER@#${PYVER}#g" pkg/resources/postflight.in > dist/resources/postflight
 	-chmod a+rx dist/resources/postflight
 	-sed -e "s#@GRASS_VER@#${GRASS_VERSION_MAJOR}.${GRASS_VERSION_MINOR}#g" pkg/resources/Description.plist.in > dist/Description.plist
 	-sed -e "s#@GRASS_VERSION_MAJOR@#${GRASS_VERSION_MAJOR}#g" -e "s#@GRASS_VERSION_MINOR@#${GRASS_VERSION_MINOR}#g" -e "s#@GRASS_VERSION_RELEASE@#${GRASS_VERSION_RELEASE}#g" -e "s#@VER_MINOR_REL@#${VER_MINOR_REL}#g" -e "s#@VER_DATE@#${VER_DATE}#g" -e "s#@PKG_INST_DIR@#${PKG_INST_DIR}#g" pkg/resources/Info.plist.in > dist/Info.plist

Modified: grass/trunk/macosx/app/Makefile
===================================================================
--- grass/trunk/macosx/app/Makefile	2009-06-20 04:30:29 UTC (rev 37988)
+++ grass/trunk/macosx/app/Makefile	2009-06-20 04:38:38 UTC (rev 37989)
@@ -23,6 +23,8 @@
 ifndef PROJ_BIN
 PROJ_BIN = `echo "${NAD2BIN}" | sed -e "s,.=,," -e "s,/nad2bin,:,"`
 endif
+# get python version - use python in path, should be config'd python
+PYVER = `python -V 2>&1 | cut -d \  -f 2 | cut -d . -f 1,2`
 
 NIBSRC := $(wildcard English.lproj/MainMenu.nib/*)
 NIBDST := $(patsubst English.lproj/%,$(APPDIR)/Resources/English.lproj/%,$(NIBSRC))
@@ -94,6 +96,7 @@
 	sed -e "s, at GDAL_BIN_PATH@,$(GDAL_BIN)," \
 	-e "s, at PROJ_BIN_PATH@,$(PROJ_BIN)," \
 	-e "s, at X11@,$(USE_X11),g" \
+	-e "s, at PYVER@,$(PYVER),g" \
 	grass.sh.in > $(OBJDIR)/grass.sh
 
 clean:

Modified: grass/trunk/macosx/app/grass.sh.in
===================================================================
--- grass/trunk/macosx/app/grass.sh.in	2009-06-20 04:30:29 UTC (rev 37988)
+++ grass/trunk/macosx/app/grass.sh.in	2009-06-20 04:38:38 UTC (rev 37989)
@@ -133,7 +133,7 @@
 # change GRASS_WXBUNDLED and pyver_want here from bundle.make, or manually
 GRASS_WXBUNDLED=
 export GRASS_WXBUNDLED
-pyver_want="2.5"
+pyver_want="@PYVER@"
 if [ -d "$GISBASE/etc/wxpython" ] && [ "$GRASS_WXBUNDLED" = "1" ] ; then
 # make sure python version used matches what wxpython wants
 py=""

Modified: grass/trunk/macosx/pkg/resources/postflight.in
===================================================================
--- grass/trunk/macosx/pkg/resources/postflight.in	2009-06-20 04:30:29 UTC (rev 37988)
+++ grass/trunk/macosx/pkg/resources/postflight.in	2009-06-20 04:38:38 UTC (rev 37989)
@@ -22,6 +22,42 @@
 
 #cp -Rf "$PACKAGE_PATH/Contents/Resources/modbuild" "$MACOSX_SUPPDIR"
 
+# cache python - use python version GRASS was compiled for
+
+pyver_want="@PYVER@"
+py=`type -p python`
+if [ "$py" ] ; then
+	pyver=`python -V 2>&1 | grep " $pyver_want"`
+	if [ ! "$pyver" ] ; then
+		py=""
+	else
+		pyconf="python-config"
+	fi
+fi
+# try standard framework
+if [ ! "$py" ] ; then
+	py="/Library/Frameworks/Python.framework/Versions/$pyver_want/bin/python"
+	if [ ! -x "$py" ] ; then
+		py=""
+	else
+		pyconf="/Library/Frameworks/Python.framework/Versions/$pyver_want/bin/python-config"
+	fi
+fi
+# try system (may be the same as in shell path)
+if [ ! "$py" ] ; then
+	py="/usr/bin/python"
+	pyver=`$py -V 2>&1 | grep " $pyver_want"`
+	if [ ! "$pyver" ] ; then
+		py=""
+	else
+		pyconf="/usr/bin/python-config"
+	fi
+fi
+if [ "$py" ] ; then
+	pycompile=`$pyconf --prefix`/lib/python$pyver_want/compileall.py
+	$py $pycompile "$INST_DIR"
+fi
+
 # readme
 # needs a better home?
 



More information about the grass-commit mailing list