2013年12月2日月曜日

開発環境

C実践プログラミング 第3版 (Steve Oualline (著)、 望月 康司 (監訳) (翻訳)、谷口 功 (翻訳)、オライリー・ジャパン)のⅡ部(単純なプログラミング)の14章(ファイル入出力)、14.1(ファイル関数)、14.2(変換ルーチン)、14.3(バイナリファイルとASCIIファイル)、14.4(行終端にまつわる謎)、14.5(バイナリI/O)、14.6(バッファリングの問題)、14.7(バッファリングを行わないI/O)、14.8(ファイル形式の設計)、14.10(プログラミング実習)、実習 14-2をHaskellで解いてみる。

その他参考書籍

実習14-2.

コード(BBEdit)

Sample.hs

{-# OPTIONS -Wall -Werror #-}
import System.Environment
import System.IO as IO

main :: IO ()
main = do
    args <- getArgs
    if length args /= 2 then
        error "Error: Wrong number of arguments\nUsabe is:copy <from> <to>"
    else do
        contents <- readFile $ args !! 0
        IO.withFile (args !! 1) AppendMode $ \handle ->
            mapM_ (\x -> if x == '\t' then
                             IO.hPutStr handle "(tab)"
                         else
                             IO.hPutChar handle x) contents

-- tab
--      

入出力結果(Terminal, runghc)

$ ghc --make Sample
[1 of 1] Compiling Main             ( Sample.hs, Sample.o )
Linking Sample ...
$ ./Sample
Sample: Error: Wrong number of arguments
Usabe is:copy <from> <to>
$ ./Sample Sample.hs temp.out
$ cat temp.out
{-# OPTIONS -Wall -Werror #-}
import System.Environment
import System.IO as IO

main :: IO ()
main = do
    args <- getArgs
    if length args /= 2 then
        error "Error: Wrong number of arguments\nUsabe is:copy <from> <to>"
    else do
        contents <- readFile $ args !! 0
        IO.withFile (args !! 1) AppendMode $ \handle ->
            mapM_ (\x -> if x == '\t' then
                             IO.hPutStr handle "(tab)"
                         else
                             IO.hPutChar handle x) contents

-- tab
-- (tab)(tab)(tab)(tab)(tab){-# OPTIONS -Wall -Werror #-}
import System.Environment
import System.IO as IO

main :: IO ()
main = do
    args <- getArgs
    if length args /= 2 then
        error "Error: Wrong number of arguments\nUsabe is:copy <from> <to>"
    else do
        contents <- readFile $ args !! 0
        IO.withFile (args !! 1) AppendMode $ \handle ->
            mapM_ (\x -> if x == '\t' then
                             IO.hPutStr handle "(tab)"
                         else
                             IO.hPutChar handle x) contents

-- tab
-- (tab)(tab)(tab)(tab)(tab)
$

慣れるまでは{-# OPTIONS -Wall -Werror #-}の記述を消さずに細かく型を指定していくことに。

0 コメント:

コメントを投稿