Blob Blame Raw


#include <assert.h>
#include <string.h>
#include <stdlib.h>
#include "ttwain_conversion.h"

#ifdef __cplusplus
extern "C" {
#endif

float TTWAIN_Fix32ToFloat(TW_FIX32 fix)
{
	TW_INT32 val;
	val = ((TW_INT32)fix.Whole << 16) | ((TW_UINT32)fix.Frac & 0xffff);
	return (float)(val / 65536.0);
}
/*---------------------------------------------------------------------------*/
TW_FIX32 TTWAIN_FloatToFix32(float fl)
{
	TW_FIX32 fix;
	TW_INT32 val;
	assert(sizeof(TW_FIX32) == sizeof(float));
	assert(sizeof(TW_FIX32) == sizeof(long));

	/* Note 1: This round-away-from-0 is new in TWAIN 1.7
   Note 2: ANSI C converts float to int by truncating toward 0.*/
	val = (TW_INT32)(fl * 65536.0 + (fl < 0 ? -0.5 : +0.5));
	fix.Whole = (TW_INT16)(val >> 16);	/* most significant 16 bits */
	fix.Frac = (TW_UINT16)(val & 0xffff); /* least */

	return fix;
}
/*---------------------------------------------------------------------------*/
void TTWAIN_ConvertRevStrToRevNum(const char *rev_str,
								  TW_UINT16 *maj_num,
								  TW_UINT16 *min_num)
{
	char *maj_str;
	char *min_str;
	size_t maj_size;
	size_t min_size;

	*maj_num = *min_num = 0;
	maj_size = strcspn(rev_str, ".");
	maj_str = (char *)calloc(sizeof(char), maj_size + 1);
	if (!maj_str)
		return;
	memcpy(maj_str, rev_str, maj_size); /*already 0term*/
	*maj_num = (TW_UINT16)atoi(maj_str);

	min_size = strlen(rev_str) - maj_size + 1;
	min_str = (char *)calloc(sizeof(char), min_size + 1);
	if (!min_str)
		return;
	memcpy(min_str, &(rev_str[maj_size + 1]), min_size); /*already 0term*/
	*min_num = (TW_UINT16)atoi(min_str);
	if (maj_str)
		free(maj_str);
	if (min_str)
		free(min_str);
}
/*---------------------------------------------------------------------------*/

#ifdef __cplusplus
}
#endif