]> git.stg.codes - stg.git/blob - stglibs/common.lib/include/stg/common.h
94c26a8b26c021fd9c478c81910e86edfaa9994a
[stg.git] / stglibs / common.lib / include / stg / common.h
1 /*
2  *    This program is free software; you can redistribute it and/or modify
3  *    it under the terms of the GNU General Public License as published by
4  *    the Free Software Foundation; either version 2 of the License, or
5  *    (at your option) any later version.
6  *
7  *    This program is distributed in the hope that it will be useful,
8  *    but WITHOUT ANY WARRANTY; without even the implied warranty of
9  *    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10  *    GNU General Public License for more details.
11  *
12  *    You should have received a copy of the GNU General Public License
13  *    along with this program; if not, write to the Free Software
14  *    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
15  */
16
17 /*
18  *    Author : Boris Mikhailenko <stg34@stargazer.dp.ua>
19  */
20
21  /*
22  $Revision: 1.32 $
23  $Date: 2010/11/08 10:11:19 $
24  $Author: faust $
25  */
26
27 #ifndef common_h
28 #define common_h
29
30 #ifdef __BORLANDC__
31 #include <time.h>
32 #else
33 #include <ctime>
34 #endif
35 #include <string>
36 #include <sstream>
37
38 #include "stg/os_int.h"
39 #include "stg/const.h"
40
41 #define STAT_TIME_3         (1)
42 #define STAT_TIME_2         (2)
43 #define STAT_TIME_1         (3)
44 #define STAT_TIME_1_2       (4)
45 #define STAT_TIME_1_4       (5)
46 #define STAT_TIME_1_6       (6)
47
48 #define FN_STR_LEN      (NAME_MAX)
49
50 #define ST_F    0
51 #define ST_B    1
52 #define ST_KB   2
53 #define ST_MB   3
54
55 //-----------------------------------------------------------------------------
56 const char    * IntToKMG(int64_t a, int statType = ST_F);
57 const char    * LogDate(time_t t);
58 int             ParesTimeStat(const char * str);
59 int             IsTimeStat(struct tm * t, int statTime);
60 /*bool            IsDigit(char c);
61 bool            IsAlpha(char c);*/
62 int             strtodouble2(const char * s, double &a);
63 int             printfd(const char * __file__, const char * fmt, ...);
64 void            Encode12(char * dst, const char * src, size_t srcLen);
65 void            Decode21(char * dst, const char * src);
66
67 void            Encode12str(std::string & dst, const std::string & src);
68 void            Decode21str(std::string & dst, const std::string & src);
69
70 int             ParseIPString(const char * str, uint32_t * ips, int maxIP);
71 void            KOIToWin(const char * s1, char * s2, int l);
72 void            WinToKOI(const char * s1, char * s2, int l);
73 void            KOIToWin(const std::string & s1, std::string * s2);
74 void            WinToKOI(const std::string & s1, std::string * s2);
75 int             DaysInMonth(unsigned year, unsigned mon);
76 int             DaysInCurrentMonth();
77 int             Min8(int a);
78 //char          * inet_ntostr(unsigned long);
79 std::string     inet_ntostring(uint32_t);
80 uint32_t        inet_strington(const std::string & value);
81 int             strprintf(std::string * str, const char * fmt, ...);
82 int             ParseTariffTimeStr(const char * str, int &h1, int &m1, int &h2, int &m2);
83 uint32_t        CalcMask(uint32_t msk);
84 void            TouchFile(const std::string & fileName);
85 #ifdef WIN32
86 void            EncodeStr(char * str, unsigned long serial, int useHDD);
87 void            DecodeStr(char * str, unsigned long serial, int useHDD);
88 #endif //WIN32
89 void            SwapBytes(uint16_t & value);
90 void            SwapBytes(uint32_t & value);
91 void            SwapBytes(uint64_t & value);
92 void            SwapBytes(int16_t & value);
93 void            SwapBytes(int32_t & value);
94 void            SwapBytes(int64_t & value);
95
96 std::string &   TrimL(std::string & val);
97 std::string &   TrimR(std::string & val);
98 std::string &   Trim(std::string & val);
99
100 template <typename C, typename F>
101 C Split(const std::string & value, char delim, F conv)
102 {
103 C res;
104 size_t startPos = 0;
105 size_t pos = value.find_first_of(delim);
106 while (pos != std::string::npos)
107     {
108     res.push_back(conv(value.substr(startPos, pos - startPos)));
109     startPos = pos + 1;
110     pos = value.find_first_of(delim, pos + 1);
111     }
112 res.push_back(conv(value.substr(startPos, pos - startPos)));
113 return res;
114 }
115
116 template <typename T>
117 T FromString(const std::string & value)
118 {
119 T res;
120 std::istringstream stream(value);
121 stream >> res;
122 return res;
123 }
124
125 template <typename C>
126 C Split(const std::string & value, char delim)
127 {
128     return Split<C>(value, delim, FromString);
129 }
130
131 std::string IconvString(const std::string & source, const std::string & from, const std::string & to);
132
133 int ParseInt(const std::string & str, int * val);
134 int ParseUnsigned(const std::string & str, unsigned * val);
135 int ParseIntInRange(const std::string & str, int min, int max, int * val);
136 int ParseUnsignedInRange(const std::string & str, unsigned min,
137                          unsigned max, unsigned * val);
138 int ParseYesNo(const std::string & str, bool * val);
139
140 bool WaitPackets(int sd);
141
142 //-----------------------------------------------------------------------------
143 int str2x(const std::string & str, int32_t & x);
144 int str2x(const std::string & str, uint32_t & x);
145 #ifndef WIN32
146 int str2x(const std::string & str, int64_t & x);
147 int str2x(const std::string & str, uint64_t & x);
148 #endif
149 //-----------------------------------------------------------------------------
150 const std::string & x2str(uint32_t x, std::string & s);
151 const std::string & x2str(uint64_t x, std::string & s);
152 //-----------------------------------------------------------------------------
153 const std::string & x2str(double x, std::string & s);
154 //-----------------------------------------------------------------------------
155
156 template <typename varT>
157 int str2x(const std::string & str, varT & x);
158 template <typename varT>
159 const std::string & x2str(varT x, std::string & s);
160 template <typename varT>
161 const std::string & x2str(varT x) { std::string s; return x2str(x, s); }
162 template <typename varT>
163 const std::string & unsigned2str(varT x, std::string & s);
164 template <typename varT>
165 const std::string & unsigned2str(varT x) { std::string s; return unsigned2str(x, s); }
166
167 //-----------------------------------------------------------------------------
168 template <typename varT>
169 inline
170 int str2x(const std::string & str, varT & x)
171 {
172     int pos = 0;
173     int minus = 1;
174
175     if (str.empty())
176         return -1;
177
178     if (str[0] == '+')
179         pos++;
180
181     if (str[0] == '-')
182     {
183         pos++;
184         minus = -1;
185     }
186
187     if ((str[pos] < '0' || str[pos] > '9'))
188         return -1;
189
190     x = str[pos++] - '0';
191
192     for (unsigned i = pos; i < str.size(); i++)
193     {
194         if ((str[i] < '0' || str[i] > '9'))
195             return -1;
196
197         x *= 10;
198         x += str[i] - '0';
199     }
200
201     x*= minus;
202
203     return 0;
204 }
205 //-----------------------------------------------------------------------------
206 template <typename varT>
207 inline
208 const std::string & x2str(varT x, std::string & s)
209 {
210     varT xx = x;
211     int pos = 1;
212
213     x /= 10;
214     while (x != 0)
215     {
216         x /= 10;
217         pos++;
218     }
219
220     if (xx < 0)
221     {
222         pos++;
223         s.resize(pos, 0);
224         s[0] = '-';
225     }
226     else if (xx > 0)
227     {
228         s.resize(pos, 0);
229     }
230     else
231     {
232         s.resize(1, 0);
233         s[0] = '0';
234         return s;
235     }
236
237     x = xx;
238
239     while (x != 0)
240     {
241         if (x < 0)
242             s[--pos] = -(x % 10) + '0';
243         else
244             s[--pos] = x % 10 + '0';
245
246         x /= 10;
247     }
248
249     return s;
250 }
251 //-----------------------------------------------------------------------------
252 template <typename varT>
253 inline
254 const std::string & unsigned2str(varT x, std::string & s)
255 {
256     varT xx = x;
257     int pos = 1;
258
259     x /= 10;
260     while (x != 0)
261     {
262         x /= 10;
263         pos++;
264     }
265
266     if (xx > 0)
267     {
268         s.resize(pos, 0);
269     }
270     else
271     {
272         s.resize(1, 0);
273         s[0] = '0';
274         return s;
275     }
276
277     x = xx;
278
279     while (x != 0)
280     {
281         s[--pos] = x % 10 + '0';
282
283         x /= 10;
284     }
285
286     return s;
287 }
288 //-----------------------------------------------------------------------------
289 char * stg_strptime(const char *, const char *, struct tm *);
290 time_t stg_timegm(struct tm *);
291
292 #endif