2 * CDE - Common Desktop Environment
4 * Copyright (c) 1993-2012, The Open Group. All rights reserved.
6 * These libraries and programs are free software; you can
7 * redistribute them and/or modify them under the terms of the GNU
8 * Lesser General Public License as published by the Free Software
9 * Foundation; either version 2 of the License, or (at your option)
12 * These libraries and programs are distributed in the hope that
13 * they will be useful, but WITHOUT ANY WARRANTY; without even the
14 * implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15 * PURPOSE. See the GNU Lesser General Public License for more
18 * You should have received a copy of the GNU Lesser General Public
19 * License along with these libraries and programs; if not, write
20 * to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
21 * Floor, Boston, MA 02110-1301 USA
23 /* lcDefConv.c 1.1 - Fujitsu source for CDEnext 95/11/06 20:32:35 */
24 /* $XConsortium: _fallcDefConv.c /main/1 1996/04/08 15:16:17 cde-fuj $ */
26 * Copyright 1992, 1993 by TOSHIBA Corp.
28 * Permission to use, copy, modify, and distribute this software and its
29 * documentation for any purpose and without fee is hereby granted, provided
30 * that the above copyright notice appear in all copies and that both that
31 * copyright notice and this permission notice appear in supporting
32 * documentation, and that the name of TOSHIBA not be used in advertising
33 * or publicity pertaining to distribution of the software without specific,
34 * written prior permission. TOSHIBA make no representations about the
35 * suitability of this software for any purpose. It is provided "as is"
36 * without express or implied warranty.
38 * TOSHIBA DISCLAIM ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
39 * ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
40 * TOSHIBA BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR
41 * ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
42 * WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
43 * ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
46 * Author: Katsuhisa Yano TOSHIBA Corp.
47 * mopi@osa.ilab.toshiba.co.jp
50 #include "_fallibint.h"
51 #include "_fallcPubI.h"
53 typedef struct _StateRec {
55 XlcCharSet GL_charset;
56 XlcCharSet GR_charset;
58 int (*to_converter)();
62 strtostr(conv, from, from_left, to, to_left, args, num_args)
71 register char *src, *dst;
75 if (from == NULL || *from == NULL)
81 length = min(*from_left, *to_left);
84 side = *((unsigned char *) src) & 0x80;
85 while (side == (*((unsigned char *) src) & 0x80) && length-- > 0)
92 *from_left -= src - (char *) *from;
93 *from = (XPointer) src;
94 *to_left -= dst - (char *) *to;
98 State state = (State) conv->state;
100 *((XlcCharSet *)args[0]) = side ? state->GR_charset : state->GL_charset;
107 wcstostr(conv, from, from_left, to, to_left, args, num_args)
116 register wchar_t *src, side;
120 if (from == NULL || *from == NULL)
123 src = (wchar_t *) *from;
126 length = min(*from_left, *to_left);
130 while (side == (*src & 0x80) && length-- > 0)
137 *from_left -= src - (wchar_t *) *from;
138 *from = (XPointer) src;
139 *to_left -= dst - (char *) *to;
140 *to = (XPointer) dst;
143 State state = (State) conv->state;
145 *((XlcCharSet *)args[0]) = side ? state->GR_charset : state->GL_charset;
152 cstostr(conv, from, from_left, to, to_left, args, num_args)
161 register char *src, *dst;
165 if (from == NULL || *from == NULL)
169 State state = (State) conv->state;
170 XlcCharSet charset = (XlcCharSet) args[0];
172 if (charset != state->GL_charset && charset != state->GR_charset)
176 src = (char *) *from;
179 length = min(*from_left, *to_left);
182 side = *((unsigned char *) src) & 0x80;
183 while (side == (*((unsigned char *) src) & 0x80) && length-- > 0)
190 *from_left -= src - (char *) *from;
191 *from = (XPointer) src;
192 *to_left -= dst - (char *) *to;
193 *to = (XPointer) dst;
196 State state = (State) conv->state;
198 *((XlcCharSet *)args[0]) = side ? state->GR_charset : state->GL_charset;
205 strtowcs(conv, from, from_left, to, to_left, args, num_args)
215 register wchar_t *dst;
218 if (from == NULL || *from == NULL)
222 State state = (State) conv->state;
223 XlcCharSet charset = (XlcCharSet) args[0];
225 if (charset != state->GL_charset && charset != state->GR_charset)
229 src = (char *) *from;
230 dst = (wchar_t *) *to;
232 length = min(*from_left, *to_left);
235 *dst++ = (wchar_t) *src++;
237 *from_left -= src - (char *) *from;
238 *from = (XPointer) src;
239 *to_left -= dst - (wchar_t *) *to;
240 *to = (XPointer) dst;
247 close_converter(conv)
251 Xfree((char *) conv->state);
253 Xfree((char *) conv);
258 XlcConvMethods methods;
260 register XlcConv conv;
262 static XlcCharSet GL_charset = NULL;
263 static XlcCharSet GR_charset = NULL;
265 if (GL_charset == NULL) {
266 GL_charset = _fallcGetCharSet("ISO8859-1:GL");
267 GR_charset = _fallcGetCharSet("ISO8859-1:GR");
270 conv = (XlcConv) Xmalloc(sizeof(XlcConvRec));
272 return (XlcConv) NULL;
276 state = (State) Xmalloc(sizeof(StateRec));
280 state->GL_charset = state->charset = GL_charset;
281 state->GR_charset = GR_charset;
283 conv->methods = methods;
284 conv->state = (XPointer) state;
289 close_converter(conv);
291 return (XlcConv) NULL;
294 static XlcConvMethodsRec strtostr_methods = {
301 open_strtostr(from_lcd, from_type, to_lcd, to_type)
307 return create_conv(&strtostr_methods);
310 static XlcConvMethodsRec wcstostr_methods = {
317 open_wcstostr(from_lcd, from_type, to_lcd, to_type)
323 return create_conv(&wcstostr_methods);
326 static XlcConvMethodsRec cstostr_methods = {
333 open_cstostr(from_lcd, from_type, to_lcd, to_type)
339 return create_conv(&cstostr_methods);
342 static XlcConvMethodsRec strtowcs_methods = {
349 open_strtowcs(from_lcd, from_type, to_lcd, to_type)
355 return create_conv(&strtowcs_methods);
359 _fallcDefaultLoader(name)
364 if (strcmp(name, "C"))
367 lcd = _fallcCreateLC(name, _fallcPublicMethods);
369 _fallcSetConverter(lcd, XlcNMultiByte, lcd, XlcNWideChar, open_strtowcs);
370 _fallcSetConverter(lcd, XlcNMultiByte, lcd, XlcNCompoundText, open_strtostr);
371 _fallcSetConverter(lcd, XlcNMultiByte, lcd, XlcNString, open_strtostr);
372 _fallcSetConverter(lcd, XlcNMultiByte, lcd, XlcNCharSet, open_strtostr);
373 _fallcSetConverter(lcd, XlcNMultiByte, lcd, XlcNChar, open_strtostr);/* XXX */
375 _fallcSetConverter(lcd, XlcNWideChar, lcd, XlcNMultiByte, open_wcstostr);
376 _fallcSetConverter(lcd, XlcNWideChar, lcd, XlcNCompoundText, open_wcstostr);
377 _fallcSetConverter(lcd, XlcNWideChar, lcd, XlcNString, open_wcstostr);
378 _fallcSetConverter(lcd, XlcNWideChar, lcd, XlcNCharSet, open_wcstostr);
380 _fallcSetConverter(lcd, XlcNString, lcd, XlcNMultiByte, open_strtostr);
381 _fallcSetConverter(lcd, XlcNString, lcd, XlcNWideChar, open_strtowcs);
383 _fallcSetConverter(lcd, XlcNCharSet, lcd, XlcNMultiByte, open_cstostr);
384 _fallcSetConverter(lcd, XlcNCharSet, lcd, XlcNWideChar, open_strtowcs);