From 98f1bfb4a034b52e5aba748915f4527ae58ca244 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Wed, 24 Jul 2002 21:38:41 +0000 Subject: Add another GCC2.95->3.1 compatibility header git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@3060 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/Support/iterator | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 include/Support/iterator (limited to 'include/Support/iterator') diff --git a/include/Support/iterator b/include/Support/iterator new file mode 100644 index 0000000..095d604 --- /dev/null +++ b/include/Support/iterator @@ -0,0 +1,36 @@ +//===-- Support/iterator - "Portable" wrapper around -*- C++ -*-===// +// +// This file provides a wrapper around the mysterious header file. +// In GCC 2.95.3, the file defines a bidirectional_iterator class (and other +// friends), instead of the standard iterator class. In GCC 3.1, the +// bidirectional_iterator class got moved out and the new, standards compliant, +// iterator<> class was added. Because there is nothing that we can do to get +// correct behavior on both compilers, we have this header with #ifdef's. Gross +// huh? +// +// By #includ'ing this file, you get the contents of plus the +// following classes in the global namespace: +// +// 1. bidirectional_iterator +// +//===----------------------------------------------------------------------===// + +#ifndef SUPPORT_ITERATOR_H +#define SUPPORT_ITERATOR_H + +#include + +#if __GNUC__ == 3 + +// Define stupid wrappers around std::iterator... +template +struct bidirectional_iterator + : public std::iterator { +}; + +#else +// Just use bidirectional_iterator directly. +using std::bidirectional_iterator; +#endif + +#endif -- cgit v1.1