summaryrefslogtreecommitdiffstats
path: root/gnu/llvm/lib/IR/DebugLoc.cpp
diff options
context:
space:
mode:
authorpatrick <patrick@openbsd.org>2020-08-03 15:06:44 +0000
committerpatrick <patrick@openbsd.org>2020-08-03 15:06:44 +0000
commitb64793999546ed8adebaeebd9d8345d18db8927d (patch)
tree4357c27b561d73b0e089727c6ed659f2ceff5f47 /gnu/llvm/lib/IR/DebugLoc.cpp
parentAdd support for UTF-8 DISPLAY-HINTs with octet length. For now only (diff)
downloadwireguard-openbsd-b64793999546ed8adebaeebd9d8345d18db8927d.tar.xz
wireguard-openbsd-b64793999546ed8adebaeebd9d8345d18db8927d.zip
Remove LLVM 8.0.1 files.
Diffstat (limited to 'gnu/llvm/lib/IR/DebugLoc.cpp')
-rw-r--r--gnu/llvm/lib/IR/DebugLoc.cpp135
1 files changed, 0 insertions, 135 deletions
diff --git a/gnu/llvm/lib/IR/DebugLoc.cpp b/gnu/llvm/lib/IR/DebugLoc.cpp
deleted file mode 100644
index 10ec98ac7e6..00000000000
--- a/gnu/llvm/lib/IR/DebugLoc.cpp
+++ /dev/null
@@ -1,135 +0,0 @@
-//===-- DebugLoc.cpp - Implement DebugLoc class ---------------------------===//
-//
-// The LLVM Compiler Infrastructure
-//
-// This file is distributed under the University of Illinois Open Source
-// License. See LICENSE.TXT for details.
-//
-//===----------------------------------------------------------------------===//
-
-#include "llvm/IR/DebugLoc.h"
-#include "LLVMContextImpl.h"
-#include "llvm/Config/llvm-config.h"
-#include "llvm/IR/DebugInfo.h"
-using namespace llvm;
-
-//===----------------------------------------------------------------------===//
-// DebugLoc Implementation
-//===----------------------------------------------------------------------===//
-DebugLoc::DebugLoc(const DILocation *L) : Loc(const_cast<DILocation *>(L)) {}
-DebugLoc::DebugLoc(const MDNode *L) : Loc(const_cast<MDNode *>(L)) {}
-
-DILocation *DebugLoc::get() const {
- return cast_or_null<DILocation>(Loc.get());
-}
-
-unsigned DebugLoc::getLine() const {
- assert(get() && "Expected valid DebugLoc");
- return get()->getLine();
-}
-
-unsigned DebugLoc::getCol() const {
- assert(get() && "Expected valid DebugLoc");
- return get()->getColumn();
-}
-
-MDNode *DebugLoc::getScope() const {
- assert(get() && "Expected valid DebugLoc");
- return get()->getScope();
-}
-
-DILocation *DebugLoc::getInlinedAt() const {
- assert(get() && "Expected valid DebugLoc");
- return get()->getInlinedAt();
-}
-
-MDNode *DebugLoc::getInlinedAtScope() const {
- return cast<DILocation>(Loc)->getInlinedAtScope();
-}
-
-DebugLoc DebugLoc::getFnDebugLoc() const {
- // FIXME: Add a method on \a DILocation that does this work.
- const MDNode *Scope = getInlinedAtScope();
- if (auto *SP = getDISubprogram(Scope))
- return DebugLoc::get(SP->getScopeLine(), 0, SP);
-
- return DebugLoc();
-}
-
-bool DebugLoc::isImplicitCode() const {
- if (DILocation *Loc = get()) {
- return Loc->isImplicitCode();
- }
- return true;
-}
-
-void DebugLoc::setImplicitCode(bool ImplicitCode) {
- if (DILocation *Loc = get()) {
- Loc->setImplicitCode(ImplicitCode);
- }
-}
-
-DebugLoc DebugLoc::get(unsigned Line, unsigned Col, const MDNode *Scope,
- const MDNode *InlinedAt, bool ImplicitCode) {
- // If no scope is available, this is an unknown location.
- if (!Scope)
- return DebugLoc();
-
- return DILocation::get(Scope->getContext(), Line, Col,
- const_cast<MDNode *>(Scope),
- const_cast<MDNode *>(InlinedAt), ImplicitCode);
-}
-
-DebugLoc DebugLoc::appendInlinedAt(DebugLoc DL, DILocation *InlinedAt,
- LLVMContext &Ctx,
- DenseMap<const MDNode *, MDNode *> &Cache,
- bool ReplaceLast) {
- SmallVector<DILocation *, 3> InlinedAtLocations;
- DILocation *Last = InlinedAt;
- DILocation *CurInlinedAt = DL;
-
- // Gather all the inlined-at nodes.
- while (DILocation *IA = CurInlinedAt->getInlinedAt()) {
- // Skip any we've already built nodes for.
- if (auto *Found = Cache[IA]) {
- Last = cast<DILocation>(Found);
- break;
- }
-
- if (ReplaceLast && !IA->getInlinedAt())
- break;
- InlinedAtLocations.push_back(IA);
- CurInlinedAt = IA;
- }
-
- // Starting from the top, rebuild the nodes to point to the new inlined-at
- // location (then rebuilding the rest of the chain behind it) and update the
- // map of already-constructed inlined-at nodes.
- for (const DILocation *MD : reverse(InlinedAtLocations))
- Cache[MD] = Last = DILocation::getDistinct(
- Ctx, MD->getLine(), MD->getColumn(), MD->getScope(), Last);
-
- return Last;
-}
-
-#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
-LLVM_DUMP_METHOD void DebugLoc::dump() const { print(dbgs()); }
-#endif
-
-void DebugLoc::print(raw_ostream &OS) const {
- if (!Loc)
- return;
-
- // Print source line info.
- auto *Scope = cast<DIScope>(getScope());
- OS << Scope->getFilename();
- OS << ':' << getLine();
- if (getCol() != 0)
- OS << ':' << getCol();
-
- if (DebugLoc InlinedAtDL = getInlinedAt()) {
- OS << " @[ ";
- InlinedAtDL.print(OS);
- OS << " ]";
- }
-}