mirror of
https://github.com/pocoproject/poco.git
synced 2025-02-03 23:55:49 +01:00
d75e68c027
windows build only
439 lines
7.4 KiB
C
439 lines
7.4 KiB
C
/*
|
|
* << Haru Free PDF Library 2.0.0 >> -- HPDF_utils.c
|
|
*
|
|
* Copyright (c) 1999-2004 Takeshi Kanno <takeshi_kanno@est.hi-ho.ne.jp>
|
|
*
|
|
* Permission to use, copy, modify, distribute and sell this software
|
|
* and its documentation for any purpose is hereby granted without fee,
|
|
* provided that the above copyright notice appear in all copies and
|
|
* that both that copyright notice and this permission notice appear
|
|
* in supporting documentation.
|
|
* It is provided "as is" without express or implied warranty.
|
|
*
|
|
*/
|
|
|
|
#include <stdlib.h>
|
|
#include "hpdf_utils.h"
|
|
#include "hpdf_consts.h"
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
HPDF_INT
|
|
HPDF_AToI (const char *s)
|
|
{
|
|
HPDF_BOOL flg = HPDF_FALSE;
|
|
HPDF_INT v = 0;
|
|
|
|
/* increment pointer until the charactor of 's' is not
|
|
* white-space-charactor.
|
|
*/
|
|
while (*s) {
|
|
if (HPDF_IS_WHITE_SPACE(*s))
|
|
s++;
|
|
else {
|
|
if (*s == '-') {
|
|
flg = HPDF_TRUE;
|
|
s++;
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
|
|
while (*s >= '0' && *s <= '9') {
|
|
v *= 10;
|
|
v += *s - '0';
|
|
s++;
|
|
}
|
|
|
|
if (flg)
|
|
v *= -1;
|
|
|
|
return v;
|
|
}
|
|
|
|
|
|
HPDF_DOUBLE
|
|
HPDF_AToF (const char *s)
|
|
{
|
|
HPDF_BOOL flg = HPDF_FALSE;
|
|
HPDF_INT i = 0;
|
|
HPDF_DOUBLE v;
|
|
HPDF_INT tmp = 1;
|
|
|
|
/* increment pointer until the charactor of 's' is not
|
|
* white-space-charactor.
|
|
*/
|
|
while (*s) {
|
|
if (HPDF_IS_WHITE_SPACE(*s))
|
|
s++;
|
|
else {
|
|
if (*s == '-') {
|
|
flg = HPDF_TRUE;
|
|
s++;
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
|
|
while (*s >= '0' && *s <= '9') {
|
|
if (i > 3276)
|
|
break;
|
|
|
|
i *= 10;
|
|
i += *s - '0';
|
|
s++;
|
|
}
|
|
|
|
if (*s == '.') {
|
|
s++;
|
|
while (*s >= '0' && *s <= '9') {
|
|
if (i > 214748364)
|
|
break;
|
|
|
|
i *= 10;
|
|
i += *s - '0';
|
|
s++;
|
|
tmp *= 10;
|
|
}
|
|
}
|
|
|
|
v = (HPDF_DOUBLE)i / tmp;
|
|
|
|
if (flg)
|
|
v *= -1;
|
|
|
|
return v;
|
|
}
|
|
|
|
|
|
char*
|
|
HPDF_IToA (char *s,
|
|
HPDF_INT32 val,
|
|
char *eptr)
|
|
{
|
|
char* t;
|
|
char buf[HPDF_INT_LEN + 1];
|
|
|
|
if (val < 0) {
|
|
if (val < HPDF_LIMIT_MIN_INT)
|
|
val = HPDF_LIMIT_MIN_INT;
|
|
*s++ = '-';
|
|
val = -val;
|
|
} else if (val > HPDF_LIMIT_MAX_INT) {
|
|
val = HPDF_LIMIT_MAX_INT;
|
|
} else if (val == 0) {
|
|
*s++ = '0';
|
|
}
|
|
|
|
t = buf + HPDF_INT_LEN;
|
|
*t-- = 0;
|
|
|
|
while (val > 0) {
|
|
*t = (char)(val % 10) + '0';
|
|
val /= 10;
|
|
t--;
|
|
}
|
|
|
|
t++;
|
|
while (s < eptr && *t != 0)
|
|
*s++ = *t++;
|
|
*s = 0;
|
|
|
|
return s;
|
|
}
|
|
|
|
|
|
char*
|
|
HPDF_IToA2 (char *s,
|
|
HPDF_UINT32 val,
|
|
HPDF_UINT len)
|
|
{
|
|
char* t;
|
|
char* u;
|
|
|
|
if (val > HPDF_LIMIT_MAX_INT)
|
|
val = HPDF_LIMIT_MAX_INT;
|
|
|
|
u = s + len - 1;
|
|
*u = 0;
|
|
t = u - 1;
|
|
while (val > 0 && t >= s) {
|
|
*t = (char)(val % 10) + '0';
|
|
val /= 10;
|
|
t--;
|
|
}
|
|
|
|
while (s <= t)
|
|
*t-- = '0';
|
|
|
|
return s + len - 1;
|
|
}
|
|
|
|
|
|
char*
|
|
HPDF_FToA (char *s,
|
|
HPDF_REAL val,
|
|
char *eptr)
|
|
{
|
|
HPDF_INT32 int_val;
|
|
HPDF_INT32 fpart_val;
|
|
char buf[HPDF_REAL_LEN + 1];
|
|
char* sptr = s;
|
|
char* t;
|
|
HPDF_UINT32 i;
|
|
|
|
if (val > HPDF_LIMIT_MAX_REAL)
|
|
val = HPDF_LIMIT_MAX_REAL;
|
|
else
|
|
if (val < HPDF_LIMIT_MIN_REAL)
|
|
val = HPDF_LIMIT_MIN_REAL;
|
|
|
|
t = buf + HPDF_REAL_LEN;
|
|
*t-- = 0;
|
|
|
|
if (val < 0) {
|
|
*s++ = '-';
|
|
val = -val;
|
|
}
|
|
|
|
/* separate an integer part and a decimal part. */
|
|
int_val = (HPDF_INT32)(val + 0.000005);
|
|
fpart_val = (HPDF_INT32)((HPDF_REAL)(val - int_val + 0.000005) * 100000);
|
|
|
|
/* process decimal part */
|
|
for (i = 0; i < 5; i++) {
|
|
*t = (char)(fpart_val % 10) + '0';
|
|
fpart_val /= 10;
|
|
t--;
|
|
}
|
|
|
|
/* process integer part */
|
|
*t-- = '.';
|
|
*t = '0';
|
|
if (int_val == 0)
|
|
t--;
|
|
|
|
while (int_val > 0) {
|
|
*t = (char)(int_val % 10) + '0';
|
|
int_val /= 10;
|
|
t--;
|
|
}
|
|
|
|
t++;
|
|
while (s <= eptr && *t != 0)
|
|
*s++ = *t++;
|
|
s--;
|
|
|
|
/* delete an excessive decimal portion. */
|
|
while (s > sptr) {
|
|
if (*s == '0')
|
|
*s = 0;
|
|
else {
|
|
if (*s == '.')
|
|
*s = 0;
|
|
break;
|
|
}
|
|
s--;
|
|
}
|
|
|
|
return (*s == 0) ? s : ++s;
|
|
}
|
|
|
|
|
|
HPDF_BYTE*
|
|
HPDF_MemCpy (HPDF_BYTE* out,
|
|
const HPDF_BYTE *in,
|
|
HPDF_UINT n)
|
|
{
|
|
while (n > 0) {
|
|
*out++ = *in++;
|
|
n--;
|
|
}
|
|
|
|
return out;
|
|
}
|
|
|
|
|
|
HPDF_BYTE*
|
|
HPDF_StrCpy (char *out,
|
|
const char *in,
|
|
char *eptr)
|
|
{
|
|
if (in != NULL) {
|
|
while (eptr > out && *in != 0)
|
|
*out++ = *in++;
|
|
}
|
|
|
|
*out = 0;
|
|
|
|
return out;
|
|
}
|
|
|
|
|
|
HPDF_INT
|
|
HPDF_MemCmp (const HPDF_BYTE *s1,
|
|
const HPDF_BYTE *s2,
|
|
HPDF_UINT n)
|
|
{
|
|
if (n == 0)
|
|
return 0;
|
|
|
|
while (*s1 == *s2) {
|
|
n--;
|
|
if (n == 0)
|
|
return 0;
|
|
s1++;
|
|
s2++;
|
|
}
|
|
|
|
return *s1 - *s2;
|
|
}
|
|
|
|
|
|
HPDF_INT
|
|
HPDF_StrCmp (const char *s1,
|
|
const char *s2)
|
|
{
|
|
if (!s1 || !s2) {
|
|
if (!s1 && s2)
|
|
return -1;
|
|
else
|
|
return 1;
|
|
}
|
|
|
|
while (*s1 == *s2) {
|
|
s1++;
|
|
s2++;
|
|
if (*s1 == 0 || *s2 == 0)
|
|
break;
|
|
}
|
|
|
|
return (HPDF_BYTE)*s1 - (HPDF_BYTE)*s2;
|
|
}
|
|
|
|
|
|
void*
|
|
HPDF_MemSet (void *s,
|
|
HPDF_BYTE c,
|
|
HPDF_UINT n)
|
|
{
|
|
HPDF_BYTE* b = (HPDF_BYTE*)s;
|
|
|
|
while (n > 0) {
|
|
*b = c;
|
|
b++;
|
|
n--;
|
|
}
|
|
|
|
return b;
|
|
}
|
|
|
|
|
|
HPDF_UINT
|
|
HPDF_StrLen (const char *s,
|
|
HPDF_INT maxlen)
|
|
{
|
|
HPDF_INT len = 0;
|
|
|
|
if (!s)
|
|
return 0;
|
|
|
|
while (*s != 0 && (maxlen < 0 || len < maxlen)) {
|
|
s++;
|
|
len++;
|
|
}
|
|
|
|
return (HPDF_UINT)len;
|
|
}
|
|
|
|
|
|
const char*
|
|
HPDF_StrStr (const char *s1,
|
|
const char *s2,
|
|
HPDF_UINT maxlen)
|
|
{
|
|
HPDF_UINT len = HPDF_StrLen (s2, -1);
|
|
|
|
if (!s1)
|
|
return NULL;
|
|
|
|
if (len == 0)
|
|
return s1;
|
|
|
|
if (maxlen == 0)
|
|
maxlen = HPDF_StrLen (s1, -1);
|
|
|
|
if (maxlen < len)
|
|
return NULL;
|
|
|
|
maxlen -= len;
|
|
maxlen++;
|
|
|
|
while (maxlen > 0) {
|
|
if (HPDF_MemCmp (s1, s2, len) == 0)
|
|
return s1;
|
|
|
|
s1++;
|
|
maxlen--;
|
|
}
|
|
|
|
return NULL;
|
|
}
|
|
|
|
|
|
HPDF_Box
|
|
HPDF_ToBox (HPDF_INT16 left,
|
|
HPDF_INT16 bottom,
|
|
HPDF_INT16 right,
|
|
HPDF_INT16 top)
|
|
{
|
|
HPDF_Box box;
|
|
|
|
box.left = left;
|
|
box.bottom = bottom;
|
|
box.right = right;
|
|
box.top = top;
|
|
|
|
return box;
|
|
}
|
|
|
|
|
|
HPDF_Point
|
|
HPDF_ToPoint (HPDF_INT16 x,
|
|
HPDF_INT16 y)
|
|
{
|
|
HPDF_Point point;
|
|
|
|
point.x = x;
|
|
point.y = y;
|
|
|
|
return point;
|
|
}
|
|
|
|
HPDF_Rect
|
|
HPDF_ToRect (HPDF_REAL left,
|
|
HPDF_REAL bottom,
|
|
HPDF_REAL right,
|
|
HPDF_REAL top)
|
|
{
|
|
HPDF_Rect rect;
|
|
|
|
rect.left = left;
|
|
rect.bottom = bottom;
|
|
rect.right = right;
|
|
rect.top = top;
|
|
|
|
return rect;
|
|
}
|
|
|
|
|
|
void
|
|
HPDF_UInt16Swap (HPDF_UINT16 *value)
|
|
{
|
|
HPDF_BYTE u[2];
|
|
|
|
HPDF_MemCpy (u, (HPDF_BYTE*)value, 2);
|
|
*value = (HPDF_UINT16)((HPDF_UINT16)u[0] << 8 | (HPDF_UINT16)u[1]);
|
|
}
|
|
|