Add prototype icc and ilink Tool specs for OS/2.
authorstevenknight <stevenknight@fdb21ef1-2011-0410-befe-b5e4ea1792b1>
Fri, 12 Jul 2002 03:09:55 +0000 (03:09 +0000)
committerstevenknight <stevenknight@fdb21ef1-2011-0410-befe-b5e4ea1792b1>
Fri, 12 Jul 2002 03:09:55 +0000 (03:09 +0000)
git-svn-id: http://scons.tigris.org/svn/scons/trunk@408 fdb21ef1-2011-0410-befe-b5e4ea1792b1

doc/man/scons.1
rpm/scons.spec
src/CHANGES.txt
src/engine/MANIFEST.in
src/engine/SCons/Platform/os2.py
src/engine/SCons/Tool/icc.py [new file with mode: 0644]
src/engine/SCons/Tool/ilink.py [new file with mode: 0644]
src/engine/SCons/Util.py

index 4f59835519ea954bbe52bbbd01b8ffe4bcd18875..8c02eff6bd60a4177a87367efb9067ea756501ad 100644 (file)
@@ -732,6 +732,8 @@ platforms:
 dvipdf
 dvips
 g77
+icc
+ilink
 latex
 lex
 nasm
index e40a16f87de3a5f5833c0d3caec1bec52ed19125..aae24a6369608ea981bd302ebc4c938e8ceed902 100644 (file)
@@ -116,6 +116,10 @@ rm -rf $RPM_BUILD_ROOT
 /usr/lib/scons/SCons/Tool/gcc.pyc
 /usr/lib/scons/SCons/Tool/gnulink.py
 /usr/lib/scons/SCons/Tool/gnulink.pyc
+/usr/lib/scons/SCons/Tool/icc.py
+/usr/lib/scons/SCons/Tool/icc.pyc
+/usr/lib/scons/SCons/Tool/ilink.py
+/usr/lib/scons/SCons/Tool/ilink.pyc
 /usr/lib/scons/SCons/Tool/latex.py
 /usr/lib/scons/SCons/Tool/latex.pyc
 /usr/lib/scons/SCons/Tool/lex.py
index 45a6517e3f48675c37bc7f7a036602b57dfd7e55..3002297b9f760f61aa2602853470a7b0b7ad3b24 100644 (file)
@@ -84,7 +84,8 @@ RELEASE 0.08 -
 
   - Add a tar archive builder.
 
-  - Add preliminary support for OS/2.
+  - Add preliminary support for the OS/2 Platform, including the icc
+    and ilink Tools.
 
   From Jeff Petkau:
 
index d5be87822b5a596d114cc4c0a787db16ddfc4ff7..118b4ba877520bb4c6fc874ba1f84131b2d2c562 100644 (file)
@@ -33,6 +33,8 @@ SCons/Tool/g77.py
 SCons/Tool/gas.py
 SCons/Tool/gcc.py
 SCons/Tool/gnulink.py
+SCons/Tool/icc.py
+SCons/Tool/ilink.py
 SCons/Tool/latex.py
 SCons/Tool/lex.py
 SCons/Tool/lib.py
index e757c35a2051b5e2c98fb7cb2e2624fe7a05f24c..74df430d76791c12fc74435827f29cadb8973a2a 100644 (file)
@@ -36,7 +36,7 @@ import SCons.Util
 
 def tool_list():
     list = ['dvipdf', 'dvips', 'g77',
-            'latex', 'lex',
+            'icc', 'ilink', 'latex', 'lex',
             'pdflatex', 'pdftex', 'tex', 'yacc']
     if SCons.Util.WhereIs('nasm'):
         list.append('nasm')
@@ -45,7 +45,6 @@ def tool_list():
 def generate(env):
     if not env.has_key('ENV'):
         env['ENV']        = {}
-    #env['ENV']['PATHEXT'] = '.COM;.EXE;.BAT;.CMD'
     env['OBJPREFIX']      = ''
     env['OBJSUFFIX']      = '.obj'
     env['PROGPREFIX']     = ''
