aboutsummaryrefslogtreecommitdiff
path: root/backends/PalmOS/Src
diff options
context:
space:
mode:
Diffstat (limited to 'backends/PalmOS/Src')
-rw-r--r--backends/PalmOS/Src/missing/_stdio.cpp69
1 files changed, 36 insertions, 33 deletions
diff --git a/backends/PalmOS/Src/missing/_stdio.cpp b/backends/PalmOS/Src/missing/_stdio.cpp
index e2898ac738..672ba4ba83 100644
--- a/backends/PalmOS/Src/missing/_stdio.cpp
+++ b/backends/PalmOS/Src/missing/_stdio.cpp
@@ -25,8 +25,12 @@
///////////////////////////////////////////////////////////////////////////////
//FileRef gLogFile;
-static void DrawStatus(Boolean show)
-{
+// WARNING : printf functions must only be used if you compile your code with
+// 4byte int option, use standard functions if 2byte int mode
+// TODO : enable use of 2byte or 4byte (ifdef PRINTF_4BYTE ...)
+
+
+static void DrawStatus(Boolean show) {
UInt8 x,y;
UInt8 *screen = (UInt8 *)(BmpGetBits(WinGetBitmap(WinGetDisplayWindow())));
UInt8 color = (show? gVars->indicator.on : gVars->indicator.off);
@@ -46,8 +50,7 @@ static void DrawStatus(Boolean show)
}
}
///////////////////////////////////////////////////////////////////////////////
-UInt16 fclose(FileRef *stream)
-{
+UInt16 fclose(FileRef *stream) {
Err error = VFSFileClose(*stream);
if (error == errNone)
@@ -59,8 +62,7 @@ UInt16 fclose(FileRef *stream)
return error;
}
///////////////////////////////////////////////////////////////////////////////
-UInt16 feof(FileRef *stream)
-{
+UInt16 feof(FileRef *stream) {
Err error = VFSFileEOF(*stream);
#ifdef DEBUG
@@ -87,8 +89,7 @@ UInt16 feof(FileRef *stream)
return error;
}
///////////////////////////////////////////////////////////////////////////////
-Char *fgets(Char *s, UInt32 n, FileRef *stream)
-{
+Char *fgets(Char *s, UInt32 n, FileRef *stream) {
UInt32 numBytesRead;
DrawStatus(true);
Err error = VFSFileRead(*stream, n, s, &numBytesRead);
@@ -133,8 +134,7 @@ Char *fgets(Char *s, UInt32 n, FileRef *stream)
return NULL;
}
///////////////////////////////////////////////////////////////////////////////
-FileRef *fopen(const Char *filename, const Char *type)
-{
+FileRef *fopen(const Char *filename, const Char *type) {
Err err;
UInt16 openMode;
FileRef *fileRefP = (FileRef *)MemPtrNew(sizeof(FileRef *));
@@ -218,8 +218,7 @@ FileRef *fopen(const Char *filename, const Char *type)
return NULL;
}
///////////////////////////////////////////////////////////////////////////////
-UInt32 fread(void *ptr, UInt32 size, UInt32 nitems, FileRef *stream)
-{
+UInt32 fread(void *ptr, UInt32 size, UInt32 nitems, FileRef *stream) {
UInt32 numBytesRead;
DrawStatus(true);
Err error = VFSFileRead(*stream, size*nitems, ptr, &numBytesRead);
@@ -253,8 +252,7 @@ UInt32 fread(void *ptr, UInt32 size, UInt32 nitems, FileRef *stream)
return 0;
}
///////////////////////////////////////////////////////////////////////////////
-UInt32 fwrite(const void *ptr, UInt32 size, UInt32 nitems, FileRef *stream)
-{
+UInt32 fwrite(const void *ptr, UInt32 size, UInt32 nitems, FileRef *stream) {
UInt32 numBytesWritten;
DrawStatus(true);
Err error = VFSFileWrite(*stream, size*nitems, ptr, &numBytesWritten);
@@ -266,14 +264,12 @@ UInt32 fwrite(const void *ptr, UInt32 size, UInt32 nitems, FileRef *stream)
return NULL;
}
///////////////////////////////////////////////////////////////////////////////
-Int32 fseek(FileRef *stream, Int32 offset, Int32 whence)
-{
+Int32 fseek(FileRef *stream, Int32 offset, Int32 whence) {
Err error = VFSFileSeek(*stream, whence, offset);
return error;
}
///////////////////////////////////////////////////////////////////////////////
-UInt32 ftell(FileRef *stream)
-{
+UInt32 ftell(FileRef *stream) {
Err e;
UInt32 filePos;
@@ -284,8 +280,7 @@ UInt32 ftell(FileRef *stream)
return filePos;
}
///////////////////////////////////////////////////////////////////////////////
-UInt16 fprintf(FileRef *stream, const Char *format, ...)
-{
+UInt16 fprintf(FileRef *stream, const Char *format, ...) {
if (!*stream)
return 0;
@@ -301,14 +296,12 @@ UInt16 fprintf(FileRef *stream, const Char *format, ...)
return numBytesWritten;
}
///////////////////////////////////////////////////////////////////////////////
-Int16 printf(const Char *format, ...)
-{
+Int16 printf(const Char *format, ...) {
if (!*stdout)
return 0;
UInt32 numBytesWritten;
Char buf[256];
-// Char *buf = (Char *)MemPtrNew(256);
va_list va;
va_start(va, format);
@@ -316,14 +309,11 @@ Int16 printf(const Char *format, ...)
va_end(va);
VFSFileWrite (*stdout, StrLen(buf), buf, &numBytesWritten);
-// MemPtrFree(buf);
return numBytesWritten;
}
///////////////////////////////////////////////////////////////////////////////
-Int16 sprintf(Char* s, const Char* formatStr, ...)
-{
+Int16 sprintf(Char* s, const Char* formatStr, ...) {
Char buf[256];
-// Char *buf = (Char *)MemPtrNew(256);
Int16 count;
va_list va;
@@ -332,16 +322,25 @@ Int16 sprintf(Char* s, const Char* formatStr, ...)
va_end(va);
StrCopy(s,buf);
-// MemPtrFree(buf);
return count;
}
///////////////////////////////////////////////////////////////////////////////
-Int16 vsprintf(Char* s, const Char* formatStr, _Palm_va_list argParam)
-{
-// Char buf[10];
-// StrPrintF(buf,"%c%c%c%c",'A' << 16 | 'B', 'C' << 16 | 'D');
+static void StrProcessCModifier(Char *ioStr, UInt16 maxLen) {
+ Char *found;
+ UInt16 length;
+
+ while (found = StrChr(ioStr, '`')) {
+ if (found[1] == 0) { // if next char is NULL
+ length = maxLen - (found - ioStr);
+ MemMove(found, found + 2, length);
+ maxLen -= 2;
+ }
+ }
+}
+Int16 vsprintf(Char* s, const Char* formatStr, _Palm_va_list argParam) {
Char format[256];
+ Int16 retval;
// TODO : need a better modifier
StrCopy(format,formatStr);
StrReplace(format, 256, "%ld", "%d");
@@ -360,8 +359,12 @@ Int16 vsprintf(Char* s, const Char* formatStr, _Palm_va_list argParam)
StrReplace(format, 256, "%5ld","%5d");
StrReplace(format, 256, "%6ld","%6d");
StrReplace(format, 256, "%02lx","%02x");
+ StrReplace(format, 256, "`%c%c","%c");
- return StrVPrintF(s, format, argParam);;
+ retval = StrVPrintF(s, format, argParam); // wrong value may be return due to %c%c
+ StrProcessCModifier(s, 256);
+
+ return retval;
}
///////////////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////////////