1 /* This testcase is part of GDB, the GNU debugger.
3 Copyright 2001, 2004, 2007, 2008, 2009, 2010 Free Software Foundation, Inc.
5 Contributed by Red Hat, originally written by Jim Blandy.
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>.
20 Please email any bugs, comments, and/or additions to this file to:
23 /* X_string is a null-terminated string in the X charset whose
24 elements are as follows. X should be the name the `set charset'
25 command uses for the character set, in lower-case, with any
26 non-identifier characters replaced with underscores. Where a
27 character set doesn't have the given character, the string should
28 contain the character 'x'.
30 [0] --- the `alert' character, '\a'
31 [1] --- the `backspace' character, '\b'
32 [2] --- the `form feed' character, '\f'
33 [3] --- the `line feed' character, '\n'
34 [4] --- the `carriage return' character, '\r'
35 [5] --- the `horizontal tab' character, '\t'
36 [6] --- the `vertical tab' character, '\v'
37 [7 .. 32] --- the uppercase letters A-Z
38 [33 .. 58] --- the lowercase letters a-z
39 [59 .. 68] --- the digits 0-9
40 [69] --- the `cent' character
41 [70] --- a control character with no defined backslash escape
43 Feel free to extend these as you like. */
45 #define NUM_CHARS (71)
47 char ascii_string
[NUM_CHARS
];
48 char iso_8859_1_string
[NUM_CHARS
];
49 char ebcdic_us_string
[NUM_CHARS
];
50 char ibm1047_string
[NUM_CHARS
];
52 /* We make a phony wchar_t and then pretend that this platform uses
53 UTF-32 (or UTF-16, depending on the size -- same difference for the
54 purposes of this test). */
55 typedef unsigned int wchar_t;
56 wchar_t utf_32_string
[NUM_CHARS
];
58 /* We also define a couple phony types for testing the u'' and U''
59 support. It is ok if these have the wrong size on some platforms
60 -- the test case will skip the tests in that case. */
61 typedef unsigned short char16_t
;
62 typedef unsigned int char32_t
;
64 /* Make sure to use the typedefs. */
71 /* A typedef to a typedef should also work. */
72 typedef wchar_t my_wchar_t
;
76 init_string (char string
[],
78 char alert
, char backspace
, char form_feed
,
79 char line_feed
, char carriage_return
, char horizontal_tab
,
80 char vertical_tab
, char cent
, char misc_ctrl
)
84 for (i
= 0; i
< NUM_CHARS
; ++i
)
87 string
[1] = backspace
;
88 string
[2] = form_feed
;
89 string
[3] = line_feed
;
90 string
[4] = carriage_return
;
91 string
[5] = horizontal_tab
;
92 string
[6] = vertical_tab
;
94 string
[70] = misc_ctrl
;
99 fill_run (char string
[], int start
, int len
, int first
)
103 for (i
= 0; i
< len
; i
++)
104 string
[start
+ i
] = first
+ i
;
113 for (i
= 0; i
< NUM_CHARS
; ++i
)
114 utf_32_string
[i
] = iso_8859_1_string
[i
] & 0xff;
123 /* Initialize ascii_string. */
124 init_string (ascii_string
,
129 fill_run (ascii_string
, 7, 26, 65);
130 fill_run (ascii_string
, 33, 26, 97);
131 fill_run (ascii_string
, 59, 10, 48);
133 /* Initialize iso_8859_1_string. */
134 init_string (iso_8859_1_string
,
139 fill_run (iso_8859_1_string
, 7, 26, 65);
140 fill_run (iso_8859_1_string
, 33, 26, 97);
141 fill_run (iso_8859_1_string
, 59, 10, 48);
143 /* Initialize ebcdic_us_string. */
144 init_string (ebcdic_us_string
,
149 /* In EBCDIC, the upper-case letters are broken into three separate runs. */
150 fill_run (ebcdic_us_string
, 7, 9, 193);
151 fill_run (ebcdic_us_string
, 16, 9, 209);
152 fill_run (ebcdic_us_string
, 25, 8, 226);
153 /* The lower-case letters are, too. */
154 fill_run (ebcdic_us_string
, 33, 9, 129);
155 fill_run (ebcdic_us_string
, 42, 9, 145);
156 fill_run (ebcdic_us_string
, 51, 8, 162);
157 /* The digits, at least, are contiguous. */
158 fill_run (ebcdic_us_string
, 59, 10, 240);
160 /* Initialize ibm1047_string. */
161 init_string (ibm1047_string
,
166 /* In EBCDIC, the upper-case letters are broken into three separate runs. */
167 fill_run (ibm1047_string
, 7, 9, 193);
168 fill_run (ibm1047_string
, 16, 9, 209);
169 fill_run (ibm1047_string
, 25, 8, 226);
170 /* The lower-case letters are, too. */
171 fill_run (ibm1047_string
, 33, 9, 129);
172 fill_run (ibm1047_string
, 42, 9, 145);
173 fill_run (ibm1047_string
, 51, 8, 162);
174 /* The digits, at least, are contiguous. */
175 fill_run (ibm1047_string
, 59, 10, 240);
179 myvar
= utf_32_string
[7];
181 return 0; /* all strings initialized */
This page took 0.046861 seconds and 4 git commands to generate.