attoparsecはファイルを解析するために私に提案されました、今私はそれを使用する方法を理解しなければなりません。誰かが私にこのコードをくれました:
#
type Environment = M.Map String String
import Data.Attoparsec (maybeResult)
import qualified Data.Attoparsec.Char8 as A
import qualified Data.ByteString.Char8 as B
environment :: A.Parser Environment
environment = M.fromList <$> A.sepBy entry A.endOfLine
parseEnvironment = maybeResult .flip A.feed B.empty . A.parse environment
spaces = A.many $ A.char ' '
entry = (,) <$> upTo ':' <*> upTo ';'
upTo delimiter = B.unpack <$> A.takeWhile (A.notInClass $ delimiter : " ")
<* (spaces >> A.char delimiter >> spaces)
これは非常にうまく機能しますが、理由はわかりません。フリップを使用する理由は何ですか。A.feedの引数を別の順序に並べるのは簡単ではありませんか。そしてなぜB.emptyがあるのですか?私が勉強できることについてのチュートリアルはありますか?前もって感謝します