diff --git a/src/engine/SCons/Tool/icc.py b/src/engine/SCons/Tool/icc.py
new file mode 100644 (file)
index 0000000..2d8afc9
--- /dev/null
@@ -0,0 +1,69 @@
+"""engine.SCons.Tool.icc
+
+Tool-specific initialization for the OS/2 icc 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
+
+CSuffixes = ['.c', '.C']
+CXXSuffixes = ['.cc', '.cpp', '.cxx', '.c++', '.C++']
+
+def generate(env, platform):
+    """Add Builders and construction variables for MSVC++ to an Environment."""
+    static_obj, shared_obj = SCons.Tool.createObjBuilders(env)
+
+    for suffix in CSuffixes:
+        static_obj.add_action(suffix, SCons.Defaults.CAction)
+        shared_obj.add_action(suffix, SCons.Defaults.ShCAction)
+
+    for suffix in CXXSuffixes:
+        static_obj.add_action(suffix, SCons.Defaults.CXXAction)
+        shared_obj.add_action(suffix, SCons.Defaults.ShCXXAction)
+
+    env['CC']         = 'icc'
+    env['CCFLAGS']    = ''
+    env['CCCOM']      = '$CC $CCFLAGS $CPPFLAGS $_CPPINCFLAGS /c $SOURCES /Fo$TARGET'
+    env['CXX']        = '$CC'
+    env['CXXFLAGS']   = '$CCFLAGS'
+    env['CXXCOM']     = '$CXX $CXXFLAGS $CPPFLAGS $_CPPINCFLAGS /c $SOURCES /Fo$TARGET'
+    env['INCPREFIX']  = '/I'
+    env['INCSUFFIX']  = '' 
+    
+    env['CFILESUFFIX'] = '.c'
+    env['CXXFILESUFFIX'] = '.cc'
+    
diff --git a/src/engine/SCons/Tool/ilink.py b/src/engine/SCons/Tool/ilink.py
new file mode 100644 (file)
index 0000000..460a468
--- /dev/null
@@ -0,0 +1,48 @@
+"""SCons.Tool.ilink
+
+Tool-specific initialization for the OS/2 ilink linker.
+
+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 SCons.Defaults
+
+def generate(env, platform):
+    """Add Builders and construction variables for ilink to an Environment."""
+    env['BUILDERS']['Program'] = SCons.Defaults.Program
+    
+    env['LINK']        = 'ilink'
+    env['LINKFLAGS']   = ''
+    env['LINKCOM']     = '$LINK $LINKFLAGS /O:$TARGET $SOURCES $( $_LIBDIRFLAGS $) $_LIBFLAGS'
+    env['LIBDIRPREFIX']='/LIBPATH:'
+    env['LIBDIRSUFFIX']=''
+    env['LIBLINKPREFIX']=''
+    env['LIBLINKSUFFIX']='$LIBSUFFIX'
index 4c3a57f63c26df9abc9c2bc7ea70d5cd79d390d3..eda8c4070e511deb15ed336cd3fe78a4bd0507ce 100644 (file)
@@ -438,6 +438,27 @@ if sys.platform == 'win32':
                     return fext
         return None
 
+elif os.name == 'os2':
+
+    def WhereIs(file, path=None, pathext=None):
+        if path is None:
+            path = os.environ['PATH']
+        if is_String(path):
+            path = string.split(path, os.pathsep)
+        if pathext is None:
+            pathext = ['.exe', '.cmd']
+        for ext in pathext:
+            if string.lower(ext) == string.lower(file[-len(ext):]):
+                pathext = ['']
+                break
+        for dir in path:
+            f = os.path.join(dir, file)
+            for ext in pathext:
+                fext = f + ext
+                if os.path.isfile(fext):
+                    return fext
+        return None
+
 else:
 
     def WhereIs(file, path=None, pathext=None):