-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathNiConverter.hs
33 lines (27 loc) · 1.02 KB
/
NiConverter.hs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
{-# LANGUAGE OverloadedStrings #-}
-- A converter tool of brainf*ck code to nico-lang code
module Main where
import Data.Text (Text)
import System.Environment (getArgs)
import qualified Data.Text as T
import qualified Data.Text.IO as T
-- Read brainf*ck code from ./hello.bf .
-- Output nico-lang code to stdout,
-- its code means same as its brainf*ck code.
main :: IO ()
main = do
targetFile <- head <$> getArgs
bfCode <- T.pack <$> readFile targetFile
let nicoCode = T.concatMap niconvert bfCode
T.putStrLn nicoCode
-- Convert bf char to nico-lang text
niconvert :: Char -> Text
niconvert '>' = "笑顔届ける矢澤にこにこ!"
niconvert '<' = "だめだめだめっ!"
niconvert '+' = "にっこにっこにー"
niconvert '-' = "にこにーって覚えてラブニコ!"
niconvert '.' = "ぴょんぴょんぴょんっ!"
niconvert ',' = "あなたのハートににこにこにー!"
niconvert '[' = "にこにーはみんなのもの!"
niconvert ']' = "キモチワルイ"
niconvert c = T.singleton c