1 // © 2016 and later: Unicode, Inc. and others.
2 // License & terms of use: http://www.unicode.org/copyright.html
4 *******************************************************************************
6 * Copyright (C) 1999-2016, International Business Machines
7 * Corporation and others. All Rights Reserved.
9 *******************************************************************************
10 * file name: icuinfo.cpp
12 * tab size: 8 (not used)
15 * created on: 2009-2010
16 * created by: Steven R. Loomis
18 * This program shows some basic info about the current ICU.
23 #include "unicode/utypes.h"
24 #include "unicode/putil.h"
25 #include "unicode/uclean.h"
32 #include "icuplugimp.h"
33 #include <unicode/uloc.h>
34 #include <unicode/ucnv.h>
35 #include "unicode/ucal.h"
36 #include <unicode/ulocdata.h>
38 #include "unicode/uchar.h"
40 static UOption options
[]={
42 /*1*/ UOPTION_HELP_QUESTION_MARK
,
43 /*2*/ UOPTION_ICUDATADIR
,
44 /*3*/ UOPTION_VERBOSE
,
45 /*4*/ UOPTION_DEF("list-plugins", 'L', UOPT_NO_ARG
), // may be a no-op if disabled
46 /*5*/ UOPTION_DEF("milisecond-time", 'm', UOPT_NO_ARG
),
47 /*6*/ UOPTION_DEF("cleanup", 'K', UOPT_NO_ARG
),
48 /*7*/ UOPTION_DEF("xml", 'x', UOPT_REQUIRES_ARG
),
49 /*8*/ UOPTION_DEF("perf", 'p', UOPT_NO_ARG
), // Apple
52 static UErrorCode initStatus
= U_ZERO_ERROR
;
53 static UBool icuInitted
= FALSE
;
55 static void do_init() {
62 static void cmd_perf(); // Apple
66 printf("Milliseconds since Epoch: %.0f\n", uprv_getUTCtime());
69 void cmd_version(UBool
/* noLoad */, UErrorCode
&errorCode
)
74 udbg_writeIcuInfo(stdout
); /* print the XML format */
81 if(U_IS_BIG_ENDIAN
==u
.byte
) {
82 //printf("U_IS_BIG_ENDIAN: %d\n", U_IS_BIG_ENDIAN);
84 fprintf(stderr
, " error: U_IS_BIG_ENDIAN=%d != %d=actual 'is big endian'\n",
85 U_IS_BIG_ENDIAN
, u
.byte
);
86 errorCode
=U_INTERNAL_PROGRAM_ERROR
;
90 // Ignore warning 4127, conditional expression is constant. This is intentional below.
92 #pragma warning(disable: 4127)
95 if(U_SIZEOF_WCHAR_T
==sizeof(wchar_t)) {
96 //printf("U_SIZEOF_WCHAR_T: %d\n", U_SIZEOF_WCHAR_T);
98 fprintf(stderr
, " error: U_SIZEOF_WCHAR_T=%d != %d=sizeof(wchar_t)\n",
99 U_SIZEOF_WCHAR_T
, (int)sizeof(wchar_t));
100 errorCode
=U_INTERNAL_PROGRAM_ERROR
;
105 charsetFamily
=U_ASCII_FAMILY
;
106 } else if('A'==0xc1) {
107 charsetFamily
=U_EBCDIC_FAMILY
;
109 charsetFamily
=-1; // unknown
111 if(U_CHARSET_FAMILY
==charsetFamily
) {
112 //printf("U_CHARSET_FAMILY: %d\n", U_CHARSET_FAMILY);
114 fprintf(stderr
, " error: U_CHARSET_FAMILY=%d != %d=actual charset family\n",
115 U_CHARSET_FAMILY
, charsetFamily
);
116 errorCode
=U_INTERNAL_PROGRAM_ERROR
;
119 #if defined(_MSC_VER)
123 printf("\n\nICU Initialization returned: %s\n", u_errorName(initStatus
));
126 #if UCONFIG_ENABLE_PLUGINS
128 const char *pluginFile
= uplug_getPluginFile();
129 printf("Plugin file is: %s\n", (pluginFile
&&*pluginFile
)?pluginFile
:"(not set. try setting ICU_PLUGINS to a directory.)");
131 fprintf(stderr
, "Dynamic Loading: is disabled. No plugins will be loaded at start-up.\n");
134 fprintf(stderr
, "Plugins are disabled.\n");
141 fprintf(stdout
, "ICU u_cleanup() called.\n");
145 void cmd_listplugins() {
146 #if UCONFIG_ENABLE_PLUGINS
151 printf("ICU Initialized: u_init() returned %s\n", u_errorName(initStatus
));
153 printf("Plugins: \n");
154 printf( "# %6s %s \n",
157 printf( " %10s:%-10s\n",
163 printf( " config| (configuration string)\n");
164 printf( " >>> Error | Explanation \n");
165 printf( "-----------------------------------\n");
167 for(i
=0;(plug
=uplug_getPlugInternal(i
))!=NULL
;i
++) {
168 UErrorCode libStatus
= U_ZERO_ERROR
;
169 const char *name
= uplug_getPlugName(plug
);
170 const char *sym
= uplug_getSymbolName(plug
);
171 const char *lib
= uplug_getLibraryName(plug
, &libStatus
);
172 const char *config
= uplug_getConfiguration(plug
);
173 UErrorCode loadStatus
= uplug_getPlugLoadStatus(plug
);
174 const char *message
= NULL
;
176 printf("\n#%d %-6s %s \n",
178 udbg_enumName(UDBG_UPlugLevel
,(int32_t)uplug_getPlugLevel(plug
)),
179 name
!=NULL
?(*name
?name
:"this plugin did not call uplug_setPlugName()"):"(null)"
181 printf(" plugin| %10s:%-10s\n",
182 (U_SUCCESS(libStatus
)?(lib
!=NULL
?lib
:"(null)"):u_errorName(libStatus
)),
183 sym
!=NULL
?sym
:"(null)"
186 if(config
!=NULL
&&*config
) {
187 printf(" config| %s\n", config
);
191 case U_PLUGIN_CHANGED_LEVEL_WARNING
:
192 message
= "Note: This plugin changed the system level (by allocating memory or calling something which does). Later plugins may not load.";
195 case U_PLUGIN_DIDNT_SET_LEVEL
:
196 message
= "Error: This plugin did not call uplug_setPlugLevel during QUERY.";
199 case U_PLUGIN_TOO_HIGH
:
200 message
= "Error: This plugin couldn't load because the system level was too high. Try loading this plugin earlier.";
204 message
= NULL
; /* no message */
207 if(U_FAILURE(loadStatus
)) {
208 message
= "error loading:";
210 message
= "warning during load:";
215 printf("\\\\\\ status| %s\n"
216 "/// %s\n", u_errorName(loadStatus
), message
);
221 printf("No plugins loaded.\n");
229 main(int argc
, char* argv
[]) {
230 UErrorCode errorCode
= U_ZERO_ERROR
;
231 UBool didSomething
= FALSE
;
233 /* preset then read command line options */
234 argc
=u_parseArgs(argc
, argv
, UPRV_LENGTHOF(options
), options
);
236 /* error handling, printing usage message */
239 "error in command line argument \"%s\"\n",
242 if( options
[0].doesOccur
|| options
[1].doesOccur
) {
243 fprintf(stderr
, "%s: Output information about the current ICU\n", argv
[0]);
244 fprintf(stderr
, "Options:\n"
245 " -h or --help - Print this help message.\n"
246 " -m or --millisecond-time - Print the current UTC time in milliseconds.\n"
247 " -d <dir> or --icudatadir <dir> - Set the ICU Data Directory\n"
248 " -v - Print version and configuration information about ICU\n"
249 #if UCONFIG_ENABLE_PLUGINS
250 " -L or --list-plugins - List and diagnose issues with ICU Plugins\n"
252 " -K or --cleanup - Call u_cleanup() before exitting (will attempt to unload plugins)\n"
253 " -p or --perf - Perf tests (Apple)\n"
255 "If no arguments are given, the tool will print ICU version and configuration information.\n"
257 fprintf(stderr
, "International Components for Unicode %s\n%s\n", U_ICU_VERSION
, U_COPYRIGHT_STRING
);
258 return argc
<0 ? U_ILLEGAL_ARGUMENT_ERROR
: U_ZERO_ERROR
;
261 if(options
[2].doesOccur
) {
262 u_setDataDirectory(options
[2].value
);
265 if(options
[5].doesOccur
) {
269 if(options
[4].doesOccur
) {
274 if(options
[3].doesOccur
) {
275 cmd_version(FALSE
, errorCode
);
279 if(options
[7].doesOccur
) { /* 2nd part of version: cleanup */
280 FILE *out
= fopen(options
[7].value
, "w");
282 fprintf(stderr
,"ERR: can't write to XML file %s\n", options
[7].value
);
285 /* todo: API for writing DTD? */
286 fprintf(out
, "<?xml version=\"1.0\" encoding=\"UTF-8\" ?>\n");
287 udbg_writeIcuInfo(out
);
292 if(options
[6].doesOccur
) { /* 2nd part of version: cleanup */
297 if(options
[8].doesOccur
) { // Apple
303 cmd_version(FALSE
, errorCode
); /* at least print the version # */
306 return U_FAILURE(errorCode
);
309 #if defined(__APPLE__) && defined(__MACH__)
312 #include <mach/mach_time.h>
313 #include <unicode/ustring.h>
314 #include <unicode/udat.h>
315 enum { kUCharsOutMax
= 128, kBytesOutMax
= 256 };
317 static void cmd_perf() {
318 static const char* locale
= "en_US";
319 static const UChar
* tzName
= (const UChar
*)u
"America/Los_Angeles";
320 static const UDate udatTry1
= 1290714600000.0; // 2010 Nov. 25 (Thurs) 11:50:00 AM PT
321 static const UDate udatTry2
= 1451736016000.0; // 2016 Jan. 02 ...
323 mach_timebase_info_data_t info
;
324 mach_timebase_info(&info
);
325 while (remaining
-- > 0) {
326 uint64_t start
, durationOpen
, durationUse1
, durationUse2
;
327 UDateFormat
*udatfmt
;
328 int32_t datlen1
, datlen2
;
329 UChar outUChars
[kUCharsOutMax
];
330 UErrorCode status
= U_ZERO_ERROR
;
332 start
= mach_absolute_time();
333 udatfmt
= udat_open(UDAT_MEDIUM
, UDAT_FULL
, locale
, tzName
, -1, NULL
, 0, &status
);
334 durationOpen
= ((mach_absolute_time() - start
) * info
.numer
)/info
.denom
;
335 if ( U_SUCCESS(status
) ) {
336 start
= mach_absolute_time();
337 datlen1
= udat_format(udatfmt
, udatTry1
, outUChars
, kUCharsOutMax
, NULL
, &status
);
338 durationUse1
= ((mach_absolute_time() - start
) * info
.numer
)/info
.denom
;
340 start
= mach_absolute_time();
341 datlen2
= udat_format(udatfmt
, udatTry2
, outUChars
, kUCharsOutMax
, NULL
, &status
);
342 durationUse2
= ((mach_absolute_time() - start
) * info
.numer
)/info
.denom
;
344 if ( U_SUCCESS(status
) ) {
345 printf("first time %d udat open, fmt1(len %d), fmt2(len %d) nsec:\t%llu\t%llu\t%llu\n", remaining
, datlen1
, datlen2
, durationOpen
, durationUse1
, durationUse2
);
347 printf("first time %d udat_format failed\n", remaining
);
351 printf("first time %d udat_open failed\n", remaining
);
356 static void cmd_perf() {
357 printf("This feature is unsupported on this platform\n");