* copy vendor drop to trunk
[lab.git] / Dev / utvpn / utvpn-unix-v101-7101-public / src / Mayaqua / Str.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 // Str.h\r
79 // Str.c のヘッダ\r
80 \r
81 #ifndef STR_H\r
82 #define STR_H\r
83 \r
84 // 文字列トークン\r
85 struct TOKEN_LIST\r
86 {\r
87         UINT NumTokens;\r
88         char **Token;\r
89 };\r
90 \r
91 // INI_ENTRY\r
92 struct INI_ENTRY\r
93 {\r
94         char *Key;\r
95         char *Value;\r
96         wchar_t *UnicodeValue;\r
97 };\r
98 \r
99 // 関数プロトタイプ\r
100 UINT StrLen(char *str);\r
101 UINT StrSize(char *str);\r
102 bool StrCheckLen(char *str, UINT len);\r
103 bool StrCheckSize(char *str, UINT size);\r
104 UINT StrCpy(char *dst, UINT size, char *src);\r
105 UINT StrCat(char *dst, UINT size, char *src);\r
106 UINT StrCatLeft(char *dst, UINT size, char *src);\r
107 char ToLower(char c);\r
108 char ToUpper(char c);\r
109 void StrUpper(char *str);\r
110 void StrLower(char *str);\r
111 int StrCmp(char *str1, char *str2);\r
112 int StrCmpi(char *str1, char *str2);\r
113 void FormatArgs(char *buf, UINT size, char *fmt, va_list args);\r
114 void Format(char *buf, UINT size, char *fmt, ...);\r
115 char *CopyFormat(char *fmt, ...);\r
116 void Print(char *fmt, ...);\r
117 void PrintArgs(char *fmt, va_list args);\r
118 void PrintStr(char *str);\r
119 void Debug(char *fmt, ...);\r
120 void DebugArgs(char *fmt, va_list args);\r
121 UINT ToInt(char *str);\r
122 bool ToBool(char *str);\r
123 int ToInti(char *str);\r
124 void ToStr(char *str, UINT i);\r
125 void ToStri(char *str, int i);\r
126 void ToStrx(char *str, UINT i);\r
127 void ToStrx8(char *str, UINT i);\r
128 void TrimCrlf(char *str);\r
129 void Trim(char *str);\r
130 void TrimRight(char *str);\r
131 void TrimLeft(char *str);\r
132 bool GetLine(char *str, UINT size);\r
133 void FreeToken(TOKEN_LIST *tokens);\r
134 bool IsInToken(TOKEN_LIST *t, char *str);\r
135 TOKEN_LIST *ParseToken(char *src, char *separator);\r
136 void InitStringLibrary();\r
137 void FreeStringLibrary();\r
138 bool CheckStringLibrary();\r
139 UINT SearchStrEx(char *string, char *keyword, UINT start, bool case_sensitive);\r
140 UINT SearchStri(char *string, char *keyword, UINT start);\r
141 UINT SearchStr(char *string, char *keyword, UINT start);\r
142 UINT CalcReplaceStrEx(char *string, char *old_keyword, char *new_keyword, bool case_sensitive);\r
143 UINT ReplaceStrEx(char *dst, UINT size, char *string, char *old_keyword, char *new_keyword, bool case_sensitive);\r
144 UINT ReplaceStr(char *dst, UINT size, char *string, char *old_keyword, char *new_keyword);\r
145 UINT ReplaceStri(char *dst, UINT size, char *string, char *old_keyword, char *new_keyword);\r
146 bool IsSafeChar(char c);\r
147 bool IsSafeStr(char *str);\r
148 void EnSafeStr(char *str, char replace);\r
149 void TruncateCharFromStr(char *str, char replace);\r
150 char *CopyStr(char *str);\r
151 void BinToStr(char *str, UINT str_size, void *data, UINT data_size);\r
152 void BinToStrW(wchar_t *str, UINT str_size, void *data, UINT data_size);\r
153 void PrintBin(void *data, UINT size);\r
154 bool StartWith(char *str, char *key);\r
155 bool EndWith(char *str, char *key);\r
156 UINT64 ToInt64(char *str);\r
157 void ToStr64(char *str, UINT64 value);\r
158 char *ReplaceFormatStringFor64(char *fmt);\r
159 TOKEN_LIST *ParseCmdLine(char *str);\r
160 TOKEN_LIST *CopyToken(TOKEN_LIST *src);\r
161 TOKEN_LIST *NullToken();\r
162 bool IsNum(char *str);\r
163 LIST *StrToStrList(char *str, UINT size);\r
164 BUF *StrListToStr(LIST *o);\r
165 void FreeStrList(LIST *o);\r
166 TOKEN_LIST *ListToTokenList(LIST *o);\r
167 LIST *TokenListToList(TOKEN_LIST *t);\r
168 bool IsEmptyStr(char *str);\r
169 void BinToStrEx(char *str, UINT str_size, void *data, UINT data_size);\r
170 void BinToStrEx2(char *str, UINT str_size, void *data, UINT data_size, char padding_char);\r
171 char *CopyBinToStrEx(void *data, UINT data_size);\r
172 char *CopyBinToStr(void *data, UINT data_size);\r
173 BUF *StrToBin(char *str);\r
174 void MacToStr(char *str, UINT size, UCHAR *mac_address);\r
175 void ToStr3(char *str, UINT size, UINT64 v);\r
176 void ToStrByte(char *str, UINT size, UINT64 v);\r
177 void ToStrByte1000(char *str, UINT size, UINT64 v);\r
178 TOKEN_LIST *UniqueToken(TOKEN_LIST *t);\r
179 char *NormalizeCrlf(char *str);\r
180 bool IsAllUpperStr(char *str);\r
181 UINT StrWidth(char *str);\r
182 char *MakeCharArray(char c, UINT count);\r
183 void MakeCharArray2(char *str, char c, UINT count);\r
184 bool StrToMac(UCHAR *mac_address, char *str);\r
185 bool IsSplitChar(char c, char *split_str);\r
186 bool GetKeyAndValue(char *str, char *key, UINT key_size, char *value, UINT value_size, char *split_str);\r
187 LIST *ReadIni(BUF *b);\r
188 INI_ENTRY *GetIniEntry(LIST *o, char *key);\r
189 void FreeIni(LIST *o);\r
190 UINT IniIntValue(LIST *o, char *key);\r
191 UINT64 IniInt64Value(LIST *o, char *key);\r
192 char *IniStrValue(LIST *o, char *key);\r
193 wchar_t *IniUniStrValue(LIST *o, char *key);\r
194 bool InStr(char *str, char *keyword);\r
195 bool InStrEx(char *str, char *keyword, bool case_sensitive);\r
196 TOKEN_LIST *ParseTokenWithoutNullStr(char *str, char *split_chars);\r
197 TOKEN_LIST *ParseTokenWithNullStr(char *str, char *split_chars);\r
198 char *DefaultTokenSplitChars();\r
199 bool IsCharInStr(char *str, char c);\r
200 UINT HexTo4Bit(char c);\r
201 char FourBitToHex(UINT value);\r
202 void ToHex(char *str, UINT value);\r
203 void ToHex64(char *str, UINT64 value);\r
204 UINT HexToInt(char *str);\r
205 UINT64 HexToInt64(char *str);\r
206 \r
207 \r
208 #endif  // STR_H\r
209 \r