///////////////////////////////////////////////////////////////////////////////

// MQ4CPP - Message queuing for C++

// Copyright (C) 2004-2007  Riccardo Pompeo (Italy)

//

// This library is free software; you can redistribute it and/or

// modify it under the terms of the GNU Lesser General Public

// License as published by the Free Software Foundation; either

// version 2.1 of the License, or (at your option) any later version.

//

// This library is distributed in the hope that it will be useful,

// but WITHOUT ANY WARRANTY; without even the implied warranty of

// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU

// Lesser General Public License for more details.

//

// You should have received a copy of the GNU Lesser General Public

// License along with this library; if not, write to the Free Software

// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

//


#include "Logger.h"

#include "Timer.h"

#include "Compression.h"

#define PCKSIZE 65535

#define CACHE true

#define MASK 0x1F

#define ITERATIONS 1000


int main(int argv,char* argc[])
{
	DISPLAY("MQ4CPP compr.cpp")
	DISPLAY("This example shows how packet compression works")

	_TIMEVAL startTime;	
	_TIMEVAL endTime;	
	PacketCompression compression(CACHE);
	unsigned int bytesCompressed=0;
	unsigned int bytesDecompressed=0;
	startTime=Timer::timeExt();
	
	for(int i=0; i < ITERATIONS; i++)
	{
		string original;
		original.reserve(PCKSIZE);

		for(int cnt=0; cnt < PCKSIZE ; cnt++)
			original += (unsigned char)(rand() & MASK);
		
		try
		{
			string compressed=compression.deflate(original);	
			bytesCompressed+=compressed.size();
			string decompressed=compression.inflate(compressed);
			bytesDecompressed+=decompressed.size();

			if(decompressed.compare(original)!=0)
			{
				DISPLAY("Test NOK " << i << " Size=" << decompressed.size())
				DISPLAY("Original='" << original << "'")
				DISPLAY("Decompre='" << decompressed << "'")
				exit(-1);
			}
		}
		catch(...)
		{
			DISPLAY("Unhandled exception")	
			exit(-1);
		}
	}
	
	endTime=Timer::timeExt();
	long deltaTime=Timer::subtractMillisecs(&startTime,&endTime);
	DISPLAY("Elapsed=" << deltaTime << " ms")
	float comprRatio=(1-(float)bytesCompressed/(float)bytesDecompressed)*100.0;
	DISPLAY("Compression=" << comprRatio << "%")
	float packetspersecond=(float)ITERATIONS/((float)deltaTime/1000.0);
	DISPLAY("Compression+decompression per seconds=" << packetspersecond)
	float duration=(float)deltaTime/(float)ITERATIONS;
	DISPLAY("Compression+decompression duration=" << duration << " ms")
	return 0;
}


syntax highlighted by Code2HTML, v. 0.9.1