#if HAVE_CRT
#define _CRTDBG_MAP_ALLOC 
#include <stdlib.h> 
#include <crtdbg.h>
#endif //HAVE_CRT
/*
* Copyright (C) 2020, University of the Basque Country (UPV/EHU)
* Contact for licensing options: <licensing-mcpttclient(at)mcopenplatform(dot)com>
*
* The original file was part of Open Source Doubango Framework
* Copyright (C) 2010-2011 Mamadou Diop.
* Copyright (C) 2012 Doubango Telecom <http://doubango.org>
*
* This file is part of Open Source Doubango Framework.
*
* DOUBANGO is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* DOUBANGO 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with DOUBANGO.
*
*/


/**@file tcomp_compressor_dummy.h
 * @brief  SigComp Dummy compressor. Used if none match. See RFC 4896 subclause 11.
 *
 * @author Mamadou Diop <diopmamadou(at)yahoo.fr>
 *

 */

#include "tcomp_compressor_dummy.h"
#include "tcomp_buffer.h"

#include <string.h>

#define UNCOMPRESSED_BYTECODE_LENGTH				13
#define UNCOMPRESSED_BYTECODE_DESTINATION_CODE		0x01 /* 128 */
#define DUMMYCOMPRESSOR_UNCOMPRESSED_BYTECODE \
	"\xf8\x00\xa1\x1c\x01\x86\x09\x22\x86\x01\x16\xf9\x23"



////////////////////////////////////////////////////////////////////////////////////////////////////
///
/// @brief	Dummy compressor as per RFC 4896 subclause 11. This function is used to create uncompressed sigcomp message.
/// Used if none match. 
///
/// @param [in,out]	lpCompartment	The compartment to use. 
/// @param [in,out]	input_ptr		The input buffer containing the message to compress. 
/// @param	input_size				The size of the input buffer. 
/// @param [in,out]	output_ptr		The output buffer where to copy the compressed message. 
/// @param [in,out]	output_size		The size of the output buffer.
/// @param	stream					Indicates whether it's a stream buffer or not. 
///
/// @return	1 if succedd and 0 otherwise. 
////////////////////////////////////////////////////////////////////////////////////////////////////
tsk_bool_t tcomp_compressor_dummy_compress(tcomp_compartment_t *lpCompartment, const void *input_ptr, tsk_size_t input_size, void *output_ptr, tsk_size_t *output_size, tsk_bool_t stream)
{
	tcomp_buffer_handle_t *output_buffer = tcomp_buffer_create_null();
	tsk_size_t pointer = 0;
	uint8_t *header;
	uint32_t codeLen;

	tcomp_buffer_referenceBuff(output_buffer, (uint8_t*)output_ptr, *output_size);
	header = tcomp_buffer_getBufferAtPos(output_buffer, pointer++);

	/* SigComp Header */
	if(lpCompartment->lpReqFeedback && tcomp_buffer_getSize(lpCompartment->lpReqFeedback)){
		/* Return the requested feedback */
		*header = 0xfc; /* T=1 */
		memcpy(tcomp_buffer_getBufferAtPos(output_buffer, pointer), tcomp_buffer_getBuffer(lpCompartment->lpReqFeedback), tcomp_buffer_getSize(lpCompartment->lpReqFeedback));
		pointer += tcomp_buffer_getSize(lpCompartment->lpReqFeedback);
	}
	else{
		*header = 0xf8;
	}

	codeLen = UNCOMPRESSED_BYTECODE_LENGTH;
	/* first byte for codelen */
	*tcomp_buffer_getBufferAtPos(output_buffer, pointer++) = ((codeLen>>4)& 0x00ff);

	/* last 4 bits for codelen */
	*tcomp_buffer_getBufferAtPos(output_buffer, pointer) = ((codeLen & 0x000f)<<4); 

	/* first and last 4 bits for destination */
	*tcomp_buffer_getBufferAtPos(output_buffer, pointer++) |= UNCOMPRESSED_BYTECODE_DESTINATION_CODE;

	/*
	*	Upload UDVM bytecode
	*/
	memcpy(tcomp_buffer_getBufferAtPos(output_buffer, pointer), (uint8_t*)DUMMYCOMPRESSOR_UNCOMPRESSED_BYTECODE, codeLen);
	pointer += codeLen;

	/*
	*	Copy data uncompressed
	*/
	memcpy(tcomp_buffer_getBufferAtPos(output_buffer, pointer), input_ptr, input_size);
	pointer += input_size;
	*output_size = (pointer);

	TSK_OBJECT_SAFE_FREE(output_buffer);

	return tsk_true;
}