[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