/*
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description:
*
*/
// STLport regression testsuite component.
// To compile as a separate example, please #define MAIN.
#include <iostream>
#include <algorithm>
#include <iterator>
#include <functional>
#ifdef MAIN
#define ptrbinf2_test main
#endif
static int sum(int x_, int y_)
{
return x_ + y_;
}
#if !defined (STLPORT) || defined(__STL_USE_NAMESPACES)
using namespace std;
#endif
int ptrbinf2_test(int, char**)
{
int failures=0;
cout<<"Results of ptrbinf2_test:"<<endl;
int input1 [4] = { 7, 2, 3, 5 };
int input2 [4] = { 1, 5, 5, 8 };
int output [4];
transform((int*)input1, (int*)input1 + 4, (int*)input2, (int*)output, ptr_fun(sum));
for(int i = 0; i < 4; i++)
cout << output[i] << endl;
if(8!=output[0])
failures++;
else if(7!=output[1])
failures++;
else if(8!=output[2])
failures++;
else if(13!=output[3])
failures++;
if(failures)
return 1;
else
return 0;
}