*** empty log message ***
This commit is contained in:
parent
6626b3a414
commit
3c65836426
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* $Id: parse.c,v 1.22 2006-01-18 15:16:01 bacon Exp $
|
* $Id: parse.c,v 1.23 2006-01-18 16:12:58 bacon Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <xp/awk/awk.h>
|
#include <xp/awk/awk.h>
|
||||||
@ -261,14 +261,16 @@ static xp_awk_node_t* __parse_block (xp_awk_t* awk)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* if you want to remove top-level null statement... get it here... */
|
||||||
|
/*
|
||||||
if (MATCH(awk,TOKEN_SEMICOLON)) {
|
if (MATCH(awk,TOKEN_SEMICOLON)) {
|
||||||
/* null statement */
|
|
||||||
if (__get_token(awk) == -1) {
|
if (__get_token(awk) == -1) {
|
||||||
if (head != XP_NULL) xp_awk_clrpt (head);
|
if (head != XP_NULL) xp_awk_clrpt (head);
|
||||||
return XP_NULL;
|
return XP_NULL;
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
node = __parse_statement (awk);
|
node = __parse_statement (awk);
|
||||||
if (node == XP_NULL) {
|
if (node == XP_NULL) {
|
||||||
@ -298,7 +300,20 @@ static xp_awk_node_t* __parse_statement (xp_awk_t* awk)
|
|||||||
{
|
{
|
||||||
xp_awk_node_t* node;
|
xp_awk_node_t* node;
|
||||||
|
|
||||||
if (MATCH(awk,TOKEN_LBRACE)) {
|
if (MATCH(awk,TOKEN_SEMICOLON)) {
|
||||||
|
/* null statement */
|
||||||
|
node = (xp_awk_node_t*) xp_malloc (xp_sizeof(xp_awk_node_t));
|
||||||
|
if (node == XP_NULL) PANIC (awk, XP_AWK_ENOMEM);
|
||||||
|
|
||||||
|
node->type = XP_AWK_NODE_NULL;
|
||||||
|
node->next = XP_NULL;
|
||||||
|
|
||||||
|
if (__get_token(awk) == -1) {
|
||||||
|
xp_free (node);
|
||||||
|
return XP_NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (MATCH(awk,TOKEN_LBRACE)) {
|
||||||
if (__get_token(awk) == -1) return XP_NULL;
|
if (__get_token(awk) == -1) return XP_NULL;
|
||||||
node = __parse_block (awk);
|
node = __parse_block (awk);
|
||||||
}
|
}
|
||||||
@ -693,8 +708,11 @@ static xp_awk_node_t* __parse_funcall (xp_awk_t* awk, xp_char_t* name)
|
|||||||
|
|
||||||
head = curr = XP_NULL;
|
head = curr = XP_NULL;
|
||||||
|
|
||||||
if (!MATCH(awk,TOKEN_RPAREN)) {
|
if (MATCH(awk,TOKEN_RPAREN)) {
|
||||||
|
/* no parameters to the function call */
|
||||||
|
if (__get_token(awk) == -1) return XP_NULL;
|
||||||
|
}
|
||||||
|
else {
|
||||||
while (1) {
|
while (1) {
|
||||||
node = __parse_expression (awk);
|
node = __parse_expression (awk);
|
||||||
if (node == XP_NULL) {
|
if (node == XP_NULL) {
|
||||||
@ -805,9 +823,46 @@ static xp_awk_node_t* __parse_if (xp_awk_t* awk)
|
|||||||
|
|
||||||
static xp_awk_node_t* __parse_while (xp_awk_t* awk)
|
static xp_awk_node_t* __parse_while (xp_awk_t* awk)
|
||||||
{
|
{
|
||||||
|
xp_awk_node_t* test, * body;
|
||||||
|
xp_awk_node_while_t* node;
|
||||||
|
|
||||||
|
if (!MATCH(awk,TOKEN_LPAREN)) PANIC (awk, XP_AWK_ELPAREN);
|
||||||
|
if (__get_token(awk) == -1) return XP_NULL;
|
||||||
|
|
||||||
|
test = __parse_expression (awk);
|
||||||
|
if (test == XP_NULL) return XP_NULL;
|
||||||
|
|
||||||
|
if (!MATCH(awk,TOKEN_RPAREN)) {
|
||||||
|
xp_awk_clrpt (test);
|
||||||
|
PANIC (awk, XP_AWK_ERPAREN);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (__get_token(awk) == -1) {
|
||||||
|
xp_awk_clrpt (test);
|
||||||
return XP_NULL;
|
return XP_NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
body = __parse_statement (awk);
|
||||||
|
if (body == XP_NULL) {
|
||||||
|
xp_awk_clrpt (test);
|
||||||
|
return XP_NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
node = (xp_awk_node_while_t*) xp_malloc (xp_sizeof(xp_awk_node_while_t));
|
||||||
|
if (node == XP_NULL) {
|
||||||
|
xp_awk_clrpt (body);
|
||||||
|
xp_awk_clrpt (test);
|
||||||
|
PANIC (awk, XP_AWK_ENOMEM);
|
||||||
|
}
|
||||||
|
|
||||||
|
node->type = XP_AWK_NODE_WHILE;
|
||||||
|
node->next = XP_NULL;
|
||||||
|
node->test = test;
|
||||||
|
node->body = body;
|
||||||
|
|
||||||
|
return (xp_awk_node_t*)node;
|
||||||
|
}
|
||||||
|
|
||||||
static xp_awk_node_t* __parse_for (xp_awk_t* awk)
|
static xp_awk_node_t* __parse_for (xp_awk_t* awk)
|
||||||
{
|
{
|
||||||
return XP_NULL;
|
return XP_NULL;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* $Id: tree.c,v 1.4 2006-01-18 15:16:01 bacon Exp $
|
* $Id: tree.c,v 1.5 2006-01-18 16:12:58 bacon Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <xp/awk/awk.h>
|
#include <xp/awk/awk.h>
|
||||||
@ -99,6 +99,11 @@ static void __print_statements (xp_awk_node_t* tree, int depth)
|
|||||||
while (p != XP_NULL) {
|
while (p != XP_NULL) {
|
||||||
|
|
||||||
switch (p->type) {
|
switch (p->type) {
|
||||||
|
case XP_AWK_NODE_NULL:
|
||||||
|
__print_tabs (depth);
|
||||||
|
xp_printf (XP_TEXT(";\n"));
|
||||||
|
break;
|
||||||
|
|
||||||
case XP_AWK_NODE_BLOCK:
|
case XP_AWK_NODE_BLOCK:
|
||||||
__print_tabs (depth);
|
__print_tabs (depth);
|
||||||
xp_printf (XP_TEXT("{\n"));
|
xp_printf (XP_TEXT("{\n"));
|
||||||
@ -114,9 +119,8 @@ static void __print_statements (xp_awk_node_t* tree, int depth)
|
|||||||
xp_printf (XP_TEXT(")\n"));
|
xp_printf (XP_TEXT(")\n"));
|
||||||
|
|
||||||
// TODO: identation of depth + 1 if then_part or else_part is not a block
|
// TODO: identation of depth + 1 if then_part or else_part is not a block
|
||||||
if (((xp_awk_node_if_t*)p)->then_part == XP_NULL)
|
xp_assert (((xp_awk_node_if_t*)p)->then_part != XP_NULL);
|
||||||
xp_printf (XP_TEXT(";\n"));
|
__print_statements (((xp_awk_node_if_t*)p)->then_part, depth);
|
||||||
else __print_statements (((xp_awk_node_if_t*)p)->then_part, depth);
|
|
||||||
|
|
||||||
if (((xp_awk_node_if_t*)p)->else_part != XP_NULL) {
|
if (((xp_awk_node_if_t*)p)->else_part != XP_NULL) {
|
||||||
__print_tabs (depth);
|
__print_tabs (depth);
|
||||||
@ -124,6 +128,16 @@ static void __print_statements (xp_awk_node_t* tree, int depth)
|
|||||||
__print_statements (((xp_awk_node_if_t*)p)->else_part, depth);
|
__print_statements (((xp_awk_node_if_t*)p)->else_part, depth);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case XP_AWK_NODE_WHILE:
|
||||||
|
__print_tabs (depth);
|
||||||
|
xp_printf (XP_TEXT("while ("));
|
||||||
|
__print_expr_node (((xp_awk_node_while_t*)p)->test);
|
||||||
|
xp_printf (XP_TEXT(")\n"));
|
||||||
|
|
||||||
|
if (((xp_awk_node_while_t*)p)->body == XP_NULL)
|
||||||
|
xp_printf (XP_TEXT(";\n"));
|
||||||
|
else __print_statements (((xp_awk_node_while_t*)p)->body, depth);
|
||||||
|
break;
|
||||||
|
|
||||||
case XP_AWK_NODE_BREAK:
|
case XP_AWK_NODE_BREAK:
|
||||||
__print_tabs (depth);
|
__print_tabs (depth);
|
||||||
@ -189,6 +203,10 @@ void xp_awk_clrpt (xp_awk_node_t* tree)
|
|||||||
next = p->next;
|
next = p->next;
|
||||||
|
|
||||||
switch (p->type) {
|
switch (p->type) {
|
||||||
|
case XP_AWK_NODE_NULL:
|
||||||
|
xp_free (p);
|
||||||
|
break;
|
||||||
|
|
||||||
case XP_AWK_NODE_BLOCK:
|
case XP_AWK_NODE_BLOCK:
|
||||||
xp_awk_clrpt (((xp_awk_node_block_t*)p)->body);
|
xp_awk_clrpt (((xp_awk_node_block_t*)p)->body);
|
||||||
xp_free (p);
|
xp_free (p);
|
||||||
@ -203,6 +221,13 @@ void xp_awk_clrpt (xp_awk_node_t* tree)
|
|||||||
xp_free (p);
|
xp_free (p);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case XP_AWK_NODE_WHILE:
|
||||||
|
xp_awk_clrpt (((xp_awk_node_while_t*)p)->test);
|
||||||
|
if (((xp_awk_node_while_t*)p)->body != XP_NULL)
|
||||||
|
xp_awk_clrpt (((xp_awk_node_while_t*)p)->body);
|
||||||
|
xp_free (p);
|
||||||
|
break;
|
||||||
|
|
||||||
case XP_AWK_NODE_BREAK:
|
case XP_AWK_NODE_BREAK:
|
||||||
case XP_AWK_NODE_CONTINUE:
|
case XP_AWK_NODE_CONTINUE:
|
||||||
xp_free (p);
|
xp_free (p);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* $Id: tree.h,v 1.9 2006-01-14 16:09:58 bacon Exp $
|
* $Id: tree.h,v 1.10 2006-01-18 16:12:58 bacon Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _XP_AWK_TREE_H_
|
#ifndef _XP_AWK_TREE_H_
|
||||||
@ -7,6 +7,7 @@
|
|||||||
|
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
|
XP_AWK_NODE_NULL,
|
||||||
XP_AWK_NODE_BLOCK,
|
XP_AWK_NODE_BLOCK,
|
||||||
XP_AWK_NODE_BREAK,
|
XP_AWK_NODE_BREAK,
|
||||||
XP_AWK_NODE_CONTINUE,
|
XP_AWK_NODE_CONTINUE,
|
||||||
@ -19,7 +20,8 @@ enum
|
|||||||
XP_AWK_NODE_NUM,
|
XP_AWK_NODE_NUM,
|
||||||
XP_AWK_NODE_VAR,
|
XP_AWK_NODE_VAR,
|
||||||
XP_AWK_NODE_CALL,
|
XP_AWK_NODE_CALL,
|
||||||
XP_AWK_NODE_IF
|
XP_AWK_NODE_IF,
|
||||||
|
XP_AWK_NODE_WHILE
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct xp_awk_node_t xp_awk_node_t;
|
typedef struct xp_awk_node_t xp_awk_node_t;
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
CC = cl
|
CC = cl
|
||||||
CFLAGS = /nologo /MT /GX /W3 /GR- /D_WIN32_WINNT=0x0400 -I..\..\..
|
#CFLAGS = /nologo /MT /W3 /GR- /D_WIN32_WINNT=0x0400 -I..\..\..
|
||||||
|
CFLAGS = /nologo /MT /W3 /GR- /D_WIN32_WINNT=0x0400 -I..\..\.. -D__STAND_ALONE
|
||||||
LDFLAGS = /libpath:..\..\bas /libpath:..\..\awk
|
LDFLAGS = /libpath:..\..\bas /libpath:..\..\awk
|
||||||
LIBS = xpbas.lib xpawk.lib
|
#LIBS = xpbas.lib xpawk.lib
|
||||||
|
LIBS = xpawk.lib
|
||||||
|
|
||||||
all: awk
|
all: awk
|
||||||
|
|
||||||
|
@ -1,4 +1,29 @@
|
|||||||
#include <xp/awk/awk.h>
|
#include <xp/awk/awk.h>
|
||||||
|
|
||||||
|
#ifdef __STAND_ALONE
|
||||||
|
|
||||||
|
static xp_ssize_t process_source (int cmd, void* arg, xp_char_t* data, xp_size_t size)
|
||||||
|
{
|
||||||
|
wchar_t c;
|
||||||
|
|
||||||
|
switch (cmd) {
|
||||||
|
case XP_AWK_IO_OPEN:
|
||||||
|
case XP_AWK_IO_CLOSE:
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
case XP_AWK_IO_DATA:
|
||||||
|
if (size < 0) return -1;
|
||||||
|
c = fgetwc (stdin);
|
||||||
|
if (c == XP_CHAR_EOF) return 0;
|
||||||
|
*data = c;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
#include <xp/bas/stdio.h>
|
#include <xp/bas/stdio.h>
|
||||||
#include <xp/bas/sio.h>
|
#include <xp/bas/sio.h>
|
||||||
|
|
||||||
@ -21,6 +46,7 @@ static xp_ssize_t process_source (int cmd, void* arg, xp_char_t* data, xp_size_t
|
|||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
int xp_main (int argc, xp_char_t* argv[])
|
int xp_main (int argc, xp_char_t* argv[])
|
||||||
{
|
{
|
||||||
@ -28,25 +54,25 @@ int xp_main (int argc, xp_char_t* argv[])
|
|||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
if (argc != 2) {
|
if (argc != 2) {
|
||||||
xp_fprintf (xp_stderr, XP_TEXT("Usage: %s file\n"), argv[0]);
|
xp_printf (XP_TEXT("Usage: %s file\n"), argv[0]);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (xp_awk_open(&awk) == XP_NULL) {
|
if (xp_awk_open(&awk) == XP_NULL) {
|
||||||
xp_fprintf (xp_stderr, XP_TEXT("Error: cannot open awk\n"));
|
xp_printf (XP_TEXT("Error: cannot open awk\n"));
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (xp_awk_attsrc(&awk, process_source, XP_NULL) == -1) {
|
if (xp_awk_attsrc(&awk, process_source, XP_NULL) == -1) {
|
||||||
xp_awk_close (&awk);
|
xp_awk_close (&awk);
|
||||||
xp_fprintf (xp_stderr, XP_TEXT("error: cannot attach source\n"));
|
xp_printf (XP_TEXT("error: cannot attach source\n"));
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (xp_awk_parse(&awk) == -1) {
|
if (xp_awk_parse(&awk) == -1) {
|
||||||
xp_awk_close (&awk);
|
xp_awk_close (&awk);
|
||||||
xp_fprintf (xp_stderr, XP_TEXT("error: cannot parse program\n"));
|
xp_printf (XP_TEXT("error: cannot parse program\n"));
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user