regerror.c
上传用户:tsgydb
上传日期:2007-04-14
资源大小:10674k
文件大小:3k
源码类别:

MySQL数据库

开发平台:

Visual C++

  1. #include <global.h>
  2. #include <m_string.h>
  3. #include <m_ctype.h>
  4. #include <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. char *name;
  30. 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. regerror(errcode, preg, errbuf, errbuf_size)
  57. int errcode;
  58. const regex_t *preg;
  59. char *errbuf;
  60. size_t errbuf_size;
  61. {
  62. register struct rerr *r;
  63. register size_t len;
  64. register int target = errcode &~ REG_ITOA;
  65. register char *s;
  66. char convbuf[50];
  67. if (errcode == REG_ATOI)
  68. s = regatoi(preg, convbuf);
  69. else {
  70. for (r = rerrs; r->code != 0; r++)
  71. if (r->code == target)
  72. break;
  73. if (errcode&REG_ITOA) {
  74. if (r->code != 0)
  75. (void) strcpy(convbuf, r->name);
  76. else
  77. sprintf(convbuf, "REG_0x%x", target);
  78. assert(strlen(convbuf) < sizeof(convbuf));
  79. s = convbuf;
  80. } else
  81. s = r->explain;
  82. }
  83. len = strlen(s) + 1;
  84. if (errbuf_size > 0) {
  85. if (errbuf_size > len)
  86. (void) strcpy(errbuf, s);
  87. else {
  88. (void) strncpy(errbuf, s, errbuf_size-1);
  89. errbuf[errbuf_size-1] = '';
  90. }
  91. }
  92. return(len);
  93. }
  94. /*
  95.  - regatoi - internal routine to implement REG_ATOI
  96.  == static char *regatoi(const regex_t *preg, char *localbuf);
  97.  */
  98. static char *
  99. regatoi(preg, localbuf)
  100. const regex_t *preg;
  101. char *localbuf;
  102. {
  103. register struct rerr *r;
  104. for (r = rerrs; r->code != 0; r++)
  105. if (strcmp(r->name, preg->re_endp) == 0)
  106. break;
  107. if (r->code == 0)
  108. return("0");
  109. sprintf(localbuf, "%d", r->code);
  110. return(localbuf);
  111. }