• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2 **********************************************************************
3 * Copyright (c) 2002-2011, International Business Machines
4 * Corporation and others.  All Rights Reserved.
5 **********************************************************************
6 **********************************************************************
7 */
8 #ifndef _NORMPERF_H
9 #define _NORMPERF_H
10 
11 #include "unicode/unorm.h"
12 #include "unicode/ustring.h"
13 
14 #include "unicode/uperf.h"
15 #include <stdlib.h>
16 
17 //  Stubs for Windows API functions when building on UNIXes.
18 //
19 #if U_PLATFORM_USES_ONLY_WIN32_API
20 // do nothing
21 #else
22 #define _UNICODE
23 typedef int DWORD;
24 inline int FoldStringW(DWORD dwMapFlags, const UChar* lpSrcStr,int cchSrc, UChar* lpDestStr,int cchDest);
25 #endif
26 
27 #define DEST_BUFFER_CAPACITY 6000
28 typedef int32_t (*NormFn)(const UChar* src,int32_t srcLen, UChar* dest,int32_t dstLen, int32_t options, UErrorCode* status);
29 typedef int32_t (*QuickCheckFn)(const UChar* src,int32_t srcLen, UNormalizationMode mode, int32_t options, UErrorCode* status);
30 
31 class QuickCheckPerfFunction : public UPerfFunction{
32 private:
33     ULine* lines;
34     int32_t numLines;
35     QuickCheckFn fn;
36     UNormalizationMode mode;
37     int32_t retVal;
38     UBool uselen;
39     const UChar* src;
40     int32_t srcLen;
41     UBool line_mode;
42     int32_t options;
43 
44 public:
call(UErrorCode * status)45     virtual void call(UErrorCode* status){
46         if(line_mode==TRUE){
47             if(uselen){
48                 for(int32_t i = 0; i< numLines; i++){
49                     retVal =  (*fn)(lines[i].name,lines[i].len,mode, options, status);
50                 }
51             }else{
52                 for(int32_t i = 0; i< numLines; i++){
53                     retVal =  (*fn)(lines[i].name,-1,mode, options, status);
54                 }
55             }
56         }else{
57             if(uselen){
58 
59                 retVal =  (*fn)(src,srcLen,mode, options, status);
60             }else{
61                 retVal =  (*fn)(src,-1,mode, options, status);
62             }
63         }
64 
65     }
getOperationsPerIteration()66     virtual long getOperationsPerIteration(){
67         if(line_mode==TRUE){
68             int32_t totalChars=0;
69             for(int32_t i =0; i< numLines; i++){
70                 totalChars+= lines[i].len;
71             }
72             return totalChars;
73         }else{
74             return srcLen;
75         }
76     }
QuickCheckPerfFunction(QuickCheckFn func,ULine * srcLines,int32_t srcNumLines,UNormalizationMode _mode,int32_t opts,UBool _uselen)77     QuickCheckPerfFunction(QuickCheckFn func, ULine* srcLines,int32_t srcNumLines, UNormalizationMode _mode, int32_t opts, UBool _uselen) : options(opts) {
78         fn = func;
79         lines = srcLines;
80         numLines = srcNumLines;
81         uselen = _uselen;
82         mode = _mode;
83         src = NULL;
84         srcLen = 0;
85         line_mode = TRUE;
86     }
QuickCheckPerfFunction(QuickCheckFn func,const UChar * source,int32_t sourceLen,UNormalizationMode _mode,int32_t opts,UBool _uselen)87     QuickCheckPerfFunction(QuickCheckFn func, const UChar* source,int32_t sourceLen, UNormalizationMode _mode, int32_t opts, UBool _uselen) : options(opts) {
88         fn = func;
89         lines = NULL;
90         numLines = 0;
91         uselen = _uselen;
92         mode = _mode;
93         src = source;
94         srcLen = sourceLen;
95         line_mode = FALSE;
96     }
97 };
98 
99 
100 class NormPerfFunction : public UPerfFunction{
101 private:
102     ULine* lines;
103     int32_t numLines;
104     UChar dest[DEST_BUFFER_CAPACITY];
105     UChar* pDest;
106     int32_t destLen;
107     NormFn fn;
108     int32_t retVal;
109     UBool uselen;
110     const UChar* src;
111     int32_t srcLen;
112     UBool line_mode;
113     int32_t options;
114 
115 public:
call(UErrorCode * status)116     virtual void call(UErrorCode* status){
117         if(line_mode==TRUE){
118             if(uselen){
119                 for(int32_t i = 0; i< numLines; i++){
120                     retVal =  (*fn)(lines[i].name,lines[i].len,pDest,destLen, options, status);
121                 }
122             }else{
123                 for(int32_t i = 0; i< numLines; i++){
124                     retVal =  (*fn)(lines[i].name,-1,pDest,destLen, options, status);
125                 }
126             }
127         }else{
128             if(uselen){
129                 retVal =  (*fn)(src,srcLen,pDest,destLen, options, status);
130             }else{
131                 retVal =  (*fn)(src,-1,pDest,destLen, options, status);
132             }
133         }
134     }
getOperationsPerIteration()135     virtual long getOperationsPerIteration(){
136         if(line_mode ==TRUE){
137             int32_t totalChars=0;
138             for(int32_t i =0; i< numLines; i++){
139                 totalChars+= lines[i].len;
140             }
141             return totalChars;
142         }else{
143             return srcLen;
144         }
145     }
NormPerfFunction(NormFn func,int32_t opts,ULine * srcLines,int32_t srcNumLines,UBool _uselen)146     NormPerfFunction(NormFn func, int32_t opts, ULine* srcLines,int32_t srcNumLines,UBool _uselen) : options(opts) {
147         fn = func;
148         lines = srcLines;
149         numLines = srcNumLines;
150         uselen = _uselen;
151         destLen = DEST_BUFFER_CAPACITY;
152         pDest = dest;
153         src = NULL;
154         srcLen = 0;
155         line_mode = TRUE;
156     }
NormPerfFunction(NormFn func,int32_t opts,const UChar * source,int32_t sourceLen,UBool _uselen)157     NormPerfFunction(NormFn func, int32_t opts, const UChar* source,int32_t sourceLen,UBool _uselen) : options(opts) {
158         fn = func;
159         lines = NULL;
160         numLines = 0;
161         uselen = _uselen;
162         destLen = sourceLen*3;
163         pDest = (UChar*) malloc(destLen * U_SIZEOF_UCHAR);
164         src = source;
165         srcLen = sourceLen;
166         line_mode = FALSE;
167     }
~NormPerfFunction()168     ~NormPerfFunction(){
169         if(dest != pDest){
170             free(pDest);
171         }
172     }
173 };
174 
175 
176 
177 class  NormalizerPerformanceTest : public UPerfTest{
178 private:
179     ULine* NFDFileLines;
180     ULine* NFCFileLines;
181     UChar* NFDBuffer;
182     UChar* NFCBuffer;
183     UChar* origBuffer;
184     int32_t origBufferLen;
185     int32_t NFDBufferLen;
186     int32_t NFCBufferLen;
187     int32_t options;
188 
189     void normalizeInput(ULine* dest,const UChar* src ,int32_t srcLen,UNormalizationMode mode, int32_t options);
190     UChar* normalizeInput(int32_t& len, const UChar* src ,int32_t srcLen,UNormalizationMode mode, int32_t options);
191 
192 public:
193 
194     NormalizerPerformanceTest(int32_t argc, const char* argv[], UErrorCode& status);
195     ~NormalizerPerformanceTest();
196     virtual UPerfFunction* runIndexedTest(int32_t index, UBool exec,const char* &name, char* par = NULL);
197     /* NFC performance */
198     UPerfFunction* TestICU_NFC_NFD_Text();
199     UPerfFunction* TestICU_NFC_NFC_Text();
200     UPerfFunction* TestICU_NFC_Orig_Text();
201 
202     /* NFD performance */
203     UPerfFunction* TestICU_NFD_NFD_Text();
204     UPerfFunction* TestICU_NFD_NFC_Text();
205     UPerfFunction* TestICU_NFD_Orig_Text();
206 
207     /* FCD performance */
208     UPerfFunction* TestICU_FCD_NFD_Text();
209     UPerfFunction* TestICU_FCD_NFC_Text();
210     UPerfFunction* TestICU_FCD_Orig_Text();
211 
212     /*Win NFC performance */
213     UPerfFunction* TestWin_NFC_NFD_Text();
214     UPerfFunction* TestWin_NFC_NFC_Text();
215     UPerfFunction* TestWin_NFC_Orig_Text();
216 
217     /* Win NFD performance */
218     UPerfFunction* TestWin_NFD_NFD_Text();
219     UPerfFunction* TestWin_NFD_NFC_Text();
220     UPerfFunction* TestWin_NFD_Orig_Text();
221 
222     /* Quick check performance */
223     UPerfFunction* TestQC_NFC_NFD_Text();
224     UPerfFunction* TestQC_NFC_NFC_Text();
225     UPerfFunction* TestQC_NFC_Orig_Text();
226 
227     UPerfFunction* TestQC_NFD_NFD_Text();
228     UPerfFunction* TestQC_NFD_NFC_Text();
229     UPerfFunction* TestQC_NFD_Orig_Text();
230 
231     UPerfFunction* TestQC_FCD_NFD_Text();
232     UPerfFunction* TestQC_FCD_NFC_Text();
233     UPerfFunction* TestQC_FCD_Orig_Text();
234 
235     /* IsNormalized performnace */
236     UPerfFunction* TestIsNormalized_NFC_NFD_Text();
237     UPerfFunction* TestIsNormalized_NFC_NFC_Text();
238     UPerfFunction* TestIsNormalized_NFC_Orig_Text();
239 
240     UPerfFunction* TestIsNormalized_NFD_NFD_Text();
241     UPerfFunction* TestIsNormalized_NFD_NFC_Text();
242     UPerfFunction* TestIsNormalized_NFD_Orig_Text();
243 
244     UPerfFunction* TestIsNormalized_FCD_NFD_Text();
245     UPerfFunction* TestIsNormalized_FCD_NFC_Text();
246     UPerfFunction* TestIsNormalized_FCD_Orig_Text();
247 
248 };
249 
250 //---------------------------------------------------------------------------------------
251 // Platform / ICU version specific proto-types
252 //---------------------------------------------------------------------------------------
253 
254 
255 #if (U_ICU_VERSION_MAJOR_NUM > 1 ) || ((U_ICU_VERSION_MAJOR_NUM == 1 )&&(U_ICU_VERSION_MINOR_NUM > 8) && (U_ICU_VERSION_PATCHLEVEL_NUM >=1))
256 
ICUNormNFD(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)257 int32_t ICUNormNFD(const UChar* src, int32_t srcLen,UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
258     return unorm_normalize(src,srcLen,UNORM_NFD, options,dest,dstLen,status);
259 }
260 
ICUNormNFC(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)261 int32_t ICUNormNFC(const UChar* src, int32_t srcLen,UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
262     return unorm_normalize(src,srcLen,UNORM_NFC, options,dest,dstLen,status);
263 }
264 
ICUNormNFKD(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)265 int32_t ICUNormNFKD(const UChar* src, int32_t srcLen,UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
266     return unorm_normalize(src,srcLen,UNORM_NFKD, options,dest,dstLen,status);
267 }
ICUNormNFKC(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)268 int32_t ICUNormNFKC(const UChar* src, int32_t srcLen,UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
269     return unorm_normalize(src,srcLen,UNORM_NFKC, options,dest,dstLen,status);
270 }
271 
ICUNormFCD(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)272 int32_t ICUNormFCD(const UChar* src, int32_t srcLen,UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
273     return unorm_normalize(src,srcLen,UNORM_FCD, options,dest,dstLen,status);
274 }
275 
ICUQuickCheck(const UChar * src,int32_t srcLen,UNormalizationMode mode,int32_t options,UErrorCode * status)276 int32_t ICUQuickCheck(const UChar* src,int32_t srcLen, UNormalizationMode mode, int32_t options, UErrorCode* status){
277 #if (U_ICU_VERSION_MAJOR_NUM > 2 ) || ((U_ICU_VERSION_MAJOR_NUM == 2 )&&(U_ICU_VERSION_MINOR_NUM >= 6))
278     return unorm_quickCheckWithOptions(src,srcLen,mode, options, status);
279 #else
280     return unorm_quickCheck(src,srcLen,mode,status);
281 #endif
282 }
ICUIsNormalized(const UChar * src,int32_t srcLen,UNormalizationMode mode,int32_t options,UErrorCode * status)283 int32_t ICUIsNormalized(const UChar* src,int32_t srcLen, UNormalizationMode mode, int32_t options, UErrorCode* status){
284     return unorm_isNormalized(src,srcLen,mode,status);
285 }
286 
287 
288 #else
289 
ICUNormNFD(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)290 int32_t ICUNormNFD(const UChar* src, int32_t srcLen,UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
291     return unorm_normalize(src,srcLen,UCOL_DECOMP_CAN, options,dest,dstLen,status);
292 }
293 
ICUNormNFC(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)294 int32_t ICUNormNFC(const UChar* src, int32_t srcLen,UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
295     return unorm_normalize(src,srcLen,UCOL_COMPOSE_CAN, options,dest,dstLen,status);
296 }
297 
ICUNormNFKD(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)298 int32_t ICUNormNFKD(const UChar* src, int32_t srcLen,UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
299     return unorm_normalize(src,srcLen,UCOL_DECOMP_COMPAT, options,dest,dstLen,status);
300 }
ICUNormNFKC(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)301 int32_t ICUNormNFKC(const UChar* src, int32_t srcLen,UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
302     return unorm_normalize(src,srcLen,UCOL_COMPOSE_COMPAT, options,dest,dstLen,status);
303 }
304 
ICUNormFCD(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)305 int32_t ICUNormFCD(const UChar* src, int32_t srcLen,UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
306     return unorm_normalize(src,srcLen,UNORM_FCD, options,dest,dstLen,status);
307 }
308 
ICUQuickCheck(const UChar * src,int32_t srcLen,UNormalizationMode mode,int32_t options,UErrorCode * status)309 int32_t ICUQuickCheck(const UChar* src,int32_t srcLen, UNormalizationMode mode, int32_t options, UErrorCode* status){
310     return unorm_quickCheck(src,srcLen,mode,status);
311 }
312 
ICUIsNormalized(const UChar * src,int32_t srcLen,UNormalizationMode mode,int32_t options,UErrorCode * status)313 int32_t ICUIsNormalized(const UChar* src,int32_t srcLen, UNormalizationMode mode, int32_t options, UErrorCode* status){
314     return 0;
315 }
316 #endif
317 
318 #if U_PLATFORM_HAS_WIN32_API
319 
WinNormNFD(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)320 int32_t WinNormNFD(const UChar* src, int32_t srcLen, UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
321     return FoldStringW(MAP_COMPOSITE,src,srcLen,dest,dstLen);
322 }
323 
WinNormNFC(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)324 int32_t WinNormNFC(const UChar* src, int32_t srcLen, UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
325     return FoldStringW(MAP_PRECOMPOSED,src,srcLen,dest,dstLen);
326 }
327 
WinNormNFKD(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)328 int32_t WinNormNFKD(const UChar* src, int32_t srcLen, UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
329     return FoldStringW(MAP_COMPOSITE+MAP_FOLDCZONE,src,srcLen,dest,dstLen);
330 }
WinNormNFKC(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)331 int32_t WinNormNFKC(const UChar* src, int32_t srcLen, UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
332     return FoldStringW(MAP_FOLDCZONE,src,srcLen,dest,dstLen);
333 }
334 #else
WinNormNFD(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)335 int32_t WinNormNFD(const UChar* src, int32_t srcLen, UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
336     return 0 ;
337 }
338 
WinNormNFC(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)339 int32_t WinNormNFC(const UChar* src, int32_t srcLen, UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
340     return 0;
341 }
342 
WinNormNFKD(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)343 int32_t WinNormNFKD(const UChar* src, int32_t srcLen, UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
344     return 0;
345 }
WinNormNFKC(const UChar * src,int32_t srcLen,UChar * dest,int32_t dstLen,int32_t options,UErrorCode * status)346 int32_t WinNormNFKC(const UChar* src, int32_t srcLen, UChar* dest, int32_t dstLen, int32_t options, UErrorCode* status) {
347     return 0;
348 }
349 #endif
350 
351 
352 #endif // NORMPERF_H
353 
354