{-# OPTIONS --cubical-compatible --guardedness #-}
module IO.Infinite where
open import Codata.Musical.Costring using (Costring)
open import Agda.Builtin.String using (String)
open import Data.Unit.Polymorphic.Base using (⊤)
import Data.Unit.Base as Unit0 using (⊤)
open import IO.Base as Base using (IO; lift; lift′)
import IO.Primitive.Core as Prim using (IO; _>>=_; _>>_)
import IO.Primitive.Infinite as Prim
using (getContents; writeFile; appendFile; putStr; putStrLn)
open import Level using (Level; Lift; 0ℓ; suc)
private
variable
a : Level
getContents : IO Costring
getContents = lift Prim.getContents
writeFile : String → Costring → IO {a} ⊤
writeFile f s = lift′ (Prim.writeFile f s)
appendFile : String → Costring → IO {a} ⊤
appendFile f s = lift′ (Prim.appendFile f s)
putStr : Costring → IO {a} ⊤
putStr s = lift′ (Prim.putStr s)
putStrLn : Costring → IO {a} ⊤
putStrLn s = lift′ (Prim.putStrLn s)