hstring.h 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. #ifndef HV_STRING_H_
  2. #define HV_STRING_H_
  3. #include <string>
  4. #include <vector>
  5. #include <map>
  6. #include "hbase.h"
  7. using std::string;
  8. typedef std::vector<string> StringList;
  9. // MultiMap
  10. namespace std {
  11. /*
  12. int main() {
  13. std::MultiMap<std::string, std::string> kvs;
  14. kvs["name"] = "hw";
  15. kvs["filename"] = "1.jpg";
  16. kvs["filename"] = "2.jpg";
  17. //kvs.insert(std::pair<std::string,std::string>("name", "hw"));
  18. //kvs.insert(std::pair<std::string,std::string>("filename", "1.jpg"));
  19. //kvs.insert(std::pair<std::string,std::string>("filename", "2.jpg"));
  20. for (auto& pair : kvs) {
  21. printf("%s:%s\n", pair.first.c_str(), pair.second.c_str());
  22. }
  23. auto iter = kvs.find("filename");
  24. if (iter != kvs.end()) {
  25. for (int i = 0; i < kvs.count("filename"); ++i, ++iter) {
  26. printf("%s:%s\n", iter->first.c_str(), iter->second.c_str());
  27. }
  28. }
  29. return 0;
  30. }
  31. */
  32. template<typename Key,typename Value>
  33. class MultiMap : public multimap<Key, Value> {
  34. public:
  35. Value& operator[](Key key) {
  36. auto iter = this->insert(std::pair<Key,Value>(key,Value()));
  37. return (*iter).second;
  38. }
  39. };
  40. }
  41. // MAP
  42. #ifdef USE_MULTIMAP
  43. #define MAP std::MultiMap
  44. #else
  45. #define MAP std::map
  46. #endif
  47. // KeyValue
  48. typedef MAP<std::string, std::string> KeyValue;
  49. // std::map<std::string, std::string, StringCaseLess>
  50. class StringCaseLess : public std::binary_function<std::string, std::string, bool> {
  51. public:
  52. bool operator()(const std::string& lhs, const std::string& rhs) const {
  53. return stricmp(lhs.c_str(), rhs.c_str()) < 0;
  54. }
  55. };
  56. #define SPACE_CHARS " \t\r\n"
  57. #define PAIR_CHARS "{}[]()<>\"\"\'\'``"
  58. string asprintf(const char* fmt, ...);
  59. // x,y,z
  60. StringList split(const string& str, char delim = ',');
  61. // user=amdin&pswd=123456
  62. KeyValue splitKV(const string& str, char kv_kv = '&', char k_v = '=');
  63. string trim(const string& str, const char* chars = SPACE_CHARS);
  64. string trimL(const string& str, const char* chars = SPACE_CHARS);
  65. string trimR(const string& str, const char* chars = SPACE_CHARS);
  66. string trim_pairs(const string& str, const char* pairs = PAIR_CHARS);
  67. string replace(const string& str, const string& find, const string& rep);
  68. // str=/mnt/share/image/test.jpg
  69. // basename=test.jpg
  70. // dirname=/mnt/share/image
  71. // filename=test
  72. // suffixname=jpg
  73. string basename(const string& str);
  74. string dirname(const string& str);
  75. string filename(const string& str);
  76. string suffixname(const string& str);
  77. #endif // HV_STRING_H_