cannam@89: import os.path, sys cannam@89: cannam@89: class ConfigurationError(Exception): cannam@89: def __init__(self, reason): cannam@89: Exception.__init__(self, "Configuration failed: %s" % reason) cannam@89: cannam@89: env = Environment() cannam@89: cannam@89: # sunos, aix, hpux, irix, sunos appear to be platforms known by SCons, assuming they're POSIX compliant cannam@89: Posix = ("linux", "darwin", "sunos", "aix", "hpux", "irix", "sunos", "netbsd") cannam@89: Windows = ("win32", "cygwin") cannam@89: cannam@89: if env["PLATFORM"] == "posix": cannam@89: if sys.platform[:5] == "linux": cannam@89: Platform = "linux" cannam@89: elif sys.platform[:6] == "netbsd": cannam@89: Platform = "netbsd" cannam@89: else: cannam@89: raise ConfigurationError("Unknown platform %s" % sys.platform) cannam@89: else: cannam@89: if not env["PLATFORM"] in ("win32", "cygwin") + Posix: cannam@89: raise ConfigurationError("Unknown platform %s" % env["PLATFORM"]) cannam@89: Platform = env["PLATFORM"] cannam@89: cannam@89: # Inspired by the versioning scheme followed by Qt, it seems sensible enough. There are three components: major, minor cannam@89: # and micro. Major changes with each subtraction from the API (backward-incompatible, i.e. V19 vs. V18), minor changes cannam@89: # with each addition to the API (backward-compatible), micro changes with each revision of the source code. cannam@89: ApiVer = "2.0.0" cannam@89: cannam@89: Export("Platform", "Posix", "ConfigurationError", "ApiVer")