Page 1 of 2 12 LastLast
Results 1 to 25 of 40
  1. #1
    Veteran DarrinS's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Jun 2005
    Post Count
    42,561
    Detroit



    Columbia, SC

  2. #2
    Veteran DarrinS's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Jun 2005
    Post Count
    42,561
    Change we can believe in!

  3. #3
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    *
    * Copyright (c) 1994
    * Hewlett-Packard Company
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Hewlett-Packard Company makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    *
    *
    * Copyright (c) 1996,1997
    * Silicon Graphics Computer Systems, Inc.
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Silicon Graphics makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    */

    #ifndef __SGI_STL_ALGO_H
    #define __SGI_STL_ALGO_H

    #include <algobase.h>
    #include <tempbuf.h>
    #include <stl_algo.h>
    #include <stl_numeric.h>

    #ifdef __STL_USE_NAMESPACES

    // Names from <stl_algo.h>
    using __STD::for_each;
    using __STD::find;
    using __STD::find_if;
    using __STD::adjacent_find;
    using __STD::count;
    using __STD::count_if;
    using __STD::search;
    using __STD::search_n;
    using __STD::swap_ranges;
    using __STD::transform;
    using __STD::replace;
    using __STD::replace_if;
    using __STD::replace_copy;
    using __STD::replace_copy_if;
    using __STD::generate;
    using __STD::generate_n;
    using __STD::remove;
    using __STD::remove_if;
    using __STD::remove_copy;
    using __STD::remove_copy_if;
    using __STD::unique;
    using __STD::unique_copy;
    using __STD::reverse;
    using __STD::reverse_copy;
    using __STD::rotate;
    using __STD::rotate_copy;
    using __STD::random_shuffle;
    using __STD::random_sample;
    using __STD::random_sample_n;
    using __STD::par ion;
    using __STD::stable_par ion;
    using __STD::sort;
    using __STD::stable_sort;
    using __STD::partial_sort;
    using __STD::partial_sort_copy;
    using __STD::nth_element;
    using __STD::lower_bound;
    using __STD::upper_bound;
    using __STD::equal_range;
    using __STD::binary_search;
    using __STD::merge;
    using __STD::inplace_merge;
    using __STD::includes;
    using __STD::set_union;
    using __STD::set_intersection;
    using __STD::set_difference;
    using __STD::set_symmetric_difference;
    using __STD::min_element;
    using __STD::max_element;
    using __STD::next_permutation;
    using __STD::prev_permutation;
    using __STD::find_first_of;
    using __STD::find_end;
    using __STD::is_sorted;
    using __STD::is_heap;

    // Names from stl_heap.h
    using __STD::push_heap;
    using __STD::pop_heap;
    using __STD::make_heap;
    using __STD::sort_heap;

    // Names from <stl_numeric.h>
    using __STD::ac ulate;
    using __STD::inner_product;
    using __STD::partial_sum;
    using __STD::adjacent_difference;
    using __STD::power;
    using __STD::iota;

    #endif /* __STL_USE_NAMESPACES */

    #endif /* __SGI_STL_ALGO_H */

    // Local Variables:
    // mode:C++
    // End:

  4. #4
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    *
    * Copyright (c) 1994
    * Hewlett-Packard Company
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Hewlett-Packard Company makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    *
    * Copyright (c) 1996,1997
    * Silicon Graphics Computer Systems, Inc.
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Silicon Graphics makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    */

    #ifndef __SGI_STL_ALGOBASE_H
    #define __SGI_STL_ALGOBASE_H

    #ifndef __SGI_STL_PAIR_H
    #include <pair.h>
    #endif
    #ifndef __SGI_STL_ITERATOR_H
    #include <iterator.h>
    #endif
    #ifndef __SGI_STL_INTERNAL_ALGOBASE_H
    #include <stl_algobase.h>
    #endif
    #ifndef __SGI_STL_INTERNAL_UNINITIALIZED_H
    #include <stl_uninitialized.h>
    #endif

    #ifdef __STL_USE_NAMESPACES

    // Names from stl_algobase.h
    using __STD::iter_swap;
    using __STD::swap;
    using __STD::min;
    using __STD::max;
    using __STD:y;
    using __STD:y_backward;
    using __STD:y_n;
    using __STD::fill;
    using __STD::fill_n;
    using __STD::mismatch;
    using __STD::equal;
    using __STD::lexicographical_compare;
    using __STD::lexicographical_compare_3way;

    // Names from stl_uninitialized.h
    using __STD::uninitialized_copy;
    using __STD::uninitialized_copy_n;
    using __STD::uninitialized_fill;
    using __STD::uninitialized_fill_n;

    #endif /* __STL_USE_NAMESPACES */

    #endif /* __SGI_STL_ALGOBASE_H */

    // Local Variables:
    // mode:C++
    // End:

  5. #5
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    *
    * Copyright (c) 1994
    * Hewlett-Packard Company
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Hewlett-Packard Company makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    *
    * Copyright (c) 1996,1997
    * Silicon Graphics Computer Systems, Inc.
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Silicon Graphics makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    */

    #ifndef __SGI_STL_ALGOBASE_H
    #define __SGI_STL_ALGOBASE_H

    #ifndef __SGI_STL_PAIR_H
    #include <pair.h>
    #endif
    #ifndef __SGI_STL_ITERATOR_H
    #include <iterator.h>
    #endif
    #ifndef __SGI_STL_INTERNAL_ALGOBASE_H
    #include <stl_algobase.h>
    #endif
    #ifndef __SGI_STL_INTERNAL_UNINITIALIZED_H
    #include <stl_uninitialized.h>
    #endif

    #ifdef __STL_USE_NAMESPACES

    // Names from stl_algobase.h
    using __STD::iter_swap;
    using __STD::swap;
    using __STD::min;
    using __STD::max;
    using __STD:y;
    using __STD:y_backward;
    using __STD:y_n;
    using __STD::fill;
    using __STD::fill_n;
    using __STD::mismatch;
    using __STD::equal;
    using __STD::lexicographical_compare;
    using __STD::lexicographical_compare_3way;

    // Names from stl_uninitialized.h
    using __STD::uninitialized_copy;
    using __STD::uninitialized_copy_n;
    using __STD::uninitialized_fill;
    using __STD::uninitialized_fill_n;

    #endif /* __STL_USE_NAMESPACES */

    #endif /* __SGI_STL_ALGOBASE_H */

    // Local Variables:
    // mode:C++
    // End:

  6. #6
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    * Copyright (c) 1996-1997
    * Silicon Graphics Computer Systems, Inc.
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Silicon Graphics makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    */

    #ifndef __SGI_STL_ALLOC_H
    #define __SGI_STL_ALLOC_H

    #ifndef __STL_CONFIG_H
    #include <stl_config.h>
    #endif
    #ifndef __SGI_STL_INTERNAL_ALLOC_H
    #include <stl_alloc.h>
    #endif

    #ifdef __STL_USE_NAMESPACES

    using __STD::__malloc_alloc_template;
    using __STD::malloc_alloc;
    using __STD::simple_alloc;
    using __STD::debug_alloc;
    using __STD::__default_alloc_template;
    using __STD::alloc;
    using __STD::single_client_alloc;
    #ifdef __STL_STATIC_TEMPLATE_MEMBER_BUG
    using __STD::__malloc_alloc_oom_handler;
    #endif /* __STL_STATIC_TEMPLATE_MEMBER_BUG */
    #ifdef __STL_USE_STD_ALLOCATORS
    using __STD::allocator;
    #endif /* __STL_USE_STD_ALLOCATORS */

    #endif /* __STL_USE_NAMESPACES */

    #endif /* __SGI_STL_ALLOC_H */

    // Local Variables:
    // mode:C++
    // End:

  7. #7
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    * Copyright (c) 1996-1997
    * Silicon Graphics Computer Systems, Inc.
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Silicon Graphics makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    */

    #ifndef __SGI_STL_ALLOC_H
    #define __SGI_STL_ALLOC_H

    #ifndef __STL_CONFIG_H
    #include <stl_config.h>
    #endif
    #ifndef __SGI_STL_INTERNAL_ALLOC_H
    #include <stl_alloc.h>
    #endif

    #ifdef __STL_USE_NAMESPACES

    using __STD::__malloc_alloc_template;
    using __STD::malloc_alloc;
    using __STD::simple_alloc;
    using __STD::debug_alloc;
    using __STD::__default_alloc_template;
    using __STD::alloc;
    using __STD::single_client_alloc;
    #ifdef __STL_STATIC_TEMPLATE_MEMBER_BUG
    using __STD::__malloc_alloc_oom_handler;
    #endif /* __STL_STATIC_TEMPLATE_MEMBER_BUG */
    #ifdef __STL_USE_STD_ALLOCATORS
    using __STD::allocator;
    #endif /* __STL_USE_STD_ALLOCATORS */

    #endif /* __STL_USE_NAMESPACES */

    #endif /* __SGI_STL_ALLOC_H */

    // Local Variables:
    // mode:C++
    // End:

  8. #8
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    *
    * Copyright (c) 1994
    * Hewlett-Packard Company
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Hewlett-Packard Company makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    *
    *
    * Copyright (c) 1996
    * Silicon Graphics Computer Systems, Inc.
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Silicon Graphics makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    */

    #ifndef __SGI_STL_BVECTOR_H
    #define __SGI_STL_BVECTOR_H

    #include <stl_range_errors.h>
    #ifdef __STL_CLASS_PARTIAL_SPECIALIZATION
    #include <vector.h>
    #else
    #include <algobase.h>
    #include <alloc.h>
    #endif

    #include <stl_bvector.h>

    #ifdef __STL_USE_NAMESPACES

    using __STD::bit_vector;

    #endif /* __STL_USE_NAMESPACES */

    #endif /* __SGI_STL_BVECTOR_H */

    // Local Variables:
    // mode:C++
    // End:

  9. #9
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    * Copyright (c) 1997
    * Silicon Graphics Computer Systems, Inc.
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Silicon Graphics makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    */

    #ifndef __SGI_STL_CHAR_TRAITS_H
    #define __SGI_STL_CHAR_TRAITS_H

    #include <string.h>
    #include <wchar.h>

    #if defined(__STL_USE_NEW_IOSTREAMS) && !defined(__SGI_STL_IOSFWD)
    #include <iosfwd>
    #endif /* use new iostreams */

    __STL_BEGIN_NAMESPACE

    // Class __char_traits_base.

    template <class _CharT, class _IntT> class __char_traits_base {
    public:
    typedef _CharT char_type;
    typedef _IntT int_type;
    #ifdef __STL_USE_NEW_IOSTREAMS
    typedef streamoff off_type;
    typedef streampos pos_type;
    typedef mbstate_t state_type;
    #endif /* __STL_USE_NEW_IOSTREAMS */

    static void assign(char_type& __c1, const char_type& __c2) { __c1 = __c2; }
    static bool eq(const _CharT& __c1, const _CharT& __c2)
    { return __c1 == __c2; }
    static bool lt(const _CharT& __c1, const _CharT& __c2)
    { return __c1 < __c2; }

    static int compare(const _CharT* __s1, const _CharT* __s2, size_t __n) {
    for (size_t __i = 0; __i < __n; ++__i)
    if (!eq(__s1[__i], __s2[__i]))
    return __s1[__i] < __s2[__i] ? -1 : 1;
    return 0;
    }

    static size_t length(const _CharT* __s) {
    const _CharT __nullchar = _CharT();
    size_t __i;
    for (__i = 0; !eq(__s[__i], __nullchar); ++__i)
    {}
    return __i;
    }

    static const _CharT* find(const _CharT* __s, size_t __n, const _CharT& __c)
    {
    for ( ; __n > 0 ; ++__s, --__n)
    if (eq(*__s, __c))
    return __s;
    return 0;
    }

    static _CharT* move(_CharT* __s1, const _CharT* __s2, size_t __n) {
    memmove(__s1, __s2, __n * sizeof(_CharT));
    return __s1;
    }

    static _CharT* copy(_CharT* __s1, const _CharT* __s2, size_t __n) {
    memcpy(__s1, __s2, __n * sizeof(_CharT));
    return __s1;
    }

    static _CharT* assign(_CharT* __s, size_t __n, _CharT __c) {
    for (size_t __i = 0; __i < __n; ++__i)
    __s[__i] = __c;
    return __s;
    }

    static int_type not_eof(const int_type& __c) {
    return !eq_int_type(__c, eof()) ? __c : 0;
    }

    static char_type to_char_type(const int_type& __c) {
    return static_cast<char_type>(__c);
    }

    static int_type to_int_type(const char_type& __c) {
    return static_cast<int_type>(__c);
    }

    static bool eq_int_type(const int_type& __c1, const int_type& __c2) {
    return __c1 == __c2;
    }

    static int_type eof() {
    return static_cast<int_type>(-1);
    }
    };

    // Generic char_traits class. Note that this class is provided only
    // as a base for explicit specialization; it is unlikely to be useful
    // as is for any particular user-defined type. In particular, it
    // *will not work* for a non-POD type.

    template <class _CharT> class char_traits
    : public __char_traits_base<_CharT, _CharT>
    {};

    // Specialization for char.

    __STL_TEMPLATE_NULL class char_traits<char>
    : public __char_traits_base<char, int>
    {
    public:
    static char_type to_char_type(const int_type& __c) {
    return static_cast<char_type>(static_cast<unsigned char>(__c));
    }

    static int_type to_int_type(const char_type& __c) {
    return static_cast<unsigned char>(__c);
    }

    static int compare(const char* __s1, const char* __s2, size_t __n)
    { return memcmp(__s1, __s2, __n); }

    static size_t length(const char* __s) { return strlen(__s); }

    static void assign(char& __c1, const char& __c2) { __c1 = __c2; }

    static char* assign(char* __s, size_t __n, char __c)
    { memset(__s, __c, __n); return __s; }
    };

    // Specialization for wchar_t.

    __STL_TEMPLATE_NULL class char_traits<wchar_t>
    : public __char_traits_base<wchar_t, wint_t>
    {};


    __STL_END_NAMESPACE

    #endif /* __SGI_STL_CHAR_TRAITS_H */

    // Local Variables:
    // mode:C++
    // End:

  10. #10
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    * Copyright (c) 1999
    * Silicon Graphics Computer Systems, Inc.
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Silicon Graphics makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    */

    #ifndef __CONCEPT_CHECKS_H
    #define __CONCEPT_CHECKS_H

    /*
    Use these macro like assertions, but they assert properties
    on types (usually template arguments). In technical terms they
    verify whether a type "models" a "concept".

    This set of requirements and the terminology used here is derived
    from the book "Generic Programming and the STL" by Matt Austern
    (Addison Wesley). For further information please consult that
    book. The requirements also are intended to match the ANSI/ISO C++
    standard.

    This file covers the basic concepts and the iterator concepts.
    There are several other files that provide the requirements
    for the STL containers:
    container_concepts.h
    sequence_concepts.h
    assoc_container_concepts.h

    Jeremy Siek, 1999

    TO DO:
    - some issues with regards to concept classification and mutability
    including AssociativeContianer -> ForwardContainer
    and SortedAssociativeContainer -> ReversibleContainer
    - HashedAssociativeContainer
    - Allocator
    - Function Object Concepts

    */

    #ifndef __STL_USE_CONCEPT_CHECKS

    // Some compilers lack the features that are necessary for concept checks.
    // On those compilers we define the concept check macros to do nothing.
    #define __STL_REQUIRES(__type_var, __concept) do {} while(0)
    #define __STL_CLASS_REQUIRES(__type_var, __concept) \
    static int __##__type_var##_##__concept
    #define __STL_CONVERTIBLE(__type_x, __type_y) do {} while(0)
    #define __STL_REQUIRES_SAME_TYPE(__type_x, __type_y) do {} while(0)
    #define __STL_CLASS_REQUIRES_SAME_TYPE(__type_x, __type_y) \
    static int __##__type_x##__type_y##_require_same_type
    #define __STL_GENERATOR_CHECK(__func, __ret) do {} while(0)
    #define __STL_CLASS_GENERATOR_CHECK(__func, __ret) \
    static int __##__func##__ret##_generator_check
    #define __STL_UNARY_FUNCTION_CHECK(__func, __ret, __arg) do {} while(0)
    #define __STL_CLASS_UNARY_FUNCTION_CHECK(__func, __ret, __arg) \
    static int __##__func##__ret##__arg##_unary_function_check
    #define __STL_BINARY_FUNCTION_CHECK(__func, __ret, __first, __second) \
    do {} while(0)
    #define __STL_CLASS_BINARY_FUNCTION_CHECK(__func, __ret, __first, __second) \
    static int __##__func##__ret##__first##__second##_binary_func tion_check
    #define __STL_REQUIRES_BINARY_OP(__opname, __ret, __first, __second) \
    do {} while(0)
    #define __STL_CLASS_REQUIRES_BINARY_OP(__opname, __ret, __first, __second) \
    static int __##__opname##__ret##__first##__second##_require_b inary_op

    #else /* __STL_USE_CONCEPT_CHECKS */

    // This macro tests whether the template argument "__type_var"
    // satisfies the requirements of "__concept". Here is a list of concepts
    // that we know how to check:
    // _Allocator
    // _Assignable
    // _DefaultConstructible
    // _EqualityComparable
    // _LessThanComparable
    // _TrivialIterator
    // _Inpu erator
    // _Outpu erator
    // _ForwardIterator
    // _BidirectionalIterator
    // _RandomAccessIterator
    // _Mutable_TrivialIterator
    // _Mutable_ForwardIterator
    // _Mutable_BidirectionalIterator
    // _Mutable_RandomAccessIterator

    #define __STL_REQUIRES(__type_var, __concept) \
    do { \
    void (*__x)( __type_var ) = __concept##_concept_specification< __type_var >\
    ::__concept##_requirement_violation; __x = __x; } while (0)

    // Use this to check whether type X is convertible to type Y
    #define __STL_CONVERTIBLE(__type_x, __type_y) \
    do { \
    void (*__x)( __type_x , __type_y ) = _STL_CONVERT_ERROR< __type_x , \
    __type_y >::__type_X_is_not_convertible_to_type_Y; \
    __x = __x; } while (0)

    // Use this to test whether two template arguments are the same type
    #define __STL_REQUIRES_SAME_TYPE(__type_x, __type_y) \
    do { \
    void (*__x)( __type_x , __type_y ) = _STL_SAME_TYPE_ERROR< __type_x, \
    __type_y >::__type_X_not_same_as_type_Y; \
    __x = __x; } while (0)


    // function object checks
    #define __STL_GENERATOR_CHECK(__func, __ret) \
    do { \
    __ret (*__x)( __func&) = \
    _STL_GENERATOR_ERROR< \
    __func, __ret>::__generator_requirement_violation; \
    __x = __x; } while (0)


    #define __STL_UNARY_FUNCTION_CHECK(__func, __ret, __arg) \
    do { \
    __ret (*__x)( __func&, const __arg& ) = \
    _STL_UNARY_FUNCTION_ERROR< \
    __func, __ret, __arg>::__unary_function_requirement_violation; \
    __x = __x; } while (0)


    #define __STL_BINARY_FUNCTION_CHECK(__func, __ret, __first, __second) \
    do { \
    __ret (*__x)( __func&, const __first&, const __second& ) = \
    _STL_BINARY_FUNCTION_ERROR< \
    __func, __ret, __first, __second>::__binary_function_requirement_violation ; \
    __x = __x; } while (0)


    #define __STL_REQUIRES_BINARY_OP(__opname, __ret, __first, __second) \
    do { \
    __ret (*__x)( __first&, __second& ) = _STL_BINARY##__opname##_ERROR< \
    __ret, __first, __second>::__binary_operator_requirement_violation ; \
    __ret (*__y)( const __first&, const __second& ) = \
    _STL_BINARY##__opname##_ERROR< __ret, __first, __second>:: \
    __const_binary_operator_requirement_violation; \
    __y = __y; __x = __x; } while (0)


    #ifdef __STL_NO_FUNCTION_PTR_IN_CLASS_TEMPLATE

    #define __STL_CLASS_REQUIRES(__type_var, __concept)
    #define __STL_CLASS_REQUIRES_SAME_TYPE(__type_x, __type_y)
    #define __STL_CLASS_GENERATOR_CHECK(__func, __ret)
    #define __STL_CLASS_UNARY_FUNCTION_CHECK(__func, __ret, __arg)
    #define __STL_CLASS_BINARY_FUNCTION_CHECK(__func, __ret, __first, __second)
    #define __STL_CLASS_REQUIRES_BINARY_OP(__opname, __ret, __first, __second)

    #else

    // Use this macro inside of template classes, where you would
    // like to place requirements on the template arguments to the class
    // Warning: do not pass pointers and such (e.g. T*) in as the __type_var,
    // since the type_var is used to construct identifiers. Instead typedef
    // the pointer type, then use the typedef name for the __type_var.
    #define __STL_CLASS_REQUIRES(__type_var, __concept) \
    typedef void (* __func##__type_var##__concept)( __type_var ); \
    template <__func##__type_var##__concept _Tp1> \
    struct __dummy_struct_##__type_var##__concept { }; \
    static __dummy_struct_##__type_var##__concept< \
    __concept##_concept_specification< \
    __type_var>::__concept##_requirement_violation> \
    __dummy_ptr_##__type_var##__concept


    #define __STL_CLASS_REQUIRES_SAME_TYPE(__type_x, __type_y) \
    typedef void (* __func_##__type_x##__type_y##same_type)( __type_x, \
    __type_y ); \
    template < __func_##__type_x##__type_y##same_type _Tp1> \
    struct __dummy_struct_##__type_x##__type_y##_same_type { }; \
    static __dummy_struct_##__type_x##__type_y##_same_type< \
    _STL_SAME_TYPE_ERROR<__type_x, __type_y>::__type_X_not_same_as_type_Y> \
    __dummy_ptr_##__type_x##__type_y##_same_type


    #define __STL_CLASS_GENERATOR_CHECK(__func, __ret) \
    typedef __ret (* __f_##__func##__ret##_generator)( __func& ); \
    template <__f_##__func##__ret##_generator _Tp1> \
    struct __dummy_struct_##__func##__ret##_generator { }; \
    static __dummy_struct_##__func##__ret##_generator< \
    _STL_GENERATOR_ERROR< \
    __func, __ret>::__generator_requirement_violation> \
    __dummy_ptr_##__func##__ret##_generator


    #define __STL_CLASS_UNARY_FUNCTION_CHECK(__func, __ret, __arg) \
    typedef __ret (* __f_##__func##__ret##__arg##_unary_check)( __func&, \
    const __arg& ); \
    template <__f_##__func##__ret##__arg##_unary_check _Tp1> \
    struct __dummy_struct_##__func##__ret##__arg##_unary_chec k { }; \
    static __dummy_struct_##__func##__ret##__arg##_unary_chec k< \
    _STL_UNARY_FUNCTION_ERROR< \
    __func, __ret, __arg>::__unary_function_requirement_violation> \
    __dummy_ptr_##__func##__ret##__arg##_unary_check


    #define __STL_CLASS_BINARY_FUNCTION_CHECK(__func, __ret, __first, __second) \
    typedef __ret (* __f_##__func##__ret##__first##__second##_binary_ch eck)( __func&, const __first&,\
    const __second& ); \
    template <__f_##__func##__ret##__first##__second##_binary_c heck _Tp1> \
    struct __dummy_struct_##__func##__ret##__first##__second# #_binary_check { }; \
    static __dummy_struct_##__func##__ret##__first##__second# #_binary_check< \
    _STL_BINARY_FUNCTION_ERROR<__func, __ret, __first, __second>:: \
    __binary_function_requirement_violation> \
    __dummy_ptr_##__func##__ret##__first##__second##_b inary_check


    #define __STL_CLASS_REQUIRES_BINARY_OP(__opname, __ret, __first, __second) \
    typedef __ret (* __f_##__func##__ret##__first##__second##_binary_op )(const __first&, \
    const __second& ); \
    template <__f_##__func##__ret##__first##__second##_binary_o p _Tp1> \
    struct __dummy_struct_##__func##__ret##__first##__second# #_binary_op { }; \
    static __dummy_struct_##__func##__ret##__first##__second# #_binary_op< \
    _STL_BINARY##__opname##_ERROR<__ret, __first, __second>:: \
    __binary_operator_requirement_violation> \
    __dummy_ptr_##__func##__ret##__first##__second##_b inary_op

    #endif

    /* helper class for finding non-const version of a type. Need to have
    something to assign to etc. when testing constant iterators. */

    template <class _Tp>
    struct _Mutable_trait {
    typedef _Tp _Type;
    };
    template <class _Tp>
    struct _Mutable_trait<const _Tp> {
    typedef _Tp _Type;
    };


    /* helper function for avoiding compiler warnings about unused variables */
    template <class _Type>
    void __sink_unused_warning(_Type) { }

    template <class _TypeX, class _TypeY>
    struct _STL_CONVERT_ERROR {
    static void
    __type_X_is_not_convertible_to_type_Y(_TypeX __x, _TypeY) {
    _TypeY __y = __x;
    __sink_unused_warning(__y);
    }
    };


    template <class _Type> struct __check_equal { };

    template <class _TypeX, class _TypeY>
    struct _STL_SAME_TYPE_ERROR {
    static void
    __type_X_not_same_as_type_Y(_TypeX , _TypeY ) {
    __check_equal<_TypeX> t1 = __check_equal<_TypeY>();
    }
    };


    // Some Functon Object Checks

    template <class _Func, class _Ret>
    struct _STL_GENERATOR_ERROR {
    static _Ret __generator_requirement_violation(_Func& __f) {
    return __f();
    }
    };

    template <class _Func>
    struct _STL_GENERATOR_ERROR<_Func, void> {
    static void __generator_requirement_violation(_Func& __f) {
    __f();
    }
    };


    template <class _Func, class _Ret, class _Arg>
    struct _STL_UNARY_FUNCTION_ERROR {
    static _Ret
    __unary_function_requirement_violation(_Func& __f,
    const _Arg& __arg) {
    return __f(__arg);
    }
    };

    template <class _Func, class _Arg>
    struct _STL_UNARY_FUNCTION_ERROR<_Func, void, _Arg> {
    static void
    __unary_function_requirement_violation(_Func& __f,
    const _Arg& __arg) {
    __f(__arg);
    }
    };

    template <class _Func, class _Ret, class _First, class _Second>
    struct _STL_BINARY_FUNCTION_ERROR {
    static _Ret
    __binary_function_requirement_violation(_Func& __f,
    const _First& __first,
    const _Second& __second) {
    return __f(__first, __second);
    }
    };

    template <class _Func, class _First, class _Second>
    struct _STL_BINARY_FUNCTION_ERROR<_Func, void, _First, _Second> {
    static void
    __binary_function_requirement_violation(_Func& __f,
    const _First& __first,
    const _Second& __second) {
    __f(__first, __second);
    }
    };


    #define __STL_DEFINE_BINARY_OP_CHECK(_OP, _NAME) \
    template <class _Ret, class _First, class _Second> \
    struct _STL_BINARY##_NAME##_ERROR { \
    static _Ret \
    __const_binary_operator_requirement_violation(cons t _First& __first, \
    const _Second& __second) { \
    return __first _OP __second; \
    } \
    static _Ret \
    __binary_operator_requirement_violation(_First& __first, \
    _Second& __second) { \
    return __first _OP __second; \
    } \
    }

    __STL_DEFINE_BINARY_OP_CHECK(==, _OP_EQUAL);
    __STL_DEFINE_BINARY_OP_CHECK(!=, _OP_NOT_EQUAL);
    __STL_DEFINE_BINARY_OP_CHECK(<, _OP_LESS_THAN);
    __STL_DEFINE_BINARY_OP_CHECK(<=, _OP_LESS_EQUAL);
    __STL_DEFINE_BINARY_OP_CHECK(>, _OP_GREATER_THAN);
    __STL_DEFINE_BINARY_OP_CHECK(>=, _OP_GREATER_EQUAL);
    __STL_DEFINE_BINARY_OP_CHECK(+, _OP_PLUS);
    __STL_DEFINE_BINARY_OP_CHECK(*, _OP_TIMES);
    __STL_DEFINE_BINARY_OP_CHECK(/, _OP_DIVIDE);
    __STL_DEFINE_BINARY_OP_CHECK(-, _OP_SUBTRACT);
    __STL_DEFINE_BINARY_OP_CHECK(%, _OP_MOD);
    // ...

    // TODO, add unary operators (prefix and postfix)

    /*
    The presence of this class is just to trick EDG into displaying
    these error messages before any other errors. Without the
    classes, the errors in the functions get reported after
    other class errors deep inside the library. The name
    choice just makes for an eye catching error message
    */
    struct _STL_ERROR {

    template <class _Type>
    static _Type
    __default_constructor_requirement_violation(_Type) {
    return _Type();
    }
    template <class _Type>
    static _Type
    __assignment_operator_requirement_violation(_Type __a) {
    __a = __a;
    return __a;
    }
    template <class _Type>
    static _Type
    __copy_constructor_requirement_violation(_Type __a) {
    _Type __c(__a);
    return __c;
    }
    template <class _Type>
    static _Type
    __const_parameter_required_for_copy_constructor(_T ype /* __a */,
    const _Type& __b) {
    _Type __c(__b);
    return __c;
    }
    template <class _Type>
    static _Type
    __const_parameter_required_for_assignment_operator (_Type __a,
    const _Type& __b) {
    __a = __b;
    return __a;
    }
    template <class _Type>
    static _Type
    __less_than_comparable_requirement_violation(_Type __a, _Type __b) {
    if (__a < __b || __a > __b || __a <= __b || __a >= __b) return __a;
    return __b;
    }
    template <class _Type>
    static _Type
    __equality_comparable_requirement_violation(_Type __a, _Type __b) {
    if (__a == __b || __a != __b) return __a;
    return __b;
    }
    template <class _Iterator>
    static void
    __dereference_operator_requirement_violation(_Iter ator __i) {
    __sink_unused_warning(*__i);
    }
    template <class _Iterator>
    static void
    __dereference_operator_and_assignment_requirement_ violation(_Iterator __i) {
    *__i = *__i;
    }
    template <class _Iterator>
    static void
    __preincrement_operator_requirement_violation(_Ite rator __i) {
    ++__i;
    }
    template <class _Iterator>
    static void
    __postincrement_operator_requirement_violation(_It erator __i) {
    __i++;
    }
    template <class _Iterator>
    static void
    __predecrement_operator_requirement_violation(_Ite rator __i) {
    --__i;
    }
    template <class _Iterator>
    static void
    __postdecrement_operator_requirement_violation(_It erator __i) {
    __i--;
    }
    template <class _Iterator, class _Type>
    static void
    __postincrement_operator_and_assignment_requiremen t_violation(_Iterator __i,
    _Type __t) {
    *__i++ = __t;
    }
    template <class _Iterator, class _Distance>
    static _Iterator
    __iterator_addition_assignment_requirement_violati on(_Iterator __i,
    _Distance __n) {
    __i += __n;
    return __i;
    }
    template <class _Iterator, class _Distance>
    static _Iterator
    __iterator_addition_requirement_violation(_Iterato r __i, _Distance __n) {
    __i = __i + __n;
    __i = __n + __i;
    return __i;
    }
    template <class _Iterator, class _Distance>
    static _Iterator
    __iterator_subtraction_assignment_requirement_viol ation(_Iterator __i,
    _Distance __n) {
    __i -= __n;
    return __i;
    }
    template <class _Iterator, class _Distance>
    static _Iterator
    __iterator_subtraction_requirement_violation(_Iter ator __i, _Distance __n) {
    __i = __i - __n;
    return __i;
    }
    template <class _Iterator, class _Distance>
    static _Distance
    __difference_operator_requirement_violation(_Itera tor __i, _Iterator __j,
    _Distance __n) {
    __n = __i - __j;
    return __n;
    }
    template <class _Exp, class _Type, class _Distance>
    static _Type
    __element_access_operator_requirement_violation(_E xp __x, _Type*,
    _Distance __n) {
    return __x[__n];
    }
    template <class _Exp, class _Type, class _Distance>
    static void
    __element_assignment_operator_requirement_violatio n(_Exp __x,
    _Type* __t,
    _Distance __n) {
    __x[__n] = *__t;
    }

    }; /* _STL_ERROR */

    /* Associated Type Requirements */

    __STL_BEGIN_NAMESPACE
    template <class _Iterator> struct iterator_traits;
    __STL_END_NAMESPACE

    template <class _Iter>
    struct __value_type_type_definition_requirement_violation {
    typedef typename __STD::iterator_traits<_Iter>::value_type value_type;
    };

    template <class _Iter>
    struct __difference_type_type_definition_requirement_viol ation {
    typedef typename __STD::iterator_traits<_Iter>::difference_type
    difference_type;
    };

    template <class _Iter>
    struct __reference_type_definition_requirement_violation {
    typedef typename __STD::iterator_traits<_Iter>::reference reference;
    };

    template <class _Iter>
    struct __pointer_type_definition_requirement_violation {
    typedef typename __STD::iterator_traits<_Iter>::pointer pointer;
    };

    template <class _Iter>
    struct __iterator_category_type_definition_requirement_vi olation {
    typedef typename __STD::iterator_traits<_Iter>::iterator_category
    iterator_category;
    };

    /* Assignable Requirements */


    template <class _Type>
    struct _Assignable_concept_specification {
    static void _Assignable_requirement_violation(_Type __a) {
    _STL_ERROR::__assignment_operator_requirement_viol ation(__a);
    _STL_ERROR::__copy_constructor_requirement_violati on(__a);
    _STL_ERROR::__const_parameter_required_for_copy_co nstructor(__a,__a);
    _STL_ERROR::__const_parameter_required_for_assignm ent_operator(__a,__a);
    }
    };

    /* DefaultConstructible Requirements */


    template <class _Type>
    struct _DefaultConstructible_concept_specification {
    static void _DefaultConstructible_requirement_violation(_Type __a) {
    _STL_ERROR::__default_constructor_requirement_viol ation(__a);
    }
    };

    /* EqualityComparable Requirements */

    template <class _Type>
    struct _EqualityComparable_concept_specification {
    static void _EqualityComparable_requirement_violation(_Type __a) {
    _STL_ERROR::__equality_comparable_requirement_viol ation(__a, __a);
    }
    };

    /* LessThanComparable Requirements */
    template <class _Type>
    struct _LessThanComparable_concept_specification {
    static void _LessThanComparable_requirement_violation(_Type __a) {
    _STL_ERROR::__less_than_comparable_requirement_vio lation(__a, __a);
    }
    };

    /* TrivialIterator Requirements */

    template <class _TrivialIterator>
    struct _TrivialIterator_concept_specification {
    static void
    _TrivialIterator_requirement_violation(_TrivialIte rator __i) {
    typedef typename
    __value_type_type_definition_requirement_violation <_TrivialIterator>::
    value_type __T;
    // Refinement of Assignable
    _Assignable_concept_specification<_TrivialIterator >::
    _Assignable_requirement_violation(__i);
    // Refinement of DefaultConstructible
    _DefaultConstructible_concept_specification<_Trivi alIterator>::
    _DefaultConstructible_requirement_violation(__i);
    // Refinement of EqualityComparable
    _EqualityComparable_concept_specification<_Trivial Iterator>::
    _EqualityComparable_requirement_violation(__i);
    // Valid Expressions
    _STL_ERROR::__dereference_operator_requirement_vio lation(__i);
    }
    };

    template <class _TrivialIterator>
    struct _Mutable_TrivialIterator_concept_specification {
    static void
    _Mutable_TrivialIterator_requirement_violation(_Tr ivialIterator __i) {
    _TrivialIterator_concept_specification<_TrivialIte rator>::
    _TrivialIterator_requirement_violation(__i);
    // Valid Expressions
    _STL_ERROR::__dereference_operator_and_assignment_ requirement_violation(__i);
    }
    };

    /* Inpu erator Requirements */

    template <class _Inpu erator>
    struct _Inpu erator_concept_specification {
    static void
    _Inpu erator_requirement_violation(_Inpu erato r __i) {
    // Refinement of TrivialIterator
    _TrivialIterator_concept_specification<_Inpu era tor>::
    _TrivialIterator_requirement_violation(__i);
    // Associated Types
    __difference_type_type_definition_requirement_viol ation<_Inpu erator>();
    __reference_type_definition_requirement_violation< _Inpu erator>();
    __pointer_type_definition_requirement_violation<_I npu erator>();
    __iterator_category_type_definition_requirement_vi olation<_Inpu erator>();
    // Valid Expressions
    _STL_ERROR::__preincrement_operator_requirement_vi olation(__i);
    _STL_ERROR::__postincrement_operator_requirement_v iolation(__i);
    }
    };

    /* Outpu erator Requirements */

    template <class _Outpu erator>
    struct _Outpu erator_concept_specification {
    static void
    _Outpu erator_requirement_violation(_Outpu era tor __i) {
    // Refinement of Assignable
    _Assignable_concept_specification<_Outpu erator> ::
    _Assignable_requirement_violation(__i);
    // Associated Types
    __iterator_category_type_definition_requirement_vi olation<_Outpu erator>();
    // Valid Expressions
    _STL_ERROR::__dereference_operator_requirement_vio lation(__i);
    _STL_ERROR::__preincrement_operator_requirement_vi olation(__i);
    _STL_ERROR::__postincrement_operator_requirement_v iolation(__i);
    _STL_ERROR::
    __postincrement_operator_and_assignment_requiremen t_violation(__i, *__i);
    }
    };

    /* ForwardIterator Requirements */

    template <class _ForwardIterator>
    struct _ForwardIterator_concept_specification {
    static void
    _ForwardIterator_requirement_violation(_ForwardIte rator __i) {
    // Refinement of Inpu erator
    _Inpu erator_concept_specification<_ForwardItera tor>::
    _Inpu erator_requirement_violation(__i);
    }
    };

    template <class _ForwardIterator>
    struct _Mutable_ForwardIterator_concept_specification {
    static void
    _Mutable_ForwardIterator_requirement_violation(_Fo rwardIterator __i) {
    _ForwardIterator_concept_specification<_ForwardIte rator>::
    _ForwardIterator_requirement_violation(__i);
    // Refinement of Outpu erator
    _Outpu erator_concept_specification<_ForwardIter ator>::
    _Outpu erator_requirement_violation(__i);
    }
    };

    /* BidirectionalIterator Requirements */

    template <class _BidirectionalIterator>
    struct _BidirectionalIterator_concept_specification {
    static void
    _BidirectionalIterator_requirement_violation(_Bidi rectionalIterator __i) {
    // Refinement of ForwardIterator
    _ForwardIterator_concept_specification<_Bidirectio nalIterator>::
    _ForwardIterator_requirement_violation(__i);
    // Valid Expressions
    _STL_ERROR::__predecrement_operator_requirement_vi olation(__i);
    _STL_ERROR::__postdecrement_operator_requirement_v iolation(__i);
    }
    };

    template <class _BidirectionalIterator>
    struct _Mutable_BidirectionalIterator_concept_specificati on {
    static void
    _Mutable_BidirectionalIterator_requirement_violati on(
    _BidirectionalIterator __i)
    {
    _BidirectionalIterator_concept_specification<_Bidi rectionalIterator>::
    _BidirectionalIterator_requirement_violation(__i);
    // Refinement of mutable_ForwardIterator
    _Mutable_ForwardIterator_concept_specification<_Bi directionalIterator>::
    _Mutable_ForwardIterator_requirement_violation(__i );
    typedef typename
    __value_type_type_definition_requirement_violation <
    _BidirectionalIterator>::value_type __T;
    typename _Mutable_trait<__T>::_Type* __tmp_ptr = 0;
    // Valid Expressions
    _STL_ERROR::
    __postincrement_operator_and_assignment_requiremen t_violation(__i,
    *__tmp_ptr);
    }
    };

    /* RandomAccessIterator Requirements */

    template <class _RandAccIter>
    struct _RandomAccessIterator_concept_specification {
    static void
    _RandomAccessIterator_requirement_violation(_RandA ccIter __i) {
    // Refinement of BidirectionalIterator
    _BidirectionalIterator_concept_specification<_Rand AccIter>::
    _BidirectionalIterator_requirement_violation(__i);
    // Refinement of LessThanComparable
    _LessThanComparable_concept_specification<_RandAcc Iter>::
    _LessThanComparable_requirement_violation(__i);
    typedef typename
    __value_type_type_definition_requirement_violation <_RandAccIter>
    ::value_type
    value_type;
    typedef typename
    __difference_type_type_definition_requirement_viol ation<_RandAccIter>
    ::difference_type
    _Dist;
    typedef typename _Mutable_trait<_Dist>::_Type _MutDist;

    // Valid Expressions
    _STL_ERROR::__iterator_addition_assignment_require ment_violation(__i,
    _MutDist());
    _STL_ERROR::__iterator_addition_requirement_violat ion(__i,
    _MutDist());
    _STL_ERROR::
    __iterator_subtraction_assignment_requirement_viol ation(__i,
    _MutDist());
    _STL_ERROR::__iterator_subtraction_requirement_vio lation(__i,
    _MutDist());
    _STL_ERROR::__difference_operator_requirement_viol ation(__i, __i,
    _MutDist());
    typename _Mutable_trait<value_type>::_Type* __dummy_ptr = 0;
    _STL_ERROR::__element_access_operator_requirement_ violation(__i,
    __dummy_ptr,
    _MutDist());
    }
    };

    template <class _RandAccIter>
    struct _Mutable_RandomAccessIterator_concept_specificatio n {
    static void
    _Mutable_RandomAccessIterator_requirement_violatio n(_RandAccIter __i)
    {
    _RandomAccessIterator_concept_specification<_RandA ccIter>::
    _RandomAccessIterator_requirement_violation(__i);
    // Refinement of mutable_BidirectionalIterator
    _Mutable_BidirectionalIterator_concept_specificati on<_RandAccIter>::
    _Mutable_BidirectionalIterator_requirement_violati on(__i);
    typedef typename
    __value_type_type_definition_requirement_violation <_RandAccIter>
    ::value_type
    value_type;
    typedef typename
    __difference_type_type_definition_requirement_viol ation<_RandAccIter>
    ::difference_type
    _Dist;

    typename _Mutable_trait<value_type>::_Type* __tmp_ptr = 0;
    // Valid Expressions
    _STL_ERROR::__element_assignment_operator_requirem ent_violation(__i,
    __tmp_ptr, _Dist());
    }
    };

    #define __STL_TYPEDEF_REQUIREMENT(__REQUIREMENT) \
    template <class Type> \
    struct __##__REQUIREMENT##__typedef_requirement_violation { \
    typedef typename Type::__REQUIREMENT __REQUIREMENT; \
    }

    __STL_TYPEDEF_REQUIREMENT(value_type);
    __STL_TYPEDEF_REQUIREMENT(difference_type);
    __STL_TYPEDEF_REQUIREMENT(size_type);
    __STL_TYPEDEF_REQUIREMENT(reference);
    __STL_TYPEDEF_REQUIREMENT(const_reference);
    __STL_TYPEDEF_REQUIREMENT(pointer);
    __STL_TYPEDEF_REQUIREMENT(const_pointer);


    template <class _Alloc>
    struct _Allocator_concept_specification {
    static void
    _Allocator_requirement_violation(_Alloc __a) {
    // Refinement of DefaultConstructible
    _DefaultConstructible_concept_specification<_Alloc >::
    _DefaultConstructible_requirement_violation(__a);
    // Refinement of EqualityComparable
    _EqualityComparable_concept_specification<_Alloc>: :
    _EqualityComparable_requirement_violation(__a);
    // Associated Types
    __value_type__typedef_requirement_violation<_Alloc >();
    __difference_type__typedef_requirement_violation<_ Alloc>();
    __size_type__typedef_requirement_violation<_Alloc> ();
    __reference__typedef_requirement_violation<_Alloc> ();
    __const_reference__typedef_requirement_violation<_ Alloc>();
    __pointer__typedef_requirement_violation<_Alloc>() ;
    __const_pointer__typedef_requirement_violation<_Al loc>();
    typedef typename _Alloc::value_type _Tp;
    //__STL_REQUIRES_SAME_TYPE(typename _Alloc::__STL_TEMPLATE rebind<_Tp>::other,
    // _Alloc);
    }
    };

    #endif /* __STL_USE_CONCEPT_CHECKS */

    #endif /* __CONCEPT_CHECKS_H */

    // Local Variables:
    // mode:C++
    // End:

  11. #11
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    * Copyright (c) 1999
    * Silicon Graphics Computer Systems, Inc.
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Silicon Graphics makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    */

    #ifndef __STL_CONTAINER_CONCEPTS_H
    #define __STL_CONTAINER_CONCEPTS_H


    #include <concept_checks.h>

    #ifdef __STL_USE_CONCEPT_CHECKS


    // This file covers the following concepts:
    // _Container
    // _ForwardContainer
    // _ReversibleContainer
    // _const_ReversibleContainer
    // _RandomAccessContainer
    //

    struct _ERROR_IN_STL_CONTAINER {

    /* Container expresssions */

    template <class _Container>
    static void
    __begin_iterator_accessor_requirement_violation(_C ontainer __c) {
    __c.begin();
    }
    template <class _Container>
    static void
    __const_begin_iterator_accessor_requirement_violat ion(const _Container& __c) {
    __c.begin();
    }
    template <class _Container>
    static void
    __end_iterator_accessor_requirement_violation(_Con tainer __c) {
    __c.end();
    }
    template <class _Container>
    static void
    __const_end_iterator_accessor_requirement_violatio n(const _Container& __c) {
    __c.end();
    }

    template <class _Container>
    static void
    __rbegin_iterator_accessor_requirement_violation(_ Container __c) {
    __c.rbegin();
    }
    template <class _Container>
    static void
    __const_rbegin_iterator_accessor_requirement_viola tion(const _Container& __c) {
    __c.rbegin();
    }
    template <class _Container>
    static void
    __rend_iterator_accessor_requirement_violation(_Co ntainer __c) {
    __c.rend();
    }
    template <class _Container>
    static void
    __const_rend_iterator_accessor_requirement_violati on(const _Container& __c) {
    __c.rend();
    }
    template <class _Container>
    static void
    __size_function_must_be_const(const _Container& __c) {
    __c.size();
    }
    template <class _Container>
    static void
    __size_function_requirement_violation(_Container& __c) {
    __c.size();
    __size_function_must_be_const(__c);
    }
    template <class _Container>
    static void
    __max_size_function_must_be_const(const _Container& __c) {
    __c.max_size();
    }
    template <class _Container>
    static void
    __max_size_function_requirement_violation(_Contain er& __c) {
    __c.max_size();
    __max_size_function_must_be_const(__c);
    }
    template <class _Container>
    static void
    __empty_function_must_be_const(const _Container& __c) {
    __c.empty();
    }
    template <class _Container>
    static void
    __empty_function_requirement_violation(_Container& __c) {
    __c.empty();
    __empty_function_must_be_const(__c);
    }
    template <class _Container>
    static void
    __swap_function_requirement_violation(_Container& __c) {
    __c.swap(__c);
    }

    };


    __STL_TYPEDEF_REQUIREMENT(iterator);
    __STL_TYPEDEF_REQUIREMENT(const_iterator);

    /* Containers */

    template <class _Container>
    struct _Container_concept_specification {
    static void
    _Container_requirement_violation(_Container __c) {
    // Refinement of Assignable
    _Assignable_concept_specification<_Container>::_As signable_requirement_violation(__c);
    // Associated Types
    __value_type__typedef_requirement_violation<_Conta iner>();
    __difference_type__typedef_requirement_violation<_ Container>();
    __size_type__typedef_requirement_violation<_Contai ner>();
    __reference__typedef_requirement_violation<_Contai ner>();
    __const_reference__typedef_requirement_violation<_ Container>();
    __pointer__typedef_requirement_violation<_Containe r>();
    __const_pointer__typedef_requirement_violation<_Co ntainer>();
    __iterator__typedef_requirement_violation<_Contain er>();
    __const_iterator__typedef_requirement_violation<_C ontainer>();
    // Valid Expressions
    _ERROR_IN_STL_CONTAINER::__const_begin_iterator_ac cessor_requirement_violation(__c);
    _ERROR_IN_STL_CONTAINER::__const_end_iterator_acce ssor_requirement_violation(__c);
    _ERROR_IN_STL_CONTAINER::__begin_iterator_accessor _requirement_violation(__c);
    _ERROR_IN_STL_CONTAINER::__end_iterator_accessor_r equirement_violation(__c);
    _ERROR_IN_STL_CONTAINER::__size_function_requireme nt_violation(__c);
    _ERROR_IN_STL_CONTAINER::__max_size_function_requi rement_violation(__c);
    _ERROR_IN_STL_CONTAINER::__empty_function_requirem ent_violation(__c);
    _ERROR_IN_STL_CONTAINER::__swap_function_requireme nt_violation(__c);
    // Requirements on Iterators
    typedef typename _Container::iterator iter;
    typedef typename _Container::const_iterator const_iter;
    _Inpu erator_concept_specification<const_iter>:: _Inpu erator_requirement_violation(const_iter()) ;
    _Inpu erator_concept_specification<iter>::_Input Iterator_requirement_violation(iter());
    }
    };

    template <class _ForwardContainer>
    struct _ForwardContainer_concept_specification {
    static void
    _ForwardContainer_requirement_violation(_ForwardCo ntainer __c) {
    // Refinement of Container
    _Container_concept_specification<_ForwardContainer >::_Container_requirement_violation(__c);
    // Requirements on Iterators
    typedef typename _ForwardContainer::iterator iter;
    typedef typename _ForwardContainer::const_iterator const_iter;
    _ForwardIterator_concept_specification<const_iter> ::_ForwardIterator_requirement_violation(const_ite r());
    _Mutable_ForwardIterator_concept_specification<ite r>::_Mutable_ForwardIterator_requirement_violation (iter());
    }
    };


    __STL_TYPEDEF_REQUIREMENT(reverse_iterator);
    __STL_TYPEDEF_REQUIREMENT(const_reverse_iterator);

    template <class _ReversibleContainer>
    struct _ReversibleContainer_concept_specification {
    static void
    _ReversibleContainer_requirement_violation(_Revers ibleContainer __c) {
    // Refinement of ForwardContainer
    _ForwardContainer_concept_specification<_Reversibl eContainer>::_ForwardContainer_requirement_violati on(__c);
    // Associated types
    __reverse_iterator__typedef_requirement_violation< _ReversibleContainer>();
    __const_reverse_iterator__typedef_requirement_viol ation<_ReversibleContainer>();
    // Valid Expressions
    _ERROR_IN_STL_CONTAINER::__const_rbegin_iterator_a ccessor_requirement_violation(__c);
    _ERROR_IN_STL_CONTAINER::__const_rend_iterator_acc essor_requirement_violation(__c);
    _ERROR_IN_STL_CONTAINER::__rbegin_iterator_accesso r_requirement_violation(__c);
    _ERROR_IN_STL_CONTAINER::__rend_iterator_accessor_ requirement_violation(__c);
    // Requirements on Iterators
    typedef typename _ReversibleContainer::iterator iter;
    typedef typename _ReversibleContainer::const_iterator const_iter;
    _BidirectionalIterator_concept_specification<const _iter>::_BidirectionalIterator_requirement_violati on(const_iter());
    _Mutable_BidirectionalIterator_concept_specificati on<iter>::_Mutable_BidirectionalIterator_requireme nt_violation(iter());
    }
    };

    template <class _ReversibleContainer>
    struct _const_ReversibleContainer_concept_specification {
    static void
    _const_ReversibleContainer_requirement_violation(_ ReversibleContainer __c) {
    // Refinement of Container (JGS, not ForwardContainer)
    _Container_concept_specification<_ReversibleContai ner>::_Container_requirement_violation(__c);
    // Associated types
    __reverse_iterator__typedef_requirement_violation< _ReversibleContainer>();
    __const_reverse_iterator__typedef_requirement_viol ation<_ReversibleContainer>();
    // Valid Expressions
    _ERROR_IN_STL_CONTAINER::__const_rbegin_iterator_a ccessor_requirement_violation(__c);
    _ERROR_IN_STL_CONTAINER::__const_rend_iterator_acc essor_requirement_violation(__c);
    _ERROR_IN_STL_CONTAINER::__rbegin_iterator_accesso r_requirement_violation(__c);
    _ERROR_IN_STL_CONTAINER::__rend_iterator_accessor_ requirement_violation(__c);
    // Requirements on Iterators
    typedef typename _ReversibleContainer::iterator iter;
    typedef typename _ReversibleContainer::const_iterator const_iter;

    // This line won't compile on gcc 2.91 due to a compiler bug.
    #if !(__GNUC__ == 2 && __GNUC_MINOR__ == 91)
    __BidirectionalIterator_concept_specification<cons t_iter>::_BidirectionalIterator_requirement_violat ion(const_iter());
    #endif
    }
    };


    template <class _RandomAccessContainer>
    struct _RandomAccessContainer_concept_specification {
    static void
    _RandomAccessContainer_requirement_violation(_Rand omAccessContainer __c) {
    // Refinement of ReversibleContainer
    _ReversibleContainer_concept_specification<_Random AccessContainer>::_ReversibleContainer_requirement _violation(__c);
    // Valid Expressions
    typedef typename _RandomAccessContainer::value_type __T;
    typedef typename _RandomAccessContainer::difference_type _Dist;
    typedef typename _Mutable_trait<__T>::_Type Type;
    typedef Type* _TypePtr;
    typedef typename _Mutable_trait<_Dist>::_Type Dist;
    _STL_ERROR::__element_access_operator_requirement_ violation(__c,
    _TypePtr(),
    Dist());
    // Requirements on Iterators
    typedef typename _RandomAccessContainer::iterator iter;
    typedef typename _RandomAccessContainer::const_iterator const_iter;
    _RandomAccessIterator_concept_specification<const_ iter>::_RandomAccessIterator_requirement_violation (const_iter());
    _Mutable_RandomAccessIterator_concept_specificatio n<iter>::_Mutable_RandomAccessIterator_requirement _violation(iter());
    }
    };

    #endif /* if __STL_USE_CONCEPT_CHECKS */

    #endif /* __STL_CONTAINER_CONCEPTS_H */

  12. #12
    🏆🏆🏆🏆🏆 ElNono's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Apr 2007
    Post Count
    153,473
    baseline with the Obama virus

  13. #13
    I play pretty, no? TeyshaBlue's Avatar
    My Team
    Dallas Mavericks
    Join Date
    Jun 2006
    Post Count
    13,321
    Wtf bb?

  14. #14
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    *
    * Copyright (c) 1994
    * Hewlett-Packard Company
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Hewlett-Packard Company makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    *
    */

    // Inclusion of this file is DEPRECATED. This is the original HP
    // default allocator. It is provided only for backward compatibility.
    // This file WILL BE REMOVED in a future release.
    //
    // DO NOT USE THIS FILE unless you have an old container implementation
    // that requires an allocator with the HP-style interface.
    //
    // Standard-conforming allocators have a very different interface. The
    // standard default allocator is declared in the header <memory>.

    #ifndef DEFALLOC_H
    #define DEFALLOC_H

    #include <new.h>
    #include <stddef.h>
    #include <stdlib.h>
    #include <limits.h>
    #include <iostream.h>
    #include <algobase.h>


    template <class T>
    inline T* allocate(ptrdiff_t size, T*) {
    set_new_handler(0);
    T* tmp = (T*)(::operator new((size_t)(size * sizeof(T))));
    if (tmp == 0) {
    cerr << "out of memory" << endl;
    exit(1);
    }
    return tmp;
    }


    template <class T>
    inline void deallocate(T* buffer) {
    ::operator delete(buffer);
    }

    template <class T>
    class allocator {
    public:
    typedef T value_type;
    typedef T* pointer;
    typedef const T* const_pointer;
    typedef T& reference;
    typedef const T& const_reference;
    typedef size_t size_type;
    typedef ptrdiff_t difference_type;
    pointer allocate(size_type n) {
    return ::allocate((difference_type)n, (pointer)0);
    }
    void deallocate(pointer p) { ::deallocate(p); }
    pointer address(reference x) { return (pointer)&x; }
    const_pointer const_address(const_reference x) {
    return (const_pointer)&x;
    }
    size_type init_page_size() {
    return max(size_type(1), size_type(4096/sizeof(T)));
    }
    size_type max_size() const {
    return max(size_type(1), size_type(UINT_MAX/sizeof(T)));
    }
    };

    class allocator<void> {
    public:
    typedef void* pointer;
    };



    #endif

  15. #15
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    *
    * Copyright (c) 1994
    * Hewlett-Packard Company
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Hewlett-Packard Company makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    *
    */

    // Inclusion of this file is DEPRECATED. This is the original HP
    // default allocator. It is provided only for backward compatibility.
    // This file WILL BE REMOVED in a future release.
    //
    // DO NOT USE THIS FILE unless you have an old container implementation
    // that requires an allocator with the HP-style interface.
    //
    // Standard-conforming allocators have a very different interface. The
    // standard default allocator is declared in the header <memory>.

    #ifndef DEFALLOC_H
    #define DEFALLOC_H

    #include <new.h>
    #include <stddef.h>
    #include <stdlib.h>
    #include <limits.h>
    #include <iostream.h>
    #include <algobase.h>


    template <class T>
    inline T* allocate(ptrdiff_t size, T*) {
    set_new_handler(0);
    T* tmp = (T*)(::operator new((size_t)(size * sizeof(T))));
    if (tmp == 0) {
    cerr << "out of memory" << endl;
    exit(1);
    }
    return tmp;
    }


    template <class T>
    inline void deallocate(T* buffer) {
    ::operator delete(buffer);
    }

    template <class T>
    class allocator {
    public:
    typedef T value_type;
    typedef T* pointer;
    typedef const T* const_pointer;
    typedef T& reference;
    typedef const T& const_reference;
    typedef size_t size_type;
    typedef ptrdiff_t difference_type;
    pointer allocate(size_type n) {
    return ::allocate((difference_type)n, (pointer)0);
    }
    void deallocate(pointer p) { ::deallocate(p); }
    pointer address(reference x) { return (pointer)&x; }
    const_pointer const_address(const_reference x) {
    return (const_pointer)&x;
    }
    size_type init_page_size() {
    return max(size_type(1), size_type(4096/sizeof(T)));
    }
    size_type max_size() const {
    return max(size_type(1), size_type(UINT_MAX/sizeof(T)));
    }
    };

    class allocator<void> {
    public:
    typedef void* pointer;
    };



    #endif

  16. #16
    Veteran DarrinS's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Jun 2005
    Post Count
    42,561
    baseline?


    WTF?

  17. #17
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    *
    * Copyright (c) 1994
    * Hewlett-Packard Company
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Hewlett-Packard Company makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    *
    *
    * Copyright (c) 1997
    * Silicon Graphics Computer Systems, Inc.
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Silicon Graphics makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    */

    #ifndef __SGI_STL_DEQUE_H
    #define __SGI_STL_DEQUE_H

    #include <stl_range_errors.h>
    #include <algobase.h>
    #include <alloc.h>
    #include <stl_deque.h>

    #ifdef __STL_USE_NAMESPACES
    using __STD::deque;
    #endif /* __STL_USE_NAMESPACES */

    #endif /* __SGI_STL_DEQUE_H */

    // Local Variables:
    // mode:C++
    // End:

  18. #18
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    *
    * Copyright (c) 1994
    * Hewlett-Packard Company
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Hewlett-Packard Company makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    *
    *
    * Copyright (c) 1996,1997
    * Silicon Graphics Computer Systems, Inc.
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Silicon Graphics makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    */

    #ifndef __SGI_STL_FUNCTION_H
    #define __SGI_STL_FUNCTION_H

    #ifndef __STL_CONFIG_H
    #include <stl_config.h>
    #endif
    #ifndef __SGI_STL_INTERNAL_RELOPS
    #include <stl_relops.h>
    #endif
    #include <stddef.h>
    #ifndef __SGI_STL_INTERNAL_FUNCTION_H
    #include <stl_function.h>
    #endif

    #ifdef __STL_USE_NAMESPACE_FOR_RELOPS

    // Names from stl_relops.h
    using __STD_RELOPS::operator!=;
    using __STD_RELOPS::operator>;
    using __STD_RELOPS::operator<=;
    using __STD_RELOPS::operator>=;

    #endif /* __STL_USE_NAMESPACE_FOR_RELOPS */

    #ifdef __STL_USE_NAMESPACES

    // Names from stl_function.h
    using __STD::unary_function;
    using __STD::binary_function;
    using __STD::plus;
    using __STD::minus;
    using __STD::multiplies;
    using __STD::divides;
    using __STD::iden y_element;
    using __STD::modulus;
    using __STD::negate;
    using __STD::equal_to;
    using __STD::not_equal_to;
    using __STD::greater;
    using __STD::less;
    using __STD::greater_equal;
    using __STD::less_equal;
    using __STD::logical_and;
    using __STD::logical_or;
    using __STD::logical_not;
    using __STD::unary_negate;
    using __STD::binary_negate;
    using __STD::not1;
    using __STD::not2;
    using __STD::binder1st;
    using __STD::binder2nd;
    using __STD::bind1st;
    using __STD::bind2nd;
    using __STD::unary_compose;
    using __STD::binary_compose;
    using __STD::compose1;
    using __STD::compose2;
    using __STD::pointer_to_unary_function;
    using __STD::pointer_to_binary_function;
    using __STD::ptr_fun;
    using __STD::iden y;
    using __STD::select1st;
    using __STD::select2nd;
    using __STD::project1st;
    using __STD::project2nd;
    using __STD::constant_void_fun;
    using __STD::constant_unary_fun;
    using __STD::constant_binary_fun;
    using __STD::constant0;
    using __STD::constant1;
    using __STD::constant2;
    using __STD::subtractive_rng;
    using __STD::mem_fun_t;
    using __STD::const_mem_fun_t;
    using __STD::mem_fun_ref_t;
    using __STD::const_mem_fun_ref_t;
    using __STD::mem_fun1_t;
    using __STD::const_mem_fun1_t;
    using __STD::mem_fun1_ref_t;
    using __STD::const_mem_fun1_ref_t;
    using __STD::mem_fun;
    using __STD::mem_fun_ref;
    using __STD::mem_fun1;
    using __STD::mem_fun1_ref;

    #endif /* __STL_USE_NAMESPACES */

    #endif /* __SGI_STL_FUNCTION_H */

    // Local Variables:
    // mode:C++
    // End:

  19. #19
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    *
    * Copyright (c) 1994
    * Hewlett-Packard Company
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Hewlett-Packard Company makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    *
    *
    * Copyright (c) 1996,1997
    * Silicon Graphics Computer Systems, Inc.
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Silicon Graphics makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    */

    #ifndef __SGI_STL_FUNCTION_H
    #define __SGI_STL_FUNCTION_H

    #ifndef __STL_CONFIG_H
    #include <stl_config.h>
    #endif
    #ifndef __SGI_STL_INTERNAL_RELOPS
    #include <stl_relops.h>
    #endif
    #include <stddef.h>
    #ifndef __SGI_STL_INTERNAL_FUNCTION_H
    #include <stl_function.h>
    #endif

    #ifdef __STL_USE_NAMESPACE_FOR_RELOPS

    // Names from stl_relops.h
    using __STD_RELOPS::operator!=;
    using __STD_RELOPS::operator>;
    using __STD_RELOPS::operator<=;
    using __STD_RELOPS::operator>=;

    #endif /* __STL_USE_NAMESPACE_FOR_RELOPS */

    #ifdef __STL_USE_NAMESPACES

    // Names from stl_function.h
    using __STD::unary_function;
    using __STD::binary_function;
    using __STD::plus;
    using __STD::minus;
    using __STD::multiplies;
    using __STD::divides;
    using __STD::iden y_element;
    using __STD::modulus;
    using __STD::negate;
    using __STD::equal_to;
    using __STD::not_equal_to;
    using __STD::greater;
    using __STD::less;
    using __STD::greater_equal;
    using __STD::less_equal;
    using __STD::logical_and;
    using __STD::logical_or;
    using __STD::logical_not;
    using __STD::unary_negate;
    using __STD::binary_negate;
    using __STD::not1;
    using __STD::not2;
    using __STD::binder1st;
    using __STD::binder2nd;
    using __STD::bind1st;
    using __STD::bind2nd;
    using __STD::unary_compose;
    using __STD::binary_compose;
    using __STD::compose1;
    using __STD::compose2;
    using __STD::pointer_to_unary_function;
    using __STD::pointer_to_binary_function;
    using __STD::ptr_fun;
    using __STD::iden y;
    using __STD::select1st;
    using __STD::select2nd;
    using __STD::project1st;
    using __STD::project2nd;
    using __STD::constant_void_fun;
    using __STD::constant_unary_fun;
    using __STD::constant_binary_fun;
    using __STD::constant0;
    using __STD::constant1;
    using __STD::constant2;
    using __STD::subtractive_rng;
    using __STD::mem_fun_t;
    using __STD::const_mem_fun_t;
    using __STD::mem_fun_ref_t;
    using __STD::const_mem_fun_ref_t;
    using __STD::mem_fun1_t;
    using __STD::const_mem_fun1_t;
    using __STD::mem_fun1_ref_t;
    using __STD::const_mem_fun1_ref_t;
    using __STD::mem_fun;
    using __STD::mem_fun_ref;
    using __STD::mem_fun1;
    using __STD::mem_fun1_ref;

    #endif /* __STL_USE_NAMESPACES */

    #endif /* __SGI_STL_FUNCTION_H */

    // Local Variables:
    // mode:C++
    // End:

  20. #20
    🏆🏆🏆🏆🏆 ElNono's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Apr 2007
    Post Count
    153,473
    At least it's just the standard C++ headers.... if it would be some proprietary stuff he'll be in deep

  21. #21
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    * Copyright (c) 1996
    * Silicon Graphics Computer Systems, Inc.
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Silicon Graphics makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    *
    *
    * Copyright (c) 1994
    * Hewlett-Packard Company
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Hewlett-Packard Company makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    *
    */

    #ifndef __SGI_STL_HASH_MAP_H
    #define __SGI_STL_HASH_MAP_H

    #ifndef __SGI_STL_INTERNAL_HASHTABLE_H
    #include <stl_hashtable.h>
    #endif

    #include <algobase.h>
    #include <stl_hash_map.h>

    #ifdef __STL_USE_NAMESPACES
    using __STD::hash;
    using __STD::hashtable;
    using __STD::hash_map;
    using __STD::hash_multimap;
    #endif /* __STL_USE_NAMESPACES */


    #endif /* __SGI_STL_HASH_MAP_H */

    // Local Variables:
    // mode:C++
    // End:

  22. #22
    Veteran DarrinS's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Jun 2005
    Post Count
    42,561
    obamabot, baseline bum, is malfunctioning.

  23. #23
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    * Copyright (c) 1996
    * Silicon Graphics Computer Systems, Inc.
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Silicon Graphics makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    *
    *
    * Copyright (c) 1994
    * Hewlett-Packard Company
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Hewlett-Packard Company makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    *
    */

    #ifndef __SGI_STL_HASH_MAP_H
    #define __SGI_STL_HASH_MAP_H

    #ifndef __SGI_STL_INTERNAL_HASHTABLE_H
    #include <stl_hashtable.h>
    #endif

    #include <algobase.h>
    #include <stl_hash_map.h>

    #ifdef __STL_USE_NAMESPACES
    using __STD::hash;
    using __STD::hashtable;
    using __STD::hash_map;
    using __STD::hash_multimap;
    #endif /* __STL_USE_NAMESPACES */


    #endif /* __SGI_STL_HASH_MAP_H */

    // Local Variables:
    // mode:C++
    // End:

  24. #24
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    This thread needed some redeeming value, so a full implementation of the STL provides it.

  25. #25
    俺はまんこが大好きなんだよ baseline bum's Avatar
    My Team
    San Antonio Spurs
    Join Date
    Mar 2003
    Post Count
    97,881
    /*
    * Copyright (c) 1996
    * Silicon Graphics Computer Systems, Inc.
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Silicon Graphics makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    *
    *
    * Copyright (c) 1994
    * Hewlett-Packard Company
    *
    * Permission to use, copy, modify, distribute and sell this software
    * and its do entation for any purpose is hereby granted without fee,
    * provided that the above copyright notice appear in all copies and
    * that both that copyright notice and this permission notice appear
    * in supporting do entation. Hewlett-Packard Company makes no
    * representations about the suitability of this software for any
    * purpose. It is provided "as is" without express or implied warranty.
    *
    */

    #ifndef __SGI_STL_HASH_SET
    #define __SGI_STL_HASH_SET

    #ifndef __SGI_STL_INTERNAL_HASHTABLE_H
    #include <stl_hashtable.h>
    #endif

    #include <stl_hash_set.h>

    #endif /* __SGI_STL_HASH_SET */

    // Local Variables:
    // mode:C++
    // End:

Thread Information

Users Browsing this Thread

There are currently 1 users browsing this thread. (0 members and 1 guests)

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts
  •