source: trunk/lib/utility.cc @ 523

Last change on this file since 523 was 523, checked in by Peter Johansson, 14 years ago

fixes ticket:284 - validate [file-name-dictionary] section in config file

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 7.6 KB
Line 
1// $Id: utility.cc 523 2007-12-25 01:51:54Z peter $
2
3/*
4  Copyright (C) 2006, 2007 Jari Häkkinen, Peter Johansson
5
6  This file is part of svndigest, http://trac.thep.lu.se/svndigest
7
8  svndigest is free software; you can redistribute it and/or modify it
9  under the terms of the GNU General Public License as published by
10  the Free Software Foundation; either version 2 of the License, or
11  (at your option) any later version.
12
13  svndigest is distributed in the hope that it will be useful, but
14  WITHOUT ANY WARRANTY; without even the implied warranty of
15  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16  General Public License for more details.
17
18  You should have received a copy of the GNU General Public License
19  along with this program; if not, write to the Free Software
20  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
21  02111-1307, USA.
22*/
23
24#include "utility.h"
25
26#include <cassert>
27#include <cerrno> 
28#include <cstdlib>
29#include <fstream>
30#include <sstream>
31#include <stdexcept>
32#include <string>
33#include <sys/param.h>
34#include <unistd.h>
35
36#include <iostream>
37
38namespace theplu{
39namespace svndigest{
40
41  int access_rights(const std::string& path, const std::string& bits)
42  {
43    if (access(path.c_str(),F_OK)) {
44      throw std::runtime_error(std::string("access_rights: ") + path +
45                               "' does not exist.");
46    }
47    int mode=0;
48    for (u_int i=0; i<bits.length(); ++i)
49      switch (bits[i]) {
50          case 'r':
51            mode|=R_OK;
52            break;
53          case 'w':
54            mode|=W_OK;
55            break;
56          case 'x':
57            mode|=X_OK;
58            break;
59      }
60    return access(path.c_str(),mode);
61  }
62
63
64  void copy_file(const std::string& source, const std::string& target)
65  {
66    std::ofstream o(target.c_str());
67    std::ifstream i(source.c_str());
68    while (i.good()) {
69      char ch=i.get();
70      if (i.good())
71        o.put(ch);
72      if (!o.good())
73        throw std::runtime_error(std::string("copy_file: ") +
74                                 "writing target file failed '" + target + "'");
75    }
76    if (!i.eof() && (i.bad() || i.fail()))  // fail on everything except eof
77      throw std::runtime_error(std::string("copy_file: ") +
78                               "error reading source file '" + source + "'");
79    i.close(); o.close();
80  }
81
82
83  std::string directory_name(std::string path)
84  {
85    size_t pos = path.find_last_of("/");
86    if (pos==path.size()-1)
87      return directory_name(path.substr(0,path.size()-2));
88    return path.substr(0,pos+1);
89  }
90
91
92  bool equal(std::string::const_iterator first1, 
93             std::string::const_iterator end1,
94             std::string::const_iterator first2,
95             std::string::const_iterator end2)
96  {
97    if (first1==end1 && first2==end2)
98      return true;
99    if (first1!=end1 && first2!=end2 && 
100        (*first1==*first2 || *first1=='*' || *first2=='*' ||
101         *first1=='?' || *first2=='?') && 
102        equal(first1+1, end1, first2+1, end2) )
103      return true;
104    if ( (first1!=end1 && first2!=end2 && (*first1=='*'|| *first2=='*') ) && 
105         (equal(first1+1, end1, first2, end2) || 
106          equal(first1, end1, first2+1, end2))
107         )
108      return true;
109    return false;
110  }
111
112
113  std::string file_name(const std::string& full_path)
114  {
115    std::stringstream ss(full_path);
116    std::string name;
117    while (getline(ss,name,'/')) {}
118    return name;
119  }
120
121
122  std::string getenv(const std::string& var)
123  {
124    char* buffer=std::getenv(var.c_str());
125    if (!buffer)
126      throw std::runtime_error("Environment variable "+var+" is not set");
127    return std::string(buffer);
128  }
129
130
131  std::string hex(int x, u_int width)
132  {
133    std::stringstream ss;
134    ss << std::hex << x;
135    if (!width)
136      return ss.str();
137    if (ss.str().size()<width) 
138      return std::string(width-ss.str().size(), '0') + ss.str();
139    return ss.str().substr(0, width);
140  }
141
142
143  std::string htrim(std::string str)
144  {
145    size_t length=str.size();
146    while(length && isspace(str[length-1]))
147      --length;
148    return str.substr(0,length);
149  }
150
151
152  bool is_int(std::string s)
153  {
154    std::stringstream ss(s);
155    int a;
156    ss >> a;
157    if(ss.fail()) 
158      return false;
159    // Check that nothing is left on stream
160    std::string b;
161    ss >> b;
162    return b.empty();
163  }
164
165
166  std::string ltrim(std::string str)
167  {
168    size_t i = 0;
169    while(i<str.size() && isspace(str[i]))
170      ++i;
171    return str.substr(i);
172  }
173
174  void mkdir(const std::string& dir)
175  { 
176    int code = ::mkdir(dir.c_str(),0777);
177    if (code){
178      std::stringstream ss;
179      ss << "mkdir(" << dir << "): failed with error code: errno=" << errno;
180      throw std::runtime_error(ss.str());
181    }
182  }
183
184
185  bool node_exist(const std::string& path)
186  {
187    struct stat buf;
188    return !stat(path.c_str(),&buf);
189  }
190
191
192  int percent(int a, int b)
193  {
194    if (b)
195      return (100*a)/b;
196    return 0;
197  }
198
199
200  std::string pwd(void)
201  {
202    char buffer[MAXPATHLEN];
203    if (!getcwd(buffer, MAXPATHLEN))
204      throw std::runtime_error("Failed to get current working directory");
205    return std::string(buffer);
206  }
207
208
209  bool regexp(std::string::const_iterator first1, 
210              std::string::const_iterator last1,
211              std::string::const_iterator first2,
212              std::string::const_iterator last2,
213              std::vector<std::string>& vec)
214  {
215    if (vec.empty())
216      vec.push_back("");
217
218    // first two cases when ranges are empty
219    if (first1==last1 && first2==last2){
220      vec.pop_back();
221      return true;
222    }
223    if (first1==last1 || first2==last2)
224      return false;
225
226    // then we take care of the real stuff
227    if (*first2 == '*'){
228      // trying '*' to consume another character
229      vec.back().append(1, *first1);
230      if (regexp(first1+1, last1, first2, last2, vec) )
231        return true;
232      assert(vec.back().size());
233      vec.back().resize(vec.back().size()-1);
234
235      // stepping away from the '*'
236      vec.push_back("");
237      if (regexp(first1, last1, first2+1, last2, vec)) 
238        return true;
239      vec.pop_back();
240      return false;
241    }
242    else if (*first2 == '?'){
243      // eating a character
244      vec.back() = std::string(first1, first1+1);
245      vec.push_back("");
246      if (regexp(first1+1, last1, first2+1, last2, vec) )
247        return true;
248      vec.pop_back();
249      // ? interpreted as zero characters
250      vec.back() = "";
251      vec.push_back("");
252      if (regexp(first1, last1, first2+1, last2, vec) )
253        return true;
254      vec.pop_back();
255      return false;
256    }
257    if (*first1 != *first2)
258      return false;
259    return regexp(++first1, last1, ++first2, last2, vec);
260  }
261
262
263  void replace(std::string& str, std::string old_str, std::string new_str)
264  {
265    std::string::iterator iter(str.begin());
266    while ((iter=search(iter, str.end(), old_str)) != str.end()) {
267      size_t i = iter-str.begin();
268      str = std::string(str.begin(), iter) + new_str + 
269        std::string(iter+old_str.size(), str.end());
270      // pointing to char after substr we just inserted
271      iter = str.begin() + (i+new_str.size()); 
272    }
273  }
274
275
276  void touch(std::string str)
277  {
278    if (!node_exist(str)) {
279      std::ofstream os(str.c_str());
280      os.close();
281    }
282  }
283
284  time_t str2time(const std::string& str)
285  {
286    //  str in format 2006-09-09T10:55:52.132733Z
287    std::stringstream sstream(str);
288    time_t rawtime;
289    struct tm * timeinfo;
290    time ( &rawtime );
291    timeinfo =  gmtime ( &rawtime );
292
293    u_int year, month, day, hour, minute, second;
294    std::string tmp;
295    getline(sstream,tmp,'-');
296    year=atoi(tmp.c_str());
297    timeinfo->tm_year = year - 1900;
298
299    getline(sstream,tmp,'-');
300    month=atoi(tmp.c_str());
301    timeinfo->tm_mon = month - 1;
302
303    getline(sstream,tmp,'T');
304    day=atoi(tmp.c_str());
305    timeinfo->tm_mday = day;
306
307    getline(sstream,tmp,':');
308    hour=atoi(tmp.c_str());
309    timeinfo->tm_hour = hour;
310
311    getline(sstream,tmp,':');
312    minute=atoi(tmp.c_str());
313    timeinfo->tm_min = minute;
314
315    getline(sstream,tmp,'.');
316    second=atoi(tmp.c_str());
317    timeinfo->tm_sec = second;
318
319    return mktime(timeinfo);
320  }
321
322
323  std::string match(std::string::const_iterator& first,
324                    const std::string::const_iterator& last,
325                    std::string str)
326  {
327    if (match_begin(first, last, str)){
328      first+=str.size();
329      return str;
330    }
331    return std::string();
332  }
333
334}} // end of namespace svndigest and namespace theplu
Note: See TracBrowser for help on using the repository browser.