cchar.c revision 1.9 1 1.9 uwe /* $NetBSD: cchar.c,v 1.9 2018/11/20 21:42:52 uwe Exp $ */
2 1.1 blymn
3 1.1 blymn /*
4 1.1 blymn * Copyright (c) 2005 The NetBSD Foundation Inc.
5 1.1 blymn * All rights reserved.
6 1.1 blymn *
7 1.1 blymn * This code is derived from code donated to the NetBSD Foundation
8 1.1 blymn * by Ruibiao Qiu <ruibiao (at) arl.wustl.edu,ruibiao (at) gmail.com>.
9 1.1 blymn *
10 1.1 blymn *
11 1.1 blymn * Redistribution and use in source and binary forms, with or without
12 1.1 blymn * modification, are permitted provided that the following conditions
13 1.1 blymn * are met:
14 1.1 blymn * 1. Redistributions of source code must retain the above copyright
15 1.1 blymn * notice, this list of conditions and the following disclaimer.
16 1.1 blymn * 2. Redistributions in binary form must reproduce the above copyright
17 1.1 blymn * notice, this list of conditions and the following disclaimer in the
18 1.1 blymn * documentation and/or other materials provided with the distribution.
19 1.1 blymn * 3. Neither the name of the NetBSD Foundation nor the names of its
20 1.1 blymn * contributors may be used to endorse or promote products derived
21 1.1 blymn * from this software without specific prior written permission.
22 1.1 blymn *
23 1.1 blymn * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND
24 1.1 blymn * CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
25 1.1 blymn * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
26 1.1 blymn * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27 1.1 blymn * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
28 1.1 blymn * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
29 1.1 blymn * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
30 1.1 blymn * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
31 1.1 blymn * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32 1.1 blymn * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
33 1.1 blymn * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
34 1.1 blymn * SUCH DAMAGE.
35 1.1 blymn */
36 1.1 blymn
37 1.1 blymn #include <sys/cdefs.h>
38 1.1 blymn #ifndef lint
39 1.9 uwe __RCSID("$NetBSD: cchar.c,v 1.9 2018/11/20 21:42:52 uwe Exp $");
40 1.1 blymn #endif /* not lint */
41 1.1 blymn
42 1.1 blymn #include <string.h>
43 1.1 blymn
44 1.1 blymn #include "curses.h"
45 1.1 blymn #include "curses_private.h"
46 1.1 blymn
47 1.1 blymn /*
48 1.1 blymn * getcchar --
49 1.5 wiz * get a wide-character string and rendition from a cchar_t
50 1.1 blymn */
51 1.1 blymn int
52 1.1 blymn getcchar(const cchar_t *wcval, wchar_t *wch, attr_t *attrs,
53 1.6 roy short *color_pair, void *opts)
54 1.1 blymn {
55 1.1 blymn #ifndef HAVE_WCHAR
56 1.1 blymn return ERR;
57 1.1 blymn #else
58 1.1 blymn wchar_t *wp;
59 1.3 blymn size_t len;
60 1.1 blymn
61 1.8 uwe if (__predict_false(opts != NULL))
62 1.1 blymn return ERR;
63 1.1 blymn
64 1.8 uwe wp = wmemchr(wcval->vals, L'\0', CCHARW_MAX);
65 1.8 uwe len = wp ? wp - wcval->vals : CCHARW_MAX;
66 1.1 blymn
67 1.1 blymn if (wch == NULL)
68 1.6 roy return (int)len;
69 1.1 blymn if (attrs == 0 || color_pair == 0)
70 1.1 blymn return ERR;
71 1.3 blymn if (len > 0) {
72 1.3 blymn *attrs = wcval->attributes;
73 1.7 uwe if (__using_color)
74 1.7 uwe *color_pair = PAIR_NUMBER(wcval->attributes);
75 1.7 uwe else
76 1.7 uwe *color_pair = 0;
77 1.9 uwe wmemcpy(wch, wcval->vals, len);
78 1.1 blymn wch[len] = L'\0';
79 1.1 blymn }
80 1.1 blymn return OK;
81 1.1 blymn #endif /* HAVE_WCHAR */
82 1.1 blymn }
83 1.1 blymn
84 1.1 blymn /*
85 1.1 blymn * setcchar --
86 1.5 wiz * set cchar_t from a wide-character string and rendition
87 1.1 blymn */
88 1.1 blymn int
89 1.1 blymn setcchar(cchar_t *wcval, const wchar_t *wch, const attr_t attrs,
90 1.6 roy short color_pair, const void *opts)
91 1.1 blymn {
92 1.1 blymn #ifndef HAVE_WCHAR
93 1.1 blymn return ERR;
94 1.1 blymn #else
95 1.1 blymn int i;
96 1.3 blymn size_t len;
97 1.1 blymn
98 1.8 uwe if (__predict_false(opts != NULL))
99 1.8 uwe return ERR;
100 1.8 uwe
101 1.8 uwe len = wcslen(wch);
102 1.8 uwe if (len > CCHARW_MAX || (len > 1 && wcwidth(wch[0]) < 0))
103 1.1 blymn return ERR;
104 1.1 blymn
105 1.1 blymn /*
106 1.1 blymn * If we have a following spacing-character, stop at that point. We
107 1.1 blymn * are only interested in adding non-spacing characters.
108 1.1 blymn */
109 1.1 blymn for (i = 1; i < len; ++i) {
110 1.1 blymn if (wcwidth(wch[i]) != 0) {
111 1.1 blymn len = i;
112 1.1 blymn break;
113 1.1 blymn }
114 1.1 blymn }
115 1.1 blymn
116 1.1 blymn memset(wcval, 0, sizeof(*wcval));
117 1.1 blymn if (len != 0) {
118 1.7 uwe wcval->attributes = attrs & ~__COLOR;
119 1.7 uwe if (__using_color && color_pair)
120 1.7 uwe wcval->attributes |= COLOR_PAIR(color_pair);
121 1.6 roy wcval->elements = 1;
122 1.1 blymn memcpy(&wcval->vals, wch, len * sizeof(wchar_t));
123 1.1 blymn }
124 1.1 blymn
125 1.1 blymn return OK;
126 1.1 blymn #endif /* HAVE_WCHAR */
127 1.1 blymn }
128 1.4 drochner
129 1.4 drochner void
130 1.4 drochner __cursesi_chtype_to_cchar(chtype in, cchar_t *out)
131 1.4 drochner {
132 1.4 drochner unsigned int idx;
133 1.4 drochner
134 1.4 drochner if (in & __ACS_IS_WACS) {
135 1.4 drochner idx = in & __CHARTEXT;
136 1.4 drochner if (idx < NUM_ACS) {
137 1.4 drochner memcpy(out, &_wacs_char[idx], sizeof(cchar_t));
138 1.4 drochner out->attributes |= in & __ATTRIBUTES;
139 1.4 drochner return;
140 1.4 drochner }
141 1.4 drochner }
142 1.4 drochner out->vals[0] = in & __CHARTEXT;
143 1.4 drochner out->attributes = in & __ATTRIBUTES;
144 1.4 drochner out->elements = 1;
145 1.4 drochner }
146