[Numpy-svn] r4474 - branches/numpy.scons/numpy/distutils/scons/tools

numpy-svn at scipy.org numpy-svn at scipy.org
Tue Nov 20 04:56:45 EST 2007


Author: cdavid
Date: 2007-11-20 03:56:30 -0600 (Tue, 20 Nov 2007)
New Revision: 4474

Modified:
   branches/numpy.scons/numpy/distutils/scons/tools/f2py.py
Log:
Clean up f2py tool, add a F2PY builer in it

Modified: branches/numpy.scons/numpy/distutils/scons/tools/f2py.py
===================================================================
--- branches/numpy.scons/numpy/distutils/scons/tools/f2py.py	2007-11-20 08:12:09 UTC (rev 4473)
+++ branches/numpy.scons/numpy/distutils/scons/tools/f2py.py	2007-11-20 09:56:30 UTC (rev 4474)
@@ -33,13 +33,17 @@
     build_dir = os.path.dirname(str(target[0]))
     target.append(SCons.Node.FS.default_fs.Entry(
         os.path.join(build_dir, _mangle_fortranobject(str(target[0]), 'fortranobject.c'))))
-    basename = os.path.splitext(os.path.basename(str(target[0])))
-    basename = basename[0]
-    basename = basename.split('module')[0]
-    target.append(SCons.Node.FS.default_fs.Entry(
-        os.path.join(build_dir, '%s-f2pywrappers.f' % basename)))
+    if _is_pyf(str(source[0])):
+        basename = os.path.splitext(os.path.basename(str(target[0])))
+        basename = basename[0]
+        basename = basename.split('module')[0]
+        target.append(SCons.Node.FS.default_fs.Entry(
+            os.path.join(build_dir, '%s-f2pywrappers.f' % basename)))
     return (target, source)
 
+def _is_pyf(source_file):
+    return os.path.splitext(source_file)[1] == '.pyf'
+
 def _pyf2c(target, source, env):
     from SCons.Script import Touch
     from threading import Lock
@@ -54,10 +58,6 @@
     d = os.path.dirname(numpy.f2py.__file__)
     source_c = os.path.join(d,'src','fortranobject.c')
 
-    # XXX: scons has a way to force buidler to only use one source file
-    if len(source_file_names) > 1:
-        raise NotImplementedError("FIXME: multiple source files")
-
     # Copy source files for f2py generated modules in the build dir
     build_dir = os.path.dirname(target_file_names[0])
 
@@ -73,30 +73,29 @@
         raise IOError(msg)
 
     basename = os.path.basename(str(target[0]).split('module')[0])
-    wrapper = os.path.join(build_dir, '%s-f2pywrappers.f' % basename)
 
-    # Generate the source file from pyf description
-    # XXX: lock does not work...
-    #l = Lock()
-    #st = l.acquire()
-    #print "ST is %s" % st
-    try:
-        #print " STARTING %s" % basename
-        st = numpy.f2py.run_main(env['F2PYOPTIONS'] + [source_file_names[0], '--build-dir', build_dir])
+    if _is_pyf(source_file_names[0]):
+        # XXX: scons has a way to force buidler to only use one source file
+        if len(source_file_names) > 1:
+            raise NotImplementedError("FIXME: multiple source files")
+        
+        wrapper = os.path.join(build_dir, '%s-f2pywrappers.f' % basename)
+
+        cmd = env['F2PYOPTIONS'] + [source_file_names[0], '--build-dir', build_dir]
+        st = numpy.f2py.run_main(cmd)
+
         if not os.path.exists(wrapper):
-            #print "++++++++++++++++++++++++++++++++"
             f = open(wrapper, 'w')
             f.close()
-        else:
-            pass
-            #print "--------------------------------"
-        #print " FINISHED %s" % basename
-    finally:
-        #l.release()
-        pass
+    else:
+        cmd = env['F2PYOPTIONS'] + source_file_names + ['--build-dir', build_dir]
+        # fortran files, we need to give the module name
+        cmd.extend(['--lower', '-m', basename])
+        st = numpy.f2py.run_main(cmd)
 
     return 0
 
+
 def generate(env):
     """Add Builders and construction variables for swig to an Environment."""
     import numpy.f2py
@@ -119,6 +118,10 @@
     scanner = SCons.Scanner.ClassicCPP("F2PYScan", ".pyf", "F2PYPATH", expr)
     env.Append(SCANNERS = scanner)
 
+    env['BUILDERS']['F2PY'] = SCons.Builder.Builder(action = _pyf2c, 
+                                                    emitter = _f2pyEmitter,
+                                                    suffix = _f2pySuffixEmitter)
+
 _MINC = re.compile(r'<include_file=(\S+)>')                                              
 def _pyf_scanner(node, env, path):
     print "================== SCANNING ===================="




More information about the Numpy-svn mailing list