diff --git a/src/Data/Text/IO.hs b/src/Data/Text/IO.hs index 8bfb6e63..e73d8d88 100644 --- a/src/Data/Text/IO.hs +++ b/src/Data/Text/IO.hs @@ -177,13 +177,13 @@ chooseGoodBuffering h = do hGetLine :: Handle -> IO Text hGetLine = hGetLineWith T.concat + -- | Write a string to a handle. hPutStr :: Handle -> Text -> IO () hPutStr h t = hPutStrInit h $ \mode buf nl -> do (n, b) <- hPutStr' h mode nl buf 0 (stream t) - when (mode /= NoBuffering) $ let - Buffer{bufRaw,bufSize} = b - in void $ commitBuffer h bufRaw bufSize n False True + let Buffer{bufRaw,bufSize} = b + when (n /= 0) $ void $ commitBuffer h bufRaw bufSize n False True {-# INLINE hPutStrInit #-} hPutStrInit :: Handle -> (BufferMode -> CharBuffer -> Newline -> IO ()) -> IO () diff --git a/src/Data/Text/Lazy/IO.hs b/src/Data/Text/Lazy/IO.hs index 87e1a09e..718122f7 100644 --- a/src/Data/Text/Lazy/IO.hs +++ b/src/Data/Text/Lazy/IO.hs @@ -142,9 +142,8 @@ hPutStr :: Handle -> Text -> IO () hPutStr _ L.Empty = pure () hPutStr h t = T.hPutStrInit h $ \mode buf nl -> do (n, b) <- foldlM (\(n, buf) t -> T.hPutStr' h mode nl buf n (stream t)) (0, buf) (L.toChunks t) - when (mode /= NoBuffering && n /= 0) $ let - Buffer{bufRaw,bufSize} = b - in void $ T.commitBuffer h bufRaw bufSize n False True + let Buffer{bufRaw,bufSize} = b + when (n /= 0) $ void $ T.commitBuffer h bufRaw bufSize n False True -- | Write a string to a handle, followed by a newline. hPutStrLn :: Handle -> Text -> IO ()