Blame src/cp1251.c

Packit b89d10
/**********************************************************************
Packit b89d10
  cp1251.c -  Oniguruma (regular expression library)
Packit b89d10
**********************************************************************/
Packit b89d10
/*-
Packit b89d10
 * Copyright (c) 2006-2018  Byte      <byte AT mail DOT kna DOT ru>
Packit b89d10
 *                          K.Kosako  <sndgk393 AT ybb DOT ne DOT jp>
Packit b89d10
 * All rights reserved.
Packit b89d10
 *
Packit b89d10
 * Redistribution and use in source and binary forms, with or without
Packit b89d10
 * modification, are permitted provided that the following conditions
Packit b89d10
 * are met:
Packit b89d10
 * 1. Redistributions of source code must retain the above copyright
Packit b89d10
 *    notice, this list of conditions and the following disclaimer.
Packit b89d10
 * 2. Redistributions in binary form must reproduce the above copyright
Packit b89d10
 *    notice, this list of conditions and the following disclaimer in the
Packit b89d10
 *    documentation and/or other materials provided with the distribution.
Packit b89d10
 *
Packit b89d10
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
Packit b89d10
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
Packit b89d10
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
Packit b89d10
 * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
Packit b89d10
 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
Packit b89d10
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
Packit b89d10
 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
Packit b89d10
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
Packit b89d10
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
Packit b89d10
 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
Packit b89d10
 * SUCH DAMAGE.
Packit b89d10
 */
Packit b89d10
Packit b89d10
#include "regenc.h"
Packit b89d10
Packit b89d10
#define ENC_CP1251_TO_LOWER_CASE(c) EncCP1251_ToLowerCaseTable[c]
Packit b89d10
#define ENC_IS_CP1251_CTYPE(code,ctype) \
Packit b89d10
  ((EncCP1251_CtypeTable[code] & CTYPE_TO_BIT(ctype)) != 0)
