You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@stdcxx.apache.org by Farid Zaripov <Fa...@epam.com> on 2007/03/28 17:40:15 UTC
Boost: roguewave.hpp (repost)
I forgot to switch to the Mozilla Thunderbird to send the letter with
attachment, so I repost.
The boost library have the configuration header file
boost/config/stdlib/roguewave.hpp (attached).
That header file always included when building boost with stdcxx, so I
think we can use that file to configure the boost for successful compiling.
Farid.
Re: Boost: roguewave.hpp (repost)
Posted by Martin Sebor <ms...@gmail.com>.
On Wed, 2007-03-28 at 18:40 +0300, Farid Zaripov wrote:
> I forgot to switch to the Mozilla Thunderbird to send the letter with
> attachment, so I repost.
>
> The boost library have the configuration header file
> boost/config/stdlib/roguewave.hpp (attached).
>
> That header file always included when building boost with stdcxx, so I
> think we can use that file to configure the boost for successful compiling.
I agree, the header seems careful about checking the value of
the version macro so we should be able to extend it to handle
Apache stdcxx. We might want to add a new BOOST_STDLIB string
for "Apache C++ Standard Library" starting with version 4.1.2.
Martin
>
> Farid.
>
> plain text document attachment (roguewave.hpp)
> // (C) Copyright John Maddock 2001 - 2003.
> // (C) Copyright Jens Maurer 2001.
> // (C) Copyright David Abrahams 2003.
> // Use, modification and distribution are subject to the
> // Boost Software License, Version 1.0. (See accompanying file
> // LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
>
> // See http://www.boost.org for most recent version.
>
> // Rogue Wave std lib:
>
> #if !defined(__STD_RWCOMPILER_H__) && !defined(_RWSTD_VER)
> # include <utility>
> # if !defined(__STD_RWCOMPILER_H__) && !defined(_RWSTD_VER)
> # error This is not the Rogue Wave standard library
> # endif
> #endif
> //
> // figure out a consistent version number:
> //
> #ifndef _RWSTD_VER
> # define BOOST_RWSTD_VER 0x010000
> #elif _RWSTD_VER < 0x010000
> # define BOOST_RWSTD_VER (_RWSTD_VER << 8)
> #else
> # define BOOST_RWSTD_VER _RWSTD_VER
> #endif
>
> #ifndef _RWSTD_VER
> # define BOOST_STDLIB "Rogue Wave standard library version (Unknown version)"
> #else
> # define BOOST_STDLIB "Rogue Wave standard library version " BOOST_STRINGIZE(_RWSTD_VER)
> #endif
>
> //
> // Prior to version 2.2.0 the primary template for std::numeric_limits
> // does not have compile time constants, even though specializations of that
> // template do:
> //
> #if BOOST_RWSTD_VER < 0x020200
> # define BOOST_NO_LIMITS_COMPILE_TIME_CONSTANTS
> #endif
>
> // Sun CC 5.5 patch 113817-07 adds long long specialization, but does not change the
> // library version number (http://sunsolve6.sun.com/search/document.do?assetkey=1-21-113817):
> #if BOOST_RWSTD_VER <= 0x020101 && (!defined(__SUNPRO_CC) || (__SUNPRO_CC < 0x550))
> # define BOOST_NO_LONG_LONG_NUMERIC_LIMITS
> # endif
>
> //
> // Borland version of numeric_limits lacks __int64 specialisation:
> //
> #ifdef __BORLANDC__
> # define BOOST_NO_MS_INT64_NUMERIC_LIMITS
> #endif
>
> //
> // No std::iterator if it can't figure out default template args:
> //
> #if defined(_RWSTD_NO_SIMPLE_DEFAULT_TEMPLATES) || defined(RWSTD_NO_SIMPLE_DEFAULT_TEMPLATES) || (BOOST_RWSTD_VER < 0x020000)
> # define BOOST_NO_STD_ITERATOR
> #endif
>
> //
> // No iterator traits without partial specialization:
> //
> #if defined(_RWSTD_NO_CLASS_PARTIAL_SPEC) || defined(RWSTD_NO_CLASS_PARTIAL_SPEC)
> # define BOOST_NO_STD_ITERATOR_TRAITS
> #endif
>
> //
> // Prior to version 2.0, std::auto_ptr was buggy, and there were no
> // new-style iostreams, and no conformant std::allocator:
> //
> #if (BOOST_RWSTD_VER < 0x020000)
> # define BOOST_NO_AUTO_PTR
> # define BOOST_NO_STRINGSTREAM
> # define BOOST_NO_STD_ALLOCATOR
> # define BOOST_NO_STD_LOCALE
> #endif
>
> //
> // No template iterator constructors without member template support:
> //
> #if defined(RWSTD_NO_MEMBER_TEMPLATES) || defined(_RWSTD_NO_MEMBER_TEMPLATES)
> # define BOOST_NO_TEMPLATED_ITERATOR_CONSTRUCTORS
> #endif
>
> //
> // RW defines _RWSTD_ALLOCATOR if the allocator is conformant and in use
> // (the or _HPACC_ part is a hack - the library seems to define _RWSTD_ALLOCATOR
> // on HP aCC systems even though the allocator is in fact broken):
> //
> #if !defined(_RWSTD_ALLOCATOR) || (defined(__HP_aCC) && __HP_aCC <= 33100)
> # define BOOST_NO_STD_ALLOCATOR
> #endif
>
> //
> // If we have a std::locale, we still may not have std::use_facet:
> //
> #if defined(_RWSTD_NO_TEMPLATE_ON_RETURN_TYPE) && !defined(BOOST_NO_STD_LOCALE)
> # define BOOST_NO_STD_USE_FACET
> # define BOOST_HAS_TWO_ARG_USE_FACET
> #endif
>
> //
> // There's no std::distance prior to version 2, or without
> // partial specialization support:
> //
> #if (BOOST_RWSTD_VER < 0x020000) || defined(_RWSTD_NO_CLASS_PARTIAL_SPEC)
> #define BOOST_NO_STD_DISTANCE
> #endif
>
> //
> // Some versions of the rogue wave library don't have assignable
> // OutputIterators:
> //
> #if BOOST_RWSTD_VER < 0x020100
> # define BOOST_NO_STD_OUTPUT_ITERATOR_ASSIGN
> #endif
>
> //
> // Disable BOOST_HAS_LONG_LONG when the library has no support for it.
> //
> #if !defined(_RWSTD_LONG_LONG) && defined(BOOST_HAS_LONG_LONG)
> # undef BOOST_HAS_LONG_LONG
> #endif