*** empty log message ***
This commit is contained in:
parent
bb35e822fd
commit
dd982502f2
118
ase/stx/parser.c
118
ase/stx/parser.c
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* $Id: parser.c,v 1.39 2005-06-23 04:59:00 bacon Exp $
|
* $Id: parser.c,v 1.40 2005-06-23 07:20:44 bacon Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <xp/stx/parser.h>
|
#include <xp/stx/parser.h>
|
||||||
@ -148,7 +148,10 @@ const xp_char_t* xp_stx_parser_error_string (xp_stx_parser_t* parser)
|
|||||||
XP_TEXT("invalid primary/expression-start"),
|
XP_TEXT("invalid primary/expression-start"),
|
||||||
|
|
||||||
XP_TEXT("no period at end of statement"),
|
XP_TEXT("no period at end of statement"),
|
||||||
XP_TEXT("no closing parenthesis")
|
XP_TEXT("no closing parenthesis"),
|
||||||
|
XP_TEXT("block argument name missing"),
|
||||||
|
XP_TEXT("block argument list not closed"),
|
||||||
|
XP_TEXT("block not closed")
|
||||||
};
|
};
|
||||||
|
|
||||||
if (parser->error_code >= 0 &&
|
if (parser->error_code >= 0 &&
|
||||||
@ -167,6 +170,42 @@ static inline xp_bool_t __is_pseudo_variable (const xp_stx_token_t* token)
|
|||||||
xp_strcmp(token->name.buffer, XP_TEXT("false")) == 0);
|
xp_strcmp(token->name.buffer, XP_TEXT("false")) == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline xp_bool_t __is_vbar_token (const xp_stx_token_t* token)
|
||||||
|
{
|
||||||
|
return
|
||||||
|
token->type == XP_STX_TOKEN_BINARY &&
|
||||||
|
token->name.size == 1 &&
|
||||||
|
token->name.buffer[0] == XP_CHAR('|');
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline xp_bool_t __is_binary_char (xp_cint_t c)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* binaryCharacter ::=
|
||||||
|
* '!' | '%' | '&' | '*' | '+' | ',' |
|
||||||
|
* '/' | '<' | '=' | '>' | '?' | '@' |
|
||||||
|
* '\' | '~' | '|' | '-'
|
||||||
|
*/
|
||||||
|
|
||||||
|
return
|
||||||
|
c == XP_CHAR('!') || c == XP_CHAR('%') ||
|
||||||
|
c == XP_CHAR('&') || c == XP_CHAR('*') ||
|
||||||
|
c == XP_CHAR('+') || c == XP_CHAR(',') ||
|
||||||
|
c == XP_CHAR('/') || c == XP_CHAR('<') ||
|
||||||
|
c == XP_CHAR('=') || c == XP_CHAR('>') ||
|
||||||
|
c == XP_CHAR('?') || c == XP_CHAR('@') ||
|
||||||
|
c == XP_CHAR('\\') || c == XP_CHAR('|') ||
|
||||||
|
c == XP_CHAR('~') || c == XP_CHAR('-');
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline xp_bool_t __is_closing_char (xp_cint_t c)
|
||||||
|
{
|
||||||
|
return
|
||||||
|
c == XP_CHAR('.') || c == XP_CHAR(']') ||
|
||||||
|
c == XP_CHAR(')') || c == XP_CHAR(';') ||
|
||||||
|
c == XP_CHAR('\"') || c == XP_CHAR('\'');
|
||||||
|
}
|
||||||
|
|
||||||
int xp_stx_parser_parse_method (
|
int xp_stx_parser_parse_method (
|
||||||
xp_stx_parser_t* parser, xp_word_t method_class, void* input)
|
xp_stx_parser_t* parser, xp_word_t method_class, void* input)
|
||||||
{
|
{
|
||||||
@ -205,9 +244,9 @@ static int __parse_method (
|
|||||||
xp_free (parser->temporary[--parser->temporary_count]);
|
xp_free (parser->temporary[--parser->temporary_count]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (__parse_message_pattern (parser) == -1) return -1;
|
if (__parse_message_pattern(parser) == -1) return -1;
|
||||||
if (__parse_temporaries (parser) == -1) return -1;
|
if (__parse_temporaries(parser) == -1) return -1;
|
||||||
if (__parse_statements (parser) == -1) return -1;
|
if (__parse_statements(parser) == -1) return -1;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -331,14 +370,6 @@ xp_printf (XP_TEXT("METHOD NAME ==> [%s]\n"), parser->method_name.buffer);
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline xp_bool_t __is_vbar_token (const xp_stx_token_t* token)
|
|
||||||
{
|
|
||||||
return
|
|
||||||
token->type == XP_STX_TOKEN_BINARY &&
|
|
||||||
token->name.size == 1 &&
|
|
||||||
token->name.buffer[0] == XP_CHAR('|');
|
|
||||||
}
|
|
||||||
|
|
||||||
static int __parse_temporaries (xp_stx_parser_t* parser)
|
static int __parse_temporaries (xp_stx_parser_t* parser)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
@ -581,12 +612,43 @@ static int __parse_block_constructor (xp_stx_parser_t* parser)
|
|||||||
* <block argument> ::= ':' identifier
|
* <block argument> ::= ':' identifier
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
if (parser->token.type == XP_STX_TOKEN_COLON) {
|
||||||
|
do {
|
||||||
|
if (parser->token.type != XP_STX_TOKEN_IDENT) {
|
||||||
|
parser->error_code = XP_STX_PARSER_ERROR_BLOCK_ARGUMENT_NAME;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* TODO : store block arguments */
|
||||||
|
GET_TOKEN (parser);
|
||||||
|
} while (parser->token.type == XP_STX_TOKEN_COLON);
|
||||||
|
|
||||||
|
if (!__is_vbar_token(&parser->token)) {
|
||||||
|
parser->error_code = XP_STX_PARSER_ERROR_BLOCK_ARGUMENT_LIST;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
GET_TOKEN (parser);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* TODO: create a block closure */
|
||||||
|
if (__parse_temporaries(parser, xp_true) == -1) return -1;
|
||||||
|
if (__parse_statements(parser, xp_true) == -1) return -1;
|
||||||
|
|
||||||
|
if (parser->token.type != XP_STX_TOKEN_RBRACKET) {
|
||||||
|
parser->error_code = XP_STX_PARSER_ERROR_BLOCK_NOT_CLOSED;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
GET_TOKEN (parser);
|
||||||
|
|
||||||
|
/* TODO: do special treatment for block closures */
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __parse_message_continuation (xp_stx_parser_t* parser)
|
static int __parse_message_continuation (xp_stx_parser_t* parser)
|
||||||
{
|
{
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* <messages> ::=
|
* <messages> ::=
|
||||||
* (<unary message>+ <binary message>* [<keyword message>] ) |
|
* (<unary message>+ <binary message>* [<keyword message>] ) |
|
||||||
@ -703,34 +765,6 @@ static int __emit_code (
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static inline xp_bool_t __is_binary_char (xp_cint_t c)
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
* binaryCharacter ::=
|
|
||||||
* '!' | '%' | '&' | '*' | '+' | ',' |
|
|
||||||
* '/' | '<' | '=' | '>' | '?' | '@' |
|
|
||||||
* '\' | '~' | '|' | '-'
|
|
||||||
*/
|
|
||||||
|
|
||||||
return
|
|
||||||
c == XP_CHAR('!') || c == XP_CHAR('%') ||
|
|
||||||
c == XP_CHAR('&') || c == XP_CHAR('*') ||
|
|
||||||
c == XP_CHAR('+') || c == XP_CHAR(',') ||
|
|
||||||
c == XP_CHAR('/') || c == XP_CHAR('<') ||
|
|
||||||
c == XP_CHAR('=') || c == XP_CHAR('>') ||
|
|
||||||
c == XP_CHAR('?') || c == XP_CHAR('@') ||
|
|
||||||
c == XP_CHAR('\\') || c == XP_CHAR('|') ||
|
|
||||||
c == XP_CHAR('~') || c == XP_CHAR('-');
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline xp_bool_t __is_closing_char (xp_cint_t c)
|
|
||||||
{
|
|
||||||
return
|
|
||||||
c == XP_CHAR('.') || c == XP_CHAR(']') ||
|
|
||||||
c == XP_CHAR(')') || c == XP_CHAR(';') ||
|
|
||||||
c == XP_CHAR('\"') || c == XP_CHAR('\'');
|
|
||||||
}
|
|
||||||
|
|
||||||
static int __get_token (xp_stx_parser_t* parser)
|
static int __get_token (xp_stx_parser_t* parser)
|
||||||
{
|
{
|
||||||
xp_cint_t c;
|
xp_cint_t c;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* $Id: parser.h,v 1.23 2005-06-23 04:55:44 bacon Exp $
|
* $Id: parser.h,v 1.24 2005-06-23 07:20:44 bacon Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _XP_STX_PARSER_H_
|
#ifndef _XP_STX_PARSER_H_
|
||||||
@ -35,7 +35,10 @@ enum
|
|||||||
XP_STX_PARSER_ERROR_PRIMARY,
|
XP_STX_PARSER_ERROR_PRIMARY,
|
||||||
|
|
||||||
XP_STX_PARSER_ERROR_NO_PERIOD,
|
XP_STX_PARSER_ERROR_NO_PERIOD,
|
||||||
XP_STX_PARSER_ERROR_NO_RPAREN
|
XP_STX_PARSER_ERROR_NO_RPAREN,
|
||||||
|
XP_STX_PARSER_ERROR_BLOCK_ARGUMENT_NAME,
|
||||||
|
XP_STX_PARSER_ERROR_BLOCK_ARGUMENT_LIST,
|
||||||
|
XP_STX_PARSER_ERROR_BLOCK_NOT_CLOSED
|
||||||
};
|
};
|
||||||
|
|
||||||
enum
|
enum
|
||||||
|
Loading…
Reference in New Issue
Block a user