Bug fixes

This commit is contained in:
Valk Richard Li 2019-08-24 11:38:22 -05:00 committed by GitHub
parent 194777ab40
commit 936053c2a5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 38 additions and 10 deletions

View File

@ -45,9 +45,11 @@ data type = <scalar> <identifier> <calculation> <list> <hash> <function>
<func> <(> <identifier>|<identifiers> <)> <{> <statement> <}> <func> <(> <identifier>|<identifiers> <)> <{> <statement> <}>
<1><definition> ::= <1><definition> ::=
<var> <identifier> <=> <scalar>|<identifier>|<list>|<hash>|<calculation> <;> <var> <identifier> <=> <scalar>|<identifier>|<list>|<hash>|<calculation> <;>
<var> <identifier> <=> <(> <scalar>|<identifier>|<list>|<hash>|<calculation> <)> <;>
<var> <identifier> <=> <function> <var> <identifier> <=> <function>
<1><assigntment> ::= <1><assigntment> ::=
<!=var> <identifier> <=> <scalar>|<identifier>|<list>|<hash>|<calculation> <;> <!=var> <identifier> <=> <scalar>|<identifier>|<list>|<hash>|<calculation> <;>
<!=var> <identifier> <=> <(> <scalar>|<identifier>|<list>|<hash>|<calculation> <)> <;>
<statement> ::= <statement> ::=
<!=<for> <(>> <definition>|<assignment> <!=<for> <(>> <definition>|<assignment>
<return> <scalar>|<identifier>|<list>|<hash>|<calculation> <;> <return> <scalar>|<identifier>|<list>|<hash>|<calculation> <;>

View File

@ -20,3 +20,5 @@ var e=e.e("str",1).e()*e.e("str",1).e*0.001;
e.e("str",1).e("str",e-e); e.e("str",1).e("str",e-e);
e.e(e("str",e.e()/2880)~"str"); e.e(e("str",e.e()/2880)~"str");
var e=func(){e;}; var e=func(){e;};
var e=e+e-e;
var e=e+e+e+e;

View File

@ -7,8 +7,10 @@ int main()
nasal_lexer lex; nasal_lexer lex;
nasal_parser par; nasal_parser par;
std::string command; std::string command;
std::cout<<">> nasal-- script by ValKmjolnir"<<std::endl; std::cout<<">> nasal script interpreter by ValKmjolnir"<<std::endl;
std::cout<<">> input \"help\" to find help."<<std::endl; std::cout<<">> input \"help\" to find help."<<std::endl;
std::cout<<">> Be careful: this interpreter uses strict methods to check if there's an error."<<std::endl;
std::cout<<" Always add \";\" after each statement (except loop and if-else)."<<std::endl;
while(1) while(1)
{ {
std::cout<<">> "; std::cout<<">> ";

View File

@ -451,7 +451,7 @@ class nasal_parser
temp.pop(); temp.pop();
} }
if((tbl[2]!=__scalar) && (tbl[2]!=__identifier) && ((tbl[1]==__sub_operator) || (tbl[1]==__add_operator)) && (tbl[0]==__identifier)) if((tbl[2]!=__scalar) && (tbl[2]!=__identifier) && (tbl[2]!=__calculation) && ((tbl[1]==__sub_operator) || (tbl[1]==__add_operator)) && (tbl[0]==__identifier))
{ {
parse_unit t; parse_unit t;
t.type=__identifier; t.type=__identifier;
@ -759,9 +759,9 @@ class nasal_parser
} }
bool definition_check() bool definition_check()
{ {
int tbl[5]={0}; int tbl[7]={0};
std::stack<parse_unit> temp; std::stack<parse_unit> temp;
for(int i=0;i<5;++i) for(int i=0;i<7;++i)
{ {
if(parser.empty()) if(parser.empty())
break; break;
@ -769,7 +769,7 @@ class nasal_parser
tbl[i]=temp.top().type; tbl[i]=temp.top().type;
parser.pop(); parser.pop();
} }
for(int i=0;i<5;++i) for(int i=0;i<7;++i)
{ {
if(temp.empty()) if(temp.empty())
break; break;
@ -786,6 +786,16 @@ class nasal_parser
parser.push(t); parser.push(t);
return true; return true;
} }
else if((tbl[6]==__var) && (tbl[5]==__identifier) && (tbl[4]==__equal) && (tbl[3]==__left_curve) && ((tbl[2]==__identifier) || (tbl[2]==__scalar) || (tbl[2]==__list) || (tbl[2]==__hash) || (tbl[2]==__calculation)) && (tbl[1]==__right_curve) && (tbl[0]==__semi))
{
parse_unit t;
t.type=__definition;
t.line=parser.top().line;
for(int i=0;i<7;++i)
parser.pop();
parser.push(t);
return true;
}
else if((tbl[3]=__var) && (tbl[2]==__identifier) && (tbl[1]==__equal) && (tbl[0]==__function)) else if((tbl[3]=__var) && (tbl[2]==__identifier) && (tbl[1]==__equal) && (tbl[0]==__function))
{ {
parse_unit t; parse_unit t;
@ -800,9 +810,9 @@ class nasal_parser
} }
bool assignment_check() bool assignment_check()
{ {
int tbl[4]={0}; int tbl[6]={0};
std::stack<parse_unit> temp; std::stack<parse_unit> temp;
for(int i=0;i<4;++i) for(int i=0;i<6;++i)
{ {
if(parser.empty()) if(parser.empty())
break; break;
@ -810,7 +820,7 @@ class nasal_parser
tbl[i]=temp.top().type; tbl[i]=temp.top().type;
parser.pop(); parser.pop();
} }
for(int i=0;i<4;++i) for(int i=0;i<6;++i)
{ {
if(temp.empty()) if(temp.empty())
break; break;
@ -830,6 +840,18 @@ class nasal_parser
parser.push(t); parser.push(t);
return true; return true;
} }
else if((tbl[5]==__identifier) && ((tbl[4]==__equal) || (tbl[4]==__add_equal) || (tbl[4]==__sub_equal)
|| (tbl[4]==__mul_equal) || (tbl[4]==__div_equal) || (tbl[4]==__link_equal))
&& (tbl[3]==__left_curve) && ((tbl[2]==__identifier) || (tbl[2]==__scalar) || (tbl[2]==__list) || (tbl[2]==__hash) || (tbl[2]==__calculation)) && (tbl[1]==__right_curve) && (tbl[0]==__semi))
{
parse_unit t;
t.type=__definition;
t.line=parser.top().line;
for(int i=0;i<6;++i)
parser.pop();
parser.push(t);
return true;
}
return false; return false;
} }
bool function_def() bool function_def()