123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- //===----------------------------------------------------------------------===//
- //
- // The LLVM Compiler Infrastructure
- //
- // This file is dual licensed under the MIT and the University of Illinois Open
- // Source Licenses. See LICENSE.TXT for details.
- //
- //===----------------------------------------------------------------------===//
- // <string>
- // basic_string(const basic_string& str, const Allocator& alloc);
- #include <string>
- #include <cassert>
- #include "test_macros.h"
- #include "test_allocator.h"
- #include "min_allocator.h"
- #ifndef TEST_HAS_NO_EXCEPTIONS
- template <class T>
- struct alloc_imp {
- bool active;
- alloc_imp() : active(true) {}
- T* allocate(std::size_t n)
- {
- if (active)
- return static_cast<T*>(std::malloc(n * sizeof(T)));
- else
- throw std::bad_alloc();
- }
- void deallocate(T* p, std::size_t) { std::free(p); }
- void activate () { active = true; }
- void deactivate() { active = false; }
- };
- template <class T>
- struct poca_alloc {
- typedef T value_type;
- typedef std::true_type propagate_on_container_copy_assignment;
- alloc_imp<T> *imp;
- poca_alloc(alloc_imp<T> *imp_) : imp (imp_) {}
- template <class U>
- poca_alloc(const poca_alloc<U>& other) : imp(other.imp) {}
- T* allocate (std::size_t n) { return imp->allocate(n);}
- void deallocate(T* p, std::size_t n) { imp->deallocate(p, n); }
- };
- template <typename T, typename U>
- bool operator==(const poca_alloc<T>& lhs, const poca_alloc<U>& rhs)
- {
- return lhs.imp == rhs.imp;
- }
- template <typename T, typename U>
- bool operator!=(const poca_alloc<T>& lhs, const poca_alloc<U>& rhs)
- {
- return lhs.imp != rhs.imp;
- }
- template <class S>
- void test_assign(S &s1, const S& s2)
- {
- try { s1 = s2; }
- catch ( std::bad_alloc &) { return; }
- assert(false);
- }
- #endif
- template <class S>
- void
- test(S s1, const typename S::allocator_type& a)
- {
- S s2(s1, a);
- LIBCPP_ASSERT(s2.__invariants());
- assert(s2 == s1);
- assert(s2.capacity() >= s2.size());
- assert(s2.get_allocator() == a);
- }
- int main()
- {
- {
- typedef test_allocator<char> A;
- typedef std::basic_string<char, std::char_traits<char>, A> S;
- test(S(), A(3));
- test(S("1"), A(5));
- test(S("1234567890123456789012345678901234567890123456789012345678901234567890"), A(7));
- }
- #if TEST_STD_VER >= 11
- {
- typedef min_allocator<char> A;
- typedef std::basic_string<char, std::char_traits<char>, A> S;
- test(S(), A());
- test(S("1"), A());
- test(S("1234567890123456789012345678901234567890123456789012345678901234567890"), A());
- }
- #ifndef TEST_HAS_NO_EXCEPTIONS
- {
- typedef poca_alloc<char> A;
- typedef std::basic_string<char, std::char_traits<char>, A> S;
- const char * p1 = "This is my first string";
- const char * p2 = "This is my second string";
- alloc_imp<char> imp1;
- alloc_imp<char> imp2;
- S s1(p1, A(&imp1));
- S s2(p2, A(&imp2));
- assert(s1 == p1);
- assert(s2 == p2);
- imp2.deactivate();
- test_assign(s1, s2);
- assert(s1 == p1);
- assert(s2 == p2);
- }
- #endif
- #endif
- }
|