*** empty log message ***
This commit is contained in:
parent
537312c735
commit
689e6e2bf8
154
ase/stx/parser.c
154
ase/stx/parser.c
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* $Id: parser.c,v 1.12 2005-06-05 05:26:24 bacon Exp $
|
* $Id: parser.c,v 1.13 2005-06-05 16:44:05 bacon Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <xp/stx/parser.h>
|
#include <xp/stx/parser.h>
|
||||||
@ -7,6 +7,9 @@
|
|||||||
#include <xp/stx/misc.h>
|
#include <xp/stx/misc.h>
|
||||||
|
|
||||||
static int __get_token (xp_stx_parser_t* parser);
|
static int __get_token (xp_stx_parser_t* parser);
|
||||||
|
static int __get_ident (xp_stx_parser_t* parser);
|
||||||
|
static int __get_charlit (xp_stx_parser_t* parser);
|
||||||
|
static int __get_strlit (xp_stx_parser_t* parser);
|
||||||
static int __skip_spaces (xp_stx_parser_t* parser);
|
static int __skip_spaces (xp_stx_parser_t* parser);
|
||||||
static int __skip_comment (xp_stx_parser_t* parser);
|
static int __skip_comment (xp_stx_parser_t* parser);
|
||||||
static int __get_char (xp_stx_parser_t* parser);
|
static int __get_char (xp_stx_parser_t* parser);
|
||||||
@ -50,12 +53,14 @@ void xp_stx_parser_close (xp_stx_parser_t* parser)
|
|||||||
do { if (__get_char(parser) == -1) return -1; } while (0)
|
do { if (__get_char(parser) == -1) return -1; } while (0)
|
||||||
#define UNGET_CHAR(parser,c) \
|
#define UNGET_CHAR(parser,c) \
|
||||||
do { if (__unget_char(parser,c) == -1) return -1; } while (0)
|
do { if (__unget_char(parser,c) == -1) return -1; } while (0)
|
||||||
|
#define GET_TOKEN(parser) \
|
||||||
|
do { if (__get_token(parser) == -1) return -1; } while (0)
|
||||||
|
|
||||||
|
|
||||||
int xp_stx_parser_parse_method (
|
int xp_stx_parser_parse_method (
|
||||||
xp_stx_parser_t* parser, xp_stx_word_t method_class, void* input)
|
xp_stx_parser_t* parser, xp_stx_word_t method_class, void* input)
|
||||||
{
|
{
|
||||||
if (parser->input == XP_NULL ||
|
if (parser->input_reset == XP_NULL ||
|
||||||
parser->input_reset == XP_NULL ||
|
|
||||||
parser->input_consume == XP_NULL) {
|
parser->input_consume == XP_NULL) {
|
||||||
parser->error_code = XP_STX_PARSER_ERROR_INVALID;
|
parser->error_code = XP_STX_PARSER_ERROR_INVALID;
|
||||||
return -1;
|
return -1;
|
||||||
@ -64,6 +69,9 @@ int xp_stx_parser_parse_method (
|
|||||||
RESET_INPUT (parser, input);
|
RESET_INPUT (parser, input);
|
||||||
GET_CHAR (parser);
|
GET_CHAR (parser);
|
||||||
|
|
||||||
|
GET_TOKEN (parser);
|
||||||
|
xp_printf (XP_TEXT("%d, [%s]\n"), parser->token.type, parser->token.buffer);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -81,12 +89,18 @@ static int __get_token (xp_stx_parser_t* parser)
|
|||||||
} while (1);
|
} while (1);
|
||||||
|
|
||||||
c = parser->curc;
|
c = parser->curc;
|
||||||
|
xp_stx_token_clear (&parser->token);
|
||||||
|
|
||||||
if (xp_stx_isalpha(c)) {
|
if (xp_stx_isalpha(c)) {
|
||||||
|
if (__get_ident(parser) == -1) return -1;
|
||||||
}
|
}
|
||||||
else if (xp_stx_isdigit(c)) {
|
else if (xp_stx_isdigit(c)) {
|
||||||
}
|
}
|
||||||
|
else if (c == XP_STX_CHAR('$')) {
|
||||||
|
if (__get_charlit(parser) == -1) return -1;
|
||||||
|
}
|
||||||
else if (c == XP_STX_CHAR('\'')) {
|
else if (c == XP_STX_CHAR('\'')) {
|
||||||
|
if (__get_strlit(parser) == -1) return -1;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
parser->error_code = XP_STX_PARSER_ERROR_CHAR;
|
parser->error_code = XP_STX_PARSER_ERROR_CHAR;
|
||||||
@ -96,6 +110,91 @@ static int __get_token (xp_stx_parser_t* parser)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int __get_ident (xp_stx_parser_t* parser)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* identifier ::= letter (letter | digit)*
|
||||||
|
* keyword ::= identifier ':'
|
||||||
|
*/
|
||||||
|
|
||||||
|
xp_cint_t c = parser->curc;
|
||||||
|
parser->token.type = XP_STX_TOKEN_IDENT;
|
||||||
|
|
||||||
|
do {
|
||||||
|
if (xp_stx_token_addc (&parser->token, c) == -1) {
|
||||||
|
parser->error_code = XP_STX_PARSER_ERROR_MEMORY;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
GET_CHAR (parser);
|
||||||
|
c = parser->curc;
|
||||||
|
} while (xp_stx_isalnum(c));
|
||||||
|
|
||||||
|
if (c == XP_STX_CHAR(':')) {
|
||||||
|
parser->token.type = XP_STX_TOKEN_KEYWORD;
|
||||||
|
GET_CHAR (parser);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int __get_charlit (xp_stx_parser_t* parser)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* character_literal ::= '$' character
|
||||||
|
* character ::= "Any character in the implementation-defined character set"
|
||||||
|
*/
|
||||||
|
|
||||||
|
xp_cint_t c = parser->curc;
|
||||||
|
if (c == XP_STX_CHAR_EOF) {
|
||||||
|
parser->error_code = XP_STX_PARSER_ERROR_CHARLIT;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
parser->token.type = XP_STX_TOKEN_CHARLIT;
|
||||||
|
if (xp_stx_token_addc (&parser->token, c) == -1) {
|
||||||
|
parser->error_code = XP_STX_PARSER_ERROR_MEMORY;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
GET_CHAR (parser);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int __get_strlit (xp_stx_parser_t* parser)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* string_literal ::= stringDelimiter stringBody stringDelimiter
|
||||||
|
* stringBody ::= (nonStringDelimiter | (stringDelimiter stringDelimiter)*)
|
||||||
|
* stringDelimiter ::= ''' "a single quote"
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* TODO: C-like string */
|
||||||
|
|
||||||
|
xp_cint_t c = parser->curc;
|
||||||
|
parser->token.type = XP_STX_TOKEN_STRLIT;
|
||||||
|
|
||||||
|
do {
|
||||||
|
do {
|
||||||
|
if (xp_stx_token_addc (&parser->token, c) == -1) {
|
||||||
|
parser->error_code = XP_STX_PARSER_ERROR_MEMORY;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
GET_CHAR (parser);
|
||||||
|
c = parser->curc;
|
||||||
|
|
||||||
|
if (c == XP_STX_CHAR_EOF) {
|
||||||
|
parser->error_code = XP_STX_PARSER_ERROR_STRLIT;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
} while (c != XP_STX_CHAR('\''));
|
||||||
|
|
||||||
|
GET_CHAR (parser);
|
||||||
|
c = parser->curc;
|
||||||
|
} while (c == XP_STX_CHAR('\''));
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int __skip_spaces (xp_stx_parser_t* parser)
|
static int __skip_spaces (xp_stx_parser_t* parser)
|
||||||
{
|
{
|
||||||
while (xp_stx_isspace(parser->curc)) GET_CHAR (parser);
|
while (xp_stx_isspace(parser->curc)) GET_CHAR (parser);
|
||||||
@ -112,11 +211,17 @@ static int __skip_comment (xp_stx_parser_t* parser)
|
|||||||
static int __get_char (xp_stx_parser_t* parser)
|
static int __get_char (xp_stx_parser_t* parser)
|
||||||
{
|
{
|
||||||
xp_cint_t c;
|
xp_cint_t c;
|
||||||
if (parser->input_consume (parser, &c) == -1) {
|
|
||||||
parser->error_code = XP_STX_PARSER_ERROR_INPUT;
|
if (parser->ungotc_count > 0) {
|
||||||
return -1;
|
parser->curc = parser->ungotc[parser->ungotc_count--];
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (parser->input_consume (parser, &c) == -1) {
|
||||||
|
parser->error_code = XP_STX_PARSER_ERROR_INPUT;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
parser->curc = c;
|
||||||
}
|
}
|
||||||
parser->curc = c;
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -138,38 +243,3 @@ static int __reset_input (xp_stx_parser_t* parser, void* input)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
static int __get_token (xp_stx_parser_t* parser)
|
|
||||||
{
|
|
||||||
xp_cint_t c = parser->curc;
|
|
||||||
|
|
||||||
__skip_spaces (parser);
|
|
||||||
__skip_comment (parser);
|
|
||||||
|
|
||||||
switch (c) {
|
|
||||||
case
|
|
||||||
}
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int __get_char (xp_stx_parser_t* parser)
|
|
||||||
{
|
|
||||||
xp_cint_t c = parser->curp;
|
|
||||||
|
|
||||||
if (c == XP_STX_CHAR('\0')) {
|
|
||||||
parser->curc = XP_EOF_CHAR;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
parser->curc = c;
|
|
||||||
parser->curp++;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int __skip_spaces (xp_stx_parser_t* parser)
|
|
||||||
{
|
|
||||||
while (xp_stx_isspace(parser->curc)) __get_char
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* $Id: parser.h,v 1.9 2005-06-05 05:26:24 bacon Exp $
|
* $Id: parser.h,v 1.10 2005-06-05 16:44:05 bacon Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _XP_STX_PARSER_H_
|
#ifndef _XP_STX_PARSER_H_
|
||||||
@ -12,8 +12,11 @@ enum
|
|||||||
{
|
{
|
||||||
XP_STX_PARSER_ERROR_NONE = 0,
|
XP_STX_PARSER_ERROR_NONE = 0,
|
||||||
XP_STX_PARSER_ERROR_INPUT,
|
XP_STX_PARSER_ERROR_INPUT,
|
||||||
|
XP_STX_PARSER_ERROR_MEMORY,
|
||||||
XP_STX_PARSER_ERROR_INVALID,
|
XP_STX_PARSER_ERROR_INVALID,
|
||||||
XP_STX_PARSER_ERROR_CHAR
|
XP_STX_PARSER_ERROR_CHAR,
|
||||||
|
XP_STX_PARSER_ERROR_CHARLIT,
|
||||||
|
XP_STX_PARSER_ERROR_STRLIT
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct xp_stx_parser_t xp_stx_parser_t;
|
typedef struct xp_stx_parser_t xp_stx_parser_t;
|
||||||
@ -41,8 +44,8 @@ extern "C" {
|
|||||||
xp_stx_parser_t* xp_stx_parser_open (xp_stx_parser_t* parser);
|
xp_stx_parser_t* xp_stx_parser_open (xp_stx_parser_t* parser);
|
||||||
void xp_stx_parser_close (xp_stx_parser_t* parser);
|
void xp_stx_parser_close (xp_stx_parser_t* parser);
|
||||||
|
|
||||||
int xp_stx_parse_method (xp_stx_parser_t* parser,
|
int xp_stx_parser_parse_method (
|
||||||
xp_stx_word_t method_class, xp_stx_char_t* method_text);
|
xp_stx_parser_t* parser, xp_stx_word_t method_class, void* input);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
196
ase/stx/syntax.bnf
Normal file
196
ase/stx/syntax.bnf
Normal file
@ -0,0 +1,196 @@
|
|||||||
|
~~~ method grammar ~~~
|
||||||
|
|
||||||
|
<method definition> ::=
|
||||||
|
<message pattern>
|
||||||
|
[<temporaries> ]
|
||||||
|
[<statements>]
|
||||||
|
|
||||||
|
<message pattern> ::= <unary pattern> |
|
||||||
|
<binary pattern> |
|
||||||
|
<keyword pattern>
|
||||||
|
|
||||||
|
<unary pattern> ::= unarySelector
|
||||||
|
|
||||||
|
<binary pattern> ::= binarySelector <method argument>
|
||||||
|
|
||||||
|
<keyword pattern> ::= (keyword <method argument>)+
|
||||||
|
|
||||||
|
<temporaries> ::= '|' <temporary variable list> '|'
|
||||||
|
|
||||||
|
<temporary variable list> ::= identifier*
|
||||||
|
|
||||||
|
<block constructor> ::= '[' <block body> ']'
|
||||||
|
|
||||||
|
<block body> ::= [<block argument>* '|']
|
||||||
|
[<temporaries>] [<statements>]
|
||||||
|
|
||||||
|
<block argument> ::= ':' identifier
|
||||||
|
|
||||||
|
<statements> ::=
|
||||||
|
(<return statement> ['.'] ) |
|
||||||
|
(<expression> ['.' [<statements>]])
|
||||||
|
|
||||||
|
<return statement> ::= returnOperator <expression>
|
||||||
|
|
||||||
|
<expression> ::=
|
||||||
|
<assignment> |
|
||||||
|
<basic expression>
|
||||||
|
|
||||||
|
<assignment> ::= <assignment target> assignmentOperator <expression>
|
||||||
|
|
||||||
|
<basic expression> ::=
|
||||||
|
<primary> [<messages> <cascaded messages>]
|
||||||
|
|
||||||
|
<assignment target> := identifier
|
||||||
|
|
||||||
|
<primary> ::=
|
||||||
|
identifier |
|
||||||
|
<literal> |
|
||||||
|
<block constructor> |
|
||||||
|
( '(' <expression> ')' )
|
||||||
|
|
||||||
|
|
||||||
|
<messages> ::=
|
||||||
|
(<unary message>+ <binary message>* [<keyword message>] ) |
|
||||||
|
(<binary message>+ [<keyword message>] ) |
|
||||||
|
<keyword message>
|
||||||
|
|
||||||
|
<unary message> ::= unarySelector
|
||||||
|
|
||||||
|
<binary message> ::= binarySelector <binary argument>
|
||||||
|
|
||||||
|
<binary argument> ::= <primary> <unary message>*
|
||||||
|
|
||||||
|
<keyword message> ::= (keyword <keyword argument> )+
|
||||||
|
|
||||||
|
<keyword argument> ::= <primary> <unary message>* <binary message>*
|
||||||
|
|
||||||
|
<cascaded messages> ::= (';' <messages>)*
|
||||||
|
|
||||||
|
<literal> ::=
|
||||||
|
<number literal> |
|
||||||
|
<string literal> |
|
||||||
|
<character literal> |
|
||||||
|
<symbol literal> |
|
||||||
|
<selector literal> |
|
||||||
|
<array literal>
|
||||||
|
|
||||||
|
<number literal> ::= ['-'] <number>
|
||||||
|
|
||||||
|
<number> ::= integer | float | scaledDecimal
|
||||||
|
|
||||||
|
<character literal> ::= quotedCharacter
|
||||||
|
|
||||||
|
<string literal> ::= quotedString
|
||||||
|
|
||||||
|
<symbol literal> ::= hashedString
|
||||||
|
|
||||||
|
<selector literal> ::= quotedSelector
|
||||||
|
|
||||||
|
<array literal> ::= '#(' <array element>* ')'
|
||||||
|
|
||||||
|
<array element> ::= <literal> | identifier
|
||||||
|
|
||||||
|
reserved identifiers -> nil true false self super
|
||||||
|
|
||||||
|
|
||||||
|
~~~ lexical grammar ~~~
|
||||||
|
|
||||||
|
character ::=
|
||||||
|
"Any character in the implementation-defined character set"
|
||||||
|
|
||||||
|
whitespace ::=
|
||||||
|
"Any non-printing character interpreted as white space
|
||||||
|
including spaces, tabs, and line breaks"
|
||||||
|
|
||||||
|
digit ::=
|
||||||
|
'0' | '1' | '2' | '3' | '4' | '5' | '6' | '7' | '8' | '9'
|
||||||
|
|
||||||
|
uppercaseAlphabetic ::=
|
||||||
|
'A' | 'B' | 'C' | 'D' | 'E' | 'F' | 'G' | 'H' | 'I' |
|
||||||
|
'J' | 'K' | 'L' | 'M' | 'N' | 'O' | 'P' | 'Q' | 'R' |
|
||||||
|
'S' | 'T' | 'U' | 'V' | 'W' | 'X' | 'Y' | 'Z'
|
||||||
|
|
||||||
|
lowercaseAlphabetic ::=
|
||||||
|
'a' | 'b' | 'c' | 'd' | 'e' | 'f' | 'g' | 'h' | 'i' |
|
||||||
|
'j' | 'k' | 'l' | 'm' | 'n' | 'o' | 'p' | 'q' | 'r' |
|
||||||
|
's' | 't' | 'u' | 'v' | 'w' | 'x' | 'y' | 'z'
|
||||||
|
|
||||||
|
nonCaseLetter ::= '_'
|
||||||
|
|
||||||
|
letter ::=
|
||||||
|
uppercaseAlphabetic |
|
||||||
|
lowercaseAlphabetic |
|
||||||
|
nonCaseLetter |
|
||||||
|
"implementation defined letters"
|
||||||
|
|
||||||
|
commentDelimiter ::= '"'
|
||||||
|
|
||||||
|
nonCommentDelimiter::=
|
||||||
|
"any character that is not a commentDelimiter "
|
||||||
|
|
||||||
|
comment :=
|
||||||
|
commentDelimiter nonCommentDelimiter * commentDelimiter
|
||||||
|
|
||||||
|
identifier ::= letter (letter | digit)*
|
||||||
|
|
||||||
|
keyword ::= identifier ':'
|
||||||
|
|
||||||
|
binaryCharacter ::=
|
||||||
|
'!' | '%' | '&' | '*' | '+' | ',' |
|
||||||
|
'/' | '<' | '=' | '>' | '?' | '@' |
|
||||||
|
'\' | '~' | '|' | '-'
|
||||||
|
|
||||||
|
binarySelector ::= binaryCharacter+
|
||||||
|
|
||||||
|
returnOperator ::= '^'
|
||||||
|
|
||||||
|
assignmentOperator ::= ':='
|
||||||
|
|
||||||
|
|
||||||
|
integer ::= decimalInteger | radixInteger
|
||||||
|
|
||||||
|
decimalInteger ::= digits
|
||||||
|
|
||||||
|
digits ::= digit+
|
||||||
|
|
||||||
|
radixInteger ::= radixSpecifier 'r' radixDigits
|
||||||
|
|
||||||
|
radixSpecifier := digits
|
||||||
|
|
||||||
|
radixDigits ::= (digit | uppercaseAlphabetic)+
|
||||||
|
|
||||||
|
|
||||||
|
float ::= mantissa [exponentLetter exponent]
|
||||||
|
|
||||||
|
mantissa ::= digits'.' digits
|
||||||
|
|
||||||
|
exponent ::= ['-']decimalInteger
|
||||||
|
|
||||||
|
exponentLetter ::= 'e' | 'd' | 'q'
|
||||||
|
|
||||||
|
scaledDecimal ::= scaledMantissa 's' [fractionalDigits]
|
||||||
|
|
||||||
|
scaledMantissa ::= decimalInteger | mantissa
|
||||||
|
|
||||||
|
fractionalDigits ::= decimalInteger
|
||||||
|
|
||||||
|
quotedCharacter ::= '$' character
|
||||||
|
|
||||||
|
quotedString ::= stringDelimiter stringBody stringDelimiter
|
||||||
|
|
||||||
|
stringBody ::= (nonStringDelimiter | (stringDelimiter stringDelimiter)*)
|
||||||
|
|
||||||
|
stringDelimiter ::= ''' "a single quote"
|
||||||
|
|
||||||
|
nonStringDelimiter ::= "any character except stringDelimiter"
|
||||||
|
|
||||||
|
hashedString ::= '#' quotedString
|
||||||
|
|
||||||
|
quotedSelector ::= '#' (unarySelector | binarySelector | keywordSelector)
|
||||||
|
|
||||||
|
keywordSelector ::= keyword+
|
||||||
|
|
||||||
|
separator ::= (whitespace | comment)*
|
||||||
|
|
||||||
|
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* $Id: token.h,v 1.3 2005-06-02 16:14:58 bacon Exp $
|
* $Id: token.h,v 1.4 2005-06-05 16:44:05 bacon Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _XP_STX_TOKEN_H_
|
#ifndef _XP_STX_TOKEN_H_
|
||||||
@ -9,14 +9,11 @@
|
|||||||
|
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
XP_STX_TOKEN_END = 0,
|
XP_STX_TOKEN_END = 0,
|
||||||
XP_STX_TOKEN_STRING = 1,
|
XP_STX_TOKEN_CHARLIT,
|
||||||
XP_STX_TOKEN_IDENT = 2,
|
XP_STX_TOKEN_STRLIT,
|
||||||
XP_STX_TOKEN_SELF = 3,
|
XP_STX_TOKEN_IDENT,
|
||||||
XP_STX_TOKEN_SUPER = 4,
|
XP_STX_TOKEN_KEYWORD
|
||||||
XP_STX_TOKEN_NIL = 5,
|
|
||||||
XP_STX_TOKEN_TRUE = 6,
|
|
||||||
XP_STX_TOKEN_FALSE = 7
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct xp_stx_token_t
|
struct xp_stx_token_t
|
||||||
|
@ -12,23 +12,27 @@
|
|||||||
|
|
||||||
struct ss_t
|
struct ss_t
|
||||||
{
|
{
|
||||||
xp_stx_char_t* text;
|
const xp_stx_char_t* text;
|
||||||
xp_size_t size;
|
xp_size_t size;
|
||||||
xp_size_t index;
|
xp_size_t index;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct ss_t ss_t;
|
typedef struct ss_t ss_t;
|
||||||
|
|
||||||
int ss_reset (xp_stx_parser_t* parser)
|
int ss_input (void* owner, int cmd, void* arg)
|
||||||
{
|
{
|
||||||
return 0;
|
ss_t* ss = (ss_t*)owner;
|
||||||
}
|
|
||||||
|
|
||||||
int ss_consume (xp_stx_parser_t* parser, xp_stx_cint_t* c)
|
if (cmd == XP_STX_PARSER_INPUT_OPEN) {
|
||||||
{
|
return 0;
|
||||||
ss_t* ss = (ss_t*)parser->input;
|
}
|
||||||
if (ss->index < ss->size) *c = ss->text[ss->index++];
|
else if (cmd == XP_STX_PARSER_INPUT_CLOSE) {
|
||||||
else *c = XP_STX_CHAR_EOF;
|
return 0;
|
||||||
|
}
|
||||||
|
else if (cmd == XP_STX_PARSER_INPUT_CONSUME) {
|
||||||
|
if (ss->index < ss->size) *c = ss->text[ss->index++];
|
||||||
|
else *c = XP_STX_CHAR_EOF;
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -49,8 +53,18 @@ int xp_main (int argc, xp_char_t* argv[])
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
parser.input_reset = ss_reset;
|
parser.input_func = ss_func;
|
||||||
parser.input_consume = ss_consume;
|
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
ss_t ss = {
|
||||||
|
XP_STX_TEXT("isNil\n^true"),
|
||||||
|
11,
|
||||||
|
0
|
||||||
|
};
|
||||||
|
*/
|
||||||
|
xp_stx_parser_parse_method (&parser, 0, &ss);
|
||||||
|
}
|
||||||
|
|
||||||
xp_stx_parser_close (&parser);
|
xp_stx_parser_close (&parser);
|
||||||
xp_printf (XP_TEXT("== End of program ==\n"));
|
xp_printf (XP_TEXT("== End of program ==\n"));
|
||||||
|
Loading…
Reference in New Issue
Block a user