module Test.Unicode(main) where import Development.Shake import Development.Shake.FilePath import Test.Type import General.GetOpt import Control.Exception.Extra import Control.Monad -- | Decode a dull ASCII string to certain unicode points, necessary because -- withArgs (even the UTF8 version) throws an encoding error on the > 256 code points decode :: String -> String decode ('e':'^':xs) = '\xEA' : decode xs -- Latin Small Letter E With Circumflex decode (':':')':xs) = '\x263A' : decode xs -- White Smiling Face decode (x:xs) = x : decode xs decode [] = [] data Arg = Prefix String | Want String opts = [Option "" ["prefix"] (ReqArg (Right . Prefix) "") "" ,Option "" ["want"] (ReqArg (Right . Want) "") ""] main = testBuildArgs test opts $ \xs -> do let pre = last $ "" : [decode x | Prefix x <- xs :: [Arg]] want [decode x | Want x <- xs] pre ++ "dir/*" %> \out -> do let src = takeDirectory (takeDirectory out) takeFileName out copyFile' src out pre ++ ".out" %> \out -> do a <- readFile' $ pre ++ "dir" pre <.> "source" b <- readFile' $ pre <.> "multi1" writeFile' out $ a ++ b ["*.multi1","*.multi2"] &%> \[m1,m2] -> do b <- doesFileExist $ m1 -<.> "exist" writeFile' m1 $ show b writeFile' m2 $ show b test build = do build ["clean"] -- Useful, if the error message starts crashing... -- IO.hSetEncoding IO.stdout IO.char8 -- IO.hSetEncoding IO.stderr IO.char8 forM_ ["normal","e^",":)","e^-:)"] $ \pre -> do let ext x = decode pre <.> x res <- try_ $ writeFile (ext "source") "x" case res of Left _ -> putStrLn $ "WARNING: Failed to write file " ++ pre ++ ", skipping unicode test (LANG=C ?)" Right _ -> do build ["--prefix=" ++ pre, "--want=" ++ pre <.> "out", "--sleep"] assertContents (ext "out") $ "x" ++ "False" writeFile (ext "source") "y" build ["--prefix=" ++ pre, "--want=" ++ pre <.> "out", "--sleep"] assertContents (ext "out") $ "y" ++ "False" writeFile (ext "exist") "" build ["--prefix=" ++ pre, "--want=" ++ pre <.> "out"] assertContents (ext "out") $ "y" ++ "True"