]> git.saurik.com Git - apple/icu.git/blame - icuSources/tools/genrb/derb.c
ICU-551.24.tar.gz
[apple/icu.git] / icuSources / tools / genrb / derb.c
CommitLineData
b75a7d8f
A
1/*
2*******************************************************************************
3*
57a6839d 4* Copyright (C) 1999-2013, International Business Machines
b75a7d8f
A
5* Corporation and others. All Rights Reserved.
6*
7*******************************************************************************
8* file name: derb.c
9* encoding: US-ASCII
10* tab size: 8 (not used)
11* indentation:4
12*
13* created on: 2000sep6
14* created by: Vladimir Weinstein as an ICU workshop example
15* maintained by: Yves Arrouye <yves@realnames.com>
16*/
17
18#include "unicode/ucnv.h"
19#include "unicode/ustring.h"
374ca955 20#include "unicode/putil.h"
57a6839d 21#include "unicode/ustdio.h"
b75a7d8f
A
22
23#include "uresimp.h"
24#include "cmemory.h"
25#include "cstring.h"
26#include "uoptions.h"
27#include "toolutil.h"
28#include "ustrfmt.h"
29
57a6839d 30#if !UCONFIG_NO_FORMATTING
b75a7d8f 31
57a6839d 32#define DERB_VERSION "1.1"
b75a7d8f
A
33
34#define DERB_DEFAULT_TRUNC 80
35
b75a7d8f
A
36static const int32_t indentsize = 4;
37static int32_t truncsize = DERB_DEFAULT_TRUNC;
51004dcb 38static UBool opt_truncate = FALSE;
b75a7d8f 39
b75a7d8f
A
40static const char *getEncodingName(const char *encoding);
41static void reportError(const char *pname, UErrorCode *status, const char *when);
42static UChar *quotedString(const UChar *string);
57a6839d
A
43static void printOutBundle(UFILE *out, UConverter *converter, UResourceBundle *resource, int32_t indent, const char *pname, UErrorCode *status);
44static void printString(UFILE *out, UConverter *converter, const UChar *str, int32_t len);
45static void printCString(UFILE *out, UConverter *converter, const char *str, int32_t len);
46static void printIndent(UFILE *out, UConverter *converter, int32_t indent);
47static void printHex(UFILE *out, UConverter *converter, uint8_t what);
b75a7d8f
A
48
49static UOption options[]={
50 UOPTION_HELP_H,
51 UOPTION_HELP_QUESTION_MARK,
52/* 2 */ UOPTION_ENCODING,
53/* 3 */ { "to-stdout", NULL, NULL, NULL, 'c', UOPT_NO_ARG, 0 } ,
54/* 4 */ { "truncate", NULL, NULL, NULL, 't', UOPT_OPTIONAL_ARG, 0 },
55/* 5 */ UOPTION_VERBOSE,
56/* 6 */ UOPTION_DESTDIR,
57/* 7 */ UOPTION_SOURCEDIR,
58/* 8 */ { "bom", NULL, NULL, NULL, 0, UOPT_NO_ARG, 0 },
59/* 9 */ UOPTION_ICUDATADIR,
60/* 10 */ UOPTION_VERSION,
57a6839d 61/* 11 */ { "suppressAliases", NULL, NULL, NULL, 'A', UOPT_NO_ARG, 0 },
b75a7d8f
A
62};
63
64static UBool verbose = FALSE;
65static UBool suppressAliases = FALSE;
57a6839d 66static UFILE *ustderr = NULL;
b75a7d8f
A
67
68extern int
69main(int argc, char* argv[]) {
70 const char *encoding = NULL;
71 const char *outputDir = NULL; /* NULL = no output directory, use current */
72 const char *inputDir = ".";
73 int tostdout = 0;
74 int prbom = 0;
75
76 const char *pname;
77
78 UResourceBundle *bundle = NULL;
79 UErrorCode status = U_ZERO_ERROR;
80 int32_t i = 0;
81
57a6839d 82 UConverter *converter = NULL; // not used
b75a7d8f
A
83
84 const char* arg;
85
86 /* Get the name of tool. */
87 pname = uprv_strrchr(*argv, U_FILE_SEP_CHAR);
73c04bcf 88#if U_FILE_SEP_CHAR != U_FILE_ALT_SEP_CHAR
b75a7d8f 89 if (!pname) {
73c04bcf 90 pname = uprv_strrchr(*argv, U_FILE_ALT_SEP_CHAR);
b75a7d8f
A
91 }
92#endif
93 if (!pname) {
94 pname = *argv;
95 } else {
96 ++pname;
97 }
98
99 /* error handling, printing usage message */
100 argc=u_parseArgs(argc, argv, sizeof(options)/sizeof(options[0]), options);
101
102 /* error handling, printing usage message */
103 if(argc<0) {
104 fprintf(stderr,
105 "%s: error in command line argument \"%s\"\n", pname,
106 argv[-argc]);
107 }
108 if(argc<0 || options[0].doesOccur || options[1].doesOccur) {
109 fprintf(argc < 0 ? stderr : stdout,
110 "%csage: %s [ -h, -?, --help ] [ -V, --version ]\n"
111 " [ -v, --verbose ] [ -e, --encoding encoding ] [ --bom ]\n"
112 " [ -t, --truncate [ size ] ]\n"
113 " [ -s, --sourcedir source ] [ -d, --destdir destination ]\n"
114 " [ -i, --icudatadir directory ] [ -c, --to-stdout ]\n"
115 " [ -A, --suppressAliases]\n"
116 " bundle ...\n", argc < 0 ? 'u' : 'U',
117 pname);
118 return argc<0 ? U_ILLEGAL_ARGUMENT_ERROR : U_ZERO_ERROR;
119 }
120
121 if(options[10].doesOccur) {
122 fprintf(stderr,
123 "%s version %s (ICU version %s).\n"
124 "%s\n",
125 pname, DERB_VERSION, U_ICU_VERSION, U_COPYRIGHT_STRING);
126 return U_ZERO_ERROR;
127 }
128 if(options[2].doesOccur) {
129 encoding = options[2].value;
130 }
131
132 if (options[3].doesOccur) {
57a6839d
A
133 if(options[2].doesOccur) {
134 fprintf(stderr, "%s: Error: don't specify an encoding (-e) when writing to stdout (-c).\n", pname);
135 return 3;
136 }
137 tostdout = 1;
b75a7d8f
A
138 }
139
140 if(options[4].doesOccur) {
51004dcb 141 opt_truncate = TRUE;
b75a7d8f
A
142 if(options[4].value != NULL) {
143 truncsize = atoi(options[4].value); /* user defined printable size */
144 } else {
145 truncsize = DERB_DEFAULT_TRUNC; /* we'll use default omitting size */
146 }
147 } else {
51004dcb 148 opt_truncate = FALSE;
b75a7d8f
A
149 }
150
151 if(options[5].doesOccur) {
152 verbose = TRUE;
153 }
154
155 if (options[6].doesOccur) {
156 outputDir = options[6].value;
157 }
158
159 if(options[7].doesOccur) {
160 inputDir = options[7].value; /* we'll use users resources */
161 }
162
163 if (options[8].doesOccur) {
164 prbom = 1;
165 }
166
167 if (options[9].doesOccur) {
168 u_setDataDirectory(options[9].value);
169 }
170
171 if (options[11].doesOccur) {
172 suppressAliases = TRUE;
173 }
174
57a6839d
A
175 fflush(stderr); // use ustderr now.
176 ustderr = u_finit(stderr, NULL, NULL);
b75a7d8f
A
177
178 for (i = 1; i < argc; ++i) {
179 static const UChar sp[] = { 0x0020 }; /* " " */
180 char infile[4096]; /* XXX Sloppy. */
181 char locale[64];
182 const char *thename = 0, *p, *q;
183 UBool fromICUData = FALSE;
184
185 arg = getLongPathname(argv[i]);
186
187 if (verbose) {
57a6839d 188 u_fprintf(ustderr, "processing bundle \"%s\"\n", argv[i]);
b75a7d8f
A
189 }
190
191 p = uprv_strrchr(arg, U_FILE_SEP_CHAR);
73c04bcf
A
192#if U_FILE_SEP_CHAR != U_FILE_ALT_SEP_CHAR
193 if (p == NULL) {
194 p = uprv_strrchr(arg, U_FILE_ALT_SEP_CHAR);
195 }
196#endif
b75a7d8f
A
197 if (!p) {
198 p = arg;
199 } else {
73c04bcf 200 p++;
b75a7d8f
A
201 }
202 q = uprv_strrchr(p, '.');
203 if (!q) {
73c04bcf
A
204 for (q = p; *q; ++q)
205 ;
b75a7d8f
A
206 }
207 uprv_strncpy(locale, p, q - p);
208 locale[q - p] = 0;
209
210 if (!(fromICUData = !uprv_strcmp(inputDir, "-"))) {
211 UBool absfilename = *arg == U_FILE_SEP_CHAR;
4388f060 212#if U_PLATFORM_HAS_WIN32_API
b75a7d8f
A
213 if (!absfilename) {
214 absfilename = (uprv_strlen(arg) > 2 && isalpha(arg[0])
73c04bcf 215 && arg[1] == ':' && arg[2] == U_FILE_SEP_CHAR);
b75a7d8f
A
216 }
217#endif
218 if (absfilename) {
219 thename = arg;
220 } else {
73c04bcf
A
221 q = uprv_strrchr(arg, U_FILE_SEP_CHAR);
222#if U_FILE_SEP_CHAR != U_FILE_ALT_SEP_CHAR
223 if (q == NULL) {
224 q = uprv_strrchr(arg, U_FILE_ALT_SEP_CHAR);
225 }
226#endif
227 uprv_strcpy(infile, inputDir);
228 if(q != NULL) {
229 uprv_strcat(infile, U_FILE_SEP_STRING);
230 strncat(infile, arg, q-arg);
231 }
232 thename = infile;
b75a7d8f
A
233 }
234 }
235 status = U_ZERO_ERROR;
236 if (thename) {
237 bundle = ures_openDirect(thename, locale, &status);
238 } else {
239 bundle = ures_open(fromICUData ? 0 : inputDir, locale, &status);
240 }
241 if (status == U_ZERO_ERROR) {
57a6839d 242 UFILE *out = NULL;
b75a7d8f
A
243
244 const char *filename = 0;
245 const char *ext = 0;
246
729e4ab9 247 if (!locale[0] || !tostdout) {
b75a7d8f
A
248 filename = uprv_strrchr(arg, U_FILE_SEP_CHAR);
249
73c04bcf 250#if U_FILE_SEP_CHAR != U_FILE_ALT_SEP_CHAR
b75a7d8f 251 if (!filename) {
73c04bcf 252 filename = uprv_strrchr(arg, U_FILE_ALT_SEP_CHAR);
b75a7d8f
A
253 }
254#endif
255 if (!filename) {
256 filename = arg;
257 } else {
258 ++filename;
259 }
260 ext = uprv_strrchr(arg, '.');
261 if (!ext) {
262 ext = filename + uprv_strlen(filename);
263 }
264 }
265
266 if (tostdout) {
57a6839d 267 out = u_get_stdout();
b75a7d8f
A
268 } else {
269 char thefile[4096], *tp;
270 int32_t len;
271
272 if (outputDir) {
273 uprv_strcpy(thefile, outputDir);
274 uprv_strcat(thefile, U_FILE_SEP_STRING);
275 } else {
276 *thefile = 0;
277 }
278 uprv_strcat(thefile, filename);
279 tp = thefile + uprv_strlen(thefile);
280 len = (int32_t)uprv_strlen(ext);
281 if (len) {
282 tp -= len - 1;
283 } else {
284 *tp++ = '.';
285 }
286 uprv_strcpy(tp, "txt");
287
57a6839d 288 out = u_fopen(thefile, "w", NULL, encoding);
b75a7d8f 289 if (!out) {
57a6839d
A
290 u_fprintf(ustderr, "%s: couldn't create %s\n", pname, thefile);
291 u_fclose(ustderr);
292 return 4;
b75a7d8f
A
293 }
294 }
295
57a6839d
A
296 // now, set the callback.
297 ucnv_setFromUCallBack(u_fgetConverter(out), UCNV_FROM_U_CALLBACK_ESCAPE, UCNV_ESCAPE_C, 0, 0, &status);
298 if (U_FAILURE(status)) {
299 u_fprintf(ustderr, "%s: couldn't configure converter for encoding\n", pname);
300 u_fclose(ustderr);
301 if(!tostdout) {
302 u_fclose(out);
303 }
304 return 3;
b75a7d8f
A
305 }
306
57a6839d
A
307 if (prbom) { /* XXX: Should be done only for UTFs */
308 u_fputc(0xFEFF, out);
309 }
310 u_fprintf(out, "// -*- Coding: %s; -*-\n//\n", encoding ? encoding : getEncodingName(ucnv_getDefaultName()));
311 u_fprintf(out, "// This file was dumped by derb(8) from ");
b75a7d8f 312 if (thename) {
57a6839d 313 u_fprintf(out, "%s", thename);
b75a7d8f 314 } else if (fromICUData) {
57a6839d 315 u_fprintf(out, "the ICU internal %s locale", locale);
b75a7d8f
A
316 }
317
57a6839d 318 u_fprintf(out, "\n// derb(8) by Vladimir Weinstein and Yves Arrouye\n\n");
b75a7d8f 319
729e4ab9 320 if (locale[0]) {
57a6839d 321 u_fprintf(out, "%s", locale);
b75a7d8f 322 } else {
57a6839d 323 u_fprintf(out, "%.*s%.*S", (int32_t)(ext - filename), filename, (int32_t)(sizeof(sp)/sizeof(*sp)), sp);
b75a7d8f
A
324 }
325 printOutBundle(out, converter, bundle, 0, pname, &status);
326
57a6839d
A
327 if (!tostdout) {
328 u_fclose(out);
b75a7d8f 329 }
73c04bcf
A
330 }
331 else {
b75a7d8f
A
332 reportError(pname, &status, "opening resource file");
333 }
334
335 ures_close(bundle);
336 }
337
b75a7d8f
A
338 ucnv_close(converter);
339
340 return 0;
341}
342
343static UChar *quotedString(const UChar *string) {
344 int len = u_strlen(string);
345 int alen = len;
346 const UChar *sp;
347 UChar *newstr, *np;
348
349 for (sp = string; *sp; ++sp) {
350 switch (*sp) {
351 case '\n':
352 case 0x0022:
353 ++alen;
354 break;
355 }
356 }
357
358 newstr = (UChar *) uprv_malloc((1 + alen) * sizeof(*newstr));
359 for (sp = string, np = newstr; *sp; ++sp) {
360 switch (*sp) {
361 case '\n':
362 *np++ = 0x005C;
363 *np++ = 0x006E;
364 break;
365
366 case 0x0022:
367 *np++ = 0x005C;
368
369 default:
370 *np++ = *sp;
371 break;
372 }
373 }
374 *np = 0;
375
376 return newstr;
377}
378
379
57a6839d
A
380static void printString(UFILE *out, UConverter *converter, const UChar *str, int32_t len) {
381 u_file_write(str, len, out);
b75a7d8f
A
382}
383
57a6839d
A
384static void printCString(UFILE *out, UConverter *converter, const char *str, int32_t len) {
385 if(len==-1) {
386 u_fprintf(out, "%s", str);
387 } else {
388 u_fprintf(out, "%.*s", len, str);
389 }
b75a7d8f
A
390}
391
57a6839d 392static void printIndent(UFILE *out, UConverter *converter, int32_t indent) {
b75a7d8f
A
393 UChar inchar[256];
394 int32_t i = 0;
395 for(i = 0; i<indent; i++) {
396 inchar[i] = 0x0020;
397 }
398 inchar[indent] = 0;
399
400 printString(out, converter, inchar, indent);
401}
402
57a6839d 403static void printHex(UFILE *out, UConverter *converter, uint8_t what) {
b75a7d8f
A
404 static const char map[] = "0123456789ABCDEF";
405 UChar hex[2];
406
407 hex[0] = map[what >> 4];
408 hex[1] = map[what & 0xf];
409
410 printString(out, converter, hex, (int32_t)(sizeof(hex)/sizeof(*hex)));
411}
b75a7d8f 412
57a6839d 413static void printOutAlias(UFILE *out, UConverter *converter, UResourceBundle *parent, Resource r, const char *key, int32_t indent, const char *pname, UErrorCode *status) {
b75a7d8f
A
414 static const UChar cr[] = { '\n' };
415 int32_t len = 0;
729e4ab9 416 const UChar* thestr = res_getAlias(&(parent->fResData), r, &len);
b75a7d8f 417 UChar *string = quotedString(thestr);
51004dcb 418 if(opt_truncate && len > truncsize) {
b75a7d8f
A
419 char msg[128];
420 printIndent(out, converter, indent);
421 sprintf(msg, "// WARNING: this resource, size %li is truncated to %li\n",
422 (long)len, (long)truncsize/2);
423 printCString(out, converter, msg, -1);
424 len = truncsize;
425 }
426 if(U_SUCCESS(*status)) {
374ca955
A
427 static const UChar openStr[] = { 0x003A, 0x0061, 0x006C, 0x0069, 0x0061, 0x0073, 0x0020, 0x007B, 0x0020, 0x0022 }; /* ":alias { \"" */
428 static const UChar closeStr[] = { 0x0022, 0x0020, 0x007D, 0x0020 }; /* "\" } " */
b75a7d8f
A
429 printIndent(out, converter, indent);
430 if(key != NULL) {
431 printCString(out, converter, key, -1);
432 }
374ca955 433 printString(out, converter, openStr, (int32_t)(sizeof(openStr) / sizeof(*openStr)));
b75a7d8f 434 printString(out, converter, string, len);
374ca955 435 printString(out, converter, closeStr, (int32_t)(sizeof(closeStr) / sizeof(*closeStr)));
b75a7d8f
A
436 if(verbose) {
437 printCString(out, converter, " // ALIAS", -1);
438 }
439 printString(out, converter, cr, (int32_t)(sizeof(cr) / sizeof(*cr)));
440 } else {
441 reportError(pname, status, "getting binary value");
442 }
46f4442e 443 uprv_free(string);
b75a7d8f
A
444}
445
57a6839d 446static void printOutBundle(UFILE *out, UConverter *converter, UResourceBundle *resource, int32_t indent, const char *pname, UErrorCode *status)
b75a7d8f
A
447{
448 static const UChar cr[] = { '\n' };
449
450/* int32_t noOfElements = ures_getSize(resource);*/
451 int32_t i = 0;
452 const char *key = ures_getKey(resource);
453
454 switch(ures_getType(resource)) {
729e4ab9 455 case URES_STRING :
b75a7d8f
A
456 {
457 int32_t len=0;
458 const UChar* thestr = ures_getString(resource, &len, status);
46f4442e 459 UChar *string = quotedString(thestr);
b75a7d8f
A
460
461 /* TODO: String truncation */
51004dcb 462 if(opt_truncate && len > truncsize) {
b75a7d8f
A
463 char msg[128];
464 printIndent(out, converter, indent);
465 sprintf(msg, "// WARNING: this resource, size %li is truncated to %li\n",
466 (long)len, (long)(truncsize/2));
467 printCString(out, converter, msg, -1);
468 len = truncsize/2;
469 }
470 printIndent(out, converter, indent);
471 if(key != NULL) {
374ca955
A
472 static const UChar openStr[] = { 0x0020, 0x007B, 0x0020, 0x0022 }; /* " { \"" */
473 static const UChar closeStr[] = { 0x0022, 0x0020, 0x007D }; /* "\" }" */
b75a7d8f 474 printCString(out, converter, key, (int32_t)uprv_strlen(key));
374ca955 475 printString(out, converter, openStr, (int32_t)(sizeof(openStr)/sizeof(*openStr)));
b75a7d8f 476 printString(out, converter, string, len);
374ca955 477 printString(out, converter, closeStr, (int32_t)(sizeof(closeStr) / sizeof(*closeStr)));
b75a7d8f 478 } else {
374ca955
A
479 static const UChar openStr[] = { 0x0022 }; /* "\"" */
480 static const UChar closeStr[] = { 0x0022, 0x002C }; /* "\"," */
b75a7d8f 481
374ca955 482 printString(out, converter, openStr, (int32_t)(sizeof(openStr) / sizeof(*openStr)));
b75a7d8f 483 printString(out, converter, string, (int32_t)(u_strlen(string)));
374ca955 484 printString(out, converter, closeStr, (int32_t)(sizeof(closeStr) / sizeof(*closeStr)));
b75a7d8f
A
485 }
486
487 if(verbose) {
488 printCString(out, converter, "// STRING", -1);
489 }
490 printString(out, converter, cr, (int32_t)(sizeof(cr) / sizeof(*cr)));
491
492 uprv_free(string);
493 }
494 break;
495
729e4ab9 496 case URES_INT :
b75a7d8f 497 {
374ca955
A
498 static const UChar openStr[] = { 0x003A, 0x0069, 0x006E, 0x0074, 0x0020, 0x007B, 0x0020 }; /* ":int { " */
499 static const UChar closeStr[] = { 0x0020, 0x007D }; /* " }" */
b75a7d8f
A
500 UChar num[20];
501
502 printIndent(out, converter, indent);
503 if(key != NULL) {
504 printCString(out, converter, key, -1);
505 }
374ca955 506 printString(out, converter, openStr, (int32_t)(sizeof(openStr) / sizeof(*openStr)));
b75a7d8f
A
507 uprv_itou(num, 20, ures_getInt(resource, status), 10, 0);
508 printString(out, converter, num, u_strlen(num));
374ca955 509 printString(out, converter, closeStr, (int32_t)(sizeof(closeStr) / sizeof(*closeStr)));
b75a7d8f
A
510
511 if(verbose) {
512 printCString(out, converter, "// INT", -1);
513 }
514 printString(out, converter, cr, (int32_t)(sizeof(cr) / sizeof(*cr)));
515 break;
516 }
729e4ab9 517 case URES_BINARY :
b75a7d8f
A
518 {
519 int32_t len = 0;
520 const int8_t *data = (const int8_t *)ures_getBinary(resource, &len, status);
51004dcb 521 if(opt_truncate && len > truncsize) {
b75a7d8f
A
522 char msg[128];
523 printIndent(out, converter, indent);
524 sprintf(msg, "// WARNING: this resource, size %li is truncated to %li\n",
525 (long)len, (long)(truncsize/2));
526 printCString(out, converter, msg, -1);
527 len = truncsize;
528 }
529 if(U_SUCCESS(*status)) {
374ca955
A
530 static const UChar openStr[] = { 0x003A, 0x0062, 0x0069, 0x006E, 0x0061, 0x0072, 0x0079, 0x0020, 0x007B, 0x0020 }; /* ":binary { " */
531 static const UChar closeStr[] = { 0x0020, 0x007D, 0x0020 }; /* " } " */
b75a7d8f
A
532 printIndent(out, converter, indent);
533 if(key != NULL) {
534 printCString(out, converter, key, -1);
535 }
374ca955 536 printString(out, converter, openStr, (int32_t)(sizeof(openStr) / sizeof(*openStr)));
b75a7d8f
A
537 for(i = 0; i<len; i++) {
538 printHex(out, converter, *data++);
539 }
374ca955 540 printString(out, converter, closeStr, (int32_t)(sizeof(closeStr) / sizeof(*closeStr)));
b75a7d8f
A
541 if(verbose) {
542 printCString(out, converter, " // BINARY", -1);
543 }
544 printString(out, converter, cr, (int32_t)(sizeof(cr) / sizeof(*cr)));
545 } else {
546 reportError(pname, status, "getting binary value");
547 }
548 }
549 break;
729e4ab9 550 case URES_INT_VECTOR :
b75a7d8f
A
551 {
552 int32_t len = 0;
553 const int32_t *data = ures_getIntVector(resource, &len, status);
554 if(U_SUCCESS(*status)) {
374ca955
A
555 static const UChar openStr[] = { 0x003A, 0x0069, 0x006E, 0x0074, 0x0076, 0x0065, 0x0063, 0x0074, 0x006F, 0x0072, 0x0020, 0x007B, 0x0020 }; /* ":intvector { " */
556 static const UChar closeStr[] = { 0x0020, 0x007D, 0x0020 }; /* " } " */
b75a7d8f
A
557 UChar num[20];
558
559 printIndent(out, converter, indent);
560 if(key != NULL) {
561 printCString(out, converter, key, -1);
562 }
374ca955 563 printString(out, converter, openStr, (int32_t)(sizeof(openStr) / sizeof(*openStr)));
b75a7d8f
A
564 for(i = 0; i < len - 1; i++) {
565 int32_t numLen = uprv_itou(num, 20, data[i], 10, 0);
566 num[numLen++] = 0x002C; /* ',' */
567 num[numLen++] = 0x0020; /* ' ' */
568 num[numLen] = 0;
569 printString(out, converter, num, u_strlen(num));
570 }
571 if(len > 0) {
572 uprv_itou(num, 20, data[len - 1], 10, 0);
573 printString(out, converter, num, u_strlen(num));
574 }
374ca955 575 printString(out, converter, closeStr, (int32_t)(sizeof(closeStr) / sizeof(*closeStr)));
b75a7d8f
A
576 if(verbose) {
577 printCString(out, converter, "// INTVECTOR", -1);
578 }
579 printString(out, converter, cr, (int32_t)(sizeof(cr) / sizeof(*cr)));
580 } else {
581 reportError(pname, status, "getting int vector");
582 }
583 }
584 break;
729e4ab9
A
585 case URES_TABLE :
586 case URES_ARRAY :
b75a7d8f 587 {
374ca955
A
588 static const UChar openStr[] = { 0x007B }; /* "{" */
589 static const UChar closeStr[] = { 0x007D, '\n' }; /* "}\n" */
b75a7d8f
A
590
591 UResourceBundle *t = NULL;
592 ures_resetIterator(resource);
593 printIndent(out, converter, indent);
594 if(key != NULL) {
595 printCString(out, converter, key, -1);
596 }
374ca955 597 printString(out, converter, openStr, (int32_t)(sizeof(openStr) / sizeof(*openStr)));
b75a7d8f 598 if(verbose) {
729e4ab9 599 if(ures_getType(resource) == URES_TABLE) {
b75a7d8f
A
600 printCString(out, converter, "// TABLE", -1);
601 } else {
602 printCString(out, converter, "// ARRAY", -1);
603 }
604 }
605 printString(out, converter, cr, (int32_t)(sizeof(cr) / sizeof(*cr)));
606
607 if(suppressAliases == FALSE) {
608 while(U_SUCCESS(*status) && ures_hasNext(resource)) {
609 t = ures_getNextResource(resource, t, status);
610 if(U_SUCCESS(*status)) {
611 printOutBundle(out, converter, t, indent+indentsize, pname, status);
612 } else {
613 reportError(pname, status, "While processing table");
614 *status = U_ZERO_ERROR;
615 }
616 }
617 } else { /* we have to use low level access to do this */
729e4ab9
A
618 Resource r;
619 int32_t resSize = ures_getSize(resource);
620 UBool isTable = (UBool)(ures_getType(resource) == URES_TABLE);
621 for(i = 0; i < resSize; i++) {
b75a7d8f 622 /* need to know if it's an alias */
729e4ab9
A
623 if(isTable) {
624 r = res_getTableItemByIndex(&resource->fResData, resource->fRes, i, &key);
b75a7d8f 625 } else {
729e4ab9 626 r = res_getArrayItem(&resource->fResData, resource->fRes, i);
b75a7d8f
A
627 }
628 if(U_SUCCESS(*status)) {
729e4ab9 629 if(res_getPublicType(r) == URES_ALIAS) {
b75a7d8f
A
630 printOutAlias(out, converter, resource, r, key, indent+indentsize, pname, status);
631 } else {
632 t = ures_getByIndex(resource, i, t, status);
633 printOutBundle(out, converter, t, indent+indentsize, pname, status);
634 }
635 } else {
636 reportError(pname, status, "While processing table");
637 *status = U_ZERO_ERROR;
638 }
639 }
640 }
641
642 printIndent(out, converter, indent);
374ca955 643 printString(out, converter, closeStr, (int32_t)(sizeof(closeStr) / sizeof(*closeStr)));
b75a7d8f
A
644 ures_close(t);
645 }
646 break;
647 default:
648 break;
649 }
650
651}
652
653static const char *getEncodingName(const char *encoding) {
654 UErrorCode err;
655 const char *enc;
656
657 err = U_ZERO_ERROR;
658 if (!(enc = ucnv_getStandardName(encoding, "MIME", &err))) {
659 err = U_ZERO_ERROR;
660 if (!(enc = ucnv_getStandardName(encoding, "IANA", &err))) {
661 ;
662 }
663 }
664
665 return enc;
666}
667
668static void reportError(const char *pname, UErrorCode *status, const char *when) {
57a6839d 669 u_fprintf(ustderr, "%s: error %d while %s: %s\n", pname, *status, when, u_errorName(*status));
b75a7d8f
A
670}
671
57a6839d
A
672#else
673extern int
674main(int argc, char* argv[]) {
675 /* Changing stdio.h ustdio.h requires that formatting not be disabled. */
676 return 3;
677}
678#endif /* !UCONFIG_NO_FORMATTING */
679
b75a7d8f
A
680/*
681 * Local Variables:
682 * indent-tabs-mode: nil
683 * End:
684 */