forked from boostorg/smart_ptr
		
	Merged revision(s) 81641-81643,81658,81669,81681 from trunk:
Use const T (&)[N] for fixed size arrays instead of std::initializer<T> in overloads of make_shared and allocate_shared for arrays. ........ Use BOOST_NO_CXX11_UNIFIED_INITIALIZATION_SYNTAX instead for certain overloads of make_shared and allocate_shared ........ Code consistency: Use the same style of #if conditional compilation checks in allocate_shared_array.hpp and make_shared_array.hpp. ........ Change make_shared and allocate_shared array form overload for size and inner array initialization list to use const T(&)[N] instead of std::initializer_list<T>. ........ Move two tests for allocate_shared and make_shared within check for BOOST_NO_CXX11_UNIFIED_INITIALIZATION_SYNTAX ........ Make specializations of detail array_deleter consistent. ........ [SVN r81682]
This commit is contained in:
		@@ -8,10 +8,16 @@
 | 
			
		||||
 */
 | 
			
		||||
#include <boost/detail/lightweight_test.hpp>
 | 
			
		||||
#include <boost/smart_ptr/make_shared_array.hpp>
 | 
			
		||||
#include <string>
 | 
			
		||||
 | 
			
		||||
int main() {
 | 
			
		||||
#if !defined(BOOST_NO_CXX11_HDR_INITIALIZER_LIST)
 | 
			
		||||
    {
 | 
			
		||||
        boost::shared_ptr<int[]> a1 = boost::make_shared<int[]>({0, 1, 2, 3});
 | 
			
		||||
        BOOST_TEST(a1[0] == 0);
 | 
			
		||||
        BOOST_TEST(a1[1] == 1);
 | 
			
		||||
        BOOST_TEST(a1[2] == 2);
 | 
			
		||||
        BOOST_TEST(a1[3] == 3);
 | 
			
		||||
    }
 | 
			
		||||
    {
 | 
			
		||||
        boost::shared_ptr<int[][2]> a1 = boost::make_shared<int[][2]>({ {0, 1}, {2, 3} });
 | 
			
		||||
        BOOST_TEST(a1[0][0] == 0);
 | 
			
		||||
@@ -19,6 +25,15 @@ int main() {
 | 
			
		||||
        BOOST_TEST(a1[1][0] == 2);
 | 
			
		||||
        BOOST_TEST(a1[1][1] == 3);
 | 
			
		||||
    }
 | 
			
		||||
#endif
 | 
			
		||||
#if !defined(BOOST_NO_CXX11_UNIFIED_INITIALIZATION_SYNTAX)
 | 
			
		||||
    {
 | 
			
		||||
        boost::shared_ptr<int[4]> a1 = boost::make_shared<int[4]>({0, 1, 2, 3});
 | 
			
		||||
        BOOST_TEST(a1[0] == 0);
 | 
			
		||||
        BOOST_TEST(a1[1] == 1);
 | 
			
		||||
        BOOST_TEST(a1[2] == 2);
 | 
			
		||||
        BOOST_TEST(a1[3] == 3);
 | 
			
		||||
    }
 | 
			
		||||
    {
 | 
			
		||||
        boost::shared_ptr<int[2][2]> a1 = boost::make_shared<int[2][2]>({ {0, 1}, {2, 3} });
 | 
			
		||||
        BOOST_TEST(a1[0][0] == 0);
 | 
			
		||||
@@ -26,13 +41,6 @@ int main() {
 | 
			
		||||
        BOOST_TEST(a1[1][0] == 2);
 | 
			
		||||
        BOOST_TEST(a1[1][1] == 3);
 | 
			
		||||
    }
 | 
			
		||||
    {
 | 
			
		||||
        boost::shared_ptr<int[2][2]> a1 = boost::make_shared<int[2][2]>({ 0, 1 });
 | 
			
		||||
        BOOST_TEST(a1[0][0] == 0);
 | 
			
		||||
        BOOST_TEST(a1[0][1] == 1);
 | 
			
		||||
        BOOST_TEST(a1[1][0] == 0);
 | 
			
		||||
        BOOST_TEST(a1[1][1] == 1);
 | 
			
		||||
    }
 | 
			
		||||
    {
 | 
			
		||||
        boost::shared_ptr<int[][2]> a1 = boost::make_shared<int[][2]>(2, {0, 1});
 | 
			
		||||
        BOOST_TEST(a1[0][0] == 0);
 | 
			
		||||
@@ -47,6 +55,13 @@ int main() {
 | 
			
		||||
        BOOST_TEST(a1[1][1][0] == 2);
 | 
			
		||||
        BOOST_TEST(a1[1][1][1] == 3);
 | 
			
		||||
    }
 | 
			
		||||
    {
 | 
			
		||||
        boost::shared_ptr<int[2][2]> a1 = boost::make_shared<int[2][2]>({ 0, 1 });
 | 
			
		||||
        BOOST_TEST(a1[0][0] == 0);
 | 
			
		||||
        BOOST_TEST(a1[0][1] == 1);
 | 
			
		||||
        BOOST_TEST(a1[1][0] == 0);
 | 
			
		||||
        BOOST_TEST(a1[1][1] == 1);
 | 
			
		||||
    }
 | 
			
		||||
    {
 | 
			
		||||
        boost::shared_ptr<int[2][2][2]> a1 = boost::make_shared<int[2][2][2]>({ {0, 1}, {2, 3} });
 | 
			
		||||
        BOOST_TEST(a1[0][0][0] == 0);
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user