diff options
| author | Ed Maste <emaste@FreeBSD.org> | 2014-02-18 16:23:10 +0000 | 
|---|---|---|
| committer | Ed Maste <emaste@FreeBSD.org> | 2014-02-18 16:23:10 +0000 | 
| commit | 866dcdacfe59f5f448e008fe2c4cb9dfcf72b2ec (patch) | |
| tree | 95cb16075f0af1b3a05b9b84eb18dda8e6c903e9 /source/Core/StringList.cpp | |
| parent | de889deb2c386f2a7831befaf226e5c86685fa53 (diff) | |
Notes
Diffstat (limited to 'source/Core/StringList.cpp')
| -rw-r--r-- | source/Core/StringList.cpp | 91 | 
1 files changed, 68 insertions, 23 deletions
| diff --git a/source/Core/StringList.cpp b/source/Core/StringList.cpp index 994975116789..d2fa8cfb4a88 100644 --- a/source/Core/StringList.cpp +++ b/source/Core/StringList.cpp @@ -56,6 +56,12 @@ StringList::AppendString (const std::string &s)  }  void +StringList::AppendString (std::string &&s) +{ +    m_strings.push_back (s); +} + +void  StringList::AppendString (const char *str, size_t str_len)  {      if (str) @@ -93,6 +99,20 @@ StringList::GetSize () const      return m_strings.size();  } +size_t +StringList::GetMaxStringLength () const +{ +    size_t max_length = 0; +    for (const auto &s : m_strings) +    { +        const size_t len = s.size(); +        if (max_length < len) +            max_length = len; +    } +    return max_length; +} + +  const char *  StringList::GetStringAtIndex (size_t idx) const  { @@ -126,37 +146,39 @@ StringList::Clear ()  void  StringList::LongestCommonPrefix (std::string &common_prefix)  { -    //arg_sstr_collection::iterator pos, end = m_args.end(); -    size_t pos = 0; -    size_t end = m_strings.size(); +    const size_t num_strings = m_strings.size(); -    if (pos == end) +    if (num_strings == 0) +    {          common_prefix.clear(); +    }      else -        common_prefix = m_strings[pos]; - -    for (++pos; pos != end; ++pos)      { -        size_t new_size = strlen (m_strings[pos].c_str()); +        common_prefix = m_strings.front(); -        // First trim common_prefix if it is longer than the current element: -        if (common_prefix.size() > new_size) -            common_prefix.erase (new_size); +        for (size_t idx = 1; idx < num_strings; ++idx) +        { +            std::string &curr_string = m_strings[idx]; +            size_t new_size = curr_string.size(); -        // Then trim it at the first disparity: +            // First trim common_prefix if it is longer than the current element: +            if (common_prefix.size() > new_size) +                common_prefix.erase (new_size); -        for (size_t i = 0; i < common_prefix.size(); i++) -        { -            if (m_strings[pos][i]  != common_prefix[i]) +            // Then trim it at the first disparity: +            for (size_t i = 0; i < common_prefix.size(); i++)              { -                common_prefix.erase(i); -                break; +                if (curr_string[i] != common_prefix[i]) +                { +                    common_prefix.erase(i); +                    break; +                }              } -        } -        // If we've emptied the common prefix, we're done. -        if (common_prefix.empty()) -            break; +            // If we've emptied the common prefix, we're done. +            if (common_prefix.empty()) +                break; +        }      }  } @@ -173,6 +195,24 @@ StringList::InsertStringAtIndex (size_t idx, const char *str)  }  void +StringList::InsertStringAtIndex (size_t idx, const std::string &str) +{ +    if (idx < m_strings.size()) +        m_strings.insert (m_strings.begin() + idx, str); +    else +        m_strings.push_back (str); +} + +void +StringList::InsertStringAtIndex (size_t idx, std::string &&str) +{ +    if (idx < m_strings.size()) +        m_strings.insert (m_strings.begin() + idx, str); +    else +        m_strings.push_back (str); +} + +void  StringList::DeleteStringAtIndex (size_t idx)  {      if (idx < m_strings.size()) @@ -180,6 +220,12 @@ StringList::DeleteStringAtIndex (size_t idx)  }  size_t +StringList::SplitIntoLines (const std::string &lines) +{ +    return SplitIntoLines (lines.c_str(), lines.size()); +} + +size_t  StringList::SplitIntoLines (const char *lines, size_t len)  {      const size_t orig_size = m_strings.size(); @@ -231,8 +277,7 @@ StringList::RemoveBlankLines ()  }  std::string -StringList::CopyList(const char* item_preamble, -                     const char* items_sep) +StringList::CopyList(const char* item_preamble, const char* items_sep) const  {      StreamString strm;      for (size_t i = 0; i < GetSize(); i++) | 
