diff options
author | Anton Korobeynikov <asl@math.spbu.ru> | 2008-06-27 21:22:49 +0000 |
---|---|---|
committer | Anton Korobeynikov <asl@math.spbu.ru> | 2008-06-27 21:22:49 +0000 |
commit | 8573986f3043bb9ed3754464dc0dabed0434b914 (patch) | |
tree | b1b80c356f9e3729dc8dd3d6cd440840216915d8 /lib | |
parent | d0ebbff8a322b3322d5dbecf86d402f0835b76ce (diff) | |
download | external_llvm-8573986f3043bb9ed3754464dc0dabed0434b914.zip external_llvm-8573986f3043bb9ed3754464dc0dabed0434b914.tar.gz external_llvm-8573986f3043bb9ed3754464dc0dabed0434b914.tar.bz2 |
Use StringSet instead of std::set<std::string>
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@52836 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r-- | lib/Target/X86/X86AsmPrinter.cpp | 28 | ||||
-rw-r--r-- | lib/Target/X86/X86AsmPrinter.h | 7 | ||||
-rw-r--r-- | lib/Target/X86/X86IntelAsmPrinter.cpp | 16 |
3 files changed, 25 insertions, 26 deletions
diff --git a/lib/Target/X86/X86AsmPrinter.cpp b/lib/Target/X86/X86AsmPrinter.cpp index 9f3f769..409cb20 100644 --- a/lib/Target/X86/X86AsmPrinter.cpp +++ b/lib/Target/X86/X86AsmPrinter.cpp @@ -368,32 +368,32 @@ bool X86SharedAsmPrinter::doFinalization(Module &M) { SwitchToDataSection(".section .drectve"); } - for (std::set<std::string>::iterator i = DLLExportedGVs.begin(), + for (StringSet<>::iterator i = DLLExportedGVs.begin(), e = DLLExportedGVs.end(); i != e; ++i) { - O << "\t.ascii \" -export:" << *i << ",data\"\n"; - } + O << "\t.ascii \" -export:" << i->getKeyData() << ",data\"\n"; + } if (!DLLExportedFns.empty()) { SwitchToDataSection(".section .drectve"); } - for (std::set<std::string>::iterator i = DLLExportedFns.begin(), + for (StringSet<>::iterator i = DLLExportedFns.begin(), e = DLLExportedFns.end(); i != e; ++i) { - O << "\t.ascii \" -export:" << *i << "\"\n"; - } + O << "\t.ascii \" -export:" << i->getKeyData() << "\"\n"; + } if (Subtarget->isTargetDarwin()) { SwitchToDataSection(""); // Output stubs for dynamically-linked functions unsigned j = 1; - for (std::set<std::string>::iterator i = FnStubs.begin(), e = FnStubs.end(); + for (StringSet<>::iterator i = FnStubs.begin(), e = FnStubs.end(); i != e; ++i, ++j) { SwitchToDataSection("\t.section __IMPORT,__jump_table,symbol_stubs," "self_modifying_code+pure_instructions,5", 0); - std::string p = *i; + std::string p = i->getKeyData(); printSuffixedName(p, "$stub"); O << ":\n"; O << "\t.indirect_symbol " << p << "\n"; @@ -416,9 +416,9 @@ bool X86SharedAsmPrinter::doFinalization(Module &M) { if (!GVStubs.empty()) SwitchToDataSection( "\t.section __IMPORT,__pointers,non_lazy_symbol_pointers"); - for (std::set<std::string>::iterator i = GVStubs.begin(), e = GVStubs.end(); + for (StringSet<>::iterator i = GVStubs.begin(), e = GVStubs.end(); i != e; ++i) { - std::string p = *i; + std::string p = i->getKeyData(); printSuffixedName(p, "$non_lazy_ptr"); O << ":\n"; O << "\t.indirect_symbol " << p << "\n"; @@ -436,16 +436,16 @@ bool X86SharedAsmPrinter::doFinalization(Module &M) { O << "\t.subsections_via_symbols\n"; } else if (Subtarget->isTargetCygMing()) { // Emit type information for external functions - for (std::set<std::string>::iterator i = FnStubs.begin(), e = FnStubs.end(); + for (StringSet<>::iterator i = FnStubs.begin(), e = FnStubs.end(); i != e; ++i) { - O << "\t.def\t " << *i + O << "\t.def\t " << i->getKeyData() << ";\t.scl\t" << COFF::C_EXT << ";\t.type\t" << (COFF::DT_FCN << COFF::N_BTSHFT) << ";\t.endef\n"; } - + // Emit final debug information. - DW.EndModule(); + DW.EndModule(); } else if (Subtarget->isTargetELF()) { // Emit final debug information. DW.EndModule(); diff --git a/lib/Target/X86/X86AsmPrinter.h b/lib/Target/X86/X86AsmPrinter.h index 6c47e0c..95e2460 100644 --- a/lib/Target/X86/X86AsmPrinter.h +++ b/lib/Target/X86/X86AsmPrinter.h @@ -19,12 +19,11 @@ #include "X86.h" #include "X86MachineFunctionInfo.h" #include "X86TargetMachine.h" +#include "llvm/ADT/StringSet.h" #include "llvm/CodeGen/AsmPrinter.h" #include "llvm/CodeGen/DwarfWriter.h" #include "llvm/CodeGen/MachineModuleInfo.h" #include "llvm/Support/Compiler.h" -#include <set> - namespace llvm { @@ -70,10 +69,10 @@ struct VISIBILITY_HIDDEN X86SharedAsmPrinter : public AsmPrinter { const X86Subtarget *Subtarget; // Necessary for Darwin to print out the apprioriate types of linker stubs - std::set<std::string> FnStubs, GVStubs, LinkOnceStubs; + StringSet<> FnStubs, GVStubs, LinkOnceStubs; // Necessary for dllexport support - std::set<std::string> DLLExportedFns, DLLExportedGVs; + StringSet<> DLLExportedFns, DLLExportedGVs; inline static bool isScale(const MachineOperand &MO) { return MO.isImmediate() && diff --git a/lib/Target/X86/X86IntelAsmPrinter.cpp b/lib/Target/X86/X86IntelAsmPrinter.cpp index 09a40b8..842f9e4 100644 --- a/lib/Target/X86/X86IntelAsmPrinter.cpp +++ b/lib/Target/X86/X86IntelAsmPrinter.cpp @@ -425,23 +425,23 @@ bool X86IntelAsmPrinter::doFinalization(Module &M) { O << "_drectve\t segment info alias('.drectve')\n"; } - for (std::set<std::string>::iterator i = DLLExportedGVs.begin(), + for (StringSet<>::iterator i = DLLExportedGVs.begin(), e = DLLExportedGVs.end(); i != e; ++i) { - O << "\t db ' /EXPORT:" << *i << ",data'\n"; - } + O << "\t db ' /EXPORT:" << i->getKeyData() << ",data'\n"; + } - for (std::set<std::string>::iterator i = DLLExportedFns.begin(), + for (StringSet<>::iterator i = DLLExportedFns.begin(), e = DLLExportedFns.end(); i != e; ++i) { - O << "\t db ' /EXPORT:" << *i << "'\n"; - } + O << "\t db ' /EXPORT:" << i->getKeyData() << "'\n"; + } if (!DLLExportedGVs.empty() || !DLLExportedFns.empty()) { - O << "_drectve\t ends\n"; + O << "_drectve\t ends\n"; } - + // Bypass X86SharedAsmPrinter::doFinalization(). bool Result = AsmPrinter::doFinalization(M); SwitchToDataSection(""); |