{"blog_title":"Scala \u3067 TAPL\u3092\u52c9\u5f37\u3057\u3064\u3064 LLVM \u30b3\u30f3\u30d1\u30a4\u30e9\u3092\u4f5c\u308b\u65e5\u8a18","author_url":"https://blog.hatena.ne.jp/h_sakurai/","description":"\u30d1\u30fc\u30b5\u8ffd\u52a0\u3057\u3066\u3001\u7c21\u5358\u306a\u8a55\u4fa1\u5668\u3092\u4ed8\u3051\u3066\u307f\u307e\u3057\u305f\u3088\u3002 \u3053\u308c\u3092\u3069\u3093\u3069\u3093\u62e1\u5f35\u3057\u3066\u3044\u3051\u3070\u3001\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u306fmincaml\u3068\u304b\u3068\u540c\u3058\u7269\u3092\u4f7f\u3063\u305f\u308a\u51fa\u6765\u3066\u697d\u3057\u3044\u306e\u3067\u306f\u306a\u3044\u304b\u3068\u601d\u3044\u307e\u3059\u3002 package C2E5 import util.parsing.combinator._ object parser extends RegexParsers { def expr: Parser[E] = term~rep(\"+\"~>term) ^^ { case a ~ b => b.foldLeft[E](a){case (a, b)=> EAdd(a,b)} } def term : Parser[E] = facto\u2026","provider_url":"https://hatena.blog","author_name":"h_sakurai","height":"190","provider_name":"Hatena Blog","type":"rich","version":"1.0","published":"2014-02-03 00:00:00","url":"https://h-sakurai.hatenadiary.org/entry/20140203/p1","blog_url":"https://h-sakurai.hatenadiary.org/","categories":[],"html":"<iframe src=\"https://hatenablog-parts.com/embed?url=https%3A%2F%2Fh-sakurai.hatenadiary.org%2Fentry%2F20140203%2Fp1\" title=\"C2E\u3092\u5909\u3048\u3066\u307f\u308b - Scala \u3067 TAPL\u3092\u52c9\u5f37\u3057\u3064\u3064 LLVM \u30b3\u30f3\u30d1\u30a4\u30e9\u3092\u4f5c\u308b\u65e5\u8a18\" class=\"embed-card embed-blogcard\" scrolling=\"no\" frameborder=\"0\" style=\"display: block; width: 100%; height: 190px; max-width: 500px; margin: 10px 0px;\"></iframe>","title":"C2E\u3092\u5909\u3048\u3066\u307f\u308b","image_url":null,"width":"100%"}