support for Lazy.Text;
authorwenzelm
Sat, 31 Jul 2021 23:15:17 +0200
changeset 74096 cb64ccdc3ac1
parent 74095 cc23b4e66dce
child 74097 6d7be1227d02
support for Lazy.Text;
src/Tools/Haskell/Haskell.thy
--- a/src/Tools/Haskell/Haskell.thy	Sat Jul 31 22:03:33 2021 +0200
+++ b/src/Tools/Haskell/Haskell.thy	Sat Jul 31 23:15:17 2021 +0200
@@ -226,6 +226,7 @@
 
 import qualified Data.Text as Text
 import Data.Text (Text)
+import qualified Data.Text.Lazy as Lazy
 import Data.String (IsString)
 import qualified Data.List.Split as Split
 import qualified Isabelle.Symbol as Symbol
@@ -297,21 +298,25 @@
 class (IsString a, Monoid a, Eq a, Ord a) => StringLike a
 instance StringLike String
 instance StringLike Text
+instance StringLike Lazy.Text
 instance StringLike Bytes
 
 class StringLike a => STRING a where make_string :: a -> String
 instance STRING String where make_string = id
 instance STRING Text where make_string = Text.unpack
+instance STRING Lazy.Text where make_string = Lazy.unpack
 instance STRING Bytes where make_string = UTF8.decode
 
 class StringLike a => TEXT a where make_text :: a -> Text
 instance TEXT String where make_text = Text.pack
 instance TEXT Text where make_text = id
+instance TEXT Lazy.Text where make_text = Lazy.toStrict
 instance TEXT Bytes where make_text = UTF8.decode
 
 class StringLike a => BYTES a where make_bytes :: a -> Bytes
 instance BYTES String where make_bytes = UTF8.encode
 instance BYTES Text where make_bytes = UTF8.encode
+instance BYTES Lazy.Text where make_bytes = UTF8.encode . Lazy.toStrict
 instance BYTES Bytes where make_bytes = id