mirror of
https://github.com/intel/llvm.git
synced 2026-01-15 12:25:46 +08:00
Added a new "interpreter" properties to encapsulate any properties for the command interpreter. Right now this contains only "expand-regex-aliases", so you can now enable (disabled by default) the echoing of the command that a regular expression alias expands to: (lldb) b main Breakpoint created: 1: name = 'main', locations = 1 Note that the expanded regular expression command wasn't shown by default. You can enable it if you want to: (lldb) settings set interpreter.expand-regex-aliases true (lldb) b main breakpoint set --name 'main' Breakpoint created: 1: name = 'main', locations = 1 Also enabled auto completion for enumeration option values (OptionValueEnumeration) and for boolean option values (OptionValueBoolean). Fixed auto completion for settings names when nothing has been type (it should show all settings). llvm-svn: 162418
291 lines
6.0 KiB
C++
291 lines
6.0 KiB
C++
//===-- StringList.cpp ------------------------------------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "lldb/Core/StringList.h"
|
|
|
|
#include "lldb/Core/StreamString.h"
|
|
#include "lldb/Host/FileSpec.h"
|
|
|
|
#include <string>
|
|
|
|
using namespace lldb_private;
|
|
|
|
StringList::StringList () :
|
|
m_strings ()
|
|
{
|
|
}
|
|
|
|
StringList::StringList (const char *str) :
|
|
m_strings ()
|
|
{
|
|
if (str)
|
|
m_strings.push_back (str);
|
|
}
|
|
|
|
StringList::StringList (const char **strv, int strc) :
|
|
m_strings ()
|
|
{
|
|
for (int i = 0; i < strc; ++i)
|
|
{
|
|
if (strv[i])
|
|
m_strings.push_back (strv[i]);
|
|
}
|
|
}
|
|
|
|
StringList::~StringList ()
|
|
{
|
|
}
|
|
|
|
void
|
|
StringList::AppendString (const char *str)
|
|
{
|
|
if (str)
|
|
m_strings.push_back (str);
|
|
}
|
|
|
|
void
|
|
StringList::AppendString (const std::string &s)
|
|
{
|
|
m_strings.push_back (s);
|
|
}
|
|
|
|
void
|
|
StringList::AppendString (const char *str, size_t str_len)
|
|
{
|
|
if (str)
|
|
m_strings.push_back (std::string (str, str_len));
|
|
}
|
|
|
|
void
|
|
StringList::AppendList (const char **strv, int strc)
|
|
{
|
|
for (int i = 0; i < strc; ++i)
|
|
{
|
|
if (strv[i])
|
|
m_strings.push_back (strv[i]);
|
|
}
|
|
}
|
|
|
|
void
|
|
StringList::AppendList (StringList strings)
|
|
{
|
|
uint32_t len = strings.GetSize();
|
|
|
|
for (uint32_t i = 0; i < len; ++i)
|
|
m_strings.push_back (strings.GetStringAtIndex(i));
|
|
}
|
|
|
|
bool
|
|
StringList::ReadFileLines (FileSpec &input_file)
|
|
{
|
|
return input_file.ReadFileLines (m_strings);
|
|
}
|
|
|
|
uint32_t
|
|
StringList::GetSize () const
|
|
{
|
|
return m_strings.size();
|
|
}
|
|
|
|
const char *
|
|
StringList::GetStringAtIndex (size_t idx) const
|
|
{
|
|
if (idx < m_strings.size())
|
|
return m_strings[idx].c_str();
|
|
return NULL;
|
|
}
|
|
|
|
void
|
|
StringList::Join (const char *separator, Stream &strm)
|
|
{
|
|
uint32_t size = GetSize();
|
|
|
|
if (size == 0)
|
|
return;
|
|
|
|
for (uint32_t i = 0; i < size; ++i)
|
|
{
|
|
if (i > 0)
|
|
strm.PutCString(separator);
|
|
strm.PutCString(GetStringAtIndex(i));
|
|
}
|
|
}
|
|
|
|
void
|
|
StringList::Clear ()
|
|
{
|
|
m_strings.clear();
|
|
}
|
|
|
|
void
|
|
StringList::LongestCommonPrefix (std::string &common_prefix)
|
|
{
|
|
//arg_sstr_collection::iterator pos, end = m_args.end();
|
|
int pos = 0;
|
|
int end = m_strings.size();
|
|
|
|
if (pos == end)
|
|
common_prefix.clear();
|
|
else
|
|
common_prefix = m_strings[pos];
|
|
|
|
for (++pos; pos != end; ++pos)
|
|
{
|
|
size_t new_size = strlen (m_strings[pos].c_str());
|
|
|
|
// First trim common_prefix if it is longer than the current element:
|
|
if (common_prefix.size() > new_size)
|
|
common_prefix.erase (new_size);
|
|
|
|
// Then trim it at the first disparity:
|
|
|
|
for (size_t i = 0; i < common_prefix.size(); i++)
|
|
{
|
|
if (m_strings[pos][i] != common_prefix[i])
|
|
{
|
|
common_prefix.erase(i);
|
|
break;
|
|
}
|
|
}
|
|
|
|
// If we've emptied the common prefix, we're done.
|
|
if (common_prefix.empty())
|
|
break;
|
|
}
|
|
}
|
|
|
|
void
|
|
StringList::InsertStringAtIndex (size_t idx, const char *str)
|
|
{
|
|
if (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())
|
|
m_strings.erase (m_strings.begin() + idx);
|
|
}
|
|
|
|
size_t
|
|
StringList::SplitIntoLines (const char *lines, size_t len)
|
|
{
|
|
const size_t orig_size = m_strings.size();
|
|
|
|
if (len == 0)
|
|
return 0;
|
|
|
|
const char *k_newline_chars = "\r\n";
|
|
const char *p = lines;
|
|
const char *end = lines + len;
|
|
while (p < end)
|
|
{
|
|
size_t count = strcspn (p, k_newline_chars);
|
|
if (count == 0)
|
|
{
|
|
if (p[count] == '\r' || p[count] == '\n')
|
|
m_strings.push_back(std::string());
|
|
else
|
|
break;
|
|
}
|
|
else
|
|
{
|
|
if (p + count > end)
|
|
count = end - p;
|
|
m_strings.push_back(std::string(p, count));
|
|
}
|
|
if (p[count] == '\r' && p[count+1] == '\n')
|
|
count++; // Skip an extra newline char for the DOS newline
|
|
count++; // Skip the newline character
|
|
p += count;
|
|
}
|
|
return m_strings.size() - orig_size;
|
|
}
|
|
|
|
void
|
|
StringList::RemoveBlankLines ()
|
|
{
|
|
if (GetSize() == 0)
|
|
return;
|
|
|
|
size_t idx = 0;
|
|
while (idx < m_strings.size())
|
|
{
|
|
if (m_strings[idx].empty())
|
|
DeleteStringAtIndex(idx);
|
|
else
|
|
idx++;
|
|
}
|
|
}
|
|
|
|
std::string
|
|
StringList::CopyList(const char* item_preamble,
|
|
const char* items_sep)
|
|
{
|
|
StreamString strm;
|
|
for (int i = 0; i < GetSize(); i++)
|
|
{
|
|
if (i && items_sep && items_sep[0])
|
|
strm << items_sep;
|
|
if (item_preamble)
|
|
strm << item_preamble;
|
|
strm << GetStringAtIndex(i);
|
|
}
|
|
return std::string(strm.GetData());
|
|
}
|
|
|
|
StringList&
|
|
StringList::operator << (const char* str)
|
|
{
|
|
AppendString(str);
|
|
return *this;
|
|
}
|
|
|
|
StringList&
|
|
StringList::operator << (StringList strings)
|
|
{
|
|
AppendList(strings);
|
|
return *this;
|
|
}
|
|
|
|
size_t
|
|
StringList::AutoComplete (const char *s, StringList &matches, size_t &exact_idx) const
|
|
{
|
|
matches.Clear();
|
|
exact_idx = SIZE_MAX;
|
|
if (s && s[0])
|
|
{
|
|
const size_t s_len = strlen (s);
|
|
const size_t num_strings = m_strings.size();
|
|
|
|
for (size_t i=0; i<num_strings; ++i)
|
|
{
|
|
if (m_strings[i].find(s) == 0)
|
|
{
|
|
if (exact_idx == SIZE_MAX && m_strings[i].size() == s_len)
|
|
exact_idx = matches.GetSize();
|
|
matches.AppendString (m_strings[i]);
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
// No string, so it matches everything
|
|
matches = *this;
|
|
}
|
|
return matches.GetSize();
|
|
}
|
|
|