mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-06 04:31:08 +00:00
Changes to make it GCC 3.1 compatible
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@3052 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
5a6d63ae29
commit
a1cb4737b0
@ -12,7 +12,7 @@
|
|||||||
// The ilist class itself, should be a plug in replacement for list, assuming
|
// The ilist class itself, should be a plug in replacement for list, assuming
|
||||||
// that the nodes contain next/prev pointers. This list replacement does not
|
// that the nodes contain next/prev pointers. This list replacement does not
|
||||||
// provides a constant time size() method, so be careful to use empty() when you
|
// provides a constant time size() method, so be careful to use empty() when you
|
||||||
// really want to know if I'm empty.
|
// really want to know if it's empty.
|
||||||
//
|
//
|
||||||
// The ilist class is implemented by allocating a 'tail' node when the list is
|
// The ilist class is implemented by allocating a 'tail' node when the list is
|
||||||
// created (using ilist_traits<>::createEndMarker()). This tail node is
|
// created (using ilist_traits<>::createEndMarker()). This tail node is
|
||||||
@ -33,6 +33,7 @@
|
|||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
template<typename NodeTy, typename Traits> class iplist;
|
template<typename NodeTy, typename Traits> class iplist;
|
||||||
template<typename NodeTy> class ilist_iterator;
|
template<typename NodeTy> class ilist_iterator;
|
||||||
@ -69,8 +70,18 @@ struct ilist_traits<const Ty> : public ilist_traits<Ty> {};
|
|||||||
// ilist_iterator<Node> - Iterator for intrusive list.
|
// ilist_iterator<Node> - Iterator for intrusive list.
|
||||||
//
|
//
|
||||||
template<typename NodeTy>
|
template<typename NodeTy>
|
||||||
class ilist_iterator : public std::bidirectional_iterator<NodeTy, ptrdiff_t> {
|
class ilist_iterator
|
||||||
|
#if __GNUC__ == 3
|
||||||
|
: public std::iterator<std::bidirectional_iterator_tag, NodeTy> {
|
||||||
|
typedef std::iterator<std::bidirectional_iterator_tag, NodeTy> super;
|
||||||
|
#else
|
||||||
|
: public std::bidirectional_iterator<NodeTy, ptrdiff_t> {
|
||||||
|
typedef std::bidirectional_iterator<NodeTy, ptrdiff_t> super;
|
||||||
|
#endif
|
||||||
typedef ilist_traits<NodeTy> Traits;
|
typedef ilist_traits<NodeTy> Traits;
|
||||||
|
|
||||||
|
typedef typename super::pointer pointer;
|
||||||
|
typedef typename super::reference reference;
|
||||||
pointer NodePtr;
|
pointer NodePtr;
|
||||||
public:
|
public:
|
||||||
typedef size_t size_type;
|
typedef size_t size_type;
|
||||||
@ -301,8 +312,12 @@ public:
|
|||||||
//
|
//
|
||||||
|
|
||||||
size_type size() const {
|
size_type size() const {
|
||||||
|
#if __GNUC__ == 3
|
||||||
|
size_type Result = std::distance(begin(), end());
|
||||||
|
#else
|
||||||
size_type Result = 0;
|
size_type Result = 0;
|
||||||
std::distance(begin(), end(), Result);
|
std::distance(begin(), end(), Result);
|
||||||
|
#endif
|
||||||
return Result;
|
return Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -404,6 +419,9 @@ public:
|
|||||||
|
|
||||||
template<typename NodeTy>
|
template<typename NodeTy>
|
||||||
struct ilist : public iplist<NodeTy> {
|
struct ilist : public iplist<NodeTy> {
|
||||||
|
typedef typename iplist<NodeTy>::size_type size_type;
|
||||||
|
typedef typename iplist<NodeTy>::iterator iterator;
|
||||||
|
|
||||||
ilist() {}
|
ilist() {}
|
||||||
ilist(const ilist &right) {
|
ilist(const ilist &right) {
|
||||||
insert(begin(), right.begin(), right.end());
|
insert(begin(), right.begin(), right.end());
|
||||||
@ -478,7 +496,6 @@ struct ilist : public iplist<NodeTy> {
|
|||||||
insert(end(), newsize - len, val);
|
insert(end(), newsize - len, val);
|
||||||
}
|
}
|
||||||
void resize(size_type newsize) { resize(newsize, NodeTy()); }
|
void resize(size_type newsize) { resize(newsize, NodeTy()); }
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
namespace std {
|
namespace std {
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
// The ilist class itself, should be a plug in replacement for list, assuming
|
// The ilist class itself, should be a plug in replacement for list, assuming
|
||||||
// that the nodes contain next/prev pointers. This list replacement does not
|
// that the nodes contain next/prev pointers. This list replacement does not
|
||||||
// provides a constant time size() method, so be careful to use empty() when you
|
// provides a constant time size() method, so be careful to use empty() when you
|
||||||
// really want to know if I'm empty.
|
// really want to know if it's empty.
|
||||||
//
|
//
|
||||||
// The ilist class is implemented by allocating a 'tail' node when the list is
|
// The ilist class is implemented by allocating a 'tail' node when the list is
|
||||||
// created (using ilist_traits<>::createEndMarker()). This tail node is
|
// created (using ilist_traits<>::createEndMarker()). This tail node is
|
||||||
@ -33,6 +33,7 @@
|
|||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
template<typename NodeTy, typename Traits> class iplist;
|
template<typename NodeTy, typename Traits> class iplist;
|
||||||
template<typename NodeTy> class ilist_iterator;
|
template<typename NodeTy> class ilist_iterator;
|
||||||
@ -69,8 +70,18 @@ struct ilist_traits<const Ty> : public ilist_traits<Ty> {};
|
|||||||
// ilist_iterator<Node> - Iterator for intrusive list.
|
// ilist_iterator<Node> - Iterator for intrusive list.
|
||||||
//
|
//
|
||||||
template<typename NodeTy>
|
template<typename NodeTy>
|
||||||
class ilist_iterator : public std::bidirectional_iterator<NodeTy, ptrdiff_t> {
|
class ilist_iterator
|
||||||
|
#if __GNUC__ == 3
|
||||||
|
: public std::iterator<std::bidirectional_iterator_tag, NodeTy> {
|
||||||
|
typedef std::iterator<std::bidirectional_iterator_tag, NodeTy> super;
|
||||||
|
#else
|
||||||
|
: public std::bidirectional_iterator<NodeTy, ptrdiff_t> {
|
||||||
|
typedef std::bidirectional_iterator<NodeTy, ptrdiff_t> super;
|
||||||
|
#endif
|
||||||
typedef ilist_traits<NodeTy> Traits;
|
typedef ilist_traits<NodeTy> Traits;
|
||||||
|
|
||||||
|
typedef typename super::pointer pointer;
|
||||||
|
typedef typename super::reference reference;
|
||||||
pointer NodePtr;
|
pointer NodePtr;
|
||||||
public:
|
public:
|
||||||
typedef size_t size_type;
|
typedef size_t size_type;
|
||||||
@ -301,8 +312,12 @@ public:
|
|||||||
//
|
//
|
||||||
|
|
||||||
size_type size() const {
|
size_type size() const {
|
||||||
|
#if __GNUC__ == 3
|
||||||
|
size_type Result = std::distance(begin(), end());
|
||||||
|
#else
|
||||||
size_type Result = 0;
|
size_type Result = 0;
|
||||||
std::distance(begin(), end(), Result);
|
std::distance(begin(), end(), Result);
|
||||||
|
#endif
|
||||||
return Result;
|
return Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -404,6 +419,9 @@ public:
|
|||||||
|
|
||||||
template<typename NodeTy>
|
template<typename NodeTy>
|
||||||
struct ilist : public iplist<NodeTy> {
|
struct ilist : public iplist<NodeTy> {
|
||||||
|
typedef typename iplist<NodeTy>::size_type size_type;
|
||||||
|
typedef typename iplist<NodeTy>::iterator iterator;
|
||||||
|
|
||||||
ilist() {}
|
ilist() {}
|
||||||
ilist(const ilist &right) {
|
ilist(const ilist &right) {
|
||||||
insert(begin(), right.begin(), right.end());
|
insert(begin(), right.begin(), right.end());
|
||||||
@ -478,7 +496,6 @@ struct ilist : public iplist<NodeTy> {
|
|||||||
insert(end(), newsize - len, val);
|
insert(end(), newsize - len, val);
|
||||||
}
|
}
|
||||||
void resize(size_type newsize) { resize(newsize, NodeTy()); }
|
void resize(size_type newsize) { resize(newsize, NodeTy()); }
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
namespace std {
|
namespace std {
|
||||||
|
Loading…
Reference in New Issue
Block a user