Fix seek return value; Clear structure on init; add DB to _type.
[bertos.git] / bertos / emul / kfile_posix.c
index 3fce00bcf2b46b54bde179d7c4f18b8ce6fd6d25..1f09aaff7062dd461856aee0ecaa6a7e21ed70cf 100644 (file)
@@ -37,6 +37,7 @@
  */
 
 #include <emul/kfile_posix.h>
+#include <string.h>
 
 static size_t kfile_posix_read(struct KFile *_fd, void *buf, size_t size)
 {
@@ -63,12 +64,17 @@ static kfile_off_t kfile_posix_seek(struct KFile *_fd, kfile_off_t offset, KSeek
                        std_whence = SEEK_END;
                        break;
                case KSM_SEEK_SET:
-                       /* fall */
-               default:
                        std_whence = SEEK_SET;
+                       break;
+               default:
+                       ASSERT(0);
+                       return EOF;
        }
+       int err = fseek(fd->fp, offset, std_whence);
+       if (err)
+               return err;
 
-       return fseek(fd->fp, offset, std_whence);
+       return ftell(fd->fp);
 }
 
 static int kfile_posix_close(struct KFile *_fd)
@@ -83,9 +89,10 @@ static int kfile_posix_flush(struct KFile *_fd)
        return fflush(fd->fp);
 }
 
-FILEkfile_posix_init(KFilePosix *file, const char *filename, const char *mode)
+FILE *kfile_posix_init(KFilePosix *file, const char *filename, const char *mode)
 {
-       file->fd._type = KFT_KFILEPOSIX;
+       memset(file, 0, sizeof(*file));
+       DB(file->fd._type = KFT_KFILEPOSIX);
        file->fd.read = kfile_posix_read;
        file->fd.write = kfile_posix_write;
        file->fd.close = kfile_posix_close;