Packit b89d10
Packit b89d10
static const UChar EncCP1251_ToLowerCaseTable[256] = {
Packit b89d10
  '\000', '\001', '\002', '\003', '\004', '\005', '\006', '\007',
Packit b89d10
  '\010', '\011', '\012', '\013', '\014', '\015', '\016', '\017',
Packit b89d10
  '\020', '\021', '\022', '\023', '\024', '\025', '\026', '\027',
Packit b89d10
  '\030', '\031', '\032', '\033', '\034', '\035', '\036', '\037',
Packit b89d10
  '\040', '\041', '\042', '\043', '\044', '\045', '\046', '\047',
Packit b89d10
  '\050', '\051', '\052', '\053', '\054', '\055', '\056', '\057',
Packit b89d10
  '\060', '\061', '\062', '\063', '\064', '\065', '\066', '\067',
Packit b89d10
  '\070', '\071', '\072', '\073', '\074', '\075', '\076', '\077',
Packit b89d10
  '\100', '\141', '\142', '\143', '\144', '\145', '\146', '\147',
Packit b89d10
  '\150', '\151', '\152', '\153', '\154', '\155', '\156', '\157',
Packit b89d10
  '\160', '\161', '\162', '\163', '\164', '\165', '\166', '\167',
Packit b89d10
  '\170', '\171', '\172', '\133', '\134', '\135', '\136', '\137',
Packit b89d10
  '\140', '\141', '\142', '\143', '\144', '\145', '\146', '\147',
Packit b89d10
  '\150', '\151', '\152', '\153', '\154', '\155', '\156', '\157',
Packit b89d10
  '\160', '\161', '\162', '\163', '\164', '\165', '\166', '\167',
Packit b89d10
  '\170', '\171', '\172', '\173', '\174', '\175', '\176', '\177',
Packit b89d10
  '\220', '\203', '\202', '\203', '\204', '\205', '\206', '\207',
Packit b89d10
  '\210', '\211', '\232', '\213', '\234', '\235', '\236', '\237',
Packit b89d10
  '\220', '\221', '\222', '\223', '\224', '\225', '\226', '\227',
Packit b89d10
  '\230', '\231', '\232', '\233', '\234', '\235', '\236', '\237',
Packit b89d10
  '\240', '\242', '\242', '\274', '\244', '\264', '\246', '\247',
Packit b89d10
  '\270', '\251', '\272', '\253', '\254', '\255', '\256', '\277',
Packit b89d10
  '\260', '\261', '\263', '\263', '\264', '\265', '\266', '\267',
Packit b89d10
  '\270', '\271', '\272', '\273', '\274', '\276', '\276', '\277',
Packit b89d10
  '\340', '\341', '\342', '\343', '\344', '\345', '\346', '\347',
Packit b89d10
  '\350', '\351', '\352', '\353', '\354', '\355', '\356', '\357',
Packit b89d10
  '\360', '\361', '\362', '\363', '\364', '\365', '\366', '\367',
Packit b89d10
  '\370', '\371', '\372', '\373', '\374', '\375', '\376', '\377',
Packit b89d10
  '\340', '\341', '\342', '\343', '\344', '\345', '\346', '\347',
Packit b89d10
  '\350', '\351', '\352', '\353', '\354', '\355', '\356', '\357',
Packit b89d10
  '\360', '\361', '\362', '\363', '\364', '\365', '\366', '\367',
Packit b89d10
  '\370', '\371', '\372', '\373', '\374', '\375', '\376', '\377'
Packit b89d10
};
Packit b89d10
Packit b89d10
static const unsigned short EncCP1251_CtypeTable[256] = {
Packit b89d10
  0x4008, 0x4008, 0x4008, 0x4008, 0x4008, 0x4008, 0x4008, 0x4008,
Packit b89d10
  0x4008, 0x428c, 0x4209, 0x4208, 0x4208, 0x4208, 0x4008, 0x4008,
Packit b89d10
  0x4008, 0x4008, 0x4008, 0x4008, 0x4008, 0x4008, 0x4008, 0x4008,
Packit b89d10
  0x4008, 0x4008, 0x4008, 0x4008, 0x4008, 0x4008, 0x4008, 0x4008,
Packit b89d10
  0x4284, 0x41a0, 0x41a0, 0x41a0, 0x41a0, 0x41a0, 0x41a0, 0x41a0,
Packit b89d10
  0x41a0, 0x41a0, 0x41a0, 0x41a0, 0x41a0, 0x41a0, 0x41a0, 0x41a0,
Packit b89d10
  0x78b0, 0x78b0, 0x78b0, 0x78b0, 0x78b0, 0x78b0, 0x78b0, 0x78b0,
Packit b89d10
  0x78b0, 0x78b0, 0x41a0, 0x41a0, 0x41a0, 0x41a0, 0x41a0, 0x41a0,
Packit b89d10
  0x41a0, 0x7ca2, 0x7ca2, 0x7ca2, 0x7ca2, 0x7ca2, 0x7ca2, 0x74a2,
Packit b89d10
  0x74a2, 0x74a2, 0x74a2, 0x74a2, 0x74a2, 0x74a2, 0x74a2, 0x74a2,
Packit b89d10
  0x74a2, 0x74a2, 0x74a2, 0x74a2, 0x74a2, 0x74a2, 0x74a2, 0x74a2,
Packit b89d10
  0x74a2, 0x74a2, 0x74a2, 0x41a0, 0x41a0, 0x41a0, 0x41a0, 0x51a0,
Packit b89d10
  0x41a0, 0x78e2, 0x78e2, 0x78e2, 0x78e2, 0x78e2, 0x78e2, 0x70e2,
Packit b89d10
  0x70e2, 0x70e2, 0x70e2, 0x70e2, 0x70e2, 0x70e2, 0x70e2, 0x70e2,
Packit b89d10
  0x70e2, 0x70e2, 0x70e2, 0x70e2, 0x70e2, 0x70e2, 0x70e2, 0x70e2,
Packit b89d10
  0x70e2, 0x70e2, 0x70e2, 0x41a0, 0x41a0, 0x41a0, 0x41a0, 0x4008,
Packit b89d10
  0x34a2, 0x34a2, 0x01a0, 0x30e2, 0x01a0, 0x01a0, 0x01a0, 0x01a0,
Packit b89d10
  0x0000, 0x01a0, 0x34a2, 0x01a0, 0x34a2, 0x34a2, 0x34a2, 0x34a2,
Packit b89d10
  0x30e2, 0x01a0, 0x01a0, 0x01a0, 0x01a0, 0x01a0, 0x01a0, 0x01a0,
Packit b89d10
  0x0008, 0x0000, 0x30e2, 0x01a0, 0x30e2, 0x30e2, 0x30e2, 0x30e2,
Packit b89d10
  0x0280, 0x34a2, 0x30e2, 0x34a2, 0x01a0, 0x34a2, 0x01a0, 0x01a0,
Packit b89d10
  0x34a2, 0x01a0, 0x34a2, 0x01a0, 0x01a0, 0x01a0, 0x01a0, 0x34a2,
Packit b89d10
  0x01a0, 0x01a0, 0x34a2, 0x30e2, 0x30e2, 0x31e2, 0x01a0, 0x01a0,
Packit b89d10
  0x30e2, 0x0000, 0x30e2, 0x01a0, 0x30e2, 0x34a2, 0x30e2, 0x30e2,
Packit b89d10
  0x34a2, 0x34a2, 0x34a2, 0x34a2, 0x34a2, 0x34a2, 0x34a2, 0x34a2,
Packit b89d10
  0x34a2, 0x34a2, 0x34a2, 0x34a2, 0x34a2, 0x34a2, 0x34a2, 0x34a2,
Packit b89d10
  0x34a2, 0x34a2, 0x34a2, 0x34a2, 0x34a2, 0x34a2, 0x34a2, 0x34a2,
Packit b89d10
  0x34a2, 0x34a2, 0x34a2, 0x34a2, 0x34a2, 0x34a2, 0x34a2, 0x34a2,
Packit b89d10
  0x30e2, 0x30e2, 0x30e2, 0x30e2, 0x30e2, 0x30e2, 0x30e2, 0x30e2,
Packit b89d10
  0x30e2, 0x30e2, 0x30e2, 0x30e2, 0x30e2, 0x30e2, 0x30e2, 0x30e2,
Packit b89d10
  0x30e2, 0x30e2, 0x30e2, 0x30e2, 0x30e2, 0x30e2, 0x30e2, 0x30e2,
Packit b89d10
  0x30e2, 0x30e2, 0x30e2, 0x30e2, 0x30e2, 0x30e2, 0x30e2, 0x30e2
Packit b89d10
};
Packit b89d10
Packit b89d10
static int
Packit b89d10
cp1251_mbc_case_fold(OnigCaseFoldType flag ARG_UNUSED,
Packit b89d10
             const UChar** pp, const UChar* end ARG_UNUSED, UChar* lower)
