ceba015b5989eec4b188b47a2f5b384c5956460d
[pdfium.git] / core / include / fxcrt / fx_ext.h
1 // Copyright 2014 PDFium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4  
5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
6
7 #ifndef _FXCRT_EXTENSION_
8 #define _FXCRT_EXTENSION_
9 #ifndef _FX_BASIC_H_
10 #include "fx_basic.h"
11 #endif
12 #ifndef _FXCRT_COORDINATES_
13 #include "fx_coordinates.h"
14 #endif
15 #ifndef _FX_XML_H_
16 #include "fx_xml.h"
17 #endif
18 #ifndef _FX_UNICODE_
19 #include "fx_ucd.h"
20 #endif
21 #ifndef _FX_ARABIC_
22 #include "fx_arb.h"
23 #endif
24 #ifdef __cplusplus
25 extern "C" {
26 #endif
27
28
29 FX_FLOAT                FXSYS_tan(FX_FLOAT a);
30 FX_FLOAT                FXSYS_logb(FX_FLOAT b, FX_FLOAT x);
31 FX_FLOAT                FXSYS_strtof(FX_LPCSTR pcsStr, FX_INT32 iLength = -1, FX_INT32 *pUsedLen = NULL);
32 FX_FLOAT                FXSYS_wcstof(FX_LPCWSTR pwsStr, FX_INT32 iLength = -1, FX_INT32 *pUsedLen = NULL);
33 FX_LPWSTR               FXSYS_wcsncpy(FX_LPWSTR dstStr, FX_LPCWSTR srcStr, size_t count);
34 FX_INT32                FXSYS_wcsnicmp(FX_LPCWSTR s1, FX_LPCWSTR s2, size_t count);
35 FX_INT32                FXSYS_strnicmp(FX_LPCSTR s1, FX_LPCSTR s2, size_t count);
36 inline FX_BOOL  FXSYS_islower(FX_INT32 ch)
37 {
38     return ch >= 'a' && ch <= 'z';
39 }
40 inline FX_BOOL  FXSYS_isupper(FX_INT32 ch)
41 {
42     return ch >= 'A' && ch <= 'Z';
43 }
44 inline FX_INT32 FXSYS_tolower(FX_INT32 ch)
45 {
46     return ch < 'A' || ch > 'Z' ? ch : (ch + 0x20);
47 }
48 inline FX_INT32 FXSYS_toupper(FX_INT32 ch)
49 {
50     return ch < 'a' || ch > 'z' ? ch : (ch - 0x20);
51 }
52
53
54
55 FX_DWORD        FX_HashCode_String_GetA(FX_LPCSTR pStr, FX_INT32 iLength, FX_BOOL bIgnoreCase = FALSE);
56 FX_DWORD        FX_HashCode_String_GetW(FX_LPCWSTR pStr, FX_INT32 iLength, FX_BOOL bIgnoreCase = FALSE);
57
58 #ifdef __cplusplus
59 }
60 #endif
61 #ifdef __cplusplus
62 extern "C" {
63 #endif
64
65 FX_LPVOID       FX_Random_MT_Start(FX_DWORD dwSeed);
66
67 FX_DWORD        FX_Random_MT_Generate(FX_LPVOID pContext);
68
69 void            FX_Random_MT_Close(FX_LPVOID pContext);
70
71 void            FX_Random_GenerateBase(FX_LPDWORD pBuffer, FX_INT32 iCount);
72
73 void            FX_Random_GenerateMT(FX_LPDWORD pBuffer, FX_INT32 iCount);
74
75 void            FX_Random_GenerateCrypto(FX_LPDWORD pBuffer, FX_INT32 iCount);
76 #ifdef __cplusplus
77 }
78 #endif
79 #ifdef __cplusplus
80 extern "C" {
81 #endif
82
83 typedef struct FX_GUID {
84     FX_DWORD    data1;
85     FX_WORD             data2;
86     FX_WORD             data3;
87     FX_BYTE             data4[8];
88 } FX_GUID, * FX_LPGUID;
89 typedef FX_GUID const * FX_LPCGUID;
90
91 void    FX_GUID_CreateV4(FX_LPGUID pGUID);
92
93 void    FX_GUID_ToString(FX_LPCGUID pGUID, CFX_ByteString &bsStr, FX_BOOL bSeparator = TRUE);
94 #ifdef __cplusplus
95 }
96 #endif
97 template<class baseType>
98 class CFX_SSortTemplate
99 {
100 public:
101     void ShellSort(baseType *pArray, FX_INT32 iCount)
102     {
103         FXSYS_assert(pArray != NULL && iCount > 0);
104         FX_INT32 i, j, gap;
105         baseType v1, v2;
106         gap = iCount >> 1;
107         while (gap > 0) {
108             for (i = gap; i < iCount; i ++) {
109                 j = i - gap;
110                 v1 = pArray[i];
111                 while (j > -1 && (v2 = pArray[j]) > v1) {
112                     pArray[j + gap] = v2;
113                     j -= gap;
114                 }
115                 pArray[j + gap] = v1;
116             }
117             gap >>= 1;
118         }
119     }
120 };
121 #endif