diff options
author | Jörg Frings-Fürst <debian@jff-webhosting.net> | 2015-11-21 14:51:17 +0100 |
---|---|---|
committer | Jörg Frings-Fürst <debian@jff-webhosting.net> | 2015-11-21 14:51:17 +0100 |
commit | bb9bc9051629c3319c56785c2f4ae0e605d76329 (patch) | |
tree | ec393eb145e5a7d43909bdfc43cdeaa28c4e434a /src/bitz/util.h |
Initial import of bitz-server version 0.1.6-1
Diffstat (limited to 'src/bitz/util.h')
-rw-r--r-- | src/bitz/util.h | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/src/bitz/util.h b/src/bitz/util.h new file mode 100644 index 0000000..da1b544 --- /dev/null +++ b/src/bitz/util.h @@ -0,0 +1,92 @@ +/* + * bitz-server, An ICAP server implementation in C++ + * Copyright (C) 2012 Uditha Atukorala + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + */ + +#ifndef BITZ_UTIL_H +#define BITZ_UTIL_H + +#include "common.h" + +#include <string> +#include <sstream> + + +namespace bitz { + + namespace util { + + /** + * Convert a number into a string + * + * @param number number to be converted + * @return converted string + */ + template <typename T> std::string itoa( T number ) { + std::ostringstream ss; + ss << number; + + return ss.str(); + } + + /** + * Find a matching request handler for the given method + * + * @param req_handlers request handlers + * @param req_method request method + * @return request handler (or null pointer if not found) + */ + RequestHandler * find_req_handler( req_handlers_t req_handlers, const std::string &req_method ) throw(); + + /** + * Helper method to delete any loaded request handlers apart + * from the OPTIONS handler + * + * @param req_handlers request handlers + */ + void delete_req_handlers( req_handlers_t req_handlers ) throw(); + + /** + * Extract directory path from a path + * + * @param path path to extract the directory from + * @return directory path + */ + std::string dirpath( const std::string &path ) throw(); + + /** + * Extract the file name from a path + * + * @param path path to extract the file name from + * @return file name + */ + std::string filename( const std::string &path ) throw(); + + /** + * Create a directory tree recursively + * + * @param path full directory path + * @return boolean to denote success or failure + */ + bool mkdirp( const std::string &path ) throw(); + + } /* end of namespace util */ + +} /* end of namespace bitz */ + +#endif /* !BITZ_UTIL_H */ + |