diff options
Diffstat (limited to 'llvm/unittests/AsmParser')
| -rw-r--r-- | llvm/unittests/AsmParser/AsmParserTest.cpp | 55 | 
1 files changed, 55 insertions, 0 deletions
| diff --git a/llvm/unittests/AsmParser/AsmParserTest.cpp b/llvm/unittests/AsmParser/AsmParserTest.cpp index ce22670..898a829 100644 --- a/llvm/unittests/AsmParser/AsmParserTest.cpp +++ b/llvm/unittests/AsmParser/AsmParserTest.cpp @@ -6,7 +6,9 @@  //  //===----------------------------------------------------------------------===// +#include "llvm/ADT/STLExtras.h"  #include "llvm/ADT/StringRef.h" +#include "llvm/AsmParser/AsmParserContext.h"  #include "llvm/AsmParser/Parser.h"  #include "llvm/AsmParser/SlotMapping.h"  #include "llvm/IR/Constants.h" @@ -14,10 +16,14 @@  #include "llvm/IR/DebugInfoMetadata.h"  #include "llvm/IR/LLVMContext.h"  #include "llvm/IR/Module.h" +#include "llvm/IR/Value.h" +#include "llvm/Support/Debug.h"  #include "llvm/Support/Error.h"  #include "llvm/Support/SourceMgr.h"  #include "gtest/gtest.h" +#define DEBUG_TYPE "unittest-asm-parser-tests" +  using namespace llvm;  namespace { @@ -479,4 +485,53 @@ TEST(AsmParserTest, DIExpressionBodyAtBeginningWithSlotMappingParsing) {    ASSERT_EQ(Mapping.MetadataNodes.size(), 0u);  } +#define ASSERT_EQ_LOC(Loc1, Loc2)                                              \ +  do {                                                                         \ +    EXPECT_TRUE(Loc1.contains(Loc2) && Loc2.contains(Loc1))                    \ +        << #Loc1 " location: " << Loc1.Start.Line << ":" << Loc1.Start.Col     \ +        << " - " << Loc1.End.Line << ":" << Loc1.End.Col << "\n"               \ +        << #Loc2 " location: " << Loc2.Start.Line << ":" << Loc2.Start.Col     \ +        << " - " << Loc2.End.Line << ":" << Loc2.End.Col << "\n";              \ +  } while (false) + +TEST(AsmParserTest, ParserObjectLocations) { +  StringRef Source = "define i32 @main() {\n" +                     "entry:\n" +                     "    %a = add i32 1, 2\n" +                     "    ret i32 %a\n" +                     "}\n"; +  LLVMContext Ctx; +  SMDiagnostic Error; +  SlotMapping Mapping; +  AsmParserContext ParserContext; +  auto Mod = parseAssemblyString(Source, Error, Ctx, &Mapping, &ParserContext); + +  auto *MainFn = Mod->getFunction("main"); +  ASSERT_TRUE(MainFn != nullptr); + +  auto MaybeMainLoc = ParserContext.getFunctionLocation(MainFn); +  EXPECT_TRUE(MaybeMainLoc.has_value()); +  auto MainLoc = MaybeMainLoc.value(); +  auto ExpectedMainLoc = FileLocRange(FileLoc{0, 0}, FileLoc{4, 1}); +  ASSERT_EQ_LOC(MainLoc, ExpectedMainLoc); + +  auto &EntryBB = MainFn->getEntryBlock(); +  auto MaybeEntryBBLoc = ParserContext.getBlockLocation(&EntryBB); +  ASSERT_TRUE(MaybeEntryBBLoc.has_value()); +  auto EntryBBLoc = MaybeEntryBBLoc.value(); +  auto ExpectedEntryBBLoc = FileLocRange(FileLoc{1, 0}, FileLoc{3, 14}); +  ASSERT_EQ_LOC(EntryBBLoc, ExpectedEntryBBLoc); + +  SmallVector<FileLocRange> InstructionLocations = { +      FileLocRange(FileLoc{2, 4}, FileLoc{2, 21}), +      FileLocRange(FileLoc{3, 4}, FileLoc{3, 14})}; + +  for (const auto &[Inst, ExpectedLoc] : zip(EntryBB, InstructionLocations)) { +    auto MaybeInstLoc = ParserContext.getInstructionLocation(&Inst); +    ASSERT_TRUE(MaybeMainLoc.has_value()); +    auto InstLoc = MaybeInstLoc.value(); +    ASSERT_EQ_LOC(InstLoc, ExpectedLoc); +  } +} +  } // end anonymous namespace | 