Packit b89d10
{
Packit b89d10
  const UChar* p = *pp;
Packit b89d10
Packit b89d10
  *lower = ENC_CP1251_TO_LOWER_CASE(*p);
Packit b89d10
  (*pp)++;
Packit b89d10
  return 1;
Packit b89d10
}
Packit b89d10
Packit b89d10
static int
Packit b89d10
cp1251_is_code_ctype(OnigCodePoint code, unsigned int ctype)
Packit b89d10
{
Packit b89d10
  if (code < 256)
Packit b89d10
    return ENC_IS_CP1251_CTYPE(code, ctype);
Packit b89d10
  else
Packit b89d10
    return FALSE;
Packit b89d10
}
Packit b89d10
Packit b89d10
static const OnigPairCaseFoldCodes CaseFoldMap[] = {
Packit b89d10
  { 0xb8, 0xa8 },
Packit b89d10
Packit b89d10
  { 0xe0, 0xc0 },
Packit b89d10
  { 0xe1, 0xc1 },
Packit b89d10
  { 0xe2, 0xc2 },
Packit b89d10
  { 0xe3, 0xc3 },
Packit b89d10
  { 0xe4, 0xc4 },
Packit b89d10
  { 0xe5, 0xc5 },
Packit b89d10
  { 0xe6, 0xc6 },
Packit b89d10
  { 0xe7, 0xc7 },
Packit b89d10
  { 0xe8, 0xc8 },
Packit b89d10
  { 0xe9, 0xc9 },
Packit b89d10
  { 0xea, 0xca },
Packit b89d10
  { 0xeb, 0xcb },
Packit b89d10
  { 0xec, 0xcc },
Packit b89d10
  { 0xed, 0xcd },
Packit b89d10
  { 0xee, 0xce },
Packit b89d10
  { 0xef, 0xcf },
Packit b89d10
Packit b89d10
  { 0xf0, 0xd0 },
Packit b89d10
  { 0xf1, 0xd1 },
Packit b89d10
  { 0xf2, 0xd2 },
Packit b89d10
  { 0xf3, 0xd3 },
Packit b89d10
  { 0xf4, 0xd4 },
Packit b89d10
  { 0xf5, 0xd5 },
Packit b89d10
  { 0xf6, 0xd6 },
Packit b89d10
  { 0xf7, 0xd7 },
Packit b89d10
  { 0xf8, 0xd8 },
Packit b89d10
  { 0xf9, 0xd9 },
Packit b89d10
  { 0xfa, 0xda },
Packit b89d10
  { 0xfb, 0xdb },
Packit b89d10
  { 0xfc, 0xdc },
Packit b89d10
  { 0xfd, 0xdd },
Packit b89d10
  { 0xfe, 0xde },
Packit b89d10
  { 0xff, 0xdf }
Packit b89d10
};
Packit b89d10
Packit b89d10
static int
Packit b89d10
cp1251_apply_all_case_fold(OnigCaseFoldType flag,
Packit b89d10
			       OnigApplyAllCaseFoldFunc f, void* arg)
