Reimplemented the code that backed the "settings" in lldb. There were many issues with the previous implementation:
- no setting auto completion
- very manual and error prone way of getting/setting variables
- tons of code duplication
- useless instance names for processes, threads

Now settings can easily be defined like option values. The new settings makes use of the "OptionValue" classes so we can re-use the option value code that we use to set settings in command options. No more instances, just "does the right thing".



git-svn-id: https://llvm.org/svn/llvm-project/lldb/trunk@162366 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/source/Interpreter/OptionValueEnumeration.cpp b/source/Interpreter/OptionValueEnumeration.cpp
new file mode 100644
index 0000000..61b184f
--- /dev/null
+++ b/source/Interpreter/OptionValueEnumeration.cpp
@@ -0,0 +1,131 @@
+//===-- OptionValueEnumeration.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/Interpreter/OptionValueEnumeration.h"
+
+// C Includes
+// C++ Includes
+// Other libraries and framework includes
+// Project includes
+
+using namespace lldb;
+using namespace lldb_private;
+
+OptionValueEnumeration::OptionValueEnumeration (const OptionEnumValueElement *enumerators,
+                                                enum_type value) :
+    OptionValue(),
+    m_current_value (value),
+    m_default_value (value),
+    m_enumerations ()
+{
+    SetEnumerations(enumerators);
+}
+
+OptionValueEnumeration::~OptionValueEnumeration()
+{
+}
+
+void
+OptionValueEnumeration::DumpValue (const ExecutionContext *exe_ctx, Stream &strm, uint32_t dump_mask)
+{
+    if (dump_mask & eDumpOptionType)
+        strm.Printf ("(%s)", GetTypeAsCString ());
+    if (dump_mask & eDumpOptionValue)
+    {
+        if (dump_mask & eDumpOptionType)
+            strm.PutCString (" = ");
+        const size_t count = m_enumerations.GetSize ();
+        for (size_t i=0; i<count; ++i)
+        {
+            if (m_enumerations.GetValueAtIndexUnchecked(i).value == m_current_value)
+            {
+                strm.PutCString(m_enumerations.GetCStringAtIndex(i));
+                return;
+            }
+        }
+        strm.Printf("%llu", (uint64_t)m_current_value);
+    }
+}
+
+Error
+OptionValueEnumeration::SetValueFromCString (const char *value, VarSetOperationType op)
+{
+    Error error;
+    switch (op)
+    {
+        case eVarSetOperationClear:
+            Clear ();
+            break;
+            
+        case eVarSetOperationReplace:
+        case eVarSetOperationAssign:
+            if (value && value[0])
+            {
+                ConstString const_enumerator_name(value);
+                const EnumerationMapEntry *enumerator_entry = m_enumerations.FindFirstValueForName (const_enumerator_name.GetCString());
+                if (enumerator_entry)
+                {
+                    m_current_value = enumerator_entry->value.value;
+                }
+                else
+                {
+                    StreamString error_strm;
+                    error_strm.Printf("invalid enumeration value '%s'", value);
+                    const size_t count = m_enumerations.GetSize ();
+                    if (count)
+                    {
+                        error_strm.Printf(", valid values are: %s", m_enumerations.GetCStringAtIndex(0));
+                        for (size_t i=1; i<count; ++i)
+                        {
+                            error_strm.Printf (", %s", m_enumerations.GetCStringAtIndex(i));
+                        }
+                    }
+                    error.SetErrorString(error_strm.GetData());
+                }
+            }
+            else
+            {
+                error.SetErrorString("invalid enumeration value");
+            }
+            break;
+            
+        case eVarSetOperationInsertBefore:
+        case eVarSetOperationInsertAfter:
+        case eVarSetOperationRemove:
+        case eVarSetOperationAppend:
+        case eVarSetOperationInvalid:
+            error = OptionValue::SetValueFromCString (value, op);
+            break;
+    }
+    return error;
+}
+
+void
+OptionValueEnumeration::SetEnumerations (const OptionEnumValueElement *enumerators)
+{
+    m_enumerations.Clear();
+    if (enumerators)
+    {
+        for (size_t i=0; enumerators[i].string_value != NULL; ++i)
+        {
+            ConstString const_enumerator_name(enumerators[i].string_value);
+            EnumeratorInfo enumerator_info = { enumerators[i].value, enumerators[i].usage };
+            m_enumerations.Append (const_enumerator_name.GetCString(), enumerator_info);
+        }
+        m_enumerations.Sort();
+    }
+}
+
+
+lldb::OptionValueSP
+OptionValueEnumeration::DeepCopy () const
+{
+    return OptionValueSP(new OptionValueEnumeration(*this));
+}
+