20070129.c

来自「用于进行gcc测试」· C语言 代码 · 共 95 行

C
95
字号
/* This testcase would cause a hang in PTA solving due to a complex copy   constraint and marking the wrong variable as changed.  */typedef struct RExC_state_t{ char *end; char *parse;} RExC_state_t;struct regnode_string{ unsigned char str_len; char string[1];};static void *regatom (RExC_state_t * pRExC_state, int *flagp);static void *regpiece (RExC_state_t * pRExC_state, int *flagp){ return regatom (0, 0);}static void *regbranch (RExC_state_t * pRExC_state, int *flagp, int first){ return regpiece (0, 0);}static void *reg (RExC_state_t * pRExC_state, int paren, int *flagp){ return regbranch (0, 0, 1);}void *Perl_pregcomp (char *exp, char *xend, void *pm){ return reg (0, 0, 0);}static void *regatom (RExC_state_t * pRExC_state, int *flagp){ register void *ret = 0; int flags;tryagain: switch (*(pRExC_state->parse))   {   case '(':     ret = reg (pRExC_state, 1, &flags);     if (flags & 0x8)       {         goto tryagain;       }     break;   default: {       register unsigned long len;       register unsigned ender;       register char *p;       char *oldp, *s;       unsigned long numlen;       unsigned long foldlen;       unsigned char tmpbuf[6 + 1], *foldbuf;     defchar:       s = (((struct regnode_string *) ret)->string);       for (len = 0, p = (pRExC_state->parse) - 1;            len < 127 && p < (pRExC_state->end); len++)         {           if (((*p) == '*' || (*p) == '+' || (*p) == '?'                || ((*p) == '{' && regcurly (p))))             {               unsigned long unilen;               for (foldbuf = tmpbuf; foldlen; foldlen -= numlen)                 {                   reguni (pRExC_state, ender, s, &unilen);                   s += unilen;                 }               break;             }           unsigned long unilen;           reguni (pRExC_state, ender, s, &unilen);           s += unilen;         }     };     break;   } return (ret);}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?