From 9b38026f1840853f0ed034af677ab2d8628d7dc2 Mon Sep 17 00:00:00 2001 From: Franz Sirl Date: Sun, 8 Apr 2001 23:49:43 +0000 Subject: [PATCH] 20010408-1.c: New test. 2001-04-08 Franz Sirl * gcc.c-torture/compile/20010408-1.c: New test. From-SVN: r41193 --- gcc/testsuite/ChangeLog | 4 + .../gcc.c-torture/compile/20010408-1.c | 77 +++++++++++++++++++ 2 files changed, 81 insertions(+) create mode 100644 gcc/testsuite/gcc.c-torture/compile/20010408-1.c diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 9d8f5922533..6664b42cf1b 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2001-04-08 Franz Sirl + + * gcc.c-torture/execute/20010408-1.c: New test. + 2001-04-06 Benjamin Kosnik * g++.old-deja/g++.benjamin/15071.C (main): Update to conformant diff --git a/gcc/testsuite/gcc.c-torture/compile/20010408-1.c b/gcc/testsuite/gcc.c-torture/compile/20010408-1.c new file mode 100644 index 00000000000..9aa3597a24a --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/compile/20010408-1.c @@ -0,0 +1,77 @@ +extern struct win *windows, *wtab[]; +struct win +{ + struct win *w_next; +}; + +struct auser; + +struct comm +{ + char *name; + int flags; +}; + +extern struct comm comms[]; + +extern int WindowByNoN (char *); +extern int FindCommnr (char *); +extern int AclSetPermCmd (struct auser *, char *, struct comm *); +extern int AclSetPermWin (struct auser *, struct auser *, char *, struct win *); + + +int + AclSetPerm(uu, u, mode, s) + struct auser *uu, *u; +char *mode, *s; +{ + struct win *w; + int i; + char *p, ch; + + do + { + } + while (0); + + while (*s) + { + switch (*s) + { + case '*': + return AclSetPerm(uu, u, mode, "#?"); + case '#': + if (uu) + AclSetPermWin(uu, u, mode, (struct win *)1); + else + for (w = windows; w; w = w->w_next) + AclSetPermWin((struct auser *)0, u, mode, w); + s++; + break; + case '?': + if (uu) + AclSetPermWin(uu, u, mode, (struct win *)0); + else + for (i = 0; i <= 174; i++) + AclSetPermCmd(u, mode, &comms[i]); + s++; + break; + default: + for (p = s; *p && *p != ' ' && *p != '\t' && *p != ','; p++) + ; + if ((ch = *p)) + *p++ = '\0'; + if ((i = FindCommnr(s)) != -1) + AclSetPermCmd(u, mode, &comms[i]); + else if (((i = WindowByNoN(s)) >= 0) && wtab[i]) + AclSetPermWin((struct auser *)0, u, mode, wtab[i]); + else + return -1; + if (ch) + p[-1] = ch; + s = p; + } + } + + return 0; +} -- 2.30.2