# HG changeset patch # User Shinji KONO # Date 1607776549 -32400 # Node ID e937bf565bf81e4e99efba200ba7b7a5bccb3d4a # Parent d782dd481a26afe0c10b1c846f648cd96019622d ... diff -r d782dd481a26 -r e937bf565bf8 sym5n.agda --- a/sym5n.agda Sat Dec 12 20:28:29 2020 +0900 +++ b/sym5n.agda Sat Dec 12 21:35:49 2020 +0900 @@ -59,7 +59,39 @@ FListtoStr [] = "" FListtoStr (cons a x x₁) = primStringAppend (FLtoStr a) (primStringAppend "\n" (FListtoStr x)) -open import IO -- using (IO) +-- open import IO -- using (IO) +open import Data.Maybe hiding (_>>=_) +open import Data.List -- using (IO) +open import Foreign.Haskell using (Unit) +open import IO.Primitive +open import Codata.Musical.Costring + +postulate + getArgs : IO (List String) +{-# FOREIGN GHC import qualified System.Environment #-} +{-# COMPILE GHC getArgs = System.Environment.getArgs #-} -main = run ( putStrLn $ sym5solvable 4) +charToDigit : String → Maybe ℕ +charToDigit "0" = just ( 0) +charToDigit "1" = just ( 1) +charToDigit "2" = just ( 2) +charToDigit "3" = just ( 3) +charToDigit "4" = just ( 4) +charToDigit "5" = just ( 5) +charToDigit "6" = just ( 6) +charToDigit "7" = just ( 7) +charToDigit "8" = just ( 8) +charToDigit "9" = just ( 9) +charToDigit _ = nothing +getNumArg1 : (List String) → ℕ +getNumArg1 [] = 0 +getNumArg1 (x ∷ y) with charToDigit x +... | just n = n +... | nothing = 0 + +main : IO ⊤ +main = do + x <- getArgs + putStrLn $ toCostring $ sym5solvable $ getNumArg1 x +