-
Notifications
You must be signed in to change notification settings - Fork 42
/
libwad.cpp
145 lines (125 loc) · 2.42 KB
/
libwad.cpp
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
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
#include <QtCore>
#include "libwad.h"
struct waddir {
int lumpstart;
int lumpsize;
char lumpname[8];
};
DoomWad::DoomWad(QString file){
QFile *pfile = new QFile(file);
dev = pfile;
// Opening wad from our own QFile
shouldClose = true;
}
DoomWad::DoomWad(QIODevice *dev){
// Opening wad from QIODevice
this->dev = dev;
shouldClose = false;
}
DoomWad::~DoomWad(){
if(shouldClose){
this->dev->close();
delete this->dev;
this->dev = NULL;
// Closing device
}
// Deleting DoomWad
}
bool DoomWad::open(){
// Opening wad file
if(!dev->isOpen()){
bool rc = dev->open(QIODevice::ReadOnly);
if(!rc){
// Open failed
return rc;
}
}
// Wad file opened, reading data...
bool rc = dev->seek(4);
if (!rc)
{
// Seek failed
return rc;
}
char fourbytes[4];
int rd = dev->read(fourbytes, 4);
if (rd != 4)
{
// Read failed
return false;
}
int lumps = *((int*)fourbytes);
rd = dev->read(fourbytes, 4);
if (rd != 4)
{
// Read failed
return false;
}
int diroffset = *((int*)fourbytes);
rc = dev->seek(diroffset);
if (!rc)
{
// Seek failed
return rc;
}
QString last("");
for(int i = 0; i < lumps; i++){
struct waddir dir;
rd = dev->read((char*)&dir, sizeof(struct waddir));
if(rd != sizeof(struct waddir)){
// Dropping bad lump
continue;
}
char tname[9];
memset(tname, 0, 9);
memcpy(tname, dir.lumpname, 8);
QString lumpName = tname;
int lumpStart = dir.lumpstart;
int lumpSize = dir.lumpsize;
WadLump *lump = new WadLump(lumpStart, lumpSize, lumpName, this);
wadLumps.append(lump);
if(lumpName == "THINGS" && !last.isEmpty()){
// New level
levelnames << last;
}else{
// Not a level: last
}
last = lumpName;
}
return true;
}
int DoomWad::lumps(){
return 0;
}
WadLump *DoomWad::getLump(int index){
return NULL;
}
WadLump *DoomWad::getLumpByName(QString name){
return NULL;
}
bool DoomWad::addLumps(QList<WadLump*> lumps, DoomWad::AddBehaviour behaviour){
return false;
}
QStringList DoomWad::getLumpNames(){
return QStringList();
}
QStringList DoomWad::getMapNames(){
return levelnames;
}
bool DoomWad::isCompressed(){
return false;
}
/******************** WADLUMP ***********************/
WadLump::WadLump(int start, int size, QString name, DoomWad *par){
lumpStart = start;
lumpSize = size;
lumpName = name;
parent = par;
// New lump: name
}
QString WadLump::getName(){
return QString(lumpName);
}
int WadLump::getSize(){
return lumpSize;
}