Compare commits
No commits in common. "361643a85aeb1c8422f282b2a9b180ecc3e152df" and "d1bef2193e00d502342f89205575e0a932234d70" have entirely different histories.
361643a85a
...
d1bef2193e
@ -5,7 +5,7 @@ public class TestRecursion {
|
|||||||
|
|
||||||
public TestRecursion(int n)
|
public TestRecursion(int n)
|
||||||
{
|
{
|
||||||
this.value = n;
|
value = n;
|
||||||
|
|
||||||
if(n > 0)
|
if(n > 0)
|
||||||
{
|
{
|
||||||
|
@ -204,13 +204,6 @@ testExpressionConstructorCall = TestCase $
|
|||||||
assertEqual "expect constructor call" (StatementExpressionExpression (ConstructorCall "Foo" [])) $
|
assertEqual "expect constructor call" (StatementExpressionExpression (ConstructorCall "Foo" [])) $
|
||||||
parseExpression [NEW,IDENTIFIER "Foo",LBRACE,RBRACE]
|
parseExpression [NEW,IDENTIFIER "Foo",LBRACE,RBRACE]
|
||||||
|
|
||||||
testExpresssionExternalMethodCall = TestCase $
|
|
||||||
assertEqual "expect method call on sub" (StatementExpressionExpression (MethodCall (Reference "Obj") "foo" [])) $
|
|
||||||
parseExpression [IDENTIFIER "Obj",DOT,IDENTIFIER "foo",LBRACE,RBRACE]
|
|
||||||
testExpressionAssignWithThis = TestCase $
|
|
||||||
assertEqual "expect assignment on Field" (StatementExpressionExpression (Assignment (BinaryOperation NameResolution (Reference "this") (Reference "x")) (Reference "y"))) $
|
|
||||||
parseExpression [THIS,DOT,IDENTIFIER "x",ASSIGN,IDENTIFIER "y"]
|
|
||||||
|
|
||||||
testStatementIfThen = TestCase $
|
testStatementIfThen = TestCase $
|
||||||
assertEqual "expect empty ifthen" [If (Reference "a") (Block [Block []]) Nothing] $
|
assertEqual "expect empty ifthen" [If (Reference "a") (Block [Block []]) Nothing] $
|
||||||
parseStatement [IF,LBRACE,IDENTIFIER "a",RBRACE,LBRACKET,RBRACKET]
|
parseStatement [IF,LBRACE,IDENTIFIER "a",RBRACE,LBRACKET,RBRACKET]
|
||||||
@ -299,8 +292,6 @@ tests = TestList [
|
|||||||
testExpressionSimpleFieldAccess,
|
testExpressionSimpleFieldAccess,
|
||||||
testExpressionFieldSubAccess,
|
testExpressionFieldSubAccess,
|
||||||
testExpressionConstructorCall,
|
testExpressionConstructorCall,
|
||||||
testExpresssionExternalMethodCall,
|
|
||||||
testExpressionAssignWithThis,
|
|
||||||
testStatementIfThen,
|
testStatementIfThen,
|
||||||
testStatementIfThenElse,
|
testStatementIfThenElse,
|
||||||
testStatementWhile,
|
testStatementWhile,
|
||||||
|
@ -265,7 +265,6 @@ conditionalorexpression : conditionalandexpression { $1 }
|
|||||||
-- | conditionalorexpression LOGICALOR conditionalandexpression{ }
|
-- | conditionalorexpression LOGICALOR conditionalandexpression{ }
|
||||||
|
|
||||||
lefthandside : name { $1 }
|
lefthandside : name { $1 }
|
||||||
| primary DOT IDENTIFIER { BinaryOperation NameResolution $1 (Reference $3) }
|
|
||||||
|
|
||||||
assignmentoperator : ASSIGN { Nothing }
|
assignmentoperator : ASSIGN { Nothing }
|
||||||
| TIMESEQUAL { Just Multiplication }
|
| TIMESEQUAL { Just Multiplication }
|
||||||
@ -288,8 +287,8 @@ postincrementexpression : postfixexpression INCREMENT { PostIncrement $1 }
|
|||||||
|
|
||||||
postdecrementexpression : postfixexpression DECREMENT { PostDecrement $1 }
|
postdecrementexpression : postfixexpression DECREMENT { PostDecrement $1 }
|
||||||
|
|
||||||
methodinvocation : name LBRACE RBRACE { let (exp, functionname) = extractFunctionName $1 in (MethodCall exp functionname []) }
|
methodinvocation : simplename LBRACE RBRACE { MethodCall (Reference "this") $1 [] }
|
||||||
| name LBRACE argumentlist RBRACE { let (exp, functionname) = extractFunctionName $1 in (MethodCall exp functionname $3) }
|
| simplename LBRACE argumentlist RBRACE { MethodCall (Reference "this") $1 $3 }
|
||||||
| primary DOT IDENTIFIER LBRACE RBRACE { MethodCall $1 $3 [] }
|
| primary DOT IDENTIFIER LBRACE RBRACE { MethodCall $1 $3 [] }
|
||||||
| primary DOT IDENTIFIER LBRACE argumentlist RBRACE { MethodCall $1 $3 $5 }
|
| primary DOT IDENTIFIER LBRACE argumentlist RBRACE { MethodCall $1 $3 $5 }
|
||||||
|
|
||||||
@ -375,9 +374,8 @@ data Declarator = Declarator Identifier (Maybe Expression)
|
|||||||
convertDeclarator :: DataType -> Declarator -> VariableDeclaration
|
convertDeclarator :: DataType -> Declarator -> VariableDeclaration
|
||||||
convertDeclarator dataType (Declarator id assigment) = VariableDeclaration dataType id assigment
|
convertDeclarator dataType (Declarator id assigment) = VariableDeclaration dataType id assigment
|
||||||
|
|
||||||
extractFunctionName :: Expression -> (Expression, Identifier)
|
data StatementWithoutSub = Statement
|
||||||
extractFunctionName (BinaryOperation NameResolution exp (Reference functionname)) = (exp, functionname)
|
|
||||||
extractFunctionName (Reference functionname) = ((Reference "this"), functionname)
|
|
||||||
|
|
||||||
parseError :: ([Token], [String]) -> a
|
parseError :: ([Token], [String]) -> a
|
||||||
parseError (errortoken, expected) = error ("parse error on token: " ++ show errortoken ++ "\nexpected one of: " ++ show expected)
|
parseError (errortoken, expected) = error ("parse error on token: " ++ show errortoken ++ "\nexpected one of: " ++ show expected)
|
||||||
|
Loading…
Reference in New Issue
Block a user