summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--doc/man/scons.15
-rw-r--r--src/CHANGES.txt11
-rw-r--r--src/engine/SCons/Tool/intelc.py57
3 files changed, 58 insertions, 15 deletions
diff --git a/doc/man/scons.1 b/doc/man/scons.1
index f83fc96..16a7986 100644
--- a/doc/man/scons.1
+++ b/doc/man/scons.1
@@ -5492,6 +5492,11 @@ is the construction environment
(a dictionary of construction values)
in force for this file installation.
+.IP INTEL_C_COMPILER_VERSION
+Set by the "intelc" Tool
+to the major version number of the Intel C compiler
+selected for use.
+
.IP JAR
The Java archive tool.
diff --git a/src/CHANGES.txt b/src/CHANGES.txt
index a35f378..7d5cc23 100644
--- a/src/CHANGES.txt
+++ b/src/CHANGES.txt
@@ -221,10 +221,13 @@ RELEASE 0.97 - XXX
- Avoid copying __builtin__ values into a construction environment's
dictionary when evaluating construction variables.
- - Add a new cross-platform intelc.py Tool that can detect and configure
- the Intel C++ v8 compiler on both Windows, where it's named icl,
- and Linux, where it's named icc. (Niall Douglas contributed an
- early prototype of parts of this module.)
+ - Add a new cross-platform intelc.py Tool that can detect and
+ configure the Intel C++ v8 compiler on both Windows, where it's
+ named icl, and Linux, where it's named icc. It also checks that
+ the directory specified in the Windows registry exists, and sets a
+ new $INTEL_C_COMPILER_VERSION construction variable to identify the
+ version being used. (Niall Douglas contributed an early prototype
+ of parts of this module.)
- Fix the private Conftest._Have() function so it doesn't change
non-alphanumeric characters to underscores.
diff --git a/src/engine/SCons/Tool/intelc.py b/src/engine/SCons/Tool/intelc.py
index 454998a..cea1254 100644
--- a/src/engine/SCons/Tool/intelc.py
+++ b/src/engine/SCons/Tool/intelc.py
@@ -46,6 +46,15 @@ elif is_linux:
import SCons.Util
import SCons.Warnings
+# Exceptions for this tool
+class IntelCError(SCons.Errors.InternalError):
+ pass
+class MissingRegistryError(IntelCError): # missing registry entry
+ pass
+class MissingDirError(IntelCError): # dir not found
+ pass
+class NoRegistryModuleError(IntelCError): # can't read registry at all
+ pass
def fltcmp(a, b):
"""Compare strings as floats"""
@@ -61,7 +70,7 @@ def get_intel_registry_value(valuename, version=None, abi=None):
try:
k = SCons.Util.RegOpenKeyEx(SCons.Util.HKEY_LOCAL_MACHINE, K)
except SCons.Util.RegError:
- raise SCons.Errors.InternalError, \
+ raise MissingRegistryError, \
"%s was not found in the registry, for Intel compiler version %s"%(K, version)
# Get the value:
@@ -69,7 +78,7 @@ def get_intel_registry_value(valuename, version=None, abi=None):
v = SCons.Util.RegQueryValueEx(k, valuename)[0]
return v # or v.encode('iso-8859-1', 'replace') to remove unicode?
except SCons.Util.RegError:
- raise SCons.Errors.InternalError, \
+ raise MissingRegistryError, \
"%s\\%s was not found in the registry."%(K, value)
@@ -90,7 +99,24 @@ def get_all_compiler_versions():
try:
while i < 100:
subkey = SCons.Util.RegEnumKey(k, i) # raises EnvironmentError
- versions.append(subkey)
+ # Check that this refers to an existing dir.
+ # This is not 100% perfect but should catch common
+ # installation issues like when the compiler was installed
+ # and then the install directory deleted or moved (rather
+ # than uninstalling properly), so the registry values
+ # are still there.
+ ok = False
+ for check_abi in ('IA32', 'IA64'):
+ try:
+ d = get_intel_registry_value('ProductDir', subkey, check_abi)
+ except MissingRegistryError:
+ continue # not found in reg, keep going
+ if os.path.exists(d): ok = True
+ if ok:
+ versions.append(subkey)
+ else:
+ # Registry points to nonexistent dir. Ignore this version.
+ print "Ignoring "+str(get_intel_registry_value('ProductDir', subkey, 'IA32'))
i = i + 1
except EnvironmentError:
# no more subkeys
@@ -112,21 +138,21 @@ def get_intel_compiler_top(version=None, abi=None):
if is_win32:
if not SCons.Util.can_read_reg:
- raise SCons.Errors.InternalError, "No Windows registry module was found"
+ raise NoRegistryModuleError, "No Windows registry module was found"
top = get_intel_registry_value('ProductDir', version, abi)
if not os.path.exists(os.path.join(top, "Bin", "icl.exe")):
- raise SCons.Errors.InternalError, \
+ raise MissingDirError, \
"Can't find Intel compiler in %s"%(top)
elif is_linux:
top = '/opt/intel_cc_%s'%version
if not os.path.exists(os.path.join(top, "bin", "icc")):
- raise SCons.Errors.InternalError, \
+ raise MissingDirError, \
"Can't find version %s Intel compiler in %s"%(version,top)
return top
-def generate(env, version=None, abi=None, topdir=None, verbose=1):
+def generate(env, version=None, abi=None, topdir=None, verbose=0):
"""Add Builders and construction variables for Intel C/C++ compiler
to an Environment.
args:
@@ -164,7 +190,7 @@ def generate(env, version=None, abi=None, topdir=None, verbose=1):
if topdir is None and version:
try:
topdir = get_intel_compiler_top(version, abi)
- except (SCons.Util.RegError, SCons.Errors.InternalError):
+ except (SCons.Util.RegError, IntelCError):
topdir = None
if topdir:
@@ -189,10 +215,14 @@ def generate(env, version=None, abi=None, topdir=None, verbose=1):
for p in paths:
try:
path=get_intel_registry_value(p[1], version, abi)
- except SCons.Errors.InternalError:
+ # These paths may have $(ICInstallDir)
+ # which needs to be substituted with the topdir.
+ path=path.replace('$(ICInstallDir)', topdir + os.sep)
+ except IntelCError:
+ # Couldn't get it from registry: use default subdir of topdir
env.PrependENVPath(p[0], os.path.join(topdir, p[2]))
else:
- env.PrependENVPath(p[0], ';'.split(path))
+ env.PrependENVPath(p[0], string.split(path, os.pathsep))
# print "ICL %s: %s, final=%s"%(p[0], path, str(env['ENV'][p[0]]))
if is_win32:
@@ -203,6 +233,11 @@ def generate(env, version=None, abi=None, topdir=None, verbose=1):
env['CC'] = 'icc'
env['CXX'] = 'icpc'
env['LINK'] = '$CC'
+ # This is not the exact (detailed) compiler version,
+ # just the major version as determined above or specified
+ # by the user.
+ if version:
+ env['INTEL_C_COMPILER_VERSION']=float(version)
if is_win32:
# Look for license file dir
@@ -241,7 +276,7 @@ def exists(env):
try:
top = get_intel_compiler_top()
- except (SCons.Util.RegError, SCons.Errors.InternalError):
+ except (SCons.Util.RegError, IntelCError):
top = None
if not top:
# try env.Detect, maybe that will work