forked from Infinidat/slimfastq
-
Notifications
You must be signed in to change notification settings - Fork 0
/
xfile.cpp
110 lines (94 loc) · 4.53 KB
/
xfile.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
/***********************************************************************************************************************/
/* This program was written by Josef Ezra <[email protected]> */
/* Copyright (c) 2013, Infinidat */
/* All rights reserved. */
/* */
/* Redistribution and use in source and binary forms, with or without modification, are permitted provided that */
/* the following conditions are met: */
/* */
/* Redistributions of source code must retain the above copyright notice, this list of conditions and the following */
/* disclaimer. */
/* Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following */
/* disclaimer in the documentation and/or other materials provided with the distribution. */
/* Neither the name of the Infinidat nor the names of its contributors may be used to endorse or promote products */
/* derived from this software without specific prior written permission. */
/* */
/* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, */
/* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE */
/* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, */
/* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR */
/* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, */
/* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE */
/* USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */
/***********************************************************************************************************************/
#include "xfile.hpp"
#include <stdlib.h>
#include <errno.h>
#include <string.h>
XFileBase::XFileBase(const char* filename
) : m_filename(filename)
{}
XFileSave::XFileSave(const char* filename
) : XFileBase(filename),
filer(NULL) {}
XFileSave::~XFileSave() {
if (filer) {
put(0); // no more exceptions
rcoder.done();
delete filer;
filer = NULL;
}
}
XFileLoad::XFileLoad(const char* filename
) : XFileBase(filename),
filer(NULL) {}
XFileLoad::~XFileLoad() {
if (filer) {
rcoder.done();
delete filer;
filer = NULL;
}
}
void XFileSave::init () {
filer = new FilerSave(m_filename);
assert(filer);
rcoder.init(filer);
}
bool XFileSave::put(UINT64 gap) {
rarely_if(not filer) init();
return ranger.put_u(&rcoder, gap);
}
void XFileSave::put_chr(UCHAR chr) {
rarely_if(not filer) init();
ranger_str.put(&rcoder, chr);
}
UCHAR XFileLoad::get_chr() {
rarely_if(not filer) init(); // assert(filer) ?
return ranger_str.get(&rcoder);
}
void XFileLoad::init() {
filer = new FilerLoad(m_filename, &m_valid);
assert(filer);
if (m_valid)
rcoder.init(filer);
else
DELETE(filer);
}
UINT64 XFileLoad::get() {
rarely_if(not filer) init();
return m_valid ? ranger.get_u(&rcoder) : 0;
}
void XFileSave::put_str(const UCHAR* p, size_t len) {
put(len);
for (UINT32 j = 0; j < len; j++)
ranger_str.put(&rcoder, p[j]);
}
UCHAR* XFileLoad::get_str(UCHAR* p) {
size_t len = get();
for (UINT32 j = 0; j < len; j++)
p[j] = ranger_str.get(&rcoder);
return p + len;
}
size_t XFileSave::tell() const {
return filer ? filer->tell() : 0;
}