2004-03-05 10:31:51 -05:00
|
|
|
/**********************************************************************
|
2012-02-17 02:42:23 -05:00
|
|
|
ascii.c - Onigmo (Oniguruma-mod) (regular expression library)
|
2004-03-05 10:31:51 -05:00
|
|
|
**********************************************************************/
|
2004-11-04 09:31:26 -05:00
|
|
|
/*-
|
2007-05-22 21:32:08 -04:00
|
|
|
* Copyright (c) 2002-2006 K.Kosako <sndgk393 AT ybb DOT ne DOT jp>
|
2012-02-17 02:42:23 -05:00
|
|
|
* Copyright (c) 2011 K.Takata <kentkt AT csc DOT jp>
|
2004-11-04 09:31:26 -05:00
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
2004-03-05 10:31:51 -05:00
|
|
|
#include "regenc.h"
|
2015-09-15 01:49:52 -04:00
|
|
|
#include "encindex.h"
|
|
|
|
#ifndef ENCINDEX_ASCII
|
|
|
|
#define ENCINDEX_ASCII 0
|
|
|
|
#endif
|
2004-03-05 10:31:51 -05:00
|
|
|
|
2007-12-20 21:23:26 -05:00
|
|
|
OnigEncodingDefine(ascii, ASCII) = {
|
2004-11-04 09:31:26 -05:00
|
|
|
onigenc_single_byte_mbc_enc_len,
|
2007-10-10 02:50:33 -04:00
|
|
|
"ASCII-8BIT",/* name */
|
2004-03-05 10:31:51 -05:00
|
|
|
1, /* max byte length */
|
2004-11-04 09:31:26 -05:00
|
|
|
1, /* min byte length */
|
|
|
|
onigenc_is_mbc_newline_0x0a,
|
2004-03-05 10:31:51 -05:00
|
|
|
onigenc_single_byte_mbc_to_code,
|
|
|
|
onigenc_single_byte_code_to_mbclen,
|
|
|
|
onigenc_single_byte_code_to_mbc,
|
2007-05-22 21:32:08 -04:00
|
|
|
onigenc_ascii_mbc_case_fold,
|
|
|
|
onigenc_ascii_apply_all_case_fold,
|
|
|
|
onigenc_ascii_get_case_fold_codes_by_str,
|
|
|
|
onigenc_minimum_property_name_to_ctype,
|
2007-12-22 00:38:33 -05:00
|
|
|
onigenc_ascii_is_code_ctype,
|
2004-11-04 09:31:26 -05:00
|
|
|
onigenc_not_support_get_ctype_code_range,
|
2004-03-05 10:31:51 -05:00
|
|
|
onigenc_single_byte_left_adjust_char_head,
|
2012-02-17 02:42:23 -05:00
|
|
|
onigenc_always_true_is_allowed_reverse_match,
|
2015-09-15 01:49:52 -04:00
|
|
|
ENCINDEX_ASCII,
|
2012-02-17 02:42:23 -05:00
|
|
|
ONIGENC_FLAG_NONE,
|
* include/ruby/oniguruma.h: Extend OnigEncodingTypeDefine to define a
new encoding primitive 'case_map' for case mapping
* enc/utf-8.c, utf_16be/le.c, utf_32be/le.c:
add onigenc_unicode_case_map as case_map primitive
* enc/ascii.c, big5.c, cp949.c, emacs_mule.c, euc_jp/kr/tw.c, gb18030.c,
gbk.c, iso_8859_1/2/3/4/5/6/7/8/9/10/11/13/14/15/16.c, koi8_r/u.c,
shift_jis.c, us_ascii.c, windows_1250/1251/1252.c:
add onigenc_not_support_case_map as case_map primitive
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@55113 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2016-05-22 01:57:44 -04:00
|
|
|
#ifdef ONIG_CASE_MAPPING
|
* regenc.h/c: Rename onigenc_not_support_case_map to
onigenc_ascii_only_case_map.
* regenc.h: Add definition of onigenc_single_byte_ascii_only_case_map.
* enc/iso_8859_X.c, windows_125X.c, ascii.c, us-ascii.c, koi8_x.c:
Replace onigenc_not_support_case_map by
onigenc_single_byte_ascii_only_case_map.
* enc/big5.c, cp949.c, emacs_mule.c, euc_X.c, gbX.c, shift_jis.c,
windows_31j.c: Replace onigenc_not_support_case_map by
onigenc_ascii_only_case_map.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@55305 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2016-06-07 02:05:18 -04:00
|
|
|
onigenc_single_byte_ascii_only_case_map,
|
* include/ruby/oniguruma.h: Extend OnigEncodingTypeDefine to define a
new encoding primitive 'case_map' for case mapping
* enc/utf-8.c, utf_16be/le.c, utf_32be/le.c:
add onigenc_unicode_case_map as case_map primitive
* enc/ascii.c, big5.c, cp949.c, emacs_mule.c, euc_jp/kr/tw.c, gb18030.c,
gbk.c, iso_8859_1/2/3/4/5/6/7/8/9/10/11/13/14/15/16.c, koi8_r/u.c,
shift_jis.c, us_ascii.c, windows_1250/1251/1252.c:
add onigenc_not_support_case_map as case_map primitive
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@55113 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2016-05-22 01:57:44 -04:00
|
|
|
#endif /* ONIG_CASE_MAPPING */
|
2004-03-05 10:31:51 -05:00
|
|
|
};
|
2008-07-01 04:39:10 -04:00
|
|
|
ENC_ALIAS("BINARY", "ASCII-8BIT")
|
|
|
|
ENC_REPLICATE("IBM437", "ASCII-8BIT")
|
|
|
|
ENC_ALIAS("CP437", "IBM437")
|
|
|
|
ENC_REPLICATE("IBM737", "ASCII-8BIT")
|
|
|
|
ENC_ALIAS("CP737", "IBM737")
|
|
|
|
ENC_REPLICATE("IBM775", "ASCII-8BIT")
|
|
|
|
ENC_ALIAS("CP775", "IBM775")
|
|
|
|
ENC_REPLICATE("CP850", "ASCII-8BIT")
|
|
|
|
ENC_ALIAS("IBM850", "CP850")
|
|
|
|
ENC_REPLICATE("IBM852", "ASCII-8BIT")
|
|
|
|
ENC_REPLICATE("CP852", "IBM852")
|
|
|
|
ENC_REPLICATE("IBM855", "ASCII-8BIT")
|
|
|
|
ENC_REPLICATE("CP855", "IBM855")
|
|
|
|
ENC_REPLICATE("IBM857", "ASCII-8BIT")
|
|
|
|
ENC_ALIAS("CP857", "IBM857")
|
|
|
|
ENC_REPLICATE("IBM860", "ASCII-8BIT")
|
|
|
|
ENC_ALIAS("CP860", "IBM860")
|
|
|
|
ENC_REPLICATE("IBM861", "ASCII-8BIT")
|
|
|
|
ENC_ALIAS("CP861", "IBM861")
|
|
|
|
ENC_REPLICATE("IBM862", "ASCII-8BIT")
|
|
|
|
ENC_ALIAS("CP862", "IBM862")
|
|
|
|
ENC_REPLICATE("IBM863", "ASCII-8BIT")
|
|
|
|
ENC_ALIAS("CP863", "IBM863")
|
|
|
|
ENC_REPLICATE("IBM864", "ASCII-8BIT")
|
|
|
|
ENC_ALIAS("CP864", "IBM864")
|
|
|
|
ENC_REPLICATE("IBM865", "ASCII-8BIT")
|
|
|
|
ENC_ALIAS("CP865", "IBM865")
|
|
|
|
ENC_REPLICATE("IBM866", "ASCII-8BIT")
|
|
|
|
ENC_ALIAS("CP866", "IBM866")
|
|
|
|
ENC_REPLICATE("IBM869", "ASCII-8BIT")
|
|
|
|
ENC_ALIAS("CP869", "IBM869")
|
|
|
|
ENC_REPLICATE("Windows-1258", "ASCII-8BIT")
|
|
|
|
ENC_ALIAS("CP1258", "Windows-1258")
|
|
|
|
ENC_REPLICATE("GB1988", "ASCII-8BIT")
|
|
|
|
ENC_REPLICATE("macCentEuro", "ASCII-8BIT")
|
|
|
|
ENC_REPLICATE("macCroatian", "ASCII-8BIT")
|
|
|
|
ENC_REPLICATE("macCyrillic", "ASCII-8BIT")
|
|
|
|
ENC_REPLICATE("macGreek", "ASCII-8BIT")
|
|
|
|
ENC_REPLICATE("macIceland", "ASCII-8BIT")
|
|
|
|
ENC_REPLICATE("macRoman", "ASCII-8BIT")
|
|
|
|
ENC_REPLICATE("macRomania", "ASCII-8BIT")
|
|
|
|
ENC_REPLICATE("macThai", "ASCII-8BIT")
|
|
|
|
ENC_REPLICATE("macTurkish", "ASCII-8BIT")
|
|
|
|
ENC_REPLICATE("macUkraine", "ASCII-8BIT")
|