Packit b89d10
{
Packit b89d10
  return onigenc_apply_all_case_fold_with_map(
Packit b89d10
             sizeof(CaseFoldMap)/sizeof(OnigPairCaseFoldCodes), CaseFoldMap, 0,
Packit b89d10
             flag, f, arg);
Packit b89d10
}
Packit b89d10
Packit b89d10
static int
Packit b89d10
cp1251_get_case_fold_codes_by_str(OnigCaseFoldType flag,
Packit b89d10
    const OnigUChar* p, const OnigUChar* end, OnigCaseFoldCodeItem items[])
Packit b89d10
{
Packit b89d10
  return onigenc_get_case_fold_codes_by_str_with_map(
Packit b89d10
	     sizeof(CaseFoldMap)/sizeof(OnigPairCaseFoldCodes), CaseFoldMap, 0,
Packit b89d10
	     flag, p, end, items);
Packit b89d10
}
Packit b89d10
Packit b89d10
OnigEncodingType OnigEncodingCP1251 = {
Packit b89d10
  onigenc_single_byte_mbc_enc_len,
Packit b89d10
  "CP1251",      /* name */
Packit b89d10
  1,             /* max enc length */
Packit b89d10
  1,             /* min enc length */
Packit b89d10
  onigenc_is_mbc_newline_0x0a,
Packit b89d10
  onigenc_single_byte_mbc_to_code,
Packit b89d10
  onigenc_single_byte_code_to_mbclen,
Packit b89d10
  onigenc_single_byte_code_to_mbc,
Packit b89d10
  cp1251_mbc_case_fold,
Packit b89d10
  cp1251_apply_all_case_fold,
Packit b89d10
  cp1251_get_case_fold_codes_by_str,
Packit b89d10
  onigenc_minimum_property_name_to_ctype,
Packit b89d10
  cp1251_is_code_ctype,
Packit b89d10
  onigenc_not_support_get_ctype_code_range,
Packit b89d10
  onigenc_single_byte_left_adjust_char_head,
Packit b89d10
  onigenc_always_true_is_allowed_reverse_match,
Packit b89d10
  NULL, /* init */
Packit b89d10
  NULL, /* is_initialized */
Packit b89d10
  onigenc_always_true_is_valid_mbc_string,
Packit b89d10
  ENC_FLAG_ASCII_COMPATIBLE,
Packit b89d10
  0, 0
Packit b89d10
};