version 1.1.1.1, 2012/05/29 09:29:43
|
version 1.1.1.2, 2021/03/17 13:38:46
|
Line 1
|
Line 1
|
/* |
/* |
* Copyright (C) 1999-2010 Free Software Foundation, Inc. | * Copyright (C) 1999-2010, 2012, 2016 Free Software Foundation, Inc. |
* This file is part of the GNU LIBICONV Library. |
* This file is part of the GNU LIBICONV Library. |
* |
* |
* The GNU LIBICONV Library is free software; you can redistribute it |
* The GNU LIBICONV Library is free software; you can redistribute it |
Line 14
|
Line 14
|
* |
* |
* You should have received a copy of the GNU Library General Public |
* You should have received a copy of the GNU Library General Public |
* License along with the GNU LIBICONV Library; see the file COPYING.LIB. |
* License along with the GNU LIBICONV Library; see the file COPYING.LIB. |
* If not, write to the Free Software Foundation, Inc., 51 Franklin Street, | * If not, see <https://www.gnu.org/licenses/>. |
* Fifth Floor, Boston, MA 02110-1301, USA. | |
*/ |
*/ |
|
|
/* |
/* |
Line 53 static const ucs4_t hkscs2008_2uni_upages[50] = {
|
Line 52 static const ucs4_t hkscs2008_2uni_upages[50] = {
|
}; |
}; |
|
|
static int |
static int |
hkscs2008_mbtowc (conv_t conv, ucs4_t *pwc, const unsigned char *s, int n) | hkscs2008_mbtowc (conv_t conv, ucs4_t *pwc, const unsigned char *s, size_t n) |
{ |
{ |
unsigned char c1 = s[0]; |
unsigned char c1 = s[0]; |
if ((c1 == 0x87)) { |
if ((c1 == 0x87)) { |
Line 364 static const Summary16 hkscs2008_uni2indx_page2ad[16]
|
Line 363 static const Summary16 hkscs2008_uni2indx_page2ad[16]
|
}; |
}; |
|
|
static int |
static int |
hkscs2008_wctomb (conv_t conv, unsigned char *r, ucs4_t wc, int n) | hkscs2008_wctomb (conv_t conv, unsigned char *r, ucs4_t wc, size_t n) |
{ |
{ |
if (n >= 2) { |
if (n >= 2) { |
const Summary16 *summary = NULL; |
const Summary16 *summary = NULL; |
Line 449 hkscs2008_wctomb (conv_t conv, unsigned char *r, ucs4_
|
Line 448 hkscs2008_wctomb (conv_t conv, unsigned char *r, ucs4_
|
unsigned int i = wc & 0x0f; |
unsigned int i = wc & 0x0f; |
if (used & ((unsigned short) 1 << i)) { |
if (used & ((unsigned short) 1 << i)) { |
unsigned short c; |
unsigned short c; |
/* Keep in `used' only the bits 0..i-1. */ | /* Keep in 'used' only the bits 0..i-1. */ |
used &= ((unsigned short) 1 << i) - 1; |
used &= ((unsigned short) 1 << i) - 1; |
/* Add `summary->indx' and the number of bits set in `used'. */ | /* Add 'summary->indx' and the number of bits set in 'used'. */ |
used = (used & 0x5555) + ((used & 0xaaaa) >> 1); |
used = (used & 0x5555) + ((used & 0xaaaa) >> 1); |
used = (used & 0x3333) + ((used & 0xcccc) >> 2); |
used = (used & 0x3333) + ((used & 0xcccc) >> 2); |
used = (used & 0x0f0f) + ((used & 0xf0f0) >> 4); |
used = (used & 0x0f0f) + ((used & 0xf0f0) >> 4); |