1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
|
/* ScummVM - Graphic Adventure Engine
*
* ScummVM is the legal property of its developers, whose names
* are too numerous to list here. Please refer to the COPYRIGHT
* file distributed with this source distribution.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
*/
#include "hopkins/files.h"
#include "hopkins/hopkins.h"
#include "hopkins/globals.h"
#include "common/system.h"
#include "common/debug.h"
#include "common/file.h"
#include "common/str.h"
#include "common/savefile.h"
namespace Hopkins {
void FileManager::initSaves() {
Common::String dataFilename = "HISCORE.DAT";
byte data[100];
Common::fill(&data[0], &data[100], 0);
SAUVE_FICHIER(dataFilename, data, 100);
}
bool FileManager::SAUVE_FICHIER(const Common::String &file, const void *buf, size_t n) {
return bsave(file, buf, n);
}
bool FileManager::bsave(const Common::String &file, const void *buf, size_t n) {
Common::OutSaveFile *f = g_system->getSavefileManager()->openForSaving(file);
if (f) {
size_t bytesWritten = f->write(buf, n);
f->finalize();
delete f;
return bytesWritten == n;
} else
return false;
}
void FileManager::Chage_Inifile(Common::StringMap &iniParams) {
char *iniData = (char *)CHARGE_FICHIER("config.ini");
char *ptr = iniData;
bool endOfFile = false;
while (!endOfFile) {
if (*ptr == '%') {
if (*(ptr + 1) == '%') {
endOfFile = true;
} else {
++ptr;
// Get the parameter name
Common::String paramName;
while (*ptr == ' ')
++ptr;
while (*ptr != '=') {
paramName += toupper(*ptr++);
}
while (paramName.lastChar() == ' ')
paramName.deleteLastChar();
// Get the parameter value
Common::String paramValue;
while (*++ptr == ' ')
;
while (*ptr != ';') {
paramValue += toupper(*ptr++);
}
while (paramValue.lastChar() == ' ')
paramValue.deleteLastChar();
iniParams[paramName] = paramValue;
}
}
++ptr;
}
free(iniData);
}
void *FileManager::CHARGE_FICHIER(const Common::String &file) {
DMESS1();
Common::File f;
if (!f.open(file))
error("Error opening %s", file.c_str());
// Allocate space for the file contents
size_t filesize = f.size();
void *data = malloc(filesize);
if (!data)
error("Error allocating space for file being loaded - %s", file.c_str());
bload_it(f, data, filesize);
f.close();
return data;
}
void FileManager::DMESS1() {
}
int FileManager::bload_it(Common::ReadStream &stream, void *buf, size_t nbytes) {
return stream.read(buf, nbytes);
}
} // End of namespace Hopkins
|