Public API changes:
 - Completely new implementation of SBType
 - Various enhancements in several other classes
Python synthetic children providers for std::vector<T>, std::list<T> and std::map<K,V>:
 - these return the actual elements into the container as the children of the container
 - basic template name parsing that works (hopefully) on both Clang and GCC
 - find them in examples/synthetic and in the test suite in functionalities/data-formatter/data-formatter-python-synth
New summary string token ${svar :
 - the syntax is just the same as in ${var but this new token lets you read the values
   coming from the synthetic children provider instead of the actual children
 - Python providers above provide a synthetic child len that returns the number of elements
   into the container
Full bug fix for the issue in which getting byte size for a non-complete type would crash LLDB
Several other fixes, including:
 - inverted the order of arguments in the ClangASTType constructor
 - EvaluationPoint now only returns SharedPointer's to Target and Process
 - the help text for several type subcommands now correctly indicates argument-less options as such


git-svn-id: https://llvm.org/svn/llvm-project/llvdb/trunk@136504 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/source/API/SBTarget.cpp b/source/API/SBTarget.cpp
index 2250440..82da45a 100644
--- a/source/API/SBTarget.cpp
+++ b/source/API/SBTarget.cpp
@@ -38,6 +38,7 @@
 #include "lldb/Host/FileSpec.h"
 #include "lldb/Host/Host.h"
 #include "lldb/Interpreter/Args.h"
+#include "lldb/Symbol/SymbolVendor.h"
 #include "lldb/Symbol/VariableList.h"
 #include "lldb/Target/Process.h"
 #include "lldb/Target/Target.h"
@@ -879,6 +880,52 @@
     return 0;
 }
 
+lldb::SBType
+SBTarget::FindFirstType (const char* type)
+{
+    if (m_opaque_sp)
+    {
+        size_t count = m_opaque_sp->GetImages().GetSize();
+        for (size_t idx = 0; idx < count; idx++)
+        {
+            SBType found_at_idx = GetModuleAtIndex(idx).FindFirstType(type);
+            
+            if (found_at_idx.IsValid())
+                return found_at_idx;
+        }
+    }
+    return SBType();
+}
+
+lldb::SBTypeList
+SBTarget::FindTypes (const char* type)
+{
+    
+    SBTypeList retval;
+    
+    if (m_opaque_sp)
+    {
+        ModuleList& images = m_opaque_sp->GetImages();
+        ConstString name_const(type);
+        SymbolContext sc;
+        TypeList type_list;
+        
+        uint32_t num_matches = images.FindTypes(sc,
+                                                name_const,
+                                                true,
+                                                UINT32_MAX,
+                                                type_list);
+        
+        for (size_t idx = 0; idx < num_matches; idx++)
+        {
+            TypeSP sp_at_idx = type_list.GetTypeAtIndex(idx);
+            
+            retval.AppendType(SBType(sp_at_idx));
+        }
+    }
+    return retval;
+}
+
 SBValueList
 SBTarget::FindGlobalVariables (const char *name, uint32_t max_matches)
 {