From e13e23afa5adacb9bfa7bb7bc89b273242cc64d6 Mon Sep 17 00:00:00 2001 From: Bodigrim Date: Sun, 22 Dec 2024 18:57:30 +0000 Subject: [PATCH] Bracket changes to locale encoding --- README.md | 7 +++++++ src/Test/Tasty/Bench.hs | 23 +++++++++++++++++++---- 2 files changed, 26 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 8daf13d..fffa47e 100644 --- a/README.md +++ b/README.md @@ -396,6 +396,13 @@ look for another way to speed up generation of Fibonacci numbers. : commitBuffer: invalid argument (cannot encode character '\177') ``` + or + + ``` + Uncaught exception ghc-internal:GHC.Internal.IO.Exception.IOException: + : commitBuffer: invalid argument (cannot encode character '\956') + ``` + it means that your locale does not support UTF-8. `tasty-bench` makes an effort to force locale to UTF-8, but sometimes, when benchmarks are a part of a larger application, it's [impossible](https://gitlab.haskell.org/ghc/ghc/-/issues/23606) diff --git a/src/Test/Tasty/Bench.hs b/src/Test/Tasty/Bench.hs index a0de30c..8e413b2 100644 --- a/src/Test/Tasty/Bench.hs +++ b/src/Test/Tasty/Bench.hs @@ -366,6 +366,11 @@ another way to speed up generation of Fibonacci numbers. > : commitBuffer: invalid argument (cannot encode character '\177') + or + + > Uncaught exception ghc-internal:GHC.Internal.IO.Exception.IOException: + > : commitBuffer: invalid argument (cannot encode character '\956') + it means that your locale does not support UTF-8. @tasty-bench@ makes an effort to force locale to UTF-8, but sometimes, when benchmarks are a part of a larger application, it’s @@ -706,7 +711,7 @@ import qualified Prelude import Control.Applicative import Control.Arrow (first, second) import Control.DeepSeq (NFData, force, rnf) -import Control.Exception (bracket, evaluate) +import Control.Exception (bracket, bracket_, evaluate) import Control.Monad (void, unless, guard, (>=>), when) import Data.Foldable (foldMap, traverse_) import Data.Int (Int64) @@ -1307,12 +1312,22 @@ type Benchmark = TestTree defaultMain :: [Benchmark] -> IO () defaultMain bs = do let act = defaultMain' bs - setLocaleEncoding utf8 + bracketUtf8 act + +bracketUtf8 :: IO a -> IO a +bracketUtf8 act = do + prevLocaleEnc <- getLocaleEncoding #if defined(mingw32_HOST_OS) codePage <- getConsoleOutputCP - bracket (setConsoleOutputCP 65001) (const $ setConsoleOutputCP codePage) (const act) + bracket_ + (setLocaleEncoding utf8 >> setConsoleOutputCP 65001) + (setLocaleEncoding prevLocaleEnc >> setConsoleOutputCP codePage) + act #else - act + bracket_ + (setLocaleEncoding utf8) + (setLocaleEncoding prevLocaleEnc) + act #endif defaultMain' :: [Benchmark] -> IO ()