secureswitools/swisistools/source/sisxlibrary/siscompressed.cpp
changeset 0 ba25891c3a9e
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/secureswitools/swisistools/source/sisxlibrary/siscompressed.cpp	Thu Dec 17 08:51:10 2009 +0200
@@ -0,0 +1,135 @@
+/*
+* Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "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: 
+*
+*/
+
+
+/**
+ @file 
+ @internalComponent
+ @released
+*/
+
+#ifdef _MSC_VER
+#pragma warning (disable: 4786)
+#endif // _MSC_VER
+
+#include "siswrite.h"
+#include "utility_interface.h"
+#include <zlib.h>
+
+bool CompressData (	const TUint8* aInputData, const CSISFieldRoot::TFieldSize aInputSize,
+					TUint8*& aOutputData, CSISFieldRoot::TFieldSize& aOutputSize,
+					const bool aCanAbandon)
+	{
+	assert (aOutputData == NULL);
+	assert (aInputData != NULL);
+	assert (! IsBadReadPtr (aInputData, aInputSize));
+	CSISFieldRoot::TFieldSize inputSize = aInputSize;
+	inputSize = inputSize + (inputSize / 64) + 16;
+		// see zlib library documentation for the reasons for this calculation
+	TUint8* buffer = new TUint8 [inputSize];
+	try
+		{
+		z_stream compressionState;
+		memset (&compressionState, 0, sizeof (z_stream));
+		compressionState.avail_out = inputSize;
+		compressionState.data_type = Z_BINARY;
+		compressionState.avail_in = aInputSize;
+		compressionState.next_out = buffer;
+		compressionState.next_in = const_cast <Bytef*> (aInputData);
+		try 
+			{
+			CSISException::ThrowIf (deflateInit (&compressionState, Z_DEFAULT_COMPRESSION) != Z_OK,
+									CSISException::ECompress,
+									"deflation progress");
+			CSISException::ThrowIf (deflate (&compressionState, Z_FINISH) != Z_STREAM_END,
+									CSISException::ECompress,
+									"deflation end");
+			}
+		catch (...)
+			{
+			deflateEnd (&compressionState);
+			throw;
+			}
+		deflateEnd (&compressionState);
+		aOutputData = buffer;
+		aOutputSize = static_cast <CSISFieldRoot::TFieldSize> (compressionState.total_out);
+		}
+	catch (...) 
+		{
+		delete [] buffer;
+		aOutputData = NULL;
+		aOutputSize = 0;
+		throw;
+		}
+	if ((aOutputSize < aInputSize) || ! aCanAbandon)
+		{
+		return true;
+		}
+	delete [] buffer;
+	aOutputData = NULL;
+	aOutputSize = 0;
+	return false;
+	}
+
+
+
+
+void ExpandStream (const TUint8* aInputData, const CSISFieldRoot::TFieldSize aInputSize, TSISStream& stream)
+	{
+	assert (aInputData != NULL);
+	assert (! IsBadReadPtr (aInputData, aInputSize));
+	z_stream compressionState;
+	memset (&compressionState, 0, sizeof (z_stream));
+	const uLong arbitraryBufferSize (262144);
+	TSISStream::pos_type start = stream.tell ();
+	TUint8* buffer = new TUint8 [arbitraryBufferSize];
+	try 
+		{
+		compressionState.avail_in = aInputSize;
+		compressionState.next_in = const_cast <Bytef*> (aInputData);
+		compressionState.avail_out = arbitraryBufferSize;
+		compressionState.next_out = buffer;
+		compressionState.data_type = Z_BINARY;
+		CSISException::ThrowIf (inflateInit (&compressionState) != Z_OK,
+								CSISException::ECompress,
+								"inflation initialisation");
+		int status;
+		while ((status = inflate (&compressionState, Z_NO_FLUSH)) == Z_OK)
+			{
+			stream.write (buffer, arbitraryBufferSize - compressionState.avail_out);
+			compressionState.avail_out = arbitraryBufferSize;
+			compressionState.next_out = buffer;
+			}
+		CSISException::ThrowIf (status != Z_STREAM_END,
+								CSISException::ECompress,
+								"inflation");
+		status = inflate (&compressionState, Z_FINISH);
+		CSISException::ThrowIf (status != Z_STREAM_END,
+								CSISException::ECompress,
+								"inflation");
+		stream.write (buffer, arbitraryBufferSize - compressionState.avail_out);
+		}
+	catch (...)
+		{
+		inflateEnd (&compressionState);
+		delete [] buffer;
+		stream.seek (start);
+		throw;
+		}
+	inflateEnd (&compressionState);
+	delete [] buffer;
+	}