-- Copyright 2012-2016 Samplecount S.L. -- -- Licensed under the Apache License, Version 2.0 (the "License"); -- you may not use this file except in compliance with the License. -- You may obtain a copy of the License at -- -- http://www.apache.org/licenses/LICENSE-2.0 -- -- Unless required by applicable law or agreed to in writing, software -- distributed under the License is distributed on an "AS IS" BASIS, -- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -- See the License for the specific language governing permissions and -- limitations under the License. module Development.Shake.Language.C.Host.Windows ( getHostToolChain ) where import Data.Char (isSpace, toLower) import Development.Shake import Development.Shake.Command import Development.Shake.Language.C.Target import Development.Shake.Language.C.Target.Windows import Development.Shake.Language.C.ToolChain import qualified System.Info as System trim :: String -> String trim = reverse . dropWhile isSpace . reverse getHostArch :: IO Arch getHostArch = do Stdout out <- cmd "wmic os get osarchitecture" let spec = map trim . lines $ out case map (map toLower) spec of ("osarchitecture":"32-bit":_) -> return $ X86 I686 ("osarchitecture":"64-bit":_) -> return $ X86 X86_64 ("osarchitecture":arch:_) -> error $ "Unknown host architecture " ++ arch _ -> error $ "Couldn't determine host architecture from " ++ show spec getHostToolChain :: IO (Target, Action ToolChain) getHostToolChain = do t <- fmap target getHostArch return (t, return $ toolChain Generic)