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