picoc/str.c
zik.saleeba b9e1086cbb Moving towards a working new type system
git-svn-id: http://picoc.googlecode.com/svn/trunk@36 21eae674-98b7-11dd-bd71-f92a316d2d60
2009-01-24 03:15:02 +00:00

130 lines
2.8 KiB
C

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdarg.h>
#include <math.h>
#include "picoc.h"
void StrCopy(Str *Dest, const Str *Source)
{
Dest->Str = Source->Str;
Dest->Len = Source->Len;
}
void StrToC(char *Dest, int DestSize, const Str *Source)
{
int CopyLen = min(DestSize-1, Source->Len);
memcpy(Dest, Source->Str, CopyLen);
Dest[CopyLen] = '\0';
}
void StrFromC(Str *Dest, const char *Source)
{
Dest->Str = Source;
Dest->Len = strlen(Source);
}
int StrEqual(const Str *Str1, const Str *Str2)
{
if (Str1->Len != Str2->Len)
return FALSE;
return memcmp(Str1->Str, Str2->Str, Str1->Len) == 0;
}
int StrEqualC(const Str *Str1, const char *Str2)
{
return strncmp(Str1->Str, Str2, Str1->Len) == 0 && Str2[Str1->Len] == '\0';
}
void StrPrintInt(int Num, FILE *Stream)
{
int Div;
int Remainder = 0;
int Printing = FALSE;
if (Num < 0)
{
fputc('-', Stream);
Num = -Num;
}
if (Num == 0)
fputc('0', Stream);
else
{
Div = LARGE_INT_POWER_OF_TEN;
while (Div > 0)
{
Remainder = Num / Div;
if (Printing || Remainder > 0)
{
fputc('0' + Remainder, Stream);
Printing = TRUE;
}
Num -= Remainder * Div;
Div /= 10;
}
}
}
void StrPrintFP(double Num, FILE *Stream)
{
int Exponent = 0;
if (abs(Num) >= 1e7)
Exponent = log(Num) / LOG10E;
else if (abs(Num) <= 1e-7)
Exponent = log(Num) / LOG10E - 0.999999999;
Num /= pow(10.0, Exponent);
StrPrintInt((int)Num, Stream);
fputc('.', Stream);
for (Num -= (int)Num; Num != 0.0; Num *= 10.0)
fputc('0' + (int)Num, Stream);
if (Exponent)
{
fputc('e', Stream);
StrPrintInt(Exponent, Stream);
}
}
void StrPrintf(const char *Format, ...)
{
va_list Args;
va_start(Args, Format);
vStrPrintf(Format, Args);
va_end(Args);
}
void vStrPrintf(const char *Format, va_list Args)
{
Str *str;
const char *FPos;
for (FPos = Format; *FPos != '\0'; FPos++)
{
if (*FPos == '%')
{
FPos++;
switch (*FPos)
{
case 'S': str = va_arg(Args, Str *); fwrite(str->Str, 1, str->Len, stdout); break;
case 's': fputs(va_arg(Args, char *), stdout); break;
case 'd': StrPrintInt(va_arg(Args, int), stdout); break;
case 'c': fputc(va_arg(Args, int), stdout); break;
case 'f': StrPrintFP(va_arg(Args, double), stdout); break;
case '%': fputc('%', stdout); break;
case '\0': FPos--; break;
}
}
else
putchar(*FPos);
}
}