ICU 68.2  68.2
utrace.h
Go to the documentation of this file.
1 // © 2016 and later: Unicode, Inc. and others.
2 // License & terms of use: http://www.unicode.org/copyright.html
3 /*
4 *******************************************************************************
5 *
6 * Copyright (C) 2003-2013, International Business Machines
7 * Corporation and others. All Rights Reserved.
8 *
9 *******************************************************************************
10 * file name: utrace.h
11 * encoding: UTF-8
12 * tab size: 8 (not used)
13 * indentation:4
14 *
15 * created on: 2003aug06
16 * created by: Markus W. Scherer
17 *
18 * Definitions for ICU tracing/logging.
19 *
20 */
21 
22 #ifndef __UTRACE_H__
23 #define __UTRACE_H__
24 
25 #include <stdarg.h>
26 #include "unicode/utypes.h"
27 
40 
46 typedef enum UTraceLevel {
60 
65 typedef enum UTraceFunctionNumber {
66  UTRACE_FUNCTION_START=0,
67  UTRACE_U_INIT=UTRACE_FUNCTION_START,
68  UTRACE_U_CLEANUP,
69 
70 #ifndef U_HIDE_DEPRECATED_API
71 
76 #endif // U_HIDE_DEPRECATED_API
77 
78  UTRACE_CONVERSION_START=0x1000,
79  UTRACE_UCNV_OPEN=UTRACE_CONVERSION_START,
80  UTRACE_UCNV_OPEN_PACKAGE,
81  UTRACE_UCNV_OPEN_ALGORITHMIC,
82  UTRACE_UCNV_CLONE,
83  UTRACE_UCNV_CLOSE,
84  UTRACE_UCNV_FLUSH_CACHE,
85  UTRACE_UCNV_LOAD,
86  UTRACE_UCNV_UNLOAD,
87 
88 #ifndef U_HIDE_DEPRECATED_API
89 
94 #endif // U_HIDE_DEPRECATED_API
95 
96  UTRACE_COLLATION_START=0x2000,
97  UTRACE_UCOL_OPEN=UTRACE_COLLATION_START,
98  UTRACE_UCOL_CLOSE,
99  UTRACE_UCOL_STRCOLL,
100  UTRACE_UCOL_GET_SORTKEY,
101  UTRACE_UCOL_GETLOCALE,
102  UTRACE_UCOL_NEXTSORTKEYPART,
103  UTRACE_UCOL_STRCOLLITER,
104  UTRACE_UCOL_OPEN_FROM_SHORT_STRING,
107 #ifndef U_HIDE_DEPRECATED_API
108 
113 #endif // U_HIDE_DEPRECATED_API
114 
120 
137 
145 
154 
167 
168 #ifndef U_HIDE_INTERNAL_API
169 
174 #endif // U_HIDE_INTERNAL_API
175 
176 #ifndef U_HIDE_DRAFT_API
177 
182 
189 
196 
206 
213 
220 
230 
231 #endif // U_HIDE_DRAFT_API
232 
233 #ifndef U_HIDE_INTERNAL_API
234 
239 #endif // U_HIDE_INTERNAL_API
240 
242 
248 U_CAPI void U_EXPORT2
249 utrace_setLevel(int32_t traceLevel);
250 
256 U_CAPI int32_t U_EXPORT2
258 
259 /* Trace function pointers types ----------------------------- */
260 
267 typedef void U_CALLCONV
268 UTraceEntry(const void *context, int32_t fnNumber);
269 
283 typedef void U_CALLCONV
284 UTraceExit(const void *context, int32_t fnNumber,
285  const char *fmt, va_list args);
286 
298 typedef void U_CALLCONV
299 UTraceData(const void *context, int32_t fnNumber, int32_t level,
300  const char *fmt, va_list args);
301 
330 U_CAPI void U_EXPORT2
331 utrace_setFunctions(const void *context,
332  UTraceEntry *e, UTraceExit *x, UTraceData *d);
333 
344 U_CAPI void U_EXPORT2
345 utrace_getFunctions(const void **context,
346  UTraceEntry **e, UTraceExit **x, UTraceData **d);
347 
348 
349 
350 /*
351  *
352  * ICU trace format string syntax
353  *
354  * Format Strings are passed to UTraceData functions, and define the
355  * number and types of the trace data being passed on each call.
356  *
357  * The UTraceData function, which is supplied by the application,
358  * not by ICU, can either forward the trace data (passed via
359  * varargs) and the format string back to ICU for formatting into
360  * a displayable string, or it can interpret the format itself,
361  * and do as it wishes with the trace data.
362  *
363  *
364  * Goals for the format string
365  * - basic data output
366  * - easy to use for trace programmer
367  * - sufficient provision for data types for trace output readability
368  * - well-defined types and binary portable APIs
369  *
370  * Non-goals
371  * - printf compatibility
372  * - fancy formatting
373  * - argument reordering and other internationalization features
374  *
375  * ICU trace format strings contain plain text with argument inserts,
376  * much like standard printf format strings.
377  * Each insert begins with a '%', then optionally contains a 'v',
378  * then exactly one type character.
379  * Two '%' in a row represent a '%' instead of an insert.
380  * The trace format strings need not have \n at the end.
381  *
382  *
383  * Types
384  * -----
385  *
386  * Type characters:
387  * - c A char character in the default codepage.
388  * - s A NUL-terminated char * string in the default codepage.
389  * - S A UChar * string. Requires two params, (ptr, length). Length=-1 for nul term.
390  * - b A byte (8-bit integer).
391  * - h A 16-bit integer. Also a 16 bit Unicode code unit.
392  * - d A 32-bit integer. Also a 20 bit Unicode code point value.
393  * - l A 64-bit integer.
394  * - p A data pointer.
395  *
396  * Vectors
397  * -------
398  *
399  * If the 'v' is not specified, then one item of the specified type
400  * is passed in.
401  * If the 'v' (for "vector") is specified, then a vector of items of the
402  * specified type is passed in, via a pointer to the first item
403  * and an int32_t value for the length of the vector.
404  * Length==-1 means zero or NUL termination. Works for vectors of all types.
405  *
406  * Note: %vS is a vector of (UChar *) strings. The strings must
407  * be nul terminated as there is no way to provide a
408  * separate length parameter for each string. The length
409  * parameter (required for all vectors) is the number of
410  * strings, not the length of the strings.
411  *
412  * Examples
413  * --------
414  *
415  * These examples show the parameters that will be passed to an application's
416  * UTraceData() function for various formats.
417  *
418  * - the precise formatting is up to the application!
419  * - the examples use type casts for arguments only to _show_ the types of
420  * arguments without needing variable declarations in the examples;
421  * the type casts will not be necessary in actual code
422  *
423  * UTraceDataFunc(context, fnNumber, level,
424  * "There is a character %c in the string %s.", // Format String
425  * (char)c, (const char *)s); // varargs parameters
426  * -> There is a character 0x42 'B' in the string "Bravo".
427  *
428  * UTraceDataFunc(context, fnNumber, level,
429  * "Vector of bytes %vb vector of chars %vc",
430  * (const uint8_t *)bytes, (int32_t)bytesLength,
431  * (const char *)chars, (int32_t)charsLength);
432  * -> Vector of bytes
433  * 42 63 64 3f [4]
434  * vector of chars
435  * "Bcd?"[4]
436  *
437  * UTraceDataFunc(context, fnNumber, level,
438  * "An int32_t %d and a whole bunch of them %vd",
439  * (int32_t)-5, (const int32_t *)ints, (int32_t)intsLength);
440  * -> An int32_t 0xfffffffb and a whole bunch of them
441  * fffffffb 00000005 0000010a [3]
442  *
443  */
444 
445 
446 
466 U_CAPI int32_t U_EXPORT2
467 utrace_vformat(char *outBuf, int32_t capacity,
468  int32_t indent, const char *fmt, va_list args);
469 
487 U_CAPI int32_t U_EXPORT2
488 utrace_format(char *outBuf, int32_t capacity,
489  int32_t indent, const char *fmt, ...);
490 
491 
492 
493 /* Trace function numbers --------------------------------------------------- */
494 
504 U_CAPI const char * U_EXPORT2
505 utrace_functionName(int32_t fnNumber);
506 
508 
509 #endif
utrace_setLevel
U_CAPI void utrace_setLevel(int32_t traceLevel)
Setter for the trace level.
UTRACE_UBRK_LIMIT
@ UTRACE_UBRK_LIMIT
One more than the highest normal break iterator trace location.
Definition: utrace.h:238
UTRACE_OFF
@ UTRACE_OFF
Disable all tracing.
Definition: utrace.h:48
utypes.h
Basic definitions for ICU, for both C and C++ APIs.
utrace_getLevel
U_CAPI int32_t utrace_getLevel(void)
Getter for the trace level.
UTRACE_VERBOSE
@ UTRACE_VERBOSE
Trace the maximum number of ICU operations.
Definition: utrace.h:58
utrace_vformat
U_CAPI int32_t utrace_vformat(char *outBuf, int32_t capacity, int32_t indent, const char *fmt, va_list args)
Trace output Formatter.
U_CALLCONV
#define U_CALLCONV
Similar to U_CDECL_BEGIN/U_CDECL_END, this qualifier is necessary in callback function typedefs to ma...
Definition: platform.h:870
UTRACE_UCOL_STRCOLLUTF8
@ UTRACE_UCOL_STRCOLLUTF8
Definition: utrace.h:105
UTRACE_UBRK_START
@ UTRACE_UBRK_START
The lowest break iterator location.
Definition: utrace.h:181
utrace_setFunctions
U_CAPI void utrace_setFunctions(const void *context, UTraceEntry *e, UTraceExit *x, UTraceData *d)
Set ICU Tracing functions.
UTRACE_UDATA_START
@ UTRACE_UDATA_START
The lowest resource/data location.
Definition: utrace.h:119
UTRACE_UBRK_CREATE_SENTENCE
@ UTRACE_UBRK_CREATE_SENTENCE
Indicates that a sentence instance of break iterator was created.
Definition: utrace.h:212
UTRACE_UDATA_BUNDLE
@ UTRACE_UDATA_BUNDLE
Indicates that a resource bundle was opened.
Definition: utrace.h:144
UTRACE_UDATA_RES_FILE
@ UTRACE_UDATA_RES_FILE
Indicates that a *.res file was opened.
Definition: utrace.h:166
UTRACE_CONVERSION_LIMIT
@ UTRACE_CONVERSION_LIMIT
One more than the highest normal collation trace location.
Definition: utrace.h:93
utrace_getFunctions
U_CAPI void utrace_getFunctions(const void **context, UTraceEntry **e, UTraceExit **x, UTraceData **d)
Get the currently installed ICU tracing functions.
utrace_format
U_CAPI int32_t utrace_format(char *outBuf, int32_t capacity, int32_t indent, const char *fmt,...)
Trace output Formatter.
UTRACE_COLLATION_LIMIT
@ UTRACE_COLLATION_LIMIT
One more than the highest normal collation trace location.
Definition: utrace.h:112
UTraceExit
void UTraceExit(const void *context, int32_t fnNumber, const char *fmt, va_list args)
Type signature for the trace function to be called when exiting from a function.
Definition: utrace.h:284
UTRACE_WARNING
@ UTRACE_WARNING
Trace errors and warnings.
Definition: utrace.h:52
UTraceFunctionNumber
UTraceFunctionNumber
These are the ICU functions that will be traced when tracing is enabled.
Definition: utrace.h:65
UTRACE_RES_DATA_LIMIT
@ UTRACE_RES_DATA_LIMIT
One more than the highest normal resource/data trace location.
Definition: utrace.h:173
UTRACE_UDATA_RESOURCE
@ UTRACE_UDATA_RESOURCE
Indicates that a value was read from a resource bundle.
Definition: utrace.h:136
UTRACE_INFO
@ UTRACE_INFO
Trace an intermediate number of ICU operations.
Definition: utrace.h:56
U_CDECL_END
#define U_CDECL_END
This is used to end a declaration of a library private ICU C API.
Definition: umachine.h:86
U_CDECL_BEGIN
#define U_CDECL_BEGIN
This is used to begin a declaration of a library private ICU C API.
Definition: umachine.h:85
UTRACE_UDATA_DATA_FILE
@ UTRACE_UDATA_DATA_FILE
Indicates that a data file was opened, but not *.res files.
Definition: utrace.h:153
UTRACE_UBRK_CREATE_WORD
@ UTRACE_UBRK_CREATE_WORD
Indicates that a word instance of break iterator was created.
Definition: utrace.h:195
utrace_functionName
U_CAPI const char * utrace_functionName(int32_t fnNumber)
Get the name of a function from its trace function number.
UTRACE_UBRK_CREATE_CHARACTER
@ UTRACE_UBRK_CREATE_CHARACTER
Indicates that a character instance of break iterator was created.
Definition: utrace.h:188
UTraceData
void UTraceData(const void *context, int32_t fnNumber, int32_t level, const char *fmt, va_list args)
Type signature for the trace function to be called from within an ICU function to display data or mes...
Definition: utrace.h:299
UTRACE_UBRK_CREATE_LINE
@ UTRACE_UBRK_CREATE_LINE
Indicates that a line instance of break iterator was created.
Definition: utrace.h:205
UTRACE_UBRK_CREATE_TITLE
@ UTRACE_UBRK_CREATE_TITLE
Indicates that a title instance of break iterator was created.
Definition: utrace.h:219
UTRACE_ERROR
@ UTRACE_ERROR
Trace error conditions only.
Definition: utrace.h:50
UTRACE_UBRK_CREATE_BREAK_ENGINE
@ UTRACE_UBRK_CREATE_BREAK_ENGINE
Indicates that an internal dictionary break engine was created.
Definition: utrace.h:229
UTRACE_OPEN_CLOSE
@ UTRACE_OPEN_CLOSE
Trace opens and closes of ICU services.
Definition: utrace.h:54
U_CAPI
#define U_CAPI
This is used to declare a function as a public ICU C API.
Definition: umachine.h:110
UTraceLevel
UTraceLevel
Trace severity levels.
Definition: utrace.h:46
UTraceEntry
void UTraceEntry(const void *context, int32_t fnNumber)
Type signature for the trace function to be called when entering a function.
Definition: utrace.h:268
UTRACE_FUNCTION_LIMIT
@ UTRACE_FUNCTION_LIMIT
One more than the highest normal collation trace location.
Definition: utrace.h:75