changed code to handle numeric string comparison better

This commit is contained in:
hyung-hwan 2009-06-16 02:22:48 +00:00
parent 193afb0567
commit ed6db12e27

View File

@ -1,5 +1,5 @@
/* /*
* $Id: run.c 199 2009-06-14 08:40:52Z hyunghwan.chung $ * $Id: run.c 201 2009-06-15 08:22:48Z hyunghwan.chung $
* *
Copyright 2006-2009 Chung, Hyung-Hwan. Copyright 2006-2009 Chung, Hyung-Hwan.
@ -4182,24 +4182,35 @@ static int __cmp_str_real (
} }
static int __cmp_str_str ( static int __cmp_str_str (
qse_awk_rtx_t* run, qse_awk_val_t* left, qse_awk_val_t* right) qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
{ {
int n; int n1, n2;
qse_long_t l1, l2;
qse_real_t r1, r2;
qse_awk_val_str_t* ls, * rs; qse_awk_val_str_t* ls, * rs;
ls = (qse_awk_val_str_t*)left; ls = (qse_awk_val_str_t*)left;
rs = (qse_awk_val_str_t*)right; rs = (qse_awk_val_str_t*)right;
if (run->gbl.ignorecase) if (ls->nstr == 0 && rs->nstr == 0)
{ {
n = qse_strxncasecmp (ls->ptr, ls->len, rs->ptr, rs->len); /* nother are definitely a string */
return (rtx->gbl.ignorecase)?
qse_strxncasecmp (ls->ptr, ls->len, rs->ptr, rs->len):
qse_strxncmp (ls->ptr, ls->len, rs->ptr, rs->len);
}
n1 = qse_awk_rtx_strtonum (rtx, 0, ls->ptr, ls->len, &l1, &r1);
n2 = qse_awk_rtx_strtonum (rtx, 0, rs->ptr, rs->len, &l2, &r2);
if (n1 == 0)
{
return (n2 == 0)? (l1 - l2): ((qse_real_t)l1 - r2);
} }
else else
{ {
n = qse_strxncmp (ls->ptr, ls->len, rs->ptr, rs->len); return (n2 == 0)? (r1 - (qse_real_t)l2): (r1 - r2);
} }
return n;
} }
static int __cmp_val ( static int __cmp_val (