source: cpp/frams/virtfile/virtfile.cpp @ 301

Last change on this file since 301 was 301, checked in by Maciej Komosinski, 10 years ago

VirtFILE can have fields and still be used as a DLL thanks to declspec(dllimport)

  • Property svn:eol-style set to native
File size: 5.5 KB
Line 
1// This file is a part of Framsticks SDK.  http://www.framsticks.com/
2// Copyright (C) 1999-2015  Maciej Komosinski and Szymon Ulatowski.
3// See LICENSE.txt for details.
4
5#include "virtfile.h"
6#include <common/stl-util.h>
7
8VirtFILE *VirtFILE::Vstdin = NULL;
9VirtFILE *VirtFILE::Vstdout = NULL;
10VirtFILE *VirtFILE::Vstderr = NULL;
11
12VirtFileSystem *VirtFILE::vfs = NULL;
13
14//#define DEBUG_DLL_CALLS
15
16VirtFILE *Vfopen(const char* path,const char* mode)
17{
18#ifdef DEBUG_DLL_CALLS
19printf("VirtFILE::Vfopen %s %s (vfs=%p)\n",path,mode,VirtFILE::vfs);
20#endif
21return VirtFILE::vfs ? VirtFILE::vfs->Vfopen(path,mode) : NULL;
22}
23
24VirtDIR *Vopendir(const char* path)
25{
26#ifdef DEBUG_DLL_CALLS
27printf("VirtFILE::Vfopendir %s (vfs=%p)\n",path,VirtFILE::vfs);
28#endif
29return VirtFILE::vfs ? VirtFILE::vfs->Vopendir(path) : NULL;
30}
31
32bool Vfexists(const char* path)
33{
34return VirtFILE::vfs ? VirtFILE::vfs->Vfexists(path) : false;
35}
36
37bool Vdirexists(const char* path,bool is_writable)
38{
39return VirtFILE::vfs ? VirtFILE::vfs->Vdirexists(path,is_writable) : false;
40}
41
42bool Vmkdir(const char* path)
43{
44return VirtFILE::vfs ? VirtFILE::vfs->Vmkdir(path) : false;
45}
46
47bool Vmkdirs(const char* path)
48{
49return VirtFILE::vfs ? VirtFILE::vfs->Vmkdirs(path) : false;
50}
51
52VirtFILE::~VirtFILE()
53{}
54
55void VirtFILE::selectFileSystem(VirtFileSystem *s)
56{
57vfs=s;
58#ifdef DEBUG_DLL_CALLS
59::printf("VirtFILE::selectFileSystem: %p := %p\n",vfs,s);
60#endif
61}
62
63int VirtFILE::Vprintf(const char *format, va_list args)
64{
65string s=ssprintf_va(format,args);
66return Vwrite(s.c_str(),1,s.size());
67}
68
69int VirtFILE::printf(const char *format, ...)
70{
71int ret; va_list argptr;
72va_start(argptr,format);
73ret=Vprintf(format,argptr);
74va_end(argptr);
75return ret;
76}
77
78int VirtFILE::getSize()
79{
80  int saved_pos = Vtell();
81  Vseek(0, SEEK_END);
82  int size = Vtell();
83  Vseek(saved_pos, SEEK_SET);
84  return size;
85}
86
87void VirtFILE::setVstdin(VirtFILE *f) {Vstdin=f;}
88void VirtFILE::setVstdout(VirtFILE *f) {Vstdout=f;}
89void VirtFILE::setVstderr(VirtFILE *f) {Vstderr=f;}
90VirtFILE* VirtFILE::getVstdin() {return Vstdin;}
91VirtFILE* VirtFILE::getVstdout() {return Vstdout;}
92VirtFILE* VirtFILE::getVstderr() {return Vstderr;}
93//////////////////////////////////////////////////////////////////////////
94
95// base class only returns NULL/false/not supported - implementations perform the actual work
96VirtFILE* VirtFileSystem::Vfopen(const char* path,const char* mode) {return NULL;}
97bool VirtFileSystem::Vfexists(const char* path) {return false;}
98VirtDIR* VirtFileSystem::Vopendir(const char* path) {return NULL;}
99bool VirtFileSystem::Vmkdir(const char* path) {return false;}
100bool VirtFileSystem::Vdirexists(const char* path,bool is_writable) {return false;}
101
102//////////////////////////////////////////////////////////////////////////
103
104
105
106int fread(void *ptr, size_t size, size_t nmemb, VirtFILE* f) {return f->Vread(ptr,size,nmemb);}
107int fwrite(const void *ptr, size_t size, size_t nmemb, VirtFILE* f) {return f->Vwrite(ptr,size,nmemb);}
108
109
110//since we want our own feof(VirtFILE*) function and some systems unfortunately define feof as a macro, we need to #undef it. Same as in virtfile.h
111#if defined _MSC_VER || defined __CYGWIN__ || defined SHP || defined __ANDROID__
112 #pragma push_macro("feof")
113 #undef feof
114#endif
115#if defined __BORLANDC__ //does not support #pragma push_macro/pop_macro
116 #undef feof
117#endif
118
119int feof(VirtFILE* f) {return f->Veof();}
120
121//...and then restore the original macro:
122#if defined _MSC_VER || defined __CYGWIN__ || defined SHP || defined __ANDROID__
123 #pragma pop_macro("feof")
124#endif
125#if defined __BORLANDC__
126 #define feof(__f)     ((__f)->flags & _F_EOF)
127#endif
128
129
130int fputc(int c,VirtFILE* f) {return f->Vputc(c);}
131int fputs(const char *s,VirtFILE* f) {return f->Vputs(s);}
132int fgetc(VirtFILE* f) {return f->Vgetc();}
133int fseek(VirtFILE* f,long offset, int whence) {return f->Vseek(offset,whence);}
134int ftell(VirtFILE* f) {return f->Vtell();}
135void rewind(VirtFILE* f) {f->Vrewind();}
136int fflush(VirtFILE* f) {return f->Vflush();}
137char *fgets(char *s, int size, VirtFILE* f) {return f->Vgets(s,size);}
138int fprintf(VirtFILE* f,const char *format, ...)
139        {
140        int ret; va_list argptr;
141        va_start(argptr,format);
142        ret=f->Vprintf(format,argptr);
143        va_end(argptr);
144        return ret;
145        }
146int fclose(VirtFILE* f) {delete f; return 0;}
147
148int closedir(VirtDIR* d) {delete d; return 0;}
149dirent* readdir(VirtDIR* d) {return d->Vreaddir();}
150
151/////////
152
153bool VirtFileSystem::Vmkdirs(const char* path)
154{
155if (Vdirexists(path,true)) return true;
156string parentdir = getFileDir(path);
157if (!Vmkdirs(parentdir.c_str())) return false;
158return Vmkdir(path);
159}
160
161//////////
162
163
164ChainFileSystem::ChainFileSystem(VirtFileSystem *_chain)
165{
166        chain=_chain;
167#ifdef DEBUG_DLL_CALLS
168printf("ChainFileSystem constructor: %p := %p\n",chain,_chain);
169#endif
170}
171
172
173VirtFILE *ChainFileSystem::Vfopen(const char* path, const char* mode)
174{
175#ifdef DEBUG_DLL_CALLS
176printf("ChainFileSystem::Vfopen %s %s (chain=%p)\n",path,mode,chain);
177#endif
178        return (chain != NULL) ? chain->Vfopen(path, mode) : NULL;
179}
180
181bool ChainFileSystem::Vfexists(const char* path)
182{
183        return (chain != NULL) ? chain->Vfexists(path) : false;
184}
185
186VirtDIR *ChainFileSystem::Vopendir(const char* path)
187{
188#ifdef DEBUG_DLL_CALLS
189printf("ChainFileSystem::Vfopendir %s (chain=%p)\n",path,chain);
190#endif
191        return (chain != NULL) ? chain->Vopendir(path) : NULL;
192}
193
194bool ChainFileSystem::Vmkdir(const char* path)
195{
196        return (chain != NULL) ? chain->Vmkdir(path) : false;
197}
198
199bool ChainFileSystem::Vmkdirs(const char* path)
200{
201        return (chain != NULL) ? chain->Vmkdirs(path) : false;
202}
203
204bool ChainFileSystem::Vdirexists(const char* path,bool is_writable)
205{
206        return (chain != NULL) ? chain->Vdirexists(path,is_writable) : false;
207}
Note: See TracBrowser for help on using the repository browser.