]> granicus.if.org Git - onig/commitdiff
don't use onig_new_deluxe() in sample
authorK.Kosako <kosako@sofnec.co.jp>
Thu, 27 Jun 2019 08:26:48 +0000 (17:26 +0900)
committerK.Kosako <kkosako0@gmail.com>
Sat, 6 Jul 2019 12:40:33 +0000 (21:40 +0900)
sample/bug_fix.c
sample/encode.c

index 81c278409d81f2cd42bed5dcfed77f0cb8bf110c..d0039a885f09d80a2471f45ddce9ca30f6cca1eb 100644 (file)
@@ -43,45 +43,6 @@ search(regex_t* reg, unsigned char* str, unsigned char* end)
   return 0;
 }
 
-static int
-exec_deluxe(OnigEncoding pattern_enc, OnigEncoding str_enc,
-            OnigOptionType options, char* apattern, char* astr)
-{
-  int r;
-  unsigned char *end;
-  regex_t* reg;
-  OnigCompileInfo ci;
-  OnigErrorInfo einfo;
-  UChar* pattern = (UChar* )apattern;
-  UChar* str     = (UChar* )astr;
-
-  onig_initialize(&str_enc, 1);
-
-  ci.num_of_elements = 5;
-  ci.pattern_enc = pattern_enc;
-  ci.target_enc  = str_enc;
-  ci.syntax      = ONIG_SYNTAX_DEFAULT;
-  ci.option      = options;
-  ci.case_fold_flag  = CF;
-
-  r = onig_new_deluxe(&reg, pattern,
-                      pattern + onigenc_str_bytelen_null(pattern_enc, pattern),
-                      &ci, &einfo);
-  if (r != ONIG_NORMAL) {
-    char s[ONIG_MAX_ERROR_MESSAGE_LEN];
-    onig_error_code_to_str((UChar* )s, r, &einfo);
-    fprintf(stderr, "ERROR: %s\n", s);
-    return -1;
-  }
-
-  end = str + onigenc_str_bytelen_null(str_enc, str);
-  r = search(reg, str, end);
-
-  onig_free(reg);
-  onig_end();
-  return 0;
-}
-
 static int
 exec(OnigEncoding enc, OnigOptionType options, char* apattern, char* astr)
 {
@@ -118,9 +79,8 @@ extern int main(int argc, char* argv[])
 {
   /* fix ignore case in look-behind
      commit: 3340ec2cc5627172665303fe248c9793354d2251 */
-  exec_deluxe(ONIG_ENCODING_UTF8, ONIG_ENCODING_UTF8,
-              ONIG_OPTION_IGNORECASE,
-              "(?<=\305\211)a", "\312\274na"); /* \u{0149}a  \u{02bc}na */
+  exec(ONIG_ENCODING_UTF8, ONIG_OPTION_IGNORECASE,
+       "(?<=\305\211)a", "\312\274na"); /* \u{0149}a  \u{02bc}na */
 
   exec(ONIG_ENCODING_UTF8, ONIG_OPTION_NONE, "(\\2)(\\1)", "aa"); /* fail. */
 
index 8a03ab82c7f9e6c9a242741ae8d91633ab3b53ca..9e1a2c08e12864934509e74970b8d12c649c5ccf 100644 (file)
@@ -72,55 +72,6 @@ exec(OnigEncoding enc, OnigOptionType options,
   return 0;
 }
 
-static OnigCaseFoldType CF = ONIGENC_CASE_FOLD_MIN;
-
-#if 0
-static void
-set_case_fold(OnigCaseFoldType cf)
-{
-  CF = cf;
-}
-#endif
-
-static int
-exec_deluxe(OnigEncoding pattern_enc, OnigEncoding str_enc,
-            OnigOptionType options, char* apattern, char* astr)
-{
-  int r;
-  unsigned char *end;
-  regex_t* reg;
-  OnigCompileInfo ci;
-  OnigErrorInfo einfo;
-  UChar* pattern = (UChar* )apattern;
-  UChar* str     = (UChar* )astr;
-
-  onig_initialize(&str_enc, 1);
-
-  ci.num_of_elements = 5;
-  ci.pattern_enc = pattern_enc;
-  ci.target_enc  = str_enc;
-  ci.syntax      = ONIG_SYNTAX_DEFAULT;
-  ci.option      = options;
-  ci.case_fold_flag  = CF;
-
-  r = onig_new_deluxe(&reg, pattern,
-                      pattern + onigenc_str_bytelen_null(pattern_enc, pattern),
-                      &ci, &einfo);
-  if (r != ONIG_NORMAL) {
-    char s[ONIG_MAX_ERROR_MESSAGE_LEN];
-    onig_error_code_to_str((UChar* )s, r, &einfo);
-    fprintf(stderr, "ERROR: %s\n", s);
-    return -1;
-  }
-
-  end = str + onigenc_str_bytelen_null(str_enc, str);
-  r = search(reg, str, end);
-
-  onig_free(reg);
-  onig_end();
-  return 0;
-}
-
 extern int main(int argc, char* argv[])
 {
   int r;
@@ -196,39 +147,6 @@ extern int main(int argc, char* argv[])
   r = exec(ONIG_ENCODING_ISO_8859_1, ONIG_OPTION_IGNORECASE,
            "is", "iss");
 
-  r = exec_deluxe(ONIG_ENCODING_ASCII, ONIG_ENCODING_UTF16_BE,
-                  ONIG_OPTION_NONE, "a+",
-                  "\000b\000a\000a\000a\000c\000c\000\000");
-
-  r = exec_deluxe(ONIG_ENCODING_ASCII, ONIG_ENCODING_UTF16_LE,
-                  ONIG_OPTION_NONE, "a+",
-                  "b\000a\000a\000a\000a\000c\000\000\000");
-
-  r = exec_deluxe(ONIG_ENCODING_UTF16_BE, ONIG_ENCODING_UTF16_LE,
-                  ONIG_OPTION_NONE,
-                  "\000b\000a\000a\000a\000c\000c\000\000",
-                  "x\000b\000a\000a\000a\000c\000c\000\000\000");
-
-  r = exec_deluxe(ONIG_ENCODING_ISO_8859_1, ONIG_ENCODING_UTF16_BE,
-                  ONIG_OPTION_IGNORECASE,
-                  "\337", "\000S\000S\000\000");
-
-  r = exec_deluxe(ONIG_ENCODING_ISO_8859_1, ONIG_ENCODING_UTF16_BE,
-                  ONIG_OPTION_IGNORECASE,
-                  "SS", "\000\337\000\000");
-
-  r = exec_deluxe(ONIG_ENCODING_ISO_8859_1, ONIG_ENCODING_UTF16_LE,
-                  ONIG_OPTION_IGNORECASE,
-                  "\337", "S\000S\000\000\000");
-
-  r = exec_deluxe(ONIG_ENCODING_ISO_8859_1, ONIG_ENCODING_UTF32_BE,
-                  ONIG_OPTION_IGNORECASE,
-                  "SS", "\000\000\000\337\000\000\000\000");
-
-  r = exec_deluxe(ONIG_ENCODING_ISO_8859_1, ONIG_ENCODING_UTF32_LE,
-                  ONIG_OPTION_IGNORECASE,
-                  "\337", "S\000\000\000S\000\000\000\000\000\000\000");
-
   r = exec(ONIG_ENCODING_UTF16_BE, ONIG_OPTION_NONE,
            "\000[\000[\000:\000a\000l\000n\000u\000m\000:\000]\000]\000+\000\000",
            "\000#\002\120\000a\000Z\012\077\012\076\012\075\000\000");
@@ -242,44 +160,34 @@ extern int main(int argc, char* argv[])
   r = exec(ONIG_ENCODING_GB18030, ONIG_OPTION_IGNORECASE,
            "(Aa\\d)+", "BaA5Aa0234");
 
-  r = exec_deluxe(ONIG_ENCODING_ISO_8859_1, ONIG_ENCODING_UTF16_BE,
-                  ONIG_OPTION_NONE,
-                  "^\\P{Hiragana}\\p{^Hiragana}(\\p{Hiragana}+)$",
-                  "\060\100\060\240\060\101\060\102\060\226\060\237\000\000");
-
-  r = exec_deluxe(ONIG_ENCODING_UTF16_BE, ONIG_ENCODING_UTF16_BE,
-                  ONIG_OPTION_IGNORECASE,
-                  "\000[\000\337\000]\000\000", "\000S\000S\000\000");
+  r = exec(ONIG_ENCODING_UTF16_BE, ONIG_OPTION_IGNORECASE,
+           "\000[\000\337\000]\000\000", "\000S\000S\000\000");
 
-  r = exec_deluxe(ONIG_ENCODING_UTF16_BE, ONIG_ENCODING_UTF16_BE,
-                  ONIG_OPTION_IGNORECASE,
-                  "\000[\000\337\000]\000\000", "\000s\000S\000\000");
+  r = exec(ONIG_ENCODING_UTF16_BE, ONIG_OPTION_IGNORECASE,
+           "\000[\000\337\000]\000\000", "\000s\000S\000\000");
 
-  r = exec_deluxe(ONIG_ENCODING_UTF16_BE, ONIG_ENCODING_UTF16_BE,
-                  ONIG_OPTION_IGNORECASE,
-                  "\000^\000[\000\001\000-\377\375\000]\000$\000\000",
-                  "\000s\000S\000\000");
+  r = exec(ONIG_ENCODING_UTF16_BE, ONIG_OPTION_IGNORECASE,
+           "\000^\000[\000\001\000-\377\375\000]\000$\000\000",
+           "\000s\000S\000\000");
 
-  r = exec_deluxe(ONIG_ENCODING_UTF16_BE, ONIG_ENCODING_UTF16_BE,
-                  ONIG_OPTION_IGNORECASE,
-                  "\000S\000S\000\000",
-                  "\000S\000T\000\337\000\000");
+  r = exec(ONIG_ENCODING_UTF16_BE, ONIG_OPTION_IGNORECASE,
+           "\000S\000S\000\000",
+           "\000S\000T\000\337\000\000");
 
-  r = exec_deluxe(ONIG_ENCODING_UTF16_BE, ONIG_ENCODING_UTF16_BE,
-                  ONIG_OPTION_IGNORECASE,
-                  "\000S\000T\000S\000S\000\000",
-                  "\000S\000t\000s\000S\000\000");
+  r = exec(ONIG_ENCODING_UTF16_BE, ONIG_OPTION_IGNORECASE,
+           "\000S\000T\000S\000S\000\000",
+           "\000S\000t\000s\000S\000\000");
 
   {
     UChar pat[]  = { 0x1f, 0xfc, 0x00, 0x00 };
     UChar str1[] = { 0x21, 0x26, 0x1f, 0xbe, 0x00, 0x00 };
     UChar str2[] = { 0x1f, 0xf3, 0x00, 0x00 };
 
-    r = exec_deluxe(ONIG_ENCODING_UTF16_BE, ONIG_ENCODING_UTF16_BE,
-                    ONIG_OPTION_IGNORECASE, (char* )pat, (char* )str1);
+    r = exec(ONIG_ENCODING_UTF16_BE, ONIG_OPTION_IGNORECASE,
+             (char* )pat, (char* )str1);
 
-    r = exec_deluxe(ONIG_ENCODING_UTF16_BE, ONIG_ENCODING_UTF16_BE,
-                    ONIG_OPTION_IGNORECASE, (char* )pat, (char* )str2);
+    r = exec(ONIG_ENCODING_UTF16_BE, ONIG_OPTION_IGNORECASE,
+             (char* )pat, (char* )str2);
   }
 
 #if 0
@@ -287,17 +195,14 @@ extern int main(int argc, char* argv[])
 
   set_case_fold(ONIGENC_CASE_FOLD_TURKISH_AZERI);
 
-  r = exec_deluxe(ONIG_ENCODING_UTF8, ONIG_ENCODING_UTF8,
-                  ONIG_OPTION_IGNORECASE,
-                  "Ii", "\304\261\304\260");
+  r = exec(ONIG_ENCODING_UTF8, ONIG_ENCODING_UTF8, ONIG_OPTION_IGNORECASE,
+           "Ii", "\304\261\304\260");
 
-  r = exec_deluxe(ONIG_ENCODING_UTF16_BE, ONIG_ENCODING_UTF16_BE,
-                  ONIG_OPTION_IGNORECASE,
-                  "\000I\000i\000\000", "\001\061\001\060\000\000");
+  r = exec(ONIG_ENCODING_UTF16_BE, ONIG_OPTION_IGNORECASE,
+           "\000I\000i\000\000", "\001\061\001\060\000\000");
 
-  r = exec_deluxe(ONIG_ENCODING_UTF16_BE, ONIG_ENCODING_UTF16_BE,
-                  ONIG_OPTION_IGNORECASE,
-                  "\001\061\001\060\000\000", "\000I\000i\000\000");
+  r = exec(ONIG_ENCODING_UTF16_BE, ONIG_OPTION_IGNORECASE,
+           "\001\061\001\060\000\000", "\000I\000i\000\000");
 
   set_case_fold(ONIGENC_CASE_FOLD_MIN);
 #endif