stdcpp/tsrc/Stdcpp_test/stlport/auto/stlport_deque/src/deque1.cpp
author Pat Downey <patd@symbian.org>
Fri, 04 Jun 2010 16:20:51 +0100
changeset 31 ce057bb09d0b
child 34 5fae379060a7
permissions -rw-r--r--
Revert last code drop.

/*
* 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 <deque>
#include <algorithm>
#include <iostream>


#ifdef MAIN
#define deque1_test main
#endif

#if !defined (STLPORT) || defined(__STL_USE_NAMESPACES)
using namespace std;
#endif

int deque1_test(int, char**)
{
	cout<<"Results of deque1_test:"<<endl;

	int failures = 0;
	int res_arr[4] = {1, 4, 9, 16};
	deque<int> d;
	d.push_back(4); // Add after end.
	d.push_back(9);
	d.push_back(16);
	d.push_front(1); // Insert at beginning.
	int i;
	for(i = 0; i < d.size(); i++)
	{
		cout << "d[" << i << "] = " << d[i] << endl;
		if (d[i] != res_arr[i])
			failures++;
	}
	cout << endl;

	int res_arr2[] = {4, 9, 25};

	d.pop_front(); // Erase first element.

	d[2] = 25; // Replace last element.
	for(i = 0; i < d.size(); i++)
	{
		cout << "d[" << i << "] = " << d[i] << endl;
		if (d[i] != res_arr2[i])
			failures++;
	}

	if(!failures)
    return 0;
  else
    return 1;

}