diff options
author | Steven Knight <knight@baldmt.com> | 2002-08-29 10:30:12 (GMT) |
---|---|---|
committer | Steven Knight <knight@baldmt.com> | 2002-08-29 10:30:12 (GMT) |
commit | 10d2e5186125873bdf7f4a0a4b7a5dca1f131af5 (patch) | |
tree | e9ff4e9efdc91e42008f3b76eac059617272dd35 | |
parent | f3b80332dc469f8844e1cc619d13cb88e0432469 (diff) | |
download | SCons-10d2e5186125873bdf7f4a0a4b7a5dca1f131af5.zip SCons-10d2e5186125873bdf7f4a0a4b7a5dca1f131af5.tar.gz SCons-10d2e5186125873bdf7f4a0a4b7a5dca1f131af5.tar.bz2 |
Support the Intel Fortran Compiler.
-rw-r--r-- | doc/man/scons.1 | 4 | ||||
-rw-r--r-- | src/CHANGES.txt | 2 | ||||
-rw-r--r-- | src/engine/SCons/Tool/__init__.py | 2 | ||||
-rw-r--r-- | src/engine/SCons/Tool/ifl.py | 72 |
4 files changed, 79 insertions, 1 deletions
diff --git a/doc/man/scons.1 b/doc/man/scons.1 index fd1b3ff..eb0954c 100644 --- a/doc/man/scons.1 +++ b/doc/man/scons.1 @@ -746,6 +746,7 @@ dvipdf dvips g77 icc +ifl ilink latex lex @@ -764,6 +765,9 @@ platforms: dvipdf dvips g77 +icc +ifl +ilink latex lex lib diff --git a/src/CHANGES.txt b/src/CHANGES.txt index 32479f9..56e86c3 100644 --- a/src/CHANGES.txt +++ b/src/CHANGES.txt @@ -24,6 +24,8 @@ RELEASE 0.09 - - Don't remove source files specified on the command line! + - Suport the Intel Fortran Compiler (ifl.exe). + From Anthony Roach: - Fixed use of command lines with spaces in their arguments, diff --git a/src/engine/SCons/Tool/__init__.py b/src/engine/SCons/Tool/__init__.py index d791526..6d2a44b 100644 --- a/src/engine/SCons/Tool/__init__.py +++ b/src/engine/SCons/Tool/__init__.py @@ -128,7 +128,7 @@ def createCFileBuilders(env): linkers = ['gnulink', 'mslink', 'ilink'] c_compilers = ['gcc', 'msvc', 'icc'] cxx_compilers = ['g++'] # only those that are seperate from the c compiler -fortran_compilers = ['g77'] +fortran_compilers = ['g77', 'ifl'] assemblers = ['gas', 'nasm', 'masm'] other_tools = ['ar', 'dvipdf', 'dvips', 'latex', 'lex', 'lib', diff --git a/src/engine/SCons/Tool/ifl.py b/src/engine/SCons/Tool/ifl.py new file mode 100644 index 0000000..1f4f8f4 --- /dev/null +++ b/src/engine/SCons/Tool/ifl.py @@ -0,0 +1,72 @@ +"""engine.SCons.Tool.icc + +Tool-specific initialization for the Intel Fortran compiler. + +There normally shouldn't be any need to import this module directly. +It will usually be imported through the generic SCons.Tool.Tool() +selection method. + +""" + +# +# Copyright (c) 2001, 2002 Steven Knight +# +# 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 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. +# + +__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__" + +import os.path +import string + +import SCons.Action +import SCons.Tool +import SCons.Errors + +F77Suffixes = ['.f', '.for', '.FOR'] +F77PPSuffixes = ['.fpp', '.FPP'] +if os.path.normcase('.f') == os.path.normcase('.F'): + F77Suffixes.append('.F') +else: + F77PPSuffixes.append('.F') + +def generate(env, platform): + """Add Builders and construction variables for ifl to an Environment.""" + static_obj, shared_obj = SCons.Tool.createObjBuilders(env) + + for suffix in F77Suffixes: + static_obj.add_action(suffix, SCons.Defaults.F77Action) + shared_obj.add_action(suffix, SCons.Defaults.ShF77Action) + + for suffix in F77PPSuffixes: + static_obj.add_action(suffix, SCons.Defaults.F77PPAction) + shared_obj.add_action(suffix, SCons.Defaults.ShF77PPAction) + + env['F77'] = 'ifl' + env['F77FLAGS'] = '' + env['F77COM'] = '$F77 $F77FLAGS $_F77INCFLAGS /c $SOURCES /Fo$TARGET' + env['F77PPCOM'] = '$F77 $F77FLAGS $CPPFLAGS $_F77INCFLAGS /c $SOURCES /Fo$TARGET' + env['SHF77'] = '$F77' + env['SHF77FLAGS'] = '$F77FLAGS' + env['SHF77COM'] = '$SHF77 $SHF77FLAGS $_F77INCFLAGS /c $SOURCES /Fo$TARGET' + env['SHF77PPCOM'] = '$SHF77 $SHF77FLAGS $CPPFLAGS $_F77INCFLAGS /c $SOURCES /Fo$TARGET' + +def exists(): + return SCons.Util.WhereIs('ifl') |