1
0
mirror of https://github.com/c64scene-ar/llvm-6502.git synced 2025-01-17 21:35:07 +00:00

For PR1163:

Make the Module's dependent library use a std::vector instead of SetVector
adjust #includes in .cpp files because SetVector.h is no longer included.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@33855 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Reid Spencer 2007-02-04 00:40:42 +00:00
parent 5fcaf3ed14
commit 6734b57d1b
6 changed files with 24 additions and 5 deletions

@ -16,7 +16,6 @@
#include "llvm/Function.h" #include "llvm/Function.h"
#include "llvm/GlobalVariable.h" #include "llvm/GlobalVariable.h"
#include "llvm/ADT/SetVector.h"
#include "llvm/Support/DataTypes.h" #include "llvm/Support/DataTypes.h"
namespace llvm { namespace llvm {
@ -63,7 +62,7 @@ public:
typedef iplist<Function> FunctionListType; typedef iplist<Function> FunctionListType;
/// The type for the list of dependent libraries. /// The type for the list of dependent libraries.
typedef SetVector<std::string> LibraryListType; typedef std::vector<std::string> LibraryListType;
/// The Global Variable iterator. /// The Global Variable iterator.
typedef GlobalListType::iterator global_iterator; typedef GlobalListType::iterator global_iterator;
@ -290,9 +289,9 @@ public:
/// @brief Returns the number of items in the list of libraries. /// @brief Returns the number of items in the list of libraries.
inline size_t lib_size() const { return LibraryList.size(); } inline size_t lib_size() const { return LibraryList.size(); }
/// @brief Add a library to the list of dependent libraries /// @brief Add a library to the list of dependent libraries
inline void addLibrary(const std::string& Lib){ LibraryList.insert(Lib); } void addLibrary(const std::string& Lib);
/// @brief Remove a library from the list of dependent libraries /// @brief Remove a library from the list of dependent libraries
inline void removeLibrary(const std::string& Lib) { LibraryList.remove(Lib); } void removeLibrary(const std::string& Lib);
/// @brief Get all the libraries /// @brief Get all the libraries
inline const LibraryListType& getLibraries() const { return LibraryList; } inline const LibraryListType& getLibraries() const { return LibraryList; }

@ -11,6 +11,7 @@
// //
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
#include "llvm/Transforms/RSProfiling.h" #include "llvm/Transforms/RSProfiling.h"
#include <set>
namespace llvm { namespace llvm {
/// RSProfilers_std - a simple support class for profilers that handles most /// RSProfilers_std - a simple support class for profilers that handles most

@ -54,6 +54,7 @@
#include "llvm/ADT/Statistic.h" #include "llvm/ADT/Statistic.h"
#include "llvm/ADT/STLExtras.h" #include "llvm/ADT/STLExtras.h"
#include <algorithm> #include <algorithm>
#include <set>
using namespace llvm; using namespace llvm;
using namespace llvm::PatternMatch; using namespace llvm::PatternMatch;

@ -76,7 +76,7 @@
#include "llvm/Pass.h" #include "llvm/Pass.h"
#include "llvm/ADT/DepthFirstIterator.h" #include "llvm/ADT/DepthFirstIterator.h"
#include "llvm/ADT/SetOperations.h" #include "llvm/ADT/SetOperations.h"
#include "llvm/ADT/SmallVector.h" #include "llvm/ADT/SetVector.h"
#include "llvm/ADT/Statistic.h" #include "llvm/ADT/Statistic.h"
#include "llvm/ADT/STLExtras.h" #include "llvm/ADT/STLExtras.h"
#include "llvm/Analysis/Dominators.h" #include "llvm/Analysis/Dominators.h"

@ -48,6 +48,7 @@
#include "llvm/Support/Compiler.h" #include "llvm/Support/Compiler.h"
#include "llvm/Target/TargetLowering.h" #include "llvm/Target/TargetLowering.h"
#include <csetjmp> #include <csetjmp>
#include <set>
using namespace llvm; using namespace llvm;
STATISTIC(NumInvokes, "Number of invokes replaced"); STATISTIC(NumInvokes, "Number of invokes replaced");

@ -360,3 +360,20 @@ void Module::dropAllReferences() {
I->dropAllReferences(); I->dropAllReferences();
} }
void Module::addLibrary(const std::string& Lib) {
for (Module::lib_iterator I = lib_begin(), E = lib_end(); I != E; ++I)
if (*I == Lib)
return;
LibraryList.push_back(Lib);
}
void Module::removeLibrary(const std::string& Lib) {
LibraryListType::iterator I = LibraryList.begin();
LibraryListType::iterator E = LibraryList.end();
for (;I != E; ++I)
if (*I == Lib) {
LibraryList.erase(I);
return;
}
}