StringUtils.cpp 1.91 KB
Newer Older
1 2 3 4 5
#include "StringUtils.h"

using namespace std;

bool StripString(string& src)
6
{
7
    size_t pos = 0;
8

9 10
    if (src.empty())
    {
11
        return false;
12
    }
13

14 15
    while ((pos < src.length()) && (' ' == src[pos])) pos++;
    src.erase(0, pos);
16

17 18 19
    pos = 0;
    while ((pos < src.length()) && ('\t' == src[pos])) pos++;
    src.erase(0, pos);
20

21 22 23
    pos = src.length() - 1;
    while (pos && (' ' == src[pos])) pos--;
    src.erase(pos+1);
24

25 26 27
    pos = src.length() - 1;
    while (pos && ('\t' == src[pos])) pos--;
    src.erase(pos+1);
28

29 30 31 32 33 34
    return true;
}

bool ParseString(const string& src, string& key, string& value)
{
    if (src.empty())
35
        return false;
36

37
    // find seporator ":"
38 39 40 41 42 43 44 45 46 47 48 49 50
    size_t seporator_pos = src.find(":");
    if (string::npos != seporator_pos)
    {
        key = src.substr(0, seporator_pos);
        StripString(key);
        value = src.substr(seporator_pos+1);
        StripString(value);
        return true;
    }
    else
    {
        return false;
    }
51 52 53 54 55
}

set<string> SplitString(const string& src, const char seporator)
{
    set<string> result;
56

57 58
    if (!src.empty())
    {
59 60 61 62 63 64 65 66 67
        size_t seporator_pos;
        size_t prev_pos = 0;
        do
        {
            seporator_pos = src.find(seporator, prev_pos);
            result.insert(src.substr(prev_pos, seporator_pos - prev_pos));
            prev_pos = seporator_pos + 1;
        }
        while (string::npos != seporator_pos);
68
    }
69

70 71 72 73 74 75
    return result;
}

vector<string> SplitStringVector(const string& src, const char seporator)
{
    vector<string> result;
76

77 78
    if (!src.empty())
    {
79 80 81 82 83 84 85 86 87 88
        size_t seporator_pos;
        size_t prev_pos = 0;
        do
        {
            seporator_pos = src.find(seporator, prev_pos);
            string tmp = src.substr(prev_pos, seporator_pos - prev_pos);
            result.push_back(tmp);
            prev_pos = seporator_pos + 1;
        }
        while (string::npos != seporator_pos);
89 90
    }

91 92
    return result;
}