summaryrefslogtreecommitdiffstats
path: root/llvm/unittests/MC
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2014-07-03 02:01:39 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2014-07-03 02:01:39 +0000
commit97de474a36c4df5f9de603c1d6ae2f3e0b268cf4 (patch)
treec3d8590271a568a3c79c32bada8dd98fa2491993 /llvm/unittests/MC
parentb6e8ce82509e9ba93238a6eb90fed2007db1bc76 (diff)
downloadbcm5719-llvm-97de474a36c4df5f9de603c1d6ae2f3e0b268cf4.tar.gz
bcm5719-llvm-97de474a36c4df5f9de603c1d6ae2f3e0b268cf4.zip
Invert the MC -> Object dependency.
Now that we have a lib/MC/MCAnalysis, the dependency was there just because of two helper classes. Move the two over to MC. This will allow IRObjectFile to parse inline assembly. llvm-svn: 212248
Diffstat (limited to 'llvm/unittests/MC')
-rw-r--r--llvm/unittests/MC/CMakeLists.txt2
-rw-r--r--llvm/unittests/MC/StringTableBuilderTest.cpp40
-rw-r--r--llvm/unittests/MC/YAMLTest.cpp38
3 files changed, 80 insertions, 0 deletions
diff --git a/llvm/unittests/MC/CMakeLists.txt b/llvm/unittests/MC/CMakeLists.txt
index 496056ecf59..e2beab22ff9 100644
--- a/llvm/unittests/MC/CMakeLists.txt
+++ b/llvm/unittests/MC/CMakeLists.txt
@@ -4,4 +4,6 @@ set(LLVM_LINK_COMPONENTS
add_llvm_unittest(MCTests
MCAtomTest.cpp
+ StringTableBuilderTest.cpp
+ YAMLTest.cpp
)
diff --git a/llvm/unittests/MC/StringTableBuilderTest.cpp b/llvm/unittests/MC/StringTableBuilderTest.cpp
new file mode 100644
index 00000000000..d30dc6222d2
--- /dev/null
+++ b/llvm/unittests/MC/StringTableBuilderTest.cpp
@@ -0,0 +1,40 @@
+//===----------- StringTableBuilderTest.cpp -------------------------------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#include "llvm/MC/StringTableBuilder.h"
+#include "gtest/gtest.h"
+#include <string>
+
+using namespace llvm;
+
+namespace {
+
+TEST(StringTableBuilderTest, Basic) {
+ StringTableBuilder B;
+
+ B.add("foo");
+ B.add("bar");
+ B.add("foobar");
+
+ B.finalize();
+
+ std::string Expected;
+ Expected += '\x00';
+ Expected += "foobar";
+ Expected += '\x00';
+ Expected += "foo";
+ Expected += '\x00';
+
+ EXPECT_EQ(Expected, B.data());
+ EXPECT_EQ(1U, B.getOffset("foobar"));
+ EXPECT_EQ(4U, B.getOffset("bar"));
+ EXPECT_EQ(8U, B.getOffset("foo"));
+}
+
+}
diff --git a/llvm/unittests/MC/YAMLTest.cpp b/llvm/unittests/MC/YAMLTest.cpp
new file mode 100644
index 00000000000..09709ad73fc
--- /dev/null
+++ b/llvm/unittests/MC/YAMLTest.cpp
@@ -0,0 +1,38 @@
+//===- llvm/unittest/Object/YAMLTest.cpp - Tests for Object YAML ----------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#include "llvm/MC/YAML.h"
+#include "llvm/Support/YAMLTraits.h"
+#include "gtest/gtest.h"
+
+using namespace llvm;
+
+struct BinaryHolder {
+ yaml::BinaryRef Binary;
+};
+
+namespace llvm {
+namespace yaml {
+template <>
+struct MappingTraits<BinaryHolder> {
+ static void mapping(IO &IO, BinaryHolder &BH) {
+ IO.mapRequired("Binary", BH.Binary);
+ }
+};
+} // end namespace yaml
+} // end namespace llvm
+
+TEST(ObjectYAML, BinaryRef) {
+ BinaryHolder BH;
+ SmallVector<char, 32> Buf;
+ llvm::raw_svector_ostream OS(Buf);
+ yaml::Output YOut(OS);
+ YOut << BH;
+ EXPECT_NE(OS.str().find("''"), StringRef::npos);
+}
OpenPOWER on IntegriCloud