Merge branch 'master' of git-server.vd:jerry

This commit is contained in:
Ruben Ayrapetyan
2014-07-23 15:50:07 +04:00
4 changed files with 55 additions and 45 deletions
+2 -2
View File
@@ -880,7 +880,7 @@ lexer_next_token (void)
token tok = lexer_next_token_private (); token tok = lexer_next_token_private ();
if (tok.type == TOK_NEWLINE) if (tok.type == TOK_NEWLINE)
return tok; return tok;
if (tok.type == TOK_CLOSE_PAREN) if (tok.type == TOK_CLOSE_BRACE)
{ {
// if (i == 300) // if (i == 300)
__fprintf (lexer_debug_log, "lexer_next_token(%d): type=%d, data=%d\n", i, tok.type, tok.data.uid); __fprintf (lexer_debug_log, "lexer_next_token(%d): type=%d, data=%d\n", i, tok.type, tok.data.uid);
@@ -894,7 +894,7 @@ void
lexer_save_token (token tok) lexer_save_token (token tok)
{ {
#ifdef __HOST #ifdef __HOST
if (tok.type == TOK_CLOSE_PAREN) if (tok.type == TOK_CLOSE_BRACE)
__fprintf (lexer_debug_log, "lexer_save_token(%d): type=%d, data=%d\n", i, tok.type, tok.data.uid); __fprintf (lexer_debug_log, "lexer_save_token(%d): type=%d, data=%d\n", i, tok.type, tok.data.uid);
#endif #endif
saved_token = tok; saved_token = tok;
+43 -41
View File
@@ -55,7 +55,7 @@ assert_keyword (keyword kw)
if (tok.type != TOK_KEYWORD || tok.data.kw != kw) if (tok.type != TOK_KEYWORD || tok.data.kw != kw)
{ {
#ifdef __HOST #ifdef __HOST
__printf ("assert_keyword: 0x%x\n", kw); __printf ("assert_keyword: %d\n", kw);
#endif #endif
JERRY_UNREACHABLE (); JERRY_UNREACHABLE ();
} }
@@ -73,7 +73,7 @@ current_token_must_be(token_type tt)
if (tok.type != tt) if (tok.type != tt)
{ {
#ifdef __HOST #ifdef __HOST
__printf ("current_token_must_be: 0x%x\n", tt); __printf ("current_token_must_be: %d\n", tt);
#endif #endif
parser_fatal (ERR_PARSER); parser_fatal (ERR_PARSER);
} }
@@ -94,7 +94,7 @@ next_token_must_be (token_type tt)
if (tok.type != tt) if (tok.type != tt)
{ {
#ifdef __HOST #ifdef __HOST
__printf ("next_token_must_be: 0x%x\n", tt); __printf ("next_token_must_be: %d\n", tt);
#endif #endif
parser_fatal (ERR_PARSER); parser_fatal (ERR_PARSER);
} }
@@ -771,43 +771,39 @@ parse_call_expression (void)
obj = lhs; obj = lhs;
skip_newlines (); skip_newlines ();
if (tok.type == TOK_OPEN_PAREN || tok.type == TOK_OPEN_SQUARE while (tok.type == TOK_OPEN_PAREN || tok.type == TOK_OPEN_SQUARE
|| tok.type == TOK_DOT) || tok.type == TOK_DOT)
{ {
while (tok.type == TOK_OPEN_PAREN || tok.type == TOK_OPEN_SQUARE switch (tok.type)
|| tok.type == TOK_DOT) {
{ case TOK_OPEN_PAREN:
switch (tok.type) lhs = parse_argument_list (AL_CALL_EXPR, obj);
{ skip_newlines ();
case TOK_OPEN_PAREN: break;
lhs = parse_argument_list (AL_CALL_EXPR, obj);
break; case TOK_OPEN_SQUARE:
NEXT (prop, expression);
case TOK_OPEN_SQUARE: next_token_must_be (TOK_CLOSE_SQUARE);
NEXT (prop, expression);
next_token_must_be (TOK_CLOSE_SQUARE); DUMP_OPCODE (prop_access, lhs, obj, prop);
obj = lhs;
DUMP_OPCODE (prop_access, lhs, obj, prop); skip_newlines ();
obj = lhs; break;
skip_newlines ();
break; case TOK_DOT:
token_after_newlines_must_be (TOK_NAME);
case TOK_DOT: prop = tok.data.uid;
token_after_newlines_must_be (TOK_NAME);
prop = tok.data.uid; DUMP_OPCODE (prop_access, lhs, obj, prop);
obj = lhs;
DUMP_OPCODE (prop_access, lhs, obj, prop); skip_newlines ();
obj = lhs; break;
skip_newlines ();
break; default:
JERRY_UNREACHABLE ();
default: }
JERRY_UNREACHABLE ();
}
}
} }
else lexer_save_token (tok);
lexer_save_token (tok);
return obj; return obj;
} }
@@ -1663,7 +1659,10 @@ static void
parse_statement (void) parse_statement (void)
{ {
if (tok.type == TOK_CLOSE_BRACE) if (tok.type == TOK_CLOSE_BRACE)
return; {
lexer_save_token (tok);
return;
}
if (tok.type == TOK_OPEN_BRACE) if (tok.type == TOK_OPEN_BRACE)
{ {
skip_newlines (); skip_newlines ();
@@ -1682,7 +1681,6 @@ parse_statement (void)
} }
if (tok.type == TOK_SEMICOLON) if (tok.type == TOK_SEMICOLON)
{ {
skip_newlines ();
return; return;
} }
if (is_keyword (KW_IF)) if (is_keyword (KW_IF))
@@ -1789,7 +1787,11 @@ static void
parse_source_element_list (void) parse_source_element_list (void)
{ {
while (tok.type != TOK_EOF && tok.type != TOK_CLOSE_BRACE) while (tok.type != TOK_EOF && tok.type != TOK_CLOSE_BRACE)
parse_source_element (); {
parse_source_element ();
skip_newlines ();
}
lexer_save_token (tok);
} }
/* program /* program
+8 -1
View File
@@ -26,4 +26,11 @@ serializer_dump_data (const void *data __unused, size_t size __unused)
{ {
} }
TODO (Dump memory) TODO (Dump memory)
void
serializer_rewrite_data (const int8_t offset, const void *data, size_t size)
{
TODO (implement);
JERRY_UNIMPLEMENTED_REF_UNUSED_VARS( offset, data, size);
}
+2 -1
View File
@@ -98,7 +98,8 @@ fake_exit (void)
} }
int int
main (int argc, char **argv) main (int argc __unused,
char **argv __unused)
{ {
#ifdef __HOST #ifdef __HOST
const char *file_name = NULL; const char *file_name = NULL;