2020-01-11 15:47:41 +08:00
|
|
|
#include "llvm/ADT/ArrayRef.h"
|
|
|
|
#include "llvm/ADT/DenseMap.h"
|
|
|
|
#include "llvm/ADT/Optional.h"
|
2020-01-28 00:23:39 +08:00
|
|
|
#include "llvm/ADT/PointerIntPair.h"
|
|
|
|
#include "llvm/ADT/PointerUnion.h"
|
2020-01-11 15:47:41 +08:00
|
|
|
#include "llvm/ADT/SmallString.h"
|
|
|
|
#include "llvm/ADT/SmallVector.h"
|
2020-11-19 07:36:06 +08:00
|
|
|
#include "llvm/ADT/StringMap.h"
|
2020-01-11 15:47:41 +08:00
|
|
|
#include "llvm/ADT/Twine.h"
|
2020-01-29 05:02:17 +08:00
|
|
|
#include "llvm/ADT/ilist.h"
|
2020-01-11 15:47:41 +08:00
|
|
|
#include "llvm/Support/Error.h"
|
|
|
|
|
|
|
|
int Array[] = {1, 2, 3};
|
2020-01-28 00:23:39 +08:00
|
|
|
auto IntPtr = reinterpret_cast<int *>(0xabc);
|
2020-01-11 15:47:41 +08:00
|
|
|
|
|
|
|
llvm::ArrayRef<int> ArrayRef(Array);
|
|
|
|
llvm::MutableArrayRef<int> MutableArrayRef(Array);
|
|
|
|
llvm::DenseMap<int, int> DenseMap = {{4, 5}, {6, 7}};
|
2020-11-19 07:36:06 +08:00
|
|
|
llvm::StringMap<int> StringMap = {{"foo", 123}, {"bar", 456}};
|
2020-01-11 15:47:41 +08:00
|
|
|
llvm::Expected<int> ExpectedValue(8);
|
|
|
|
llvm::Expected<int> ExpectedError(llvm::createStringError({}, ""));
|
|
|
|
llvm::Optional<int> OptionalValue(9);
|
|
|
|
llvm::Optional<int> OptionalNone(llvm::None);
|
|
|
|
llvm::SmallVector<int, 5> SmallVector = {10, 11, 12};
|
|
|
|
llvm::SmallString<5> SmallString("foo");
|
|
|
|
llvm::StringRef StringRef = "bar";
|
|
|
|
llvm::Twine Twine = llvm::Twine(SmallString) + StringRef;
|
2020-01-28 00:23:39 +08:00
|
|
|
llvm::PointerIntPair<int *, 1> PointerIntPair(IntPtr, 1);
|
2020-01-29 16:57:54 +08:00
|
|
|
|
|
|
|
struct alignas(8) Z {};
|
|
|
|
llvm::PointerUnion<Z *, int *> PointerUnion(IntPtr);
|
|
|
|
|
|
|
|
// No members which instantiate PointerUnionUIntTraits<Z *> (e.g. get<T *>())
|
|
|
|
// are called, and this instance will therefore be raw-printed.
|
|
|
|
llvm::PointerUnion<Z *, float *> RawPrintingPointerUnion(nullptr);
|
2020-01-11 15:47:41 +08:00
|
|
|
|
2020-01-29 05:02:17 +08:00
|
|
|
using IlistTag = llvm::ilist_tag<struct A>;
|
|
|
|
using SimpleIlistTag = llvm::ilist_tag<struct B>;
|
|
|
|
struct IlistNode : llvm::ilist_node<IlistNode, IlistTag>,
|
|
|
|
llvm::ilist_node<IlistNode, SimpleIlistTag> {
|
|
|
|
int Value;
|
|
|
|
};
|
|
|
|
auto Ilist = [] {
|
|
|
|
llvm::ilist<IlistNode, IlistTag> Result;
|
|
|
|
for (int I : {13, 14, 15}) {
|
|
|
|
Result.push_back(new IlistNode);
|
|
|
|
Result.back().Value = I;
|
|
|
|
}
|
|
|
|
return Result;
|
|
|
|
}();
|
|
|
|
auto SimpleIlist = []() {
|
|
|
|
llvm::simple_ilist<IlistNode, SimpleIlistTag> Result;
|
|
|
|
for (auto &Node : Ilist)
|
|
|
|
Result.push_front(Node);
|
|
|
|
return Result;
|
|
|
|
}();
|
|
|
|
|
2020-09-29 21:19:54 +08:00
|
|
|
int main() {
|
|
|
|
// Reference symbols that might otherwise be stripped.
|
|
|
|
ArrayRef[0];
|
|
|
|
MutableArrayRef[0];
|
2021-01-07 12:39:07 +08:00
|
|
|
(void)!ExpectedValue;
|
|
|
|
(void)!ExpectedError;
|
2020-09-29 21:19:54 +08:00
|
|
|
*OptionalValue;
|
|
|
|
*OptionalNone;
|
|
|
|
return 0;
|
|
|
|
}
|