forked from OSchip/llvm-project
[PECOFF] Move helper function out of class
No functionality change intended. llvm-svn: 218705
This commit is contained in:
parent
3fc12bf860
commit
dbddf11649
|
@ -1,6 +1,7 @@
|
||||||
add_lld_library(lldPECOFF
|
add_lld_library(lldPECOFF
|
||||||
EdataPass.cpp
|
EdataPass.cpp
|
||||||
IdataPass.cpp
|
IdataPass.cpp
|
||||||
|
LinkerGeneratedSymbolFile.cpp
|
||||||
LoadConfigPass.cpp
|
LoadConfigPass.cpp
|
||||||
PECOFFLinkingContext.cpp
|
PECOFFLinkingContext.cpp
|
||||||
Pass.cpp
|
Pass.cpp
|
||||||
|
|
|
@ -0,0 +1,48 @@
|
||||||
|
//===- lib/ReaderWriter/PECOFF/LinkerGeneratedSymbolFile.cpp --------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Linker
|
||||||
|
//
|
||||||
|
// This file is distributed under the University of Illinois Open Source
|
||||||
|
// License. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#include "LinkerGeneratedSymbolFile.h"
|
||||||
|
|
||||||
|
namespace lld {
|
||||||
|
namespace pecoff {
|
||||||
|
|
||||||
|
// Find decorated symbol, namely /sym@[0-9]+/ or /\?sym@@.+/.
|
||||||
|
bool findDecoratedSymbol(PECOFFLinkingContext *ctx, ResolvableSymbols *syms,
|
||||||
|
std::string sym, std::string &res) {
|
||||||
|
const std::set<std::string> &defined = syms->defined();
|
||||||
|
// Search for /sym@[0-9]+/
|
||||||
|
{
|
||||||
|
std::string s = sym + '@';
|
||||||
|
auto it = defined.lower_bound(s);
|
||||||
|
for (auto e = defined.end(); it != e; ++it) {
|
||||||
|
if (!StringRef(*it).startswith(s))
|
||||||
|
break;
|
||||||
|
if (it->size() == s.size())
|
||||||
|
continue;
|
||||||
|
StringRef suffix = StringRef(*it).substr(s.size());
|
||||||
|
if (suffix.find_first_not_of("0123456789") != StringRef::npos)
|
||||||
|
continue;
|
||||||
|
res = *it;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Search for /\?sym@@.+/
|
||||||
|
{
|
||||||
|
std::string s = "?" + ctx->undecorateSymbol(sym).str() + "@@";
|
||||||
|
auto it = defined.lower_bound(s);
|
||||||
|
if (it != defined.end() && StringRef(*it).startswith(s)) {
|
||||||
|
res = *it;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace pecoff
|
||||||
|
} // namespace lld
|
|
@ -1,4 +1,4 @@
|
||||||
//===- lib/ReaderWriter/PECOFF/LinkerGeneratedSymbolFile.cpp --------------===//
|
//===- lib/ReaderWriter/PECOFF/LinkerGeneratedSymbolFile.h ----------------===//
|
||||||
//
|
//
|
||||||
// The LLVM Linker
|
// The LLVM Linker
|
||||||
//
|
//
|
||||||
|
@ -21,6 +21,10 @@ using llvm::COFF::WindowsSubsystem;
|
||||||
namespace lld {
|
namespace lld {
|
||||||
namespace pecoff {
|
namespace pecoff {
|
||||||
|
|
||||||
|
class ResolvableSymbols;
|
||||||
|
bool findDecoratedSymbol(PECOFFLinkingContext *ctx, ResolvableSymbols *syms,
|
||||||
|
std::string sym, std::string &res);
|
||||||
|
|
||||||
namespace impl {
|
namespace impl {
|
||||||
|
|
||||||
/// The defined atom for dllexported symbols with __imp_ prefix.
|
/// The defined atom for dllexported symbols with __imp_ prefix.
|
||||||
|
@ -255,7 +259,7 @@ public:
|
||||||
if (it == _exportedSyms.end())
|
if (it == _exportedSyms.end())
|
||||||
return nullptr;
|
return nullptr;
|
||||||
std::string replace;
|
std::string replace;
|
||||||
if (!findDecoratedSymbol(sym.str(), replace))
|
if (!findDecoratedSymbol(_ctx, _syms.get(), sym.str(), replace))
|
||||||
return nullptr;
|
return nullptr;
|
||||||
it->second->name = replace;
|
it->second->name = replace;
|
||||||
if (_ctx->deadStrip())
|
if (_ctx->deadStrip())
|
||||||
|
@ -264,37 +268,6 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// Find decorated symbol, namely /sym@[0-9]+/ or /\?sym@@.+/.
|
|
||||||
bool findDecoratedSymbol(std::string sym, std::string &res) const {
|
|
||||||
const std::set<std::string> &defined = _syms->defined();
|
|
||||||
// Search for /sym@[0-9]+/
|
|
||||||
{
|
|
||||||
std::string s = sym + '@';
|
|
||||||
auto it = defined.lower_bound(s);
|
|
||||||
for (auto e = defined.end(); it != e; ++it) {
|
|
||||||
if (!StringRef(*it).startswith(s))
|
|
||||||
break;
|
|
||||||
if (it->size() == s.size())
|
|
||||||
continue;
|
|
||||||
StringRef suffix = StringRef(*it).substr(s.size());
|
|
||||||
if (suffix.find_first_not_of("0123456789") != StringRef::npos)
|
|
||||||
continue;
|
|
||||||
res = *it;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Search for /\?sym@@.+/
|
|
||||||
{
|
|
||||||
std::string s = "?" + _ctx->undecorateSymbol(sym).str() + "@@";
|
|
||||||
auto it = defined.lower_bound(s);
|
|
||||||
if (it != defined.end() && StringRef(*it).startswith(s)) {
|
|
||||||
res = *it;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::map<std::string, PECOFFLinkingContext::ExportDesc *> _exportedSyms;
|
std::map<std::string, PECOFFLinkingContext::ExportDesc *> _exportedSyms;
|
||||||
std::shared_ptr<ResolvableSymbols> _syms;
|
std::shared_ptr<ResolvableSymbols> _syms;
|
||||||
mutable llvm::BumpPtrAllocator _alloc;
|
mutable llvm::BumpPtrAllocator _alloc;
|
||||||
|
|
Loading…
Reference in New Issue