summaryrefslogtreecommitdiffstats
path: root/src/translators/pilotdb/strop.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/translators/pilotdb/strop.h')
-rw-r--r--src/translators/pilotdb/strop.h153
1 files changed, 153 insertions, 0 deletions
diff --git a/src/translators/pilotdb/strop.h b/src/translators/pilotdb/strop.h
new file mode 100644
index 0000000..3d9dc8d
--- /dev/null
+++ b/src/translators/pilotdb/strop.h
@@ -0,0 +1,153 @@
+/*
+ * palm-db-tools: Support Library: String Parsing Utility Functions
+ * Copyright (C) 1999-2000 by Tom Dyas (tdyas@users.sourceforge.net)
+ *
+ * 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 2 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., 51 Franklin Street, Fifh Floor, Boston, MA 02110-1301 USA
+ */
+
+#ifndef __LIBSUPPORT_STROP_H__
+#define __LIBSUPPORT_STROP_H__
+
+#include <stdexcept>
+#include <vector>
+#include <string>
+#include <sstream>
+#include <time.h>
+#include "libflatfile/Database.h"
+
+namespace StrOps {
+
+ // This exception is thrown whenever an error is encountered in
+ // csv_to_array and str_to_array.
+ class csv_parse_error : public std::runtime_error {
+ public:
+ csv_parse_error(const std::string& msg) : std::runtime_error(msg) { }
+ };
+
+ class csv_unterminated_quote : public std::runtime_error {
+ public:
+ csv_unterminated_quote(const std::string& msg) : std::runtime_error(msg) { }
+ };
+
+ // The results of any parse are returned as this type.
+ typedef std::vector<std::string> string_list_t;
+
+
+ /**
+ * Convert all uppercase characters in a string to lowercase.
+ */
+ void lower(std::string& str);
+
+ /**
+ * Convert a string to a boolean value.
+ *
+ * @param str The string containing a boolean value to convert.
+ */
+ bool string2boolean(const std::string& str);
+
+ /**
+ * Convert a string to a FieldType value.
+ *
+ * @param typestr The string containing a FieldType value to convert.
+ */
+ PalmLib::FlatFile::Field::FieldType string2type(std::string typestr);
+
+ /**
+ * Convert a FieldType value to a string.
+ *
+ * @param t The FieldType value containing a string to convert.
+ */
+ std::string type2string(PalmLib::FlatFile::Field::FieldType t);
+
+ /**
+ * Strip trailing characters from a string.
+ *
+ * @param str The string to strip characters from.
+ * @param what The string containing characters to strip.
+ */
+ std::string strip_back(const std::string& str, const std::string& what);
+
+ /**
+ * Strip leading characters from a string.
+ *
+ * @param str The string to strip characters from.
+ * @param what The string containing characters to strip.
+ */
+ std::string strip_front(const std::string& str, const std::string& what);
+
+ /**
+ * Convert a string to a target type using a istringstream.
+ */
+ template<class T>
+ inline void convert_string(const std::string& str, T& result) {
+ std::istringstream(str.c_str()) >> result;
+ }
+
+ /**
+ * Parse a string in CSV (comman-seperated values) format and
+ * return it as a list.
+ *
+ * @param str The string containing the CSV fields.
+ * @param delim The field delimiter. Defaults to a comma.
+ */
+ string_list_t csv_to_array(const std::string& str, char delim = ',', bool quoted_string = true);
+
+
+ /**
+ * Parse an argv-style array and return it as a list.
+ *
+ * @param str The string to parse.
+ * @param delim String containing the delimiter characters.
+ * @param multiple_delim Should multiple delimiters count as one?
+ * @param handle_comments Handle # as a comment character.
+ */
+ string_list_t str_to_array(const std::string& str,
+ const std::string& delim,
+ bool multiple_delim,
+ bool handle_comments);
+
+ /**
+ * return the current date in the palm format.
+ */
+ PalmLib::pi_uint32_t get_current_time(void);
+
+ /**
+ * fill a char array with a tm structure in the format passed.
+ * @param s the char array filled.
+ * @param format the string of the format to use to print the date.
+ * @param tm a pointer to time structure.
+ */
+ char *strptime(const char *s, const char *format, struct tm *tm);
+
+ /**
+ * read one line from the input stream of a file
+ */
+ std::string readline(std::istream& stream);
+
+ /**
+ * add the quotes to a string
+ */
+ std::string quote_string(std::string str, bool extended_mode);
+
+ /**
+ * concatenate the path directory, the file name and the extension
+ * to give the file path to a file
+ */
+ std::string concatenatepath(std::string p_Path, std::string p_FileName,
+ std::string p_Ext = std::string(""));
+
+} // namespace StrOps
+
+#endif