]> granicus.if.org Git - php/commitdiff
If an argument (<tag val=argument..) was not quoted, leave it that way.
authorSascha Schumann <sas@php.net>
Tue, 26 Mar 2002 10:23:33 +0000 (10:23 +0000)
committerSascha Schumann <sas@php.net>
Tue, 26 Mar 2002 10:23:33 +0000 (10:23 +0000)
ext/standard/url_scanner_ex.c
ext/standard/url_scanner_ex.re

index b07eb12ad3b32328a16cc4f645bb62e6f25875b3..6441626d0bb4cc441df12580bd0d311bfd109747 100644 (file)
@@ -1,4 +1,4 @@
-/* Generated by re2c 0.5 on Fri Mar  1 17:51:19 2002 */ 
+/* Generated by re2c 0.5 on Tue Mar 26 11:22:58 2002 */
 #line 1 "url_scanner_ex.re"
 /*
   +----------------------------------------------------------------------+
@@ -200,20 +200,22 @@ done:
 #undef YYLIMIT
 #undef YYMARKER
 
-static inline void tag_arg(url_adapt_state_ex_t *ctx, char quote TSRMLS_DC)
+static inline void tag_arg(url_adapt_state_ex_t *ctx, char quotes, char type TSRMLS_DC)
 {
        char f = 0;
 
        if (strncasecmp(ctx->arg.c, ctx->lookup_data, ctx->arg.len) == 0)
                f = 1;
 
-       smart_str_appendc(&ctx->result, quote);
+       if (quotes)
+               smart_str_appendc(&ctx->result, type);
        if (f) {
                append_modified_url(&ctx->val, &ctx->result, &ctx->q_name, &ctx->q_value, PG(arg_separator).output);
        } else {
                smart_str_append(&ctx->result, &ctx->val);
        }
-       smart_str_appendc(&ctx->result, quote);
+       if (quotes)
+               smart_str_appendc(&ctx->result, type);
 }
 
 enum {
@@ -281,7 +283,7 @@ static inline void handle_arg(STD_PARA)
 static inline void handle_val(STD_PARA, char quotes, char type) 
 {
        smart_str_setl(&ctx->val, start + quotes, YYCURSOR - start - quotes * 2);
-       tag_arg(ctx, type TSRMLS_CC);
+       tag_arg(ctx, quotes, type TSRMLS_CC);
 }
 
 #ifdef SCANNER_DEBUG
@@ -362,17 +364,17 @@ yy11:
        if(yybm[0+yych] & 128)  goto yy15;
 yy13:  yych = *++YYCURSOR;
 yy14:
-#line 261
+#line 263
        { passthru(STD_ARGS); STATE = STATE_TAG; goto state_tag; }
 yy15:  ++YYCURSOR;
        if(YYLIMIT == YYCURSOR) YYFILL(1);
        yych = *YYCURSOR;
 yy16:  if(yybm[0+yych] & 128)  goto yy15;
 yy17:
-#line 262
+#line 264
        { passthru(STD_ARGS); goto state_plain; }
 }
-#line 263
+#line 265
 
 
 state_tag:     
@@ -426,11 +428,11 @@ yy18:
 yy20:  yych = *++YYCURSOR;
        goto yy25;
 yy21:
-#line 268
+#line 270
        { handle_tag(STD_ARGS); /* Sets STATE */; passthru(STD_ARGS); if (STATE == STATE_PLAIN) goto state_plain; else goto state_next_arg; }
 yy22:  yych = *++YYCURSOR;
 yy23:
-#line 269
+#line 271
        { passthru(STD_ARGS); goto state_plain_begin; }
 yy24:  ++YYCURSOR;
        if(YYLIMIT == YYCURSOR) YYFILL(1);
@@ -438,7 +440,7 @@ yy24:       ++YYCURSOR;
 yy25:  if(yybm[0+yych] & 128)  goto yy24;
        goto yy21;
 }
-#line 270
+#line 272
 
 
 state_next_arg_begin:
@@ -509,20 +511,20 @@ yy26:
        }
 yy28:  yych = *++YYCURSOR;
 yy29:
-#line 278
+#line 280
        { passthru(STD_ARGS); handle_form(STD_ARGS); goto state_plain_begin; }
 yy30:  yych = *++YYCURSOR;
        goto yy37;
 yy31:
-#line 279
+#line 281
        { passthru(STD_ARGS); goto state_next_arg; }
 yy32:  yych = *++YYCURSOR;
 yy33:
-#line 280
+#line 282
        { --YYCURSOR; STATE = STATE_ARG; goto state_arg; }
 yy34:  yych = *++YYCURSOR;
 yy35:
-#line 281
+#line 283
        { passthru(STD_ARGS); goto state_plain_begin; }
 yy36:  ++YYCURSOR;
        if(YYLIMIT == YYCURSOR) YYFILL(1);
@@ -530,7 +532,7 @@ yy36:       ++YYCURSOR;
 yy37:  if(yybm[0+yych] & 128)  goto yy36;
        goto yy31;
 }
-#line 282
+#line 284
 
 
 state_arg:
@@ -584,11 +586,11 @@ yy38:
 yy40:  yych = *++YYCURSOR;
        goto yy45;
 yy41:
-#line 287
+#line 289
        { passthru(STD_ARGS); handle_arg(STD_ARGS); STATE = STATE_BEFORE_VAL; goto state_before_val; }
 yy42:  yych = *++YYCURSOR;
 yy43:
-#line 288
+#line 290
        { passthru(STD_ARGS); STATE = STATE_NEXT_ARG; goto state_next_arg; }
 yy44:  ++YYCURSOR;
        if(YYLIMIT == YYCURSOR) YYFILL(1);
@@ -596,7 +598,7 @@ yy44:       ++YYCURSOR;
 yy45:  if(yybm[0+yych] & 128)  goto yy44;
        goto yy41;
 }
-#line 289
+#line 291
 
 
 state_before_val:
@@ -651,12 +653,12 @@ yy48:     yyaccept = 0;
        if(yych == ' ') goto yy55;
        if(yych == '=') goto yy53;
 yy49:
-#line 295
+#line 297
        { --YYCURSOR; goto state_next_arg_begin; }
 yy50:  yych = *++YYCURSOR;
        goto yy54;
 yy51:
-#line 294
+#line 296
        { passthru(STD_ARGS); STATE = STATE_VAL; goto state_val; }
 yy52:  yych = *++YYCURSOR;
        goto yy49;
@@ -675,7 +677,7 @@ yy57:       YYCURSOR = YYMARKER;
        case 0: goto yy49;
        }
 }
-#line 296
+#line 298
 
 
 
@@ -745,7 +747,7 @@ yy60:       yyaccept = 0;
        yych = *(YYMARKER = ++YYCURSOR);
        if(yych != '>') goto yy74;
 yy61:
-#line 305
+#line 307
        { passthru(STD_ARGS); goto state_next_arg_begin; }
 yy62:  yyaccept = 0;
        yych = *(YYMARKER = ++YYCURSOR);
@@ -754,7 +756,7 @@ yy62:       yyaccept = 0;
 yy63:  yych = *++YYCURSOR;
        goto yy67;
 yy64:
-#line 304
+#line 306
        { handle_val(STD_ARGS, 0, '"'); goto state_next_arg_begin; }
 yy65:  yych = *++YYCURSOR;
        goto yy61;
@@ -774,7 +776,7 @@ yy70:       YYCURSOR = YYMARKER;
        }
 yy71:  yych = *++YYCURSOR;
 yy72:
-#line 303
+#line 305
        { handle_val(STD_ARGS, 1, '\''); goto state_next_arg_begin; }
 yy73:  ++YYCURSOR;
        if(YYLIMIT == YYCURSOR) YYFILL(1);
@@ -783,10 +785,10 @@ yy74:     if(yybm[0+yych] & 128)  goto yy73;
        if(yych >= '>') goto yy70;
 yy75:  yych = *++YYCURSOR;
 yy76:
-#line 302
+#line 304
        { handle_val(STD_ARGS, 1, '"'); goto state_next_arg_begin; }
 }
-#line 306
+#line 308
 
 
 stop:
index 620480a9349f2ca30412ce6fc8acdf25cbe621c5..4d7c507894085eab2dd4a61e089f7a7774c4ff71 100644 (file)
@@ -140,20 +140,22 @@ done:
 #undef YYLIMIT
 #undef YYMARKER
 
-static inline void tag_arg(url_adapt_state_ex_t *ctx, char quote TSRMLS_DC)
+static inline void tag_arg(url_adapt_state_ex_t *ctx, char quotes, char type TSRMLS_DC)
 {
        char f = 0;
 
        if (strncasecmp(ctx->arg.c, ctx->lookup_data, ctx->arg.len) == 0)
                f = 1;
 
-       smart_str_appendc(&ctx->result, quote);
+       if (quotes)
+               smart_str_appendc(&ctx->result, type);
        if (f) {
                append_modified_url(&ctx->val, &ctx->result, &ctx->q_name, &ctx->q_value, PG(arg_separator).output);
        } else {
                smart_str_append(&ctx->result, &ctx->val);
        }
-       smart_str_appendc(&ctx->result, quote);
+       if (quotes)
+               smart_str_appendc(&ctx->result, type);
 }
 
 enum {
@@ -221,7 +223,7 @@ static inline void handle_arg(STD_PARA)
 static inline void handle_val(STD_PARA, char quotes, char type) 
 {
        smart_str_setl(&ctx->val, start + quotes, YYCURSOR - start - quotes * 2);
-       tag_arg(ctx, type TSRMLS_CC);
+       tag_arg(ctx, quotes, type TSRMLS_CC);
 }
 
 #ifdef SCANNER_DEBUG