*** empty log message ***

This commit is contained in:
hyung-hwan 2006-12-04 06:50:26 +00:00
parent 9ada8cc5af
commit d4aeb27b90
4 changed files with 33 additions and 12 deletions

View File

@ -21,7 +21,7 @@ JAVAC = javac
CFLAGS_COMMON = -O2 -WM -WU -RT- -w -q -I../.. $(JNI_INCPATH) CFLAGS_COMMON = -O2 -WM -WU -RT- -w -q -I../.. $(JNI_INCPATH)
CFLAGS_RELEASE = $(CFLAGS_COMMON) -DNDEBUG CFLAGS_RELEASE = $(CFLAGS_COMMON) -DNDEBUG
CFLAGS_DEBUG = $(CFLAGS_COMMON) -D_DEBUG CFLAGS_DEBUG = $(CFLAGS_COMMON) -D_DEBUG #-DDEBUG_REX
CFLAGS = $(CFLAGS_DEBUG) CFLAGS = $(CFLAGS_DEBUG)
#CFLAGS = $(CFLAGS_RELEASE) #CFLAGS = $(CFLAGS_RELEASE)
JAVACFLAGS = -classpath ../.. JAVACFLAGS = -classpath ../..

View File

@ -1,10 +1,9 @@
/* /*
* $Id: rex.c,v 1.49 2006-12-02 16:26:03 bacon Exp $ * $Id: rex.c,v 1.50 2006-12-04 06:50:26 bacon Exp $
*/ */
#include <ase/awk/awk_i.h> #include <ase/awk/awk_i.h>
//#define DEBUG_REX
enum enum
{ {
CT_EOF, CT_EOF,
@ -1232,6 +1231,7 @@ static const ase_byte_t* __match_any_char (
matcher->awk->syscas.dprintf ( matcher->awk->syscas.dprintf (
ASE_T("__match_any_char: max si = %u\n"), (unsigned)si); ASE_T("__match_any_char: max si = %u\n"), (unsigned)si);
#endif #endif
if (si >= lbound && si <= ubound) if (si >= lbound && si <= ubound)
{ {
p = __match_occurrences (matcher, si, p, lbound, ubound, mat); p = __match_occurrences (matcher, si, p, lbound, ubound, mat);
@ -1289,8 +1289,8 @@ static const ase_byte_t* __match_ord_char (
#ifdef BUILD_REX #ifdef BUILD_REX
matcher->awk->syscas.dprintf ( matcher->awk->syscas.dprintf (
ASE_T("__match_ord_char: lbound = %u, ubound = %u\n"), ASE_T("__match_ord_char: cc = %c, lbound = %u, ubound = %u\n"),
(unsigned int)lbound, (unsigned int)ubound); cc, (unsigned int)lbound, (unsigned int)ubound);
#endif #endif
mat->matched = ase_false; mat->matched = ase_false;
@ -1302,6 +1302,11 @@ static const ase_byte_t* __match_ord_char (
while (si < ubound) while (si < ubound)
{ {
if (&mat->match_ptr[si] >= matcher->match.str.end) break; if (&mat->match_ptr[si] >= matcher->match.str.end) break;
#ifdef DEBUG_REX
matcher->awk->syscas.dprintf (
ASE_T("__match_ord_char: <ignorecase> %c %c\n"),
cc, mat->match_ptr[si]);
#endif
if (cc != ASE_AWK_TOUPPER (matcher->awk, mat->match_ptr[si])) break; if (cc != ASE_AWK_TOUPPER (matcher->awk, mat->match_ptr[si])) break;
si++; si++;
} }
@ -1312,8 +1317,9 @@ static const ase_byte_t* __match_ord_char (
{ {
if (&mat->match_ptr[si] >= matcher->match.str.end) break; if (&mat->match_ptr[si] >= matcher->match.str.end) break;
#ifdef DEBUG_REX #ifdef DEBUG_REX
matcher->awk->syscas.dprintf ( matcher->awk->syscas.dprintf (
ASE_T("__match_ord_char: %c %c\n"), cc, mat->match_ptr[si]); ASE_T("__match_ord_char: %c %c\n"),
cc, mat->match_ptr[si]);
#endif #endif
if (cc != mat->match_ptr[si]) break; if (cc != mat->match_ptr[si]) break;
si++; si++;
@ -1322,7 +1328,7 @@ static const ase_byte_t* __match_ord_char (
#ifdef DEBUG_REX #ifdef DEBUG_REX
matcher->awk->syscas.dprintf ( matcher->awk->syscas.dprintf (
ASE_T("__match_ord_char: max si=%u, lbound=%u, ubound=%u\n"), ASE_T("__match_ord_char: max occurrences=%u, lbound=%u, ubound=%u\n"),
(unsigned)si, (unsigned)lbound, (unsigned)ubound); (unsigned)si, (unsigned)lbound, (unsigned)ubound);
#endif #endif
@ -1379,7 +1385,7 @@ static const ase_byte_t* __match_charset (
#ifdef DEBUG_REX #ifdef DEBUG_REX
matcher->awk->syscas.dprintf ( matcher->awk->syscas.dprintf (
ASE_T("__match_charset: max si=%u, lbound=%u, ubound=%u\n"), ASE_T("__match_charset: max occurrences=%u, lbound=%u, ubound=%u\n"),
(unsigned)si, (unsigned)lbound, (unsigned)ubound); (unsigned)si, (unsigned)lbound, (unsigned)ubound);
#endif #endif
if (si >= lbound && si <= ubound) if (si >= lbound && si <= ubound)
@ -1631,6 +1637,10 @@ static ase_bool_t __test_charset (
c1 = *(const ase_char_t*)p; c1 = *(const ase_char_t*)p;
if (matcher->ignorecase) if (matcher->ignorecase)
c1 = ASE_AWK_TOUPPER(matcher->awk, c1); c1 = ASE_AWK_TOUPPER(matcher->awk, c1);
#ifdef DEBUG_REX
matcher->awk->syscas.dprintf (
ASE_T("__match_charset: <one> %c %c\n"), c, c1);
#endif
if (c == c1) return ase_true; if (c == c1) return ase_true;
} }
else if (c0 == CHARSET_RANGE) else if (c0 == CHARSET_RANGE)
@ -1644,11 +1654,20 @@ static ase_bool_t __test_charset (
c1 = ASE_AWK_TOUPPER(matcher->awk, c1); c1 = ASE_AWK_TOUPPER(matcher->awk, c1);
c2 = ASE_AWK_TOUPPER(matcher->awk, c2); c2 = ASE_AWK_TOUPPER(matcher->awk, c2);
} }
#ifdef DEBUG_REX
matcher->awk->syscas.dprintf (
ASE_T("__match_charset: <range> %c %c-%c\n"), c, c1, c2);
#endif
if (c >= c1 && c <= c2) return ase_true; if (c >= c1 && c <= c2) return ase_true;
} }
else if (c0 == CHARSET_CLASS) else if (c0 == CHARSET_CLASS)
{ {
c1 = *(const ase_char_t*)p; c1 = *(const ase_char_t*)p;
#ifdef DEBUG_REX
matcher->awk->syscas.dprintf (
ASE_T("__match_charset: <class> %c %s\n"),
c, __char_class[c1].name);
#endif
if (__char_class[c1].func ( if (__char_class[c1].func (
matcher->awk, c)) return ase_true; matcher->awk, c)) return ase_true;
} }

View File

@ -1,5 +1,5 @@
/* /*
* $Id: run.c,v 1.291 2006-12-04 06:28:56 bacon Exp $ * $Id: run.c,v 1.292 2006-12-04 06:50:26 bacon Exp $
*/ */
#include <ase/awk/awk_i.h> #include <ase/awk/awk_i.h>
@ -4067,7 +4067,6 @@ static ase_awk_val_t* __eval_binop_nm (
ase_awk_refupval (run, rv); ase_awk_refupval (run, rv);
wprintf (L"STRING: [%S]\n", ((ase_awk_val_str_t*)lv)->buf);
res = __eval_binop_match0 (run, lv, rv, 0); res = __eval_binop_match0 (run, lv, rv, 0);
ase_awk_refdownval (run, lv); ase_awk_refdownval (run, lv);
@ -4160,6 +4159,7 @@ static ase_awk_val_t* __eval_binop_match0 (
PANIC (run, errnum); PANIC (run, errnum);
} }
wprintf (L"n=%d, ret=%d\n", n, ret);
res = ase_awk_makeintval (run, (n == ret)); res = ase_awk_makeintval (run, (n == ret));
if (res == ASE_NULL) if (res == ASE_NULL)
{ {

View File

@ -1 +1,3 @@
$2 !~ /^[0-9]+$]/ $2 !~ /^[0-9]+$/