2
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

言語実装Advent Calendar 2023

Day 4

僕が考える最強の言語処理系

Posted at
  1. mixfix演算子を持つ。
    プログラミングしていてASTを扱いたいと思うことは多々あるわけですが、扱いづらいです。LispのS式やXML, JSON のようにプログラミング言語自体をデータとして扱えると嬉しい。Prologはエジンバラ記法と呼ばれる数式でプログラムします。CoqやAgdaで使われている演算子順位法の1種であるmixfix演算子を使うとより自由度が増します。
  2. 論理プログラミングができる。
    操作的意味論や型付け規則をきれいに書けると言語を理解するのに便利だから論理プログラミングができるとよいです。
  3. 合併型(Untaged Union Type) がある。
    TypeScriptやScala3にあるようなタグレスの合併型は作るのが極めて難しいですが、歴史的に積み上げられた理論で用いられる図式の型システムとなるので大いに意味があります。Elixirの型システムの完成が楽しみですね。
  4. 文法定義がそのまま代数的データ型の型定義にもなる。
    数学的なBNFを書けば木文法に対する構文定義であるXML SchemaやJSON Schemaの定義のようになりかつ、代数的データ型による抽象構文木の型定義となる。具象構文=抽象構文になる。

これらの要件を満たす言語を作れば高レイヤーでの簡潔な言語理解が可能になるので最強な言語となります。

mixfixや論理プログラミング言語は作れるのですが合併型がとにかく難しい。
論理プログラミングの教科書を作らないと理解できる人が少ない状況が続くのが課題です。

2
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?