forked from ponchio/untrunc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfile.cpp
116 lines (90 loc) · 2.66 KB
/
file.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
/*
Untrunc - file.cpp
Untrunc is GPL software; you can freely distribute,
redistribute, modify & use under the terms of the GNU General
Public License; either version 2 or its successor.
Untrunc is distributed under the GPL "AS IS", without
any warranty; without the implied warranty of merchantability
or fitness for either an expressed or implied particular purpose.
Please see the included GNU General Public License (GPL) for
your rights and further details; see the file COPYING. If you
cannot, write to the Free Software Foundation, 59 Temple Place
Suite 330, Boston, MA 02111-1307, USA. Or www.fsf.org
Copyright 2010 Federico Ponchio
*/
#include "file.h"
#include <string>
#include <endian.h>
using namespace std;
File::File(): file(NULL) {
}
File::~File() {
if(file)
fclose(file);
}
bool File::open(string filename) {
file = fopen(filename.c_str(), "r");
if(file == NULL) return false;
fseeko(file, 0L, SEEK_END);
size = ftello(file);
fseeko(file, 0L, SEEK_SET);
return true;
}
bool File::create(string filename) {
file = fopen(filename.c_str(), "wb");
if(file == NULL) return false;
return true;
}
void File::seek(off_t p) {
fseeko(file, p, SEEK_SET);
}
off_t File::pos() {
return ftello(file);
}
bool File::atEnd() {
return ftello(file) == size;
}
int File::readInt() {
int value;
int n = fread(&value, sizeof(int), 1, file);
if(n != 1)
throw string("Could not read atom length");
return be32toh(value);
}
int64_t File::readInt64() {
int64_t value;
int n = fread(&value, sizeof(value), 1, file);
if(n != 1)
throw string("Could not read atom length");
return be64toh(value);
}
void File::readChar(char *dest, size_t n) {
size_t len = fread(dest, sizeof(char), n, file);
if(len != n)
throw string("Could not read chars");
}
vector<unsigned char> File::read(size_t n) {
vector<unsigned char> dest(n);
size_t len = fread(&*dest.begin(), sizeof(unsigned char), n, file);
if(len != n)
throw string("Could not read at position");
return dest;
}
int File::writeInt(int n) {
n = htobe32(n);
fwrite(&n, sizeof(int), 1, file);
return 4;
}
int File::writeInt64(int64_t n) {
n = htobe64(n);
fwrite(&n, sizeof(n), 1, file);
return 8;
}
int File::writeChar(char *source, size_t n) {
fwrite(source, 1, n, file);
return n;
}
int File::write(vector<unsigned char> &v) {
fwrite(&*v.begin(), 1, v.size(), file);
return v.size();
}