最終更新
最終更新
TypeScriptコンパイラのソースは、フォルダの下にあります。
それは以下の主要な部分に分割されます:
Scanner(scanner.ts
)
Parser(parser.ts
)
Binder(binder.ts
)
checker(checker.ts
)
emitter(emitter.ts
)
これらのそれぞれは、ソース内で独自のファイルを取得します。これらの部分については、この章の後半で説明します。
私たちは、というプロジェクトを持っています。これは内部APIを公開する等によって、コンパイラのAPIを使って遊びやすくしています。あなたはこれを使用して、ローカルアプリケーションのTypeScriptのバージョンをグローバルに公開することができます。
文法(シンタックス)が正しいものが_意味_(セマンティクス)が正しいことを意味するわけではありません。以下のTypeScriptコードを考えてみましょう。文法は有効ですが、意味は間違っています:
Semantic
は英語で「意味」を意味します。このコンセプトが頭の中にあると便利です。
以下は、TypeScriptコンパイラのこれらの主要部分の構成の概要です。
Symbol
はTypeScript _semantic_システムの主要な建設部材です。示されているように、シンボルはバインディングの結果として作成されます。シンボルは、AST内の宣言ノードを、同じエンティティに寄与する他の宣言に接続します。
Symbols + ASTは、ソースコードの意味(セマンティクス)を検証するためにチェッカーが使用するものです
最後にJS出力が要求されたとき:
TypeScriptコンパイラには、これらの主要部分にユーティリティを提供するいくつかのファイルがあります。次で説明します。
core.ts
:TypeScriptコンパイラが使うコアユーティリティ。いくつか重要なもの:
let objectAllocator: ObjectAllocator
:シングルトンのグローバルとして定義された変数です。それは、getNodeConstructor
(Nodeはparser
/AST
を見るときに扱います)、getSymbolConstructor
(シンボルはbinder
のときに扱います)、getTypeConstructor
(型はchecker
で扱います)、 getSignatureConstructor
(シグネチャはインデックス、シグネチャの呼び出しと構成物です)。
types.ts
には、コンパイラ全体で使用される、主要なデータ構造とインターフェースがあります。いくつかの重要なサンプルの抜粋です:
SyntaxKind
ASTノードタイプは、SyntaxKind
enumによって識別されます。
TypeChecker
TypeCheckerが提供するインターフェースです。
CompilerHost
これはProgram
がSystem
と対話するために使用されます。
Node
ASTのノードです。
system.ts
です。TypeScriptコンパイラとオペレーティングシステムとのすべての対話は、System
インターフェースを介して行われます。インターフェースとその実装( WScript
とNode
)はsystem.ts
で定義されています。あなたはそれを_Operating Environment_(OE)として考えることができます。
主要なファイルの概要を知ったので、Program
の概念を見ていきましょう。