
These are identified by misc-include-cleaner. I've filtered out those that break builds. Also, I'm staying away from llvm-config.h, config.h, and Compiler.h, which likely cause platform- or compiler-specific build failures.
45 lines
1.1 KiB
C++
45 lines
1.1 KiB
C++
//===- lib/MC/MCValue.cpp - MCValue implementation ------------------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/MC/MCValue.h"
|
|
#include "llvm/Config/llvm-config.h"
|
|
#include "llvm/MC/MCExpr.h"
|
|
#include "llvm/MC/MCSymbol.h"
|
|
#include "llvm/Support/Debug.h"
|
|
#include "llvm/Support/raw_ostream.h"
|
|
|
|
using namespace llvm;
|
|
|
|
void MCValue::print(raw_ostream &OS) const {
|
|
if (isAbsolute()) {
|
|
OS << getConstant();
|
|
return;
|
|
}
|
|
|
|
// FIXME: prints as a number, which isn't ideal. But the meaning will be
|
|
// target-specific anyway.
|
|
if (getSpecifier())
|
|
OS << ':' << getSpecifier() << ':';
|
|
|
|
SymA->print(OS, nullptr);
|
|
|
|
if (auto *B = getSubSym()) {
|
|
OS << " - ";
|
|
B->print(OS, nullptr);
|
|
}
|
|
|
|
if (getConstant())
|
|
OS << " + " << getConstant();
|
|
}
|
|
|
|
#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
|
|
LLVM_DUMP_METHOD void MCValue::dump() const {
|
|
print(dbgs());
|
|
}
|
|
#endif
|