EP Symbolization 完善关键字行为
This commit is contained in:
@@ -1,6 +1,7 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
using static System.Net.Mime.MediaTypeNames;
|
using static System.Net.Mime.MediaTypeNames;
|
||||||
|
|
||||||
namespace Convention.Symbolization.Internal
|
namespace Convention.Symbolization.Internal
|
||||||
@@ -217,9 +218,7 @@ namespace Convention.Symbolization.Keyword
|
|||||||
}
|
}
|
||||||
else if (pause == Pause.BeforeBody)
|
else if (pause == Pause.BeforeBody)
|
||||||
{
|
{
|
||||||
if (next is not Internal.ScriptWordVariable swv)
|
if (next is Internal.ScriptWordVariable swv && swv.Word == "{")
|
||||||
throw new InvalidGrammarException($"Not expected keyword for body start, but got {next}");
|
|
||||||
if (swv.Word == "{")
|
|
||||||
{
|
{
|
||||||
pause = Pause.Body;
|
pause = Pause.Body;
|
||||||
layer++;
|
layer++;
|
||||||
@@ -249,60 +248,68 @@ namespace Convention.Symbolization.Keyword
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public abstract void BuildSpace(
|
||||||
|
SymbolizationContext context,
|
||||||
|
List<Internal.Variable> spaceExpression,
|
||||||
|
Dictionary<Internal.Variable, Internal.Variable> scopeStartAndEnd,
|
||||||
|
List<Internal.Variable> insideScopeWords
|
||||||
|
);
|
||||||
|
|
||||||
public override void BuildScope(SymbolizationContext context, List<Internal.Variable> scopeWords)
|
public override void BuildScope(SymbolizationContext context, List<Internal.Variable> scopeWords)
|
||||||
{
|
{
|
||||||
pause = Pause.BeforeExpression;
|
var pause = Pause.BeforeExpression;
|
||||||
layer = 0;
|
List<Internal.Variable> expression = new();
|
||||||
|
Dictionary<Internal.Variable, Internal.Variable> scopeStartAndEnd = new();
|
||||||
|
List<Internal.Variable> insideScopeWords = new();
|
||||||
|
Stack<Internal.Variable> stack = new();
|
||||||
foreach (var word in scopeWords)
|
foreach (var word in scopeWords)
|
||||||
{
|
{
|
||||||
if (pause == Pause.BeforeExpression)
|
if (pause == Pause.BeforeExpression)
|
||||||
{
|
{
|
||||||
if (next is not Internal.ScriptWordVariable swv)
|
|
||||||
throw new InvalidGrammarException($"Not expected a key Word: {next}");
|
|
||||||
if (swv.Word == "(")
|
|
||||||
pause = Pause.Expression;
|
pause = Pause.Expression;
|
||||||
else
|
|
||||||
throw new InvalidGrammarException($"Expected '(' symbol for expression start, but got {next}");
|
|
||||||
}
|
}
|
||||||
else if (pause == Pause.Expression)
|
else if (pause == Pause.Expression)
|
||||||
{
|
{
|
||||||
if (next is Internal.ScriptWordVariable swv && swv.Word == ")")
|
if (word is Internal.ScriptWordVariable swv && swv.Word == ")")
|
||||||
{
|
{
|
||||||
pause = Pause.BeforeBody;
|
pause = Pause.BeforeBody;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
expression.Add(word);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (pause == Pause.BeforeBody)
|
else if (pause == Pause.BeforeBody)
|
||||||
{
|
{
|
||||||
if (next is not Internal.ScriptWordVariable swv)
|
if (word is Internal.ScriptWordVariable swv && swv.Word == "{")
|
||||||
throw new InvalidGrammarException($"Not expected keyword for body start, but got {next}");
|
|
||||||
if (swv.Word == "{")
|
|
||||||
{
|
{
|
||||||
pause = Pause.Body;
|
pause = Pause.Body;
|
||||||
layer++;
|
stack.Push(word);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
pause = Pause.SingleSentence;
|
pause = Pause.SingleSentence;
|
||||||
|
insideScopeWords.Add(word);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (pause == Pause.Body)
|
else if (pause == Pause.Body)
|
||||||
{
|
{
|
||||||
if (next is Internal.ScriptWordVariable swv)
|
if (word is Internal.ScriptWordVariable swv)
|
||||||
{
|
{
|
||||||
if (swv.Word == "{")
|
if (swv.Word == "{")
|
||||||
layer++;
|
stack.Push(word);
|
||||||
else if (swv.Word == "}")
|
else if (swv.Word == "}")
|
||||||
layer--;
|
scopeStartAndEnd.Add(stack.Pop(), word);
|
||||||
if (layer == 0)
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
insideScopeWords.Add(word);
|
||||||
}
|
}
|
||||||
else if (pause == Pause.SingleSentence)
|
else if (pause == Pause.SingleSentence)
|
||||||
{
|
{
|
||||||
if (next is Internal.ScriptWordVariable swv && swv.Word == ";")
|
insideScopeWords.Add(word);
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
BuildSpace(context, expression, scopeStartAndEnd, insideScopeWords);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -315,6 +322,14 @@ namespace Convention.Symbolization.Keyword
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override void BuildSentence(SymbolizationContext context, List<Internal.Variable> sentence)
|
||||||
|
{
|
||||||
|
ToolFile importPath = new(string.Join('/', sentence.ConvertAll(x => (x as Internal.ScriptWordVariable).Word)));
|
||||||
|
if(importPath.Exists()==false)
|
||||||
|
throw new FileNotFoundException(importPath.ToString());
|
||||||
|
new SymbolizationContext(context).Compile(importPath);
|
||||||
|
}
|
||||||
|
|
||||||
public override Internal.Keyword CloneVariable(string targetSymbolName, int lineIndex, int wordIndex)
|
public override Internal.Keyword CloneVariable(string targetSymbolName, int lineIndex, int wordIndex)
|
||||||
{
|
{
|
||||||
return new Import(lineIndex, wordIndex);
|
return new Import(lineIndex, wordIndex);
|
||||||
@@ -329,6 +344,18 @@ namespace Convention.Symbolization.Keyword
|
|||||||
public Namespace(int lineIndex, int wordIndex) : base("namespace", lineIndex, wordIndex)
|
public Namespace(int lineIndex, int wordIndex) : base("namespace", lineIndex, wordIndex)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override void BuildSpace(
|
||||||
|
SymbolizationContext context,
|
||||||
|
List<Internal.ScriptWordVariable> spaceExpression,
|
||||||
|
Dictionary<Internal.Variable, Internal.Variable> scopeStartAndEnd,
|
||||||
|
List<Internal.Variable> insideScopeWords
|
||||||
|
)
|
||||||
|
{
|
||||||
|
//TODO
|
||||||
|
//将命名空间放在新的子上下文中编译
|
||||||
|
}
|
||||||
|
|
||||||
public override Internal.Keyword CloneVariable(string targetSymbolName, int lineIndex, int wordIndex)
|
public override Internal.Keyword CloneVariable(string targetSymbolName, int lineIndex, int wordIndex)
|
||||||
{
|
{
|
||||||
return new Namespace(lineIndex, wordIndex);
|
return new Namespace(lineIndex, wordIndex);
|
||||||
@@ -343,6 +370,18 @@ namespace Convention.Symbolization.Keyword
|
|||||||
public FunctionDef(int lineIndex, int wordIndex) : base("def", lineIndex, wordIndex)
|
public FunctionDef(int lineIndex, int wordIndex) : base("def", lineIndex, wordIndex)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override void BuildSpace(
|
||||||
|
SymbolizationContext context,
|
||||||
|
List<Internal.ScriptWordVariable> spaceExpression,
|
||||||
|
Dictionary<Internal.Variable, Internal.Variable> scopeStartAndEnd,
|
||||||
|
List<Internal.Variable> insideScopeWords
|
||||||
|
)
|
||||||
|
{
|
||||||
|
//TODO
|
||||||
|
//套用语法规则实现表达式向可执行语句的转换
|
||||||
|
}
|
||||||
|
|
||||||
public override Internal.Keyword CloneVariable(string targetSymbolName, int lineIndex, int wordIndex)
|
public override Internal.Keyword CloneVariable(string targetSymbolName, int lineIndex, int wordIndex)
|
||||||
{
|
{
|
||||||
return new FunctionDef(lineIndex, wordIndex);
|
return new FunctionDef(lineIndex, wordIndex);
|
||||||
@@ -357,6 +396,16 @@ namespace Convention.Symbolization.Keyword
|
|||||||
public Return(int lineIndex, int wordIndex) : base("return", lineIndex, wordIndex)
|
public Return(int lineIndex, int wordIndex) : base("return", lineIndex, wordIndex)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override void BuildSentence(SymbolizationContext context, List<Internal.Variable> sentence)
|
||||||
|
{
|
||||||
|
var symbol = sentence[0];
|
||||||
|
//TODO
|
||||||
|
//直接转换为可执行语句
|
||||||
|
//在上下文中搜索被返回的symbol, 存在则返回对应对象, 不存在则返回symbol对象
|
||||||
|
//运行时检查返回值是否满足函数签名的返回值, 否则抛出异常
|
||||||
|
}
|
||||||
|
|
||||||
public override Internal.Keyword CloneVariable(string targetSymbolName, int lineIndex, int wordIndex)
|
public override Internal.Keyword CloneVariable(string targetSymbolName, int lineIndex, int wordIndex)
|
||||||
{
|
{
|
||||||
return new Return(lineIndex, wordIndex);
|
return new Return(lineIndex, wordIndex);
|
||||||
@@ -371,6 +420,19 @@ namespace Convention.Symbolization.Keyword
|
|||||||
public If(int lineIndex, int wordIndex) : base("if", lineIndex, wordIndex)
|
public If(int lineIndex, int wordIndex) : base("if", lineIndex, wordIndex)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override void BuildSpace(
|
||||||
|
SymbolizationContext context,
|
||||||
|
List<Internal.Variable> spaceExpression,
|
||||||
|
Dictionary<Internal.Variable, Internal.Variable> scopeStartAndEnd,
|
||||||
|
List<Internal.Variable> insideScopeWords
|
||||||
|
)
|
||||||
|
{
|
||||||
|
//TODO
|
||||||
|
//检查表达式是否成功, 成功则套用函数翻译规则将作用域翻译为可执行语句
|
||||||
|
//否则跳转到末尾
|
||||||
|
}
|
||||||
|
|
||||||
public override Internal.Keyword CloneVariable(string targetSymbolName, int lineIndex, int wordIndex)
|
public override Internal.Keyword CloneVariable(string targetSymbolName, int lineIndex, int wordIndex)
|
||||||
{
|
{
|
||||||
return new If(lineIndex, wordIndex);
|
return new If(lineIndex, wordIndex);
|
||||||
|
Reference in New Issue
Block a user