regerror.c
上传用户:romrleung
上传日期:2022-05-23
资源大小:18897k
文件大小:3k
源码类别:

MySQL数据库

开发平台:

Visual C++

  1. #include <my_global.h>
  2. #include <m_string.h>
  3. #include <m_ctype.h>
  4. #include "my_regex.h"
  5. #include "utils.h"
  6. #include "regerror.ih"
  7. /*
  8.  = #define REG_NOMATCH  1
  9.  = #define REG_BADPAT  2
  10.  = #define REG_ECOLLATE  3
  11.  = #define REG_ECTYPE  4
  12.  = #define REG_EESCAPE  5
  13.  = #define REG_ESUBREG  6
  14.  = #define REG_EBRACK  7
  15.  = #define REG_EPAREN  8
  16.  = #define REG_EBRACE  9
  17.  = #define REG_BADBR 10
  18.  = #define REG_ERANGE 11
  19.  = #define REG_ESPACE 12
  20.  = #define REG_BADRPT 13
  21.  = #define REG_EMPTY 14
  22.  = #define REG_ASSERT 15
  23.  = #define REG_INVARG 16
  24.  = #define REG_ATOI 255 // convert name to number (!)
  25.  = #define REG_ITOA 0400 // convert number to name (!)
  26.  */
  27. static struct rerr {
  28. int code;
  29. const char *name;
  30.         const char *explain;
  31. } rerrs[] = {
  32. {REG_NOMATCH, "REG_NOMATCH", "regexec() failed to match"},
  33. {REG_BADPAT, "REG_BADPAT", "invalid regular expression"},
  34. {REG_ECOLLATE, "REG_ECOLLATE", "invalid collating element"},
  35. {REG_ECTYPE, "REG_ECTYPE", "invalid character class"},
  36. {REG_EESCAPE, "REG_EESCAPE", "trailing backslash (\)"},
  37. {REG_ESUBREG, "REG_ESUBREG", "invalid backreference number"},
  38. {REG_EBRACK, "REG_EBRACK", "brackets ([ ]) not balanced"},
  39. {REG_EPAREN, "REG_EPAREN", "parentheses not balanced"},
  40. {REG_EBRACE, "REG_EBRACE", "braces not balanced"},
  41. {REG_BADBR, "REG_BADBR", "invalid repetition count(s)"},
  42. {REG_ERANGE, "REG_ERANGE", "invalid character range"},
  43. {REG_ESPACE, "REG_ESPACE", "out of memory"},
  44. {REG_BADRPT, "REG_BADRPT", "repetition-operator operand invalid"},
  45. {REG_EMPTY, "REG_EMPTY", "empty (sub)expression"},
  46. {REG_ASSERT, "REG_ASSERT", ""can't happen" -- you found a bug"},
  47. {REG_INVARG, "REG_INVARG", "invalid argument to regex routine"},
  48. {0, "", "*** unknown regexp error code ***"},
  49. };
  50. /*
  51.  - regerror - the interface to error numbers
  52.  = extern size_t regerror(int, const regex_t *, char *, size_t);
  53.  */
  54. /* ARGSUSED */
  55. size_t
  56. my_regerror(int errcode, const my_regex_t *preg, char *errbuf, size_t errbuf_size)
  57. {
  58. register struct rerr *r;
  59. register size_t len;
  60. register int target = errcode &~ REG_ITOA;
  61. register char *s;
  62. char convbuf[50];
  63. if (errcode == REG_ATOI)
  64. s = regatoi(preg, convbuf);
  65. else {
  66. for (r = rerrs; r->code != 0; r++)
  67. if (r->code == target)
  68. break;
  69. if (errcode&REG_ITOA) {
  70. if (r->code != 0)
  71. (void) strcpy(convbuf, r->name);
  72. else
  73. sprintf(convbuf, "REG_0x%x", target);
  74. assert(strlen(convbuf) < sizeof(convbuf));
  75. s = convbuf;
  76. } else
  77. s = (char*) r->explain;
  78. }
  79. len = strlen(s) + 1;
  80. if (errbuf_size > 0) {
  81. if (errbuf_size > len)
  82. (void) strcpy(errbuf, s);
  83. else {
  84. (void) strncpy(errbuf, s, errbuf_size-1);
  85. errbuf[errbuf_size-1] = '';
  86. }
  87. }
  88. return(len);
  89. }
  90. /*
  91.  - regatoi - internal routine to implement REG_ATOI
  92.  == static char *regatoi(const regex_t *preg, char *localbuf);
  93.  */
  94. static char *
  95. regatoi(preg, localbuf)
  96. const my_regex_t *preg;
  97. char *localbuf;
  98. {
  99. register struct rerr *r;
  100. for (r = rerrs; r->code != 0; r++)
  101. if (strcmp(r->name, preg->re_endp) == 0)
  102. break;
  103. if (r->code == 0)
  104. return((char*) "0");
  105. sprintf(localbuf, "%d", r->code);
  106. return(localbuf);
  107. }