aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/sam
diff options
context:
space:
mode:
authorRuss Cox <rsc@swtch.com>2010-07-14 11:10:59 -0700
committerRuss Cox <rsc@swtch.com>2010-07-14 11:10:59 -0700
commit36d9b90c56e939244b7081b575dc51c2afddff93 (patch)
treebee249b449b260ac394f2977c31e22cf8986ee37 /src/cmd/sam
parent75a851e927dd7f8e562b0fd35490783b44966c9f (diff)
downloadplan9port-36d9b90c56e939244b7081b575dc51c2afddff93.tar.gz
plan9port-36d9b90c56e939244b7081b575dc51c2afddff93.tar.bz2
plan9port-36d9b90c56e939244b7081b575dc51c2afddff93.zip
acme, sam: fix regexp code for bigger Runemax
R=r http://codereview.appspot.com/1765042
Diffstat (limited to 'src/cmd/sam')
-rw-r--r--src/cmd/sam/regexp.c50
1 files changed, 26 insertions, 24 deletions
diff --git a/src/cmd/sam/regexp.c b/src/cmd/sam/regexp.c
index 3234d731..2e369fe1 100644
--- a/src/cmd/sam/regexp.c
+++ b/src/cmd/sam/regexp.c
@@ -9,7 +9,7 @@ typedef struct Inst Inst;
struct Inst
{
- long type; /* < 0x10000 ==> literal, otherwise action */
+ long type; /* < OPERATOR ==> literal, otherwise action */
union {
int rsid;
int rsubid;
@@ -53,28 +53,30 @@ static Rangeset sempty;
/*
* Actions and Tokens
*
- * 0x100xx are operators, value == precedence
- * 0x200xx are tokens, i.e. operands for operators
+ * 0x10000xx are operators, value == precedence
+ * 0x20000xx are tokens, i.e. operands for operators
*/
-#define OPERATOR 0x10000 /* Bitmask of all operators */
-#define START 0x10000 /* Start, used for marker on stack */
-#define RBRA 0x10001 /* Right bracket, ) */
-#define LBRA 0x10002 /* Left bracket, ( */
-#define OR 0x10003 /* Alternation, | */
-#define CAT 0x10004 /* Concatentation, implicit operator */
-#define STAR 0x10005 /* Closure, * */
-#define PLUS 0x10006 /* a+ == aa* */
-#define QUEST 0x10007 /* a? == a|nothing, i.e. 0 or 1 a's */
-#define ANY 0x20000 /* Any character but newline, . */
-#define NOP 0x20001 /* No operation, internal use only */
-#define BOL 0x20002 /* Beginning of line, ^ */
-#define EOL 0x20003 /* End of line, $ */
-#define CCLASS 0x20004 /* Character class, [] */
-#define NCCLASS 0x20005 /* Negated character class, [^] */
-#define END 0x20077 /* Terminate: match found */
-
-#define ISATOR 0x10000
-#define ISAND 0x20000
+#define OPERATOR 0x1000000 /* Bit set in all operators */
+#define START (OPERATOR+0) /* Start, used for marker on stack */
+#define RBRA (OPERATOR+1) /* Right bracket, ) */
+#define LBRA (OPERATOR+2) /* Left bracket, ( */
+#define OR (OPERATOR+3) /* Alternation, | */
+#define CAT (OPERATOR+4) /* Concatentation, implicit operator */
+#define STAR (OPERATOR+5) /* Closure, * */
+#define PLUS (OPERATOR+6) /* a+ == aa* */
+#define QUEST (OPERATOR+7) /* a? == a|nothing, i.e. 0 or 1 a's */
+#define ANY 0x2000000 /* Any character but newline, . */
+#define NOP (ANY+1) /* No operation, internal use only */
+#define BOL (ANY+2) /* Beginning of line, ^ */
+#define EOL (ANY+3) /* End of line, $ */
+#define CCLASS (ANY+4) /* Character class, [] */
+#define NCCLASS (ANY+5) /* Negated character class, [^] */
+#define END (ANY+0x77) /* Terminate: match found */
+
+#define ISATOR OPERATOR
+#define ISAND ANY
+
+#define QUOTED 0x4000000 /* Bit set for \-ed lex characters */
/*
* Parser Information
@@ -459,7 +461,7 @@ nextrec(void){
exprp++;
return '\n';
}
- return *exprp++|0x10000;
+ return *exprp++|QUOTED;
}
return *exprp++;
}
@@ -499,7 +501,7 @@ bldcclass(void)
classp[n+2] = c2;
n += 3;
}else
- classp[n++] = c1;
+ classp[n++] = c1 & ~QUOTED;
}
classp[n] = 0;
if(nclass == Nclass){