mirror of
https://git.hardenedbsd.org/hardenedbsd/HardenedBSD.git
synced 2025-01-22 16:44:32 +01:00
1003.2 requires that lexical comparisons be done in locale specific manner,
so we have to use strcoll() instead of strcmp(). 1003.2 requires that a null string be returned if a string does not match a \( \) subexpression. Replaced fprintf/exit with calls to err and errx as appropriate.
This commit is contained in:
parent
3e0ac24dc1
commit
55c497bf15
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=295
@ -1,13 +1,16 @@
|
|||||||
%{
|
%{
|
||||||
/* Written by Pace Willisson (pace@blitz.com)
|
/* Written by Pace Willisson (pace@blitz.com)
|
||||||
* and placed in the public domain
|
* and placed in the public domain.
|
||||||
*
|
*
|
||||||
* $Header: /b/source/CVS/src/bin/expr/expr.y,v 1.9 1993/07/20 01:10:55 jtc Exp $
|
* Largely rewritten by J.T. Conklin (jtc@wimsey.com)
|
||||||
|
*
|
||||||
|
* $Header: /b/source/CVS/src/bin/expr/expr.y,v 1.11 1993/08/17 16:01:23 jtc Exp $
|
||||||
*/
|
*/
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
#include <err.h>
|
||||||
|
|
||||||
enum valtype {
|
enum valtype {
|
||||||
integer, string
|
integer, string
|
||||||
@ -90,8 +93,7 @@ int i;
|
|||||||
|
|
||||||
vp = (struct val *) malloc (sizeof (*vp));
|
vp = (struct val *) malloc (sizeof (*vp));
|
||||||
if (vp == NULL) {
|
if (vp == NULL) {
|
||||||
fprintf (stderr, "expr: out of memory\n");
|
err (2, NULL);
|
||||||
exit (2);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
vp->type = integer;
|
vp->type = integer;
|
||||||
@ -107,8 +109,7 @@ char *s;
|
|||||||
|
|
||||||
vp = (struct val *) malloc (sizeof (*vp));
|
vp = (struct val *) malloc (sizeof (*vp));
|
||||||
if (vp == NULL || ((vp->u.s = strdup (s)) == NULL)) {
|
if (vp == NULL || ((vp->u.s = strdup (s)) == NULL)) {
|
||||||
fprintf (stderr, "expr: out of memory\n");
|
err (2, NULL);
|
||||||
exit (2);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
vp->type = string;
|
vp->type = string;
|
||||||
@ -171,8 +172,7 @@ struct val *vp;
|
|||||||
|
|
||||||
tmp = malloc (25);
|
tmp = malloc (25);
|
||||||
if (tmp == NULL) {
|
if (tmp == NULL) {
|
||||||
fprintf (stderr, "expr: out of memory\n");
|
err (2, NULL);
|
||||||
exit (2);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sprintf (tmp, "%d", vp->u.i);
|
sprintf (tmp, "%d", vp->u.i);
|
||||||
@ -251,8 +251,7 @@ int
|
|||||||
yyerror (s)
|
yyerror (s)
|
||||||
char *s;
|
char *s;
|
||||||
{
|
{
|
||||||
fprintf (stderr, "expr: syntax error\n");
|
errx (2, "syntax error");
|
||||||
exit (2);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -292,7 +291,7 @@ struct val *a, *b;
|
|||||||
if (isstring (a) || isstring (b)) {
|
if (isstring (a) || isstring (b)) {
|
||||||
to_string (a);
|
to_string (a);
|
||||||
to_string (b);
|
to_string (b);
|
||||||
r = make_integer (strcmp (a->u.s, b->u.s) == 0);
|
r = make_integer (strcoll (a->u.s, b->u.s) == 0);
|
||||||
} else {
|
} else {
|
||||||
r = make_integer (a->u.i == b->u.i);
|
r = make_integer (a->u.i == b->u.i);
|
||||||
}
|
}
|
||||||
@ -311,7 +310,7 @@ struct val *a, *b;
|
|||||||
if (isstring (a) || isstring (b)) {
|
if (isstring (a) || isstring (b)) {
|
||||||
to_string (a);
|
to_string (a);
|
||||||
to_string (b);
|
to_string (b);
|
||||||
r = make_integer (strcmp (a->u.s, b->u.s) > 0);
|
r = make_integer (strcoll (a->u.s, b->u.s) > 0);
|
||||||
} else {
|
} else {
|
||||||
r= make_integer (a->u.i > b->u.i);
|
r= make_integer (a->u.i > b->u.i);
|
||||||
}
|
}
|
||||||
@ -330,7 +329,7 @@ struct val *a, *b;
|
|||||||
if (isstring (a) || isstring (b)) {
|
if (isstring (a) || isstring (b)) {
|
||||||
to_string (a);
|
to_string (a);
|
||||||
to_string (b);
|
to_string (b);
|
||||||
r = make_integer (strcmp (a->u.s, b->u.s) < 0);
|
r = make_integer (strcoll (a->u.s, b->u.s) < 0);
|
||||||
} else {
|
} else {
|
||||||
r = make_integer (a->u.i < b->u.i);
|
r = make_integer (a->u.i < b->u.i);
|
||||||
}
|
}
|
||||||
@ -349,7 +348,7 @@ struct val *a, *b;
|
|||||||
if (isstring (a) || isstring (b)) {
|
if (isstring (a) || isstring (b)) {
|
||||||
to_string (a);
|
to_string (a);
|
||||||
to_string (b);
|
to_string (b);
|
||||||
r = make_integer (strcmp (a->u.s, b->u.s) >= 0);
|
r = make_integer (strcoll (a->u.s, b->u.s) >= 0);
|
||||||
} else {
|
} else {
|
||||||
r = make_integer (a->u.i >= b->u.i);
|
r = make_integer (a->u.i >= b->u.i);
|
||||||
}
|
}
|
||||||
@ -368,7 +367,7 @@ struct val *a, *b;
|
|||||||
if (isstring (a) || isstring (b)) {
|
if (isstring (a) || isstring (b)) {
|
||||||
to_string (a);
|
to_string (a);
|
||||||
to_string (b);
|
to_string (b);
|
||||||
r = make_integer (strcmp (a->u.s, b->u.s) <= 0);
|
r = make_integer (strcoll (a->u.s, b->u.s) <= 0);
|
||||||
} else {
|
} else {
|
||||||
r = make_integer (a->u.i <= b->u.i);
|
r = make_integer (a->u.i <= b->u.i);
|
||||||
}
|
}
|
||||||
@ -387,7 +386,7 @@ struct val *a, *b;
|
|||||||
if (isstring (a) || isstring (b)) {
|
if (isstring (a) || isstring (b)) {
|
||||||
to_string (a);
|
to_string (a);
|
||||||
to_string (b);
|
to_string (b);
|
||||||
r = make_integer (strcmp (a->u.s, b->u.s) != 0);
|
r = make_integer (strcoll (a->u.s, b->u.s) != 0);
|
||||||
} else {
|
} else {
|
||||||
r = make_integer (a->u.i != b->u.i);
|
r = make_integer (a->u.i != b->u.i);
|
||||||
}
|
}
|
||||||
@ -404,8 +403,7 @@ struct val *a, *b;
|
|||||||
struct val *r;
|
struct val *r;
|
||||||
|
|
||||||
if (!to_integer (a) || !to_integer (b)) {
|
if (!to_integer (a) || !to_integer (b)) {
|
||||||
fprintf (stderr, "expr: non-numeric argument\n");
|
errx (2, "non-numeric argument");
|
||||||
exit (2);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
r = make_integer (a->u.i + b->u.i);
|
r = make_integer (a->u.i + b->u.i);
|
||||||
@ -421,8 +419,7 @@ struct val *a, *b;
|
|||||||
struct val *r;
|
struct val *r;
|
||||||
|
|
||||||
if (!to_integer (a) || !to_integer (b)) {
|
if (!to_integer (a) || !to_integer (b)) {
|
||||||
fprintf (stderr, "expr: non-numeric argument\n");
|
errx (2, "non-numeric argument");
|
||||||
exit (2);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
r = make_integer (a->u.i - b->u.i);
|
r = make_integer (a->u.i - b->u.i);
|
||||||
@ -438,8 +435,7 @@ struct val *a, *b;
|
|||||||
struct val *r;
|
struct val *r;
|
||||||
|
|
||||||
if (!to_integer (a) || !to_integer (b)) {
|
if (!to_integer (a) || !to_integer (b)) {
|
||||||
fprintf (stderr, "expr: non-numeric argument\n");
|
errx (2, "non-numeric argument");
|
||||||
exit (2);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
r = make_integer (a->u.i * b->u.i);
|
r = make_integer (a->u.i * b->u.i);
|
||||||
@ -455,13 +451,11 @@ struct val *a, *b;
|
|||||||
struct val *r;
|
struct val *r;
|
||||||
|
|
||||||
if (!to_integer (a) || !to_integer (b)) {
|
if (!to_integer (a) || !to_integer (b)) {
|
||||||
fprintf (stderr, "expr: non-numeric argument\n");
|
errx (2, "non-numeric argument");
|
||||||
exit (2);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (b->u.i == 0) {
|
if (b->u.i == 0) {
|
||||||
fprintf (stderr, "expr: division by zero\n");
|
errx (2, "division by zero");
|
||||||
exit (2);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
r = make_integer (a->u.i / b->u.i);
|
r = make_integer (a->u.i / b->u.i);
|
||||||
@ -477,13 +471,11 @@ struct val *a, *b;
|
|||||||
struct val *r;
|
struct val *r;
|
||||||
|
|
||||||
if (!to_integer (a) || !to_integer (b)) {
|
if (!to_integer (a) || !to_integer (b)) {
|
||||||
fprintf (stderr, "expr: non-numeric argument\n");
|
errx (2, "non-numeric argument");
|
||||||
exit (2);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (b->u.i == 0) {
|
if (b->u.i == 0) {
|
||||||
fprintf (stderr, "expr: division by zero\n");
|
errx (2, "division by zero");
|
||||||
exit (2);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
r = make_integer (a->u.i % b->u.i);
|
r = make_integer (a->u.i % b->u.i);
|
||||||
@ -518,22 +510,25 @@ struct val *a, *b;
|
|||||||
/* compile regular expression */
|
/* compile regular expression */
|
||||||
if ((eval = regcomp (&rp, newpat, 0)) != 0) {
|
if ((eval = regcomp (&rp, newpat, 0)) != 0) {
|
||||||
regerror (eval, &rp, errbuf, sizeof(errbuf));
|
regerror (eval, &rp, errbuf, sizeof(errbuf));
|
||||||
fprintf (stderr, "expr: %s\n", errbuf);
|
errx (2, "%s", errbuf);
|
||||||
exit (2);
|
|
||||||
}
|
}
|
||||||
free (newpat);
|
free (newpat);
|
||||||
|
|
||||||
/* compare string against pattern */
|
/* compare string against pattern */
|
||||||
if (regexec(&rp, a->u.s, SE_MAX, rm, 0) == 0) {
|
if (regexec(&rp, a->u.s, SE_MAX, rm, 0) == 0) {
|
||||||
if (rm[1].rm_so >= 0) {
|
if (rm[1].rm_so >= 0) {
|
||||||
*(a->u.s + rm[1].rm_eo) = 0;
|
*(a->u.s + rm[1].rm_eo) = '\0';
|
||||||
v = make_str (a->u.s + rm[1].rm_so);
|
v = make_str (a->u.s + rm[1].rm_so);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
v = make_integer (rm[0].rm_eo - rm[0].rm_so);
|
v = make_integer (rm[0].rm_eo - rm[0].rm_so);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
v = make_integer (0);
|
if (rp.re_nsub == 0) {
|
||||||
|
v = make_integer (0);
|
||||||
|
} else {
|
||||||
|
v = make_str ("");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* free arguments and pattern buffer */
|
/* free arguments and pattern buffer */
|
||||||
|
Loading…
Reference in New Issue
Block a user