* Unbreak System.Info for Hugs, rearranging the whole module a bit.
* Platform-specific exports suck, so even Hugs has a compilerVersion
now, although it is currently always version 0.0 :-)
Tested with Hugs only...
------------------------------------------------------------------------------
+<-----------------------------------------------------------------------------
-- |
-- Module : System.Info
-- Copyright : (c) The University of Glasgow 2001
-- |
-- Module : System.Info
-- Copyright : (c) The University of Glasgow 2001
os, -- :: String
arch, -- :: String
compilerName, -- :: String
os, -- :: String
arch, -- :: String
compilerName, -- :: String
-#ifdef __GLASGOW_HASKELL__
compilerVersion -- :: Version
compilerVersion -- :: Version
) where
import Prelude
import Data.Version
) where
import Prelude
import Data.Version
-#ifndef __NHC__
-
-#include "ghcplatform.h"
-
-arch :: String
-arch = HOST_ARCH
-
-os :: String
-os = HOST_OS
+compilerVersion :: Version
+compilerVersion = Version {versionBranch=[maj,min], versionTags=[]}
+ where (maj,min) = compilerVersionRaw `divMod` 100
-#else
-os,arch ::String
-#include "OSInfo.hs"
-#endif
+os, arch, compilerName :: String
+compilerVersionRaw :: Int
+compilerVersionRaw = __NHC__
+
#elif defined(__GLASGOW_HASKELL__)
#elif defined(__GLASGOW_HASKELL__)
+#include "ghcplatform.h"
+os = HOST_OS
+arch = HOST_ARCH
+compilerVersionRaw = __GLASGOW_HASKELL__
+
+#include "platform.h"
+os = HOST_OS
+arch = HOST_ARCH
+compilerVersionRaw = 0 -- ToDo
+
#else
#error Unknown compiler name
#endif
#else
#error Unknown compiler name
#endif
-
-#ifdef __GLASGOW_HASKELL__
-compilerVersion :: Version
-compilerVersion = Version {versionBranch=[maj,min], versionTags=[]}
- where (maj,min) = __GLASGOW_HASKELL__ `divMod` 100
-#endif
-
-#ifdef __NHC__
-compilerVersion :: Version
-compilerVersion = Version {versionBranch=[maj,min], versionTags=[]}
- where version = __NHC__ `divMod` 100
- maj = fst version
- min = snd version
-#endif
-