+++ /dev/null
-/* This file was converted by gperf_fold_key_conv.py\r
- from gperf output file. */\r
-/* ANSI-C code produced by gperf version 3.1 */\r
-/* Command-line: /usr/local/bin/gperf -n -C -T -c -t -j1 -L ANSI-C -F,-1 -N onigenc_unicode_fold2_key unicode_fold2_key.gperf */\r
-/* Computed positions: -k'3,6' */\r
-\r
-\r
-\r
-/* This gperf source file was generated by make_unicode_fold_data.py */\r
-\r
-/*-\r
- * Copyright (c) 2017-2018 K.Kosako <sndgk393 AT ybb DOT ne DOT jp>\r
- * All rights reserved.\r
- *\r
- * Redistribution and use in source and binary forms, with or without\r
- * modification, are permitted provided that the following conditions\r
- * are met:\r
- * 1. Redistributions of source code must retain the above copyright\r
- * notice, this list of conditions and the following disclaimer.\r
- * 2. Redistributions in binary form must reproduce the above copyright\r
- * notice, this list of conditions and the following disclaimer in the\r
- * documentation and/or other materials provided with the distribution.\r
- *\r
- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND\r
- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\r
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\r
- * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE\r
- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\r
- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\r
- * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\r
- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT\r
- * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY\r
- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF\r
- * SUCH DAMAGE.\r
- */\r
-//#include <string.h>\r
-#include "regenc.h"\r
-\r
-#define TOTAL_KEYWORDS 59\r
-#define MIN_WORD_LENGTH 6\r
-#define MAX_WORD_LENGTH 6\r
-#define MIN_HASH_VALUE 0\r
-#define MAX_HASH_VALUE 58\r
-/* maximum key range = 59, duplicates = 0 */\r
-\r
-#ifdef __GNUC__\r
-__inline\r
-#else\r
-#ifdef __cplusplus\r
-inline\r
-#endif\r
-#endif\r
-/*ARGSUSED*/\r
-static unsigned int\r
-hash(OnigCodePoint codes[])\r
-{\r
- static const unsigned char asso_values[] =\r
- {\r
- 58, 57, 56, 55, 54, 53, 52, 16, 50, 59,\r
- 15, 59, 25, 59, 59, 59, 59, 59, 59, 3,\r
- 59, 59, 59, 59, 59, 59, 59, 59, 59, 59,\r
- 59, 59, 49, 48, 47, 46, 45, 44, 43, 42,\r
- 59, 59, 59, 59, 59, 59, 59, 59, 59, 21,\r
- 59, 59, 59, 59, 59, 59, 59, 59, 59, 59,\r
- 59, 59, 59, 59, 59, 59, 2, 59, 59, 59,\r
- 59, 59, 59, 59, 59, 59, 59, 59, 59, 59,\r
- 59, 59, 59, 59, 59, 59, 59, 59, 59, 59,\r
- 59, 59, 59, 59, 59, 59, 40, 20, 39, 38,\r
- 37, 14, 5, 36, 20, 7, 25, 34, 29, 32,\r
- 16, 59, 31, 59, 59, 2, 1, 59, 25, 15,\r
- 59, 14, 59, 59, 28, 59, 2, 59, 59, 59,\r
- 11, 59, 59, 59, 59, 59, 59, 59, 59, 59,\r
- 59, 59, 59, 59, 59, 59, 59, 59, 59, 59,\r
- 59, 59, 59, 59, 59, 59, 59, 59, 59, 59,\r
- 59, 59, 59, 59, 59, 59, 59, 59, 59, 59,\r
- 59, 59, 24, 59, 22, 59, 59, 11, 59, 59,\r
- 59, 59, 59, 7, 59, 0, 59, 59, 16, 59,\r
- 1, 59, 59, 16, 59, 59, 59, 15, 59, 59,\r
- 59, 6, 59, 59, 59, 59, 0, 59, 59, 59,\r
- 59, 59, 59, 59, 59, 59, 59, 59, 59, 59,\r
- 59, 59, 59, 59, 59, 59, 59, 59, 59, 59,\r
- 59, 59, 59, 59, 59, 59, 59, 59, 59, 59,\r
- 59, 59, 59, 59, 59, 59, 59, 59, 59, 59,\r
- 59, 59, 59, 59, 59, 59\r
- };\r
- return asso_values[(unsigned char)onig_codes_byte_at(codes, 5)] + asso_values[(unsigned char)onig_codes_byte_at(codes, 2)];\r
-}\r
-\r
-int\r
-onigenc_unicode_fold2_key(OnigCodePoint codes[])\r
-{\r
- static const short int wordlist[] =\r
- {\r
-\r
- 101,\r
-\r
- 253,\r
-\r
- 76,\r
-\r
- 29,\r
-\r
- 24,\r
-\r
- 239,\r
-\r
- 96,\r
-\r
- 71,\r
-\r
- 92,\r
-\r
- 67,\r
-\r
- 4,\r
-\r
- 62,\r
-\r
- 8,\r
-\r
- 58,\r
-\r
- 234,\r
-\r
- 109,\r
-\r
- 164,\r
-\r
- 88,\r
-\r
- 84,\r
-\r
- 80,\r
-\r
- 214,\r
-\r
- 0,\r
-\r
- 54,\r
-\r
- 261,\r
-\r
- 50,\r
-\r
- 105,\r
-\r
- 121,\r
-\r
- 125,\r
-\r
- 257,\r
-\r
- 42,\r
-\r
- 38,\r
-\r
- 249,\r
-\r
- 46,\r
-\r
- 117,\r
-\r
- 12,\r
-\r
- 113,\r
-\r
- 244,\r
-\r
- 229,\r
-\r
- 224,\r
-\r
- 219,\r
-\r
- 209,\r
-\r
- 16,\r
-\r
- 204,\r
-\r
- 199,\r
-\r
- 194,\r
-\r
- 189,\r
-\r
- 184,\r
-\r
- 179,\r
-\r
- 174,\r
-\r
- 169,\r
-\r
- 20,\r
-\r
- 34,\r
-\r
- 159,\r
-\r
- 154,\r
-\r
- 149,\r
-\r
- 144,\r
-\r
- 139,\r
-\r
- 134,\r
-\r
- 129\r
- };\r
-\r
- int key = hash(codes);\r
- if (key <= MAX_HASH_VALUE) {\r
- int index = wordlist[key];\r
- if (index >= 0 && onig_codes_cmp(codes, OnigUnicodeFolds2 + index, 2) == 0)\r
- return index;\r
- }\r
-\r
- return -1;\r
-}\r