[GRASS-SVN] r36784 - in grass/branches/develbranch_6/gui/wxpython:
. nviz vdigit
svn_grass at osgeo.org
svn_grass at osgeo.org
Sat Apr 18 17:44:13 EDT 2009
Author: martinl
Date: 2009-04-18 17:44:13 -0400 (Sat, 18 Apr 2009)
New Revision: 36784
Added:
grass/branches/develbranch_6/gui/wxpython/build_ext.py
Modified:
grass/branches/develbranch_6/gui/wxpython/nviz/Makefile
grass/branches/develbranch_6/gui/wxpython/nviz/setup.py
grass/branches/develbranch_6/gui/wxpython/vdigit/Makefile
grass/branches/develbranch_6/gui/wxpython/vdigit/setup.py
Log:
Build wxGUI Python extension using distutils
(merge from trunk, r36782)
Copied: grass/branches/develbranch_6/gui/wxpython/build_ext.py (from rev 36782, grass/trunk/gui/wxpython/build_ext.py)
===================================================================
--- grass/branches/develbranch_6/gui/wxpython/build_ext.py (rev 0)
+++ grass/branches/develbranch_6/gui/wxpython/build_ext.py 2009-04-18 21:44:13 UTC (rev 36784)
@@ -0,0 +1,53 @@
+# Build wxGUI extensions (vdigit and nviz)
+
+import os
+import sys
+
+def __read_variables(file, dict={}):
+ """Read variables from file (e.g. Platform.make)
+
+ @param file file descriptor
+ @param dict dictionary to store (variable, value)
+ """
+ for line in file.readlines():
+ if len(line) < 1:
+ continue # skip empty lines
+ if line[0] == '#':
+ continue # skip comments
+ try:
+ var, val = line.split('=', 1)
+ except ValueError:
+ continue
+
+ dict[var.strip()] = val.strip()
+
+def update_opts(flag, macros, inc_dirs, lib_dirs, libs):
+ """Update Extension options"""
+ global variables
+ line = variables[flag]
+ for val in line.split(' '):
+ key = val[:2]
+ if key == '-I': # includes
+ inc_dirs.append(val[2:])
+ elif key == '-D': # macros
+ if '=' in val[2:]:
+ macros.append(tuple(val[2:].split('=')))
+ else:
+ macros.append((val[2:], None))
+ elif key == '-L': # libs dir
+ lib_dirs.append(val[2:])
+ elif key == '-l':
+ libs.append(val[2:])
+
+try:
+ Platform_make = open(os.path.join('..', '..', '..',
+ 'include', 'Make', 'Platform.make'))
+ Grass_make = open(os.path.join('..', '..', '..',
+ 'include', 'Make', 'Grass.make'))
+except IOError, e:
+ print 'Unable to compile wxGUI vdigit extension.\n\n', e
+ sys.exit(1)
+
+variables = {}
+__read_variables(Platform_make, variables)
+__read_variables(Grass_make, variables)
Modified: grass/branches/develbranch_6/gui/wxpython/nviz/Makefile
===================================================================
--- grass/branches/develbranch_6/gui/wxpython/nviz/Makefile 2009-04-18 21:10:01 UTC (rev 36783)
+++ grass/branches/develbranch_6/gui/wxpython/nviz/Makefile 2009-04-18 21:44:13 UTC (rev 36784)
@@ -2,30 +2,12 @@
include $(MODULE_TOPDIR)/include/Make/Lib.make
-SHLIB_LD = $(CXX) -shared
-
LIB_NAME = grass6_wxnviz
-SOURCES := $(wildcard *.cpp) $(LIB_NAME)_wrap.cpp
-SHLIB_OBJS := $(patsubst %.cpp, $(OBJDIR)/%.o, $(SOURCES))
-EXTRA_CFLAGS = $(SHLIB_CFLAGS) $(GDALCFLAGS) $(PYTHONCFLAGS) $(WXWIDGETSCXXFLAGS) $(XCFLAGS) $(XMINC)
-EXTRA_LIBS = $(GISLIB) $(OGSFLIB) $(NVIZLIB) $(OPENGLLIB) $(OPENGLULIB)
-ifeq ($(findstring darwin,$(ARCH)),darwin)
-EXTRA_LIBS := -bundle -undefined dynamic_lookup $(EXTRA_LIBS)
-CXXFLAGS := $(subst -arch ppc64,,$(subst -arch x86_64,,$(CXXFLAGS)))
-LDFLAGS := $(subst -arch ppc64,,$(subst -arch x86_64,,$(LDFLAGS)))
-else
-EXTRA_LIBS := $(PYTHONLDFLAGS) $(WXWIDGETSLIB) $(EXTRA_LIBS)
-endif
+SHLIB = $(OBJDIR)/_$(LIB_NAME).so
-LOCAL_HEADERS = nviz.h
-
ETCDIR = $(ETC)/wxpython
-SHLIB = $(OBJDIR)/_$(LIB_NAME).so
-
-EXTRA_CLEAN_FILES = $(SHLIB) $(LIB_NAME).i $(LIB_NAME).py $(LIB_NAME)_wrap.cpp
-
default:
ifneq ($(USE_WXWIDGETS),)
@@ -43,24 +25,18 @@
echo "/* auto-generated swig typedef file */" >> $(LIB_NAME).i
cat nviz.h >> $(LIB_NAME).i
-$(LIB_NAME).py $(LIB_NAME)_wrap.cpp: $(LIB_NAME).i
- $(SWIG) -c++ -python -shadow -o $(LIB_NAME)_wrap.cpp $<
+$(LIB_NAME).py: $(SHLIB)
-$(SHLIB): $(SHLIB_OBJS)
-ifeq ($(findstring darwin,$(ARCH)),darwin)
- $(CXX) -o $@ $(LDFLAGS) $^ $(EXTRA_LIBS)
-else
- $(SHLIB_LD) -o $@ $(LDFLAGS) $^ $(EXTRA_LIBS)
-endif
+$(SHLIB): $(LIB_NAME).i
+ python setup.py build_ext --swig=$(SWIG) --build-lib=$(OBJDIR) --build-temp=$(OBJDIR)
-install_nviz:
- $(MAKE) $(ETCDIR)/nviz/_$(LIB_NAME).so $(ETCDIR)/nviz/$(LIB_NAME).py
+.NOTPARALLEL: $(LIB_NAME).py $(LIB_NAME)_wrap.cpp
+install_nviz: $(ETCDIR)/nviz/_$(LIB_NAME).so $(ETCDIR)/nviz/$(LIB_NAME).py
+
$(ETCDIR)/nviz/_$(LIB_NAME).so: $(SHLIB)
$(INSTALL) $< $@
$(ETCDIR)/nviz/$(LIB_NAME).py: $(LIB_NAME).py
$(INSTALL_DATA) $< $@
-.PHONY: install_nviz
-
Modified: grass/branches/develbranch_6/gui/wxpython/nviz/setup.py
===================================================================
--- grass/branches/develbranch_6/gui/wxpython/nviz/setup.py 2009-04-18 21:10:01 UTC (rev 36783)
+++ grass/branches/develbranch_6/gui/wxpython/nviz/setup.py 2009-04-18 21:44:13 UTC (rev 36784)
@@ -1,24 +1,56 @@
-# currently used only for osgeo4w
-# TODO: use instead of Makefile
+#!/usr/bin/env python
+
+# Setup script for wxGUI vdigit extension.
+
+import os
+import sys
+
+sys.path.append('..')
+from build_ext import variables
+from build_ext import update_opts
+
from distutils.core import setup, Extension
+macros = [('PACKAGE', '"grasslibs"')]
+inc_dirs = [os.path.join(variables['GRASS_HOME'],
+ 'dist.' + variables['ARCH'],
+ 'include')]
+lib_dirs = [os.path.join(variables['GRASS_HOME'],
+ 'dist.' + variables['ARCH'],
+ 'lib')]
+
+
+libs = ['grass_gis',
+ 'grass_nviz',
+ 'grass_ogsf',
+ 'grass_g3d']
+
+for flag in ('GDALCFLAGS',
+ 'GDALLIBS',
+ 'WXWIDGETSCXXFLAGS',
+ 'WXWIDGETSLIB'):
+ update_opts(flag, macros, inc_dirs, lib_dirs, libs)
+
setup(
- ext_modules= [
- Extension(
- '_grass6_wxnviz',
- sources=[
- "grass6_wxnviz.i",
- "change_view.cpp",
- "draw.cpp",
- "init.cpp",
- "lights.cpp",
- "load.cpp",
- "surface.cpp",
- "vector.cpp",
- "volume.cpp",
- ],
- swig_opts=['-c++','-shadow'],
- libraries=['grass_gis','grass_nviz','grass_ogsf','grass_g3d']
- )
+ ext_modules= [
+ Extension(
+ name = '_grass6_wxnviz',
+ sources=["change_view.cpp",
+ "draw.cpp",
+ "init.cpp",
+ "lights.cpp",
+ "load.cpp",
+ "surface.cpp",
+ "vector.cpp",
+ "volume.cpp",
+ "grass6_wxnviz.i"],
+ swig_opts = ['-c++',
+ '-shadow'],
+ define_macros = macros,
+ include_dirs = inc_dirs,
+ library_dirs = lib_dirs,
+ libraries = libs,
+ )
]
-)
+ )
+
Modified: grass/branches/develbranch_6/gui/wxpython/vdigit/Makefile
===================================================================
--- grass/branches/develbranch_6/gui/wxpython/vdigit/Makefile 2009-04-18 21:10:01 UTC (rev 36783)
+++ grass/branches/develbranch_6/gui/wxpython/vdigit/Makefile 2009-04-18 21:44:13 UTC (rev 36784)
@@ -2,30 +2,12 @@
include $(MODULE_TOPDIR)/include/Make/Lib.make
-SHLIB_LD = $(CXX) -shared
-
LIB_NAME = grass6_wxvdigit
-SOURCES := $(wildcard *.cpp) $(LIB_NAME)_wrap.cpp
-SHLIB_OBJS := $(patsubst %.cpp, $(OBJDIR)/%.o, $(SOURCES))
-EXTRA_CFLAGS = $(SHLIB_CFLAGS) $(GDALCFLAGS) $(PYTHONCFLAGS) $(WXWIDGETSCXXFLAGS)
-EXTRA_LIBS = $(VECTLIB) $(GISLIB) $(GDALLIBS) $(VEDITLIB)
-ifeq ($(findstring darwin,$(ARCH)),darwin)
-EXTRA_LIBS := -bundle -undefined dynamic_lookup $(EXTRA_LIBS)
-CXXFLAGS := $(subst -arch ppc64,,$(subst -arch x86_64,,$(CXXFLAGS)))
-LDFLAGS := $(subst -arch ppc64,,$(subst -arch x86_64,,$(LDFLAGS)))
-else
-EXTRA_LIBS := $(PYTHONLDFLAGS) $(WXWIDGETSLIB) $(EXTRA_LIBS)
-endif
+SHLIB = $(OBJDIR)/_$(LIB_NAME).so
-LOCAL_HEADERS = digit.h driver.h pseudodc.h
-
ETCDIR = $(ETC)/wxpython
-SHLIB = $(OBJDIR)/_$(LIB_NAME).so
-
-EXTRA_CLEAN_FILES = $(SHLIB) $(LIB_NAME).i $(LIB_NAME).py $(LIB_NAME)_wrap.cpp
-
default:
ifneq ($(USE_WXWIDGETS),)
@@ -41,18 +23,13 @@
echo "/* auto-generated swig typedef file */" >> $(LIB_NAME).i
cat driver.h digit.h >> $(LIB_NAME).i
-$(LIB_NAME).py $(LIB_NAME)_wrap.cpp: $(LIB_NAME).i
- $(SWIG) -c++ -python -shadow -o $(LIB_NAME)_wrap.cpp $<
+$(LIB_NAME).py: $(SHLIB)
+$(SHLIB): $(LIB_NAME).i
+ python setup.py build_ext --swig=$(SWIG) --build-lib=$(OBJDIR) --build-temp=$(OBJDIR)
+
.NOTPARALLEL: $(LIB_NAME).py $(LIB_NAME)_wrap.cpp
-$(SHLIB): $(SHLIB_OBJS)
-ifeq ($(findstring darwin,$(ARCH)),darwin)
- $(CXX) -o $@ $(LDFLAGS) $^ $(EXTRA_LIBS)
-else
- $(SHLIB_LD) -o $@ $(LDFLAGS) $^ $(EXTRA_LIBS)
-endif
-
install_vdigit: $(ETCDIR)/vdigit/_$(LIB_NAME).so $(ETCDIR)/vdigit/$(LIB_NAME).py
$(ETCDIR)/vdigit/_$(LIB_NAME).so: $(SHLIB)
Modified: grass/branches/develbranch_6/gui/wxpython/vdigit/setup.py
===================================================================
--- grass/branches/develbranch_6/gui/wxpython/vdigit/setup.py 2009-04-18 21:10:01 UTC (rev 36783)
+++ grass/branches/develbranch_6/gui/wxpython/vdigit/setup.py 2009-04-18 21:44:13 UTC (rev 36784)
@@ -1,27 +1,57 @@
-# currently used only for osgeo4w
-# TODO: use instead of Makefile
+#!/usr/bin/env python
+
+# Setup script for wxGUI vdigit extension.
+
+import os
+import sys
+
+sys.path.append('..')
+from build_ext import variables
+from build_ext import update_opts
+
from distutils.core import setup, Extension
+macros = [('PACKAGE', '"grasslibs"')]
+inc_dirs = [os.path.join(variables['GRASS_HOME'],
+ 'dist.' + variables['ARCH'],
+ 'include')]
+lib_dirs = [os.path.join(variables['GRASS_HOME'],
+ 'dist.' + variables['ARCH'],
+ 'lib')]
+libs = ['grass_dbmibase',
+ 'grass_dbmiclient',
+ 'grass_vect',
+ 'grass_gis',
+ 'grass_vedit']
+
+for flag in ('GDALCFLAGS',
+ 'GDALLIBS',
+ 'WXWIDGETSCXXFLAGS',
+ 'WXWIDGETSLIB'):
+ update_opts(flag, macros, inc_dirs, lib_dirs, libs)
+
setup(
- ext_modules= [
- Extension(
- '_grass6_wxvdigit',
- sources=[
- "grass6_wxvdigit.i",
- "cats.cpp",
- "driver.cpp",
- "driver_draw.cpp",
- "driver_select.cpp",
- "line.cpp",
- "message.cpp",
- "select.cpp",
- "undo.cpp",
- "vertex.cpp",
- "pseudodc.cpp",
- "digit.cpp"
- ],
- swig_opts=['-c++','-shadow'],
- libraries=['grass_dbmibase', 'grass_dbmiclient', 'grass_vect','grass_gis','grass_vedit','gdal_i', 'wxbase28u', 'wxmsw28u_core']
- )
+ ext_modules= [
+ Extension(
+ name = '_grass6_wxvdigit',
+ sources = ["cats.cpp",
+ "driver.cpp",
+ "driver_draw.cpp",
+ "driver_select.cpp",
+ "line.cpp",
+ "message.cpp",
+ "select.cpp",
+ "undo.cpp",
+ "vertex.cpp",
+ "pseudodc.cpp",
+ "digit.cpp",
+ "grass6_wxvdigit.i"],
+ swig_opts = ['-c++',
+ '-shadow'],
+ define_macros = macros,
+ include_dirs = inc_dirs,
+ library_dirs = lib_dirs,
+ libraries = libs,
+ )
]
-)
+ )
More information about the grass-commit
mailing list