summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorSaleem Abdulrasool <compnerd@compnerd.org>2015-11-12 03:57:16 +0000
committerSaleem Abdulrasool <compnerd@compnerd.org>2015-11-12 03:57:16 +0000
commit5d92eaeb17f9b3b384a9d62036ee9d81134d2762 (patch)
treeb7258c534328986f4abffbcbfa9016ed92e4b6a6 /clang
parent2af10e2eed41b8d110f905f726e4467bb03e6ed1 (diff)
downloadbcm5719-llvm-5d92eaeb17f9b3b384a9d62036ee9d81134d2762.tar.gz
bcm5719-llvm-5d92eaeb17f9b3b384a9d62036ee9d81134d2762.zip
libclang: add new StringSet type
This allows the return of a set of CXStrings from libclang. This is setup work for an upcoming change to permit returning multiple mangled symbols. llvm-svn: 252852
Diffstat (limited to 'clang')
-rw-r--r--clang/include/clang-c/CXString.h10
-rw-r--r--clang/tools/libclang/CXString.cpp15
-rw-r--r--clang/tools/libclang/CXString.h2
-rw-r--r--clang/tools/libclang/libclang.exports1
4 files changed, 28 insertions, 0 deletions
diff --git a/clang/include/clang-c/CXString.h b/clang/include/clang-c/CXString.h
index a649cdf82fc..68ab7bc5244 100644
--- a/clang/include/clang-c/CXString.h
+++ b/clang/include/clang-c/CXString.h
@@ -40,6 +40,11 @@ typedef struct {
unsigned private_flags;
} CXString;
+typedef struct {
+ CXString *Strings;
+ unsigned Count;
+} CXStringSet;
+
/**
* \brief Retrieve the character data associated with the given string.
*/
@@ -51,6 +56,11 @@ CINDEX_LINKAGE const char *clang_getCString(CXString string);
CINDEX_LINKAGE void clang_disposeString(CXString string);
/**
+ * \brief Free the given string set.
+ */
+CINDEX_LINKAGE void clang_disposeStringSet(CXStringSet *set);
+
+/**
* @}
*/
diff --git a/clang/tools/libclang/CXString.cpp b/clang/tools/libclang/CXString.cpp
index dec8ebcd98e..ca9989bc21c 100644
--- a/clang/tools/libclang/CXString.cpp
+++ b/clang/tools/libclang/CXString.cpp
@@ -112,6 +112,15 @@ CXString createCXString(CXStringBuf *buf) {
return Str;
}
+CXStringSet *createSet(const std::vector<std::string> &Strings) {
+ CXStringSet *Set = new CXStringSet;
+ Set->Count = Strings.size();
+ Set->Strings = new CXString[Set->Count];
+ for (unsigned SI = 0, SE = Set->Count; SI < SE; ++SI)
+ Set->Strings[SI] = createDup(Strings[SI]);
+ return Set;
+}
+
//===----------------------------------------------------------------------===//
// String pools.
@@ -175,5 +184,11 @@ void clang_disposeString(CXString string) {
break;
}
}
+
+void clang_disposeStringSet(CXStringSet *set) {
+ delete[] set->Strings;
+ delete set;
+}
+
} // end: extern "C"
diff --git a/clang/tools/libclang/CXString.h b/clang/tools/libclang/CXString.h
index 72ac0cf4691..6473eb2d710 100644
--- a/clang/tools/libclang/CXString.h
+++ b/clang/tools/libclang/CXString.h
@@ -68,6 +68,8 @@ CXString createRef(std::string String) = delete;
/// \brief Create a CXString object that is backed by a string buffer.
CXString createCXString(CXStringBuf *buf);
+CXStringSet *createSet(const std::vector<std::string> &Strings);
+
/// \brief A string pool used for fast allocation/deallocation of strings.
class CXStringPool {
public:
diff --git a/clang/tools/libclang/libclang.exports b/clang/tools/libclang/libclang.exports
index fd157bc4951..352ba5766ae 100644
--- a/clang/tools/libclang/libclang.exports
+++ b/clang/tools/libclang/libclang.exports
@@ -120,6 +120,7 @@ clang_disposeOverriddenCursors
clang_disposeCXPlatformAvailability
clang_disposeSourceRangeList
clang_disposeString
+clang_disposeStringSet
clang_disposeTokens
clang_disposeTranslationUnit
clang_enableStackTraces
OpenPOWER on IntegriCloud