* copy vendor drop to trunk
[lab.git] / Dev / utvpn / utvpn-unix-v101-7101-public / src / Mayaqua / Internat.h
1 // SoftEther UT-VPN SourceCode\r
2 // \r
3 // Copyright (C) 2004-2010 SoftEther Corporation.\r
4 // Copyright (C) 2004-2010 University of Tsukuba, Japan.\r
5 // Copyright (C) 2003-2010 Daiyuu Nobori.\r
6 // All Rights Reserved.\r
7 // \r
8 // http://utvpn.tsukuba.ac.jp/\r
9 // \r
10 // This program is free software; you can redistribute it and/or\r
11 // modify it under the terms of the GNU General Public License\r
12 // version 2 as published by the Free Software Foundation.\r
13 // \r
14 // This program is distributed in the hope that it will be useful,\r
15 // but WITHOUT ANY WARRANTY; without even the implied warranty of\r
16 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\r
17 // GNU General Public License for more details.\r
18 // \r
19 // You should have received a copy of the GNU General Public License version 2\r
20 // along with this program; if not, write to the Free Software\r
21 // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\r
22 // \r
23 // このファイルは GPL バージョン 2 ライセンスで公開されています。\r
24 // 誰でもこのファイルの内容を複製、改変したり、改変したバージョンを再配布\r
25 // することができます。ただし、原著作物を改変した場合は、原著作物の著作権表示\r
26 // を除去することはできません。改変した著作物を配布する場合は、改変実施者の\r
27 // 著作権表示を原著作物の著作権表示に付随して記載するようにしてください。\r
28 // \r
29 // この SoftEther UT-VPN オープンソース・プロジェクトは、日本国の\r
30 // ソフトイーサ株式会社 (SoftEther Corporation, http://www.softether.co.jp/ )\r
31 // および筑波大学 (University of Tsukuba, http://www.tsukuba.ac.jp/ ) によって\r
32 // ホストされています。\r
33 // 本プログラムの配布者は、本プログラムを、業としての利用以外のため、\r
34 // および、試験または研究のために利用が行われることを想定して配布\r
35 // しています。\r
36 // SoftEther UT-VPN プロジェクトの Web サイトは http://utvpn.tsukuba.ac.jp/ に\r
37 // あります。\r
38 // 本ソフトウェアの不具合の修正、機能改良、セキュリティホールの修復などのコード\r
39 // の改変を行った場合で、その成果物を SoftEther UT-VPN プロジェクトに提出して\r
40 // いただける場合は、 http://utvpn.tsukuba.ac.jp/ までソースコードを送付して\r
41 // ください。SoftEther UT-VPN プロジェクトの本体リリースまたはブランチリリース\r
42 // に組み込みさせていただきます。\r
43 // \r
44 // GPL に基づいて原著作物が提供される本ソフトウェアの改良版を配布、販売する\r
45 // 場合は、そのソースコードを GPL に基づいて誰にでも開示する義務が生じます。\r
46 // \r
47 // 本ソフトウェアに関連する著作権、特許権、商標権はソフトイーサ株式会社\r
48 // (SoftEther Corporation) およびその他の著作権保持者が保有しています。\r
49 // ソフトイーサ株式会社等はこれらの権利を放棄していません。本ソフトウェアの\r
50 // 二次著作物を配布、販売する場合は、これらの権利を侵害しないようにご注意\r
51 // ください。\r
52 // \r
53 // お願い: どのような通信ソフトウェアにも通常は必ず未発見の\r
54 // セキュリティホールが潜んでいます。本ソースコードをご覧いただいた結果、\r
55 // UT-VPN にセキュリティホールを発見された場合は、当該セキュリティホールの\r
56 // 情報を不特定多数に開示される前に、必ず、ソフトイーサ株式会社\r
57 // および脆弱性情報の届出を受け付ける公的機関まで通報いただき、\r
58 // 公益保護にご協力いただきますようお願い申し上げます。\r
59 // \r
60 // ソフトイーサ株式会社は、当該セキュリティホールについて迅速に対処を\r
61 // 行い、UT-VPN および UT-VPN に関連するソフトウェアのユーザー・顧客\r
62 // を保護するための努力を行います。\r
63 // \r
64 // ソフトイーサへの届出先: http://www.softether.co.jp/jp/contact/\r
65 // 日本国内の脆弱性情報届出受付公的機関:\r
66 //         独立行政法人 情報処理推進機構\r
67 //         http://www.ipa.go.jp/security/vuln/report/\r
68 // \r
69 // 上記各事項について不明な点は、ソフトイーサ株式会社までご連絡ください。\r
70 // 連絡先: http://www.softether.co.jp/jp/contact/\r
71 \r
72 // -----------------------------------------------\r
73 // [ChangeLog]\r
74 // 2010.05.20\r
75 //  新規リリース by SoftEther\r
76 // -----------------------------------------------\r
77 \r
78 // Internat.h\r
79 // Internat.c のヘッダ\r
80 \r
81 #ifndef INTERNAT_H\r
82 #define INTERNAT_H\r
83 \r
84 // 文字列トークン\r
85 struct UNI_TOKEN_LIST\r
86 {\r
87         UINT NumTokens;\r
88         wchar_t **Token;\r
89 };\r
90 \r
91 UINT UniStrLen(wchar_t *str);\r
92 UINT UniStrSize(wchar_t *str);\r
93 UINT UniStrCpy(wchar_t *dst, UINT size, wchar_t *src);\r
94 bool UniCheckStrSize(wchar_t *str, UINT size);\r
95 bool UniCheckStrLen(wchar_t *str, UINT len);\r
96 UINT UniStrCat(wchar_t *dst, UINT size, wchar_t *src);\r
97 UINT UniStrCatLeft(wchar_t *dst, UINT size, wchar_t *src);\r
98 wchar_t UniToLower(wchar_t c);\r
99 wchar_t UniToUpper(wchar_t c);\r
100 void UniStrLower(wchar_t *str);\r
101 void UniStrUpper(wchar_t *str);\r
102 int UniStrCmp(wchar_t *str1, wchar_t *str2);\r
103 int UniStrCmpi(wchar_t *str1, wchar_t *str2);\r
104 int UniSoftStrCmp(wchar_t *str1, wchar_t *str2);\r
105 void UniFormat(wchar_t *buf, UINT size, wchar_t *fmt, ...);\r
106 wchar_t *CopyUniFormat(wchar_t *fmt, ...);\r
107 void UniFormatArgs(wchar_t *buf, UINT size, wchar_t *fmt, va_list args);\r
108 void UniDebugArgs(wchar_t *fmt, va_list args);\r
109 void UniDebug(wchar_t *fmt, ...);\r
110 void UniPrint(wchar_t *fmt, ...);\r
111 void UniPrintArgs(wchar_t *fmt, va_list args);\r
112 void UniPrintStr(wchar_t *string);\r
113 void UniToStrx8(wchar_t *str, UINT i);\r
114 void UniToStrx(wchar_t *str, UINT i);\r
115 void UniToStri(wchar_t *str, int i);\r
116 void UniToStru(wchar_t *str, UINT i);\r
117 int UniToInti(wchar_t *str);\r
118 UINT UniToInt(wchar_t *str);\r
119 void UniTrim(wchar_t *str);\r
120 void UniTrimLeft(wchar_t *str);\r
121 void UniTrimRight(wchar_t *str);\r
122 void UniTrimCrlf(wchar_t *str);\r
123 bool UniGetLine(wchar_t *str, UINT size);\r
124 bool UniGetLineWin32(wchar_t *str, UINT size);\r
125 bool UniGetLineUnix(wchar_t *str, UINT size);\r
126 void UniFreeToken(UNI_TOKEN_LIST *tokens);\r
127 UNI_TOKEN_LIST *UniParseToken(wchar_t *src, wchar_t *separator);\r
128 UINT UniSearchStrEx(wchar_t *string, wchar_t *keyword, UINT start, bool case_sensitive);\r
129 UINT UniSearchStri(wchar_t *string, wchar_t *keyword, UINT start);\r
130 UINT UniSearchStr(wchar_t *string, wchar_t *keyword, UINT start);\r
131 UINT UniCalcReplaceStrEx(wchar_t *string, wchar_t *old_keyword, wchar_t *new_keyword, bool case_sensitive);\r
132 UINT UniReplaceStrEx(wchar_t *dst, UINT size, wchar_t *string, wchar_t *old_keyword, wchar_t *new_keyword, bool case_sensitive);\r
133 UINT UniReplaceStri(wchar_t *dst, UINT size, wchar_t *string, wchar_t *old_keyword, wchar_t *new_keyword);\r
134 UINT UniReplaceStr(wchar_t *dst, UINT size, wchar_t *string, wchar_t *old_keyword, wchar_t *new_keyword);\r
135 UINT GetUniType(wchar_t c);\r
136 UINT GetUtf8Type(BYTE *s, UINT size, UINT offset);\r
137 UINT CalcUniToUtf8(wchar_t *s);\r
138 UINT UniToUtf8(BYTE *u, UINT size, wchar_t *s);\r
139 UINT Utf8Len(BYTE *u, UINT size);\r
140 UINT CalcUtf8ToUni(BYTE *u, UINT u_size);\r
141 UINT Utf8ToUni(wchar_t *s, UINT size, BYTE *u, UINT u_size);\r
142 UINT CalcStrToUni(char *str);\r
143 UINT StrToUni(wchar_t *s, UINT size, char *str);\r
144 UINT CalcUniToStr(wchar_t *s);\r
145 UINT UniToStr(char *str, UINT size, wchar_t *s);\r
146 UINT CalcStrToUtf8(char *str);\r
147 UINT StrToUtf8(BYTE *u, UINT size, char *str);\r
148 UINT CalcUtf8ToStr(BYTE *u, UINT size);\r
149 UINT Utf8ToStr(char *str, UINT str_size, BYTE *u, UINT size);\r
150 bool IsSafeUniStr(wchar_t *str);\r
151 bool IsSafeUniChar(wchar_t c);\r
152 wchar_t *CopyUniStr(wchar_t *str);\r
153 wchar_t *CopyStrToUni(char *str);\r
154 UINT StrToUtf(char *utfstr, UINT size, char *str);\r
155 UINT UtfToStr(char *str, UINT size, char *utfstr);\r
156 UINT UniToUtf(char *utfstr, UINT size, wchar_t *unistr);\r
157 UINT UtfToUni(wchar_t *unistr, UINT size, char *utfstr);\r
158 char *CopyUniToUtf(wchar_t *unistr);\r
159 char *CopyStrToUtf(char *str);\r
160 char *CopyUniToStr(wchar_t *unistr);\r
161 wchar_t *CopyUtfToUni(char *utfstr);\r
162 char *CopyUtfToStr(char *utfstr);\r
163 wchar_t *UniReplaceFormatStringFor64(wchar_t *fmt);\r
164 void UniToStr64(wchar_t *str, UINT64 value);\r
165 UINT64 UniToInt64(wchar_t *str);\r
166 UNI_TOKEN_LIST *UniParseCmdLine(wchar_t *str);\r
167 UNI_TOKEN_LIST *UniCopyToken(UNI_TOKEN_LIST *src);\r
168 wchar_t *UniCopyStr(wchar_t *str);\r
169 TOKEN_LIST *UniTokenListToTokenList(UNI_TOKEN_LIST *src);\r
170 UNI_TOKEN_LIST *TokenListToUniTokenList(TOKEN_LIST *src);\r
171 UNI_TOKEN_LIST *UniNullToken();\r
172 UNI_TOKEN_LIST *NullUniToken();\r
173 bool UniIsNum(wchar_t *str);\r
174 bool IsEmptyUniStr(wchar_t *str);\r
175 bool UniIsEmptyStr(wchar_t *str);\r
176 void InitInternational();\r
177 void FreeInternational();\r
178 USHORT *WideToUtf16(wchar_t *str);\r
179 wchar_t *Utf16ToWide(USHORT *str);\r
180 void DumpUniStr(wchar_t *str);\r
181 void DumpStr(char *str);\r
182 wchar_t *InternalFormatArgs(wchar_t *fmt, va_list args, bool ansi_mode);\r
183 UINT UniStrWidth(wchar_t *str);\r
184 UNI_TOKEN_LIST *UnixUniParseToken(wchar_t *src, wchar_t *separator);\r
185 void UniToStr3(wchar_t *str, UINT size, UINT64 value);\r
186 bool UniEndWith(wchar_t *str, wchar_t *key);\r
187 bool UniStartWith(wchar_t *str, wchar_t *key);\r
188 wchar_t *UniNormalizeCrlf(wchar_t *str);\r
189 LIST *UniStrToStrList(wchar_t *str, UINT size);\r
190 BUF *UniStrListToStr(LIST *o);\r
191 void UniFreeStrList(LIST *o);\r
192 UNI_TOKEN_LIST *UniListToTokenList(LIST *o);\r
193 LIST *UniTokenListToList(UNI_TOKEN_LIST *t);\r
194 bool UniIsSafeChar(wchar_t c);\r
195 wchar_t *UniMakeCharArray(wchar_t c, UINT count);\r
196 BUF *UniStrToBin(wchar_t *str);\r
197 bool UniInStr(wchar_t *str, wchar_t *keyword);\r
198 bool UniInStrEx(wchar_t *str, wchar_t *keyword, bool case_sensitive);\r
199 \r
200 #ifdef  OS_UNIX\r
201 void GetCurrentCharSet(char *name, UINT size);\r
202 UINT UnixCalcStrToUni(char *str);\r
203 UINT UnixStrToUni(wchar_t *s, UINT size, char *str);\r
204 UINT UnixCalcUniToStr(wchar_t *s);\r
205 UINT UnixUniToStr(char *str, UINT size, wchar_t *s);\r
206 void *IconvWideToStr();\r
207 void *IconvStrToWide();\r
208 int IconvFree(void *d);\r
209 void *IconvWideToStrInternal();\r
210 void *IconvStrToWideInternal();\r
211 int IconvFreeInternal(void *d);\r
212 #endif  // OS_UNIX\r
213 \r
214 #endif  // INTERNAT_H\r
215 \r
216 \r
217 \r