annotate src/zfstream.cc @ 16088:b29b10fbb744 stable release-3-6-4

Version 3.6.4 released. * configure.ac (AC_INIT): Version is now 3.6.4. (OCTAVE_RELEASE_DATE): Now 2013-02-21.
author John W. Eaton <jwe@octave.org>
date Thu, 21 Feb 2013 15:17:54 -0500
parents c1c5b3cc2996
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
1 /*
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
2
14138
72c96de7a403 maint: update copyright notices for 2012
John W. Eaton <jwe@octave.org>
parents: 11586
diff changeset
3 Copyright (C) 2005-2012 Ludwig Schwardt, Kevin Ruland
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
4
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
5
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
6 This file is part of Octave.
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
7
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
8 Octave is free software; you can redistribute it and/or modify it
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
9 under the terms of the GNU General Public License as published by the
7016
93c65f2a5668 [project @ 2007-10-12 06:40:56 by jwe]
jwe
parents: 6959
diff changeset
10 Free Software Foundation; either version 3 of the License, or (at your
93c65f2a5668 [project @ 2007-10-12 06:40:56 by jwe]
jwe
parents: 6959
diff changeset
11 option) any later version.
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
12
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
13 Octave is distributed in the hope that it will be useful, but WITHOUT
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
16 for more details.
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
17
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
18 You should have received a copy of the GNU General Public License
7016
93c65f2a5668 [project @ 2007-10-12 06:40:56 by jwe]
jwe
parents: 6959
diff changeset
19 along with Octave; see the file COPYING. If not, see
93c65f2a5668 [project @ 2007-10-12 06:40:56 by jwe]
jwe
parents: 6959
diff changeset
20 <http://www.gnu.org/licenses/>.
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
21
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
22 */
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
23
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
24 /*
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
25
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
26 This file is adapted from the zlib 1.2.2 contrib/iostream3 code,
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
27 written by
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
28
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
29 Ludwig Schwardt <schwardt@sun.ac.za>
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
30 original version by Kevin Ruland <kevin@rodin.wustl.edu>
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
31
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
32 */
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
33
8025
60e938e1459b zfstream.cc: include <config.h>
John W. Eaton <jwe@octave.org>
parents: 7520
diff changeset
34 #ifdef HAVE_CONFIG_H
60e938e1459b zfstream.cc: include <config.h>
John W. Eaton <jwe@octave.org>
parents: 7520
diff changeset
35 #include <config.h>
60e938e1459b zfstream.cc: include <config.h>
John W. Eaton <jwe@octave.org>
parents: 7520
diff changeset
36 #endif
60e938e1459b zfstream.cc: include <config.h>
John W. Eaton <jwe@octave.org>
parents: 7520
diff changeset
37
8950
d865363208d6 include <iosfwd> instead of <iostream> in header files
John W. Eaton <jwe@octave.org>
parents: 8920
diff changeset
38 #include <iostream>
d865363208d6 include <iosfwd> instead of <iostream> in header files
John W. Eaton <jwe@octave.org>
parents: 8920
diff changeset
39
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
40 #include "zfstream.h"
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
41
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
42 #ifdef HAVE_ZLIB
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
43
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
44 #include <cstring> // for strcpy, strcat, strlen (mode strings)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
45 #include <cstdio> // for BUFSIZ
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
46
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
47 // Internal buffer sizes (default and "unbuffered" versions)
6783
f966543d105f [project @ 2007-07-20 16:13:31 by dbateman]
dbateman
parents: 6777
diff changeset
48 #define STASHED_CHARACTERS 16
11586
12df7854fa7c strip trailing whitespace from source files
John W. Eaton <jwe@octave.org>
parents: 11523
diff changeset
49 #define BIGBUFSIZE (256 * 1024 + STASHED_CHARACTERS)
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
50 #define SMALLBUFSIZE 1
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
51
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
52 /*****************************************************************************/
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
53
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
54 // Default constructor
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
55 gzfilebuf::gzfilebuf()
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
56 : file(0), io_mode(std::ios_base::openmode(0)), own_fd(false),
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
57 buffer(0), buffer_size(BIGBUFSIZE), own_buffer(true)
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
58 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
59 // No buffers to start with
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
60 this->disable_buffer();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
61 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
62
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
63 // Destructor
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
64 gzfilebuf::~gzfilebuf()
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
65 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
66 // Sync output buffer and close only if responsible for file
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
67 // (i.e. attached streams should be left open at this stage)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
68 this->sync();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
69 if (own_fd)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
70 this->close();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
71 // Make sure internal buffer is deallocated
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
72 this->disable_buffer();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
73 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
74
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
75 // Set compression level and strategy
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
76 int
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
77 gzfilebuf::setcompression(int comp_level,
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
78 int comp_strategy)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
79 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
80 return gzsetparams(file, comp_level, comp_strategy);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
81 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
82
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
83 // Open gzipped file
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
84 gzfilebuf*
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
85 gzfilebuf::open(const char *name,
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
86 std::ios_base::openmode mode)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
87 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
88 // Fail if file already open
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
89 if (this->is_open())
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
90 return 0;
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
91 // Don't support simultaneous read/write access (yet)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
92 if ((mode & std::ios_base::in) && (mode & std::ios_base::out))
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
93 return 0;
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
94
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
95 // Build mode string for gzopen and check it [27.8.1.3.2]
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
96 char char_mode[6] = "\0\0\0\0\0";
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
97 if (!this->open_mode(mode, char_mode))
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
98 return 0;
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
99
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
100 // Attempt to open file
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
101 if ((file = gzopen(name, char_mode)) == 0)
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
102 return 0;
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
103
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
104 // On success, allocate internal buffer and set flags
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
105 this->enable_buffer();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
106 io_mode = mode;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
107 own_fd = true;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
108 return this;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
109 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
110
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
111 // Attach to gzipped file
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
112 gzfilebuf*
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
113 gzfilebuf::attach(int fd,
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
114 std::ios_base::openmode mode)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
115 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
116 // Fail if file already open
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
117 if (this->is_open())
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
118 return 0;
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
119 // Don't support simultaneous read/write access (yet)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
120 if ((mode & std::ios_base::in) && (mode & std::ios_base::out))
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
121 return 0;
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
122
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
123 // Build mode string for gzdopen and check it [27.8.1.3.2]
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
124 char char_mode[6] = "\0\0\0\0\0";
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
125 if (!this->open_mode(mode, char_mode))
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
126 return 0;
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
127
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
128 // Attempt to attach to file
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
129 if ((file = gzdopen(fd, char_mode)) == 0)
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
130 return 0;
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
131
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
132 // On success, allocate internal buffer and set flags
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
133 this->enable_buffer();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
134 io_mode = mode;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
135 own_fd = false;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
136 return this;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
137 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
138
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
139 // Close gzipped file
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
140 gzfilebuf*
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
141 gzfilebuf::close()
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
142 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
143 // Fail immediately if no file is open
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
144 if (!this->is_open())
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
145 return 0;
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
146 // Assume success
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
147 gzfilebuf* retval = this;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
148 // Attempt to sync and close gzipped file
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
149 if (this->sync() == -1)
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
150 retval = 0;
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
151 if (gzclose(file) < 0)
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
152 retval = 0;
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
153 // File is now gone anyway (postcondition [27.8.1.3.8])
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
154 file = 0;
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
155 own_fd = false;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
156 // Destroy internal buffer if it exists
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
157 this->disable_buffer();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
158 return retval;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
159 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
160
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
161 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
162
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
163 // Convert int open mode to mode string
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
164 bool
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
165 gzfilebuf::open_mode(std::ios_base::openmode mode,
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
166 char* c_mode) const
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
167 {
6959
47f4f4e88166 [project @ 2007-10-04 20:43:32 by jwe]
jwe
parents: 6783
diff changeset
168 // FIXME -- do we need testb?
47f4f4e88166 [project @ 2007-10-04 20:43:32 by jwe]
jwe
parents: 6783
diff changeset
169 // bool testb = mode & std::ios_base::binary;
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
170 bool testi = mode & std::ios_base::in;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
171 bool testo = mode & std::ios_base::out;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
172 bool testt = mode & std::ios_base::trunc;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
173 bool testa = mode & std::ios_base::app;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
174
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
175 // Check for valid flag combinations - see [27.8.1.3.2] (Table 92)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
176 // Original zfstream hardcoded the compression level to maximum here...
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
177 // Double the time for less than 1% size improvement seems
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
178 // excessive though - keeping it at the default level
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
179 // To change back, just append "9" to the next three mode strings
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
180 if (!testi && testo && !testt && !testa)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
181 strcpy(c_mode, "w");
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
182 if (!testi && testo && !testt && testa)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
183 strcpy(c_mode, "a");
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
184 if (!testi && testo && testt && !testa)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
185 strcpy(c_mode, "w");
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
186 if (testi && !testo && !testt && !testa)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
187 strcpy(c_mode, "r");
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
188 // No read/write mode yet
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
189 // if (testi && testo && !testt && !testa)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
190 // strcpy(c_mode, "r+");
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
191 // if (testi && testo && testt && !testa)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
192 // strcpy(c_mode, "w+");
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
193
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
194 // Mode string should be empty for invalid combination of flags
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
195 if (strlen(c_mode) == 0)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
196 return false;
6275
6e5835ef21f8 [project @ 2007-02-07 07:29:46 by jwe]
jwe
parents: 5307
diff changeset
197
6e5835ef21f8 [project @ 2007-02-07 07:29:46 by jwe]
jwe
parents: 5307
diff changeset
198 strcat(c_mode, "b");
6e5835ef21f8 [project @ 2007-02-07 07:29:46 by jwe]
jwe
parents: 5307
diff changeset
199
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
200 return true;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
201 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
202
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
203 // Determine number of characters in internal get buffer
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
204 std::streamsize
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
205 gzfilebuf::showmanyc()
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
206 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
207 // Calls to underflow will fail if file not opened for reading
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
208 if (!this->is_open() || !(io_mode & std::ios_base::in))
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
209 return -1;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
210 // Make sure get area is in use
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
211 if (this->gptr() && (this->gptr() < this->egptr()))
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
212 return std::streamsize(this->egptr() - this->gptr());
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
213 else
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
214 return 0;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
215 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
216
6777
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
217 // Puts back a character to the stream in two cases. Firstly, when there
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
218 // is no putback position available, and secondly when the character putback
11586
12df7854fa7c strip trailing whitespace from source files
John W. Eaton <jwe@octave.org>
parents: 11523
diff changeset
219 // differs from the one in the file. We can only support the first case
6777
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
220 // with gzipped files.
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
221 gzfilebuf::int_type
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
222 gzfilebuf::pbackfail (gzfilebuf::int_type c)
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
223 {
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
224 if (this->is_open())
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
225 {
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
226 if (gzseek (file, this->gptr() - this->egptr() - 1, SEEK_CUR) < 0)
10317
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
227 return traits_type::eof();
11586
12df7854fa7c strip trailing whitespace from source files
John W. Eaton <jwe@octave.org>
parents: 11523
diff changeset
228
6777
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
229 // Invalidates contents of the buffer
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
230 enable_buffer ();
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
231
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
232 // Attempt to fill internal buffer from gzipped file
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
233 // (buffer must be guaranteed to exist...)
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
234 int bytes_read = gzread(file, buffer, buffer_size);
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
235 // Indicates error or EOF
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
236 if (bytes_read <= 0)
10317
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
237 {
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
238 // Reset get area
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
239 this->setg(buffer, buffer, buffer);
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
240 return traits_type::eof();
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
241 }
6777
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
242
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
243 // Make all bytes read from file available as get area
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
244 this->setg(buffer, buffer, buffer + bytes_read);
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
245
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
246 // If next character in get area differs from putback character
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
247 // flag a failure
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
248 gzfilebuf::int_type ret = traits_type::to_int_type(*(this->gptr()));
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
249 if (ret != c)
10317
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
250 return traits_type::eof();
6777
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
251 else
10317
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
252 return ret;
6777
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
253 }
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
254 else
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
255 return traits_type::eof();
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
256 }
4775fc1aa728 [project @ 2007-07-18 16:32:51 by dbateman]
dbateman
parents: 6275
diff changeset
257
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
258 // Fill get area from gzipped file
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
259 gzfilebuf::int_type
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
260 gzfilebuf::underflow()
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
261 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
262 // If something is left in the get area by chance, return it
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
263 // (this shouldn't normally happen, as underflow is only supposed
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
264 // to be called when gptr >= egptr, but it serves as error check)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
265 if (this->gptr() && (this->gptr() < this->egptr()))
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
266 return traits_type::to_int_type(*(this->gptr()));
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
267
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
268 // If the file hasn't been opened for reading, produce error
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
269 if (!this->is_open() || !(io_mode & std::ios_base::in))
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
270 return traits_type::eof();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
271
6783
f966543d105f [project @ 2007-07-20 16:13:31 by dbateman]
dbateman
parents: 6777
diff changeset
272 // Copy the final characters to the front of the buffer
f966543d105f [project @ 2007-07-20 16:13:31 by dbateman]
dbateman
parents: 6777
diff changeset
273 int stash = 0;
f966543d105f [project @ 2007-07-20 16:13:31 by dbateman]
dbateman
parents: 6777
diff changeset
274 if (this->eback() && buffer && buffer_size > STASHED_CHARACTERS)
f966543d105f [project @ 2007-07-20 16:13:31 by dbateman]
dbateman
parents: 6777
diff changeset
275 {
f966543d105f [project @ 2007-07-20 16:13:31 by dbateman]
dbateman
parents: 6777
diff changeset
276 char_type *ptr1 = buffer;
f966543d105f [project @ 2007-07-20 16:13:31 by dbateman]
dbateman
parents: 6777
diff changeset
277 char_type *ptr2 = this->egptr() - STASHED_CHARACTERS + 1;
f966543d105f [project @ 2007-07-20 16:13:31 by dbateman]
dbateman
parents: 6777
diff changeset
278 if (ptr2 > this->eback())
10317
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
279 while (stash++ <= STASHED_CHARACTERS)
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
280 *ptr1++ = *ptr2++;
6783
f966543d105f [project @ 2007-07-20 16:13:31 by dbateman]
dbateman
parents: 6777
diff changeset
281 }
f966543d105f [project @ 2007-07-20 16:13:31 by dbateman]
dbateman
parents: 6777
diff changeset
282
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
283 // Attempt to fill internal buffer from gzipped file
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
284 // (buffer must be guaranteed to exist...)
6783
f966543d105f [project @ 2007-07-20 16:13:31 by dbateman]
dbateman
parents: 6777
diff changeset
285 int bytes_read = gzread(file, buffer + stash, buffer_size - stash);
f966543d105f [project @ 2007-07-20 16:13:31 by dbateman]
dbateman
parents: 6777
diff changeset
286
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
287 // Indicates error or EOF
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
288 if (bytes_read <= 0)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
289 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
290 // Reset get area
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
291 this->setg(buffer, buffer, buffer);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
292 return traits_type::eof();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
293 }
6783
f966543d105f [project @ 2007-07-20 16:13:31 by dbateman]
dbateman
parents: 6777
diff changeset
294 // Make all bytes read from file plus the stash available as get area
f966543d105f [project @ 2007-07-20 16:13:31 by dbateman]
dbateman
parents: 6777
diff changeset
295 this->setg(buffer, buffer + stash, buffer + bytes_read + stash);
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
296
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
297 // Return next character in get area
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
298 return traits_type::to_int_type(*(this->gptr()));
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
299 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
300
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
301 // Write put area to gzipped file
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
302 gzfilebuf::int_type
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
303 gzfilebuf::overflow(int_type c)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
304 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
305 // Determine whether put area is in use
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
306 if (this->pbase())
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
307 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
308 // Double-check pointer range
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
309 if (this->pptr() > this->epptr() || this->pptr() < this->pbase())
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
310 return traits_type::eof();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
311 // Add extra character to buffer if not EOF
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
312 if (!traits_type::eq_int_type(c, traits_type::eof()))
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
313 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
314 *(this->pptr()) = traits_type::to_char_type(c);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
315 this->pbump(1);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
316 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
317 // Number of characters to write to file
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
318 int bytes_to_write = this->pptr() - this->pbase();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
319 // Overflow doesn't fail if nothing is to be written
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
320 if (bytes_to_write > 0)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
321 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
322 // If the file hasn't been opened for writing, produce error
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
323 if (!this->is_open() || !(io_mode & std::ios_base::out))
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
324 return traits_type::eof();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
325 // If gzipped file won't accept all bytes written to it, fail
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
326 if (gzwrite(file, this->pbase(), bytes_to_write) != bytes_to_write)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
327 return traits_type::eof();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
328 // Reset next pointer to point to pbase on success
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
329 this->pbump(-bytes_to_write);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
330 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
331 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
332 // Write extra character to file if not EOF
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
333 else if (!traits_type::eq_int_type(c, traits_type::eof()))
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
334 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
335 // If the file hasn't been opened for writing, produce error
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
336 if (!this->is_open() || !(io_mode & std::ios_base::out))
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
337 return traits_type::eof();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
338 // Impromptu char buffer (allows "unbuffered" output)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
339 char_type last_char = traits_type::to_char_type(c);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
340 // If gzipped file won't accept this character, fail
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
341 if (gzwrite(file, &last_char, 1) != 1)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
342 return traits_type::eof();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
343 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
344
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
345 // If you got here, you have succeeded (even if c was EOF)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
346 // The return value should therefore be non-EOF
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
347 if (traits_type::eq_int_type(c, traits_type::eof()))
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
348 return traits_type::not_eof(c);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
349 else
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
350 return c;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
351 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
352
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
353 // Assign new buffer
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
354 std::streambuf*
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
355 gzfilebuf::setbuf(char_type* p,
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
356 std::streamsize n)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
357 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
358 // First make sure stuff is sync'ed, for safety
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
359 if (this->sync() == -1)
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
360 return 0;
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
361 // If buffering is turned off on purpose via setbuf(0,0), still allocate one...
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
362 // "Unbuffered" only really refers to put [27.8.1.4.10], while get needs at
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
363 // least a buffer of size 1 (very inefficient though, therefore make it bigger?)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
364 // This follows from [27.5.2.4.3]/12 (gptr needs to point at something, it seems)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
365 if (!p || !n)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
366 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
367 // Replace existing buffer (if any) with small internal buffer
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
368 this->disable_buffer();
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
369 buffer = 0;
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
370 buffer_size = 0;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
371 own_buffer = true;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
372 this->enable_buffer();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
373 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
374 else
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
375 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
376 // Replace existing buffer (if any) with external buffer
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
377 this->disable_buffer();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
378 buffer = p;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
379 buffer_size = n;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
380 own_buffer = false;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
381 this->enable_buffer();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
382 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
383 return this;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
384 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
385
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
386 // Write put area to gzipped file (i.e. ensures that put area is empty)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
387 int
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
388 gzfilebuf::sync()
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
389 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
390 return traits_type::eq_int_type(this->overflow(), traits_type::eof()) ? -1 : 0;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
391 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
392
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
393 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
394
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
395 // Allocate internal buffer
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
396 void
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
397 gzfilebuf::enable_buffer()
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
398 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
399 // If internal buffer required, allocate one
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
400 if (own_buffer && !buffer)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
401 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
402 // Check for buffered vs. "unbuffered"
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
403 if (buffer_size > 0)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
404 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
405 // Allocate internal buffer
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
406 buffer = new char_type[buffer_size];
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
407 // Get area starts empty and will be expanded by underflow as need arises
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
408 this->setg(buffer, buffer, buffer);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
409 // Setup entire internal buffer as put area.
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
410 // The one-past-end pointer actually points to the last element of the buffer,
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
411 // so that overflow(c) can safely add the extra character c to the sequence.
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
412 // These pointers remain in place for the duration of the buffer
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
413 this->setp(buffer, buffer + buffer_size - 1);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
414 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
415 else
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
416 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
417 // Even in "unbuffered" case, (small?) get buffer is still required
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
418 buffer_size = SMALLBUFSIZE;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
419 buffer = new char_type[buffer_size];
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
420 this->setg(buffer, buffer, buffer);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
421 // "Unbuffered" means no put buffer
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
422 this->setp(0, 0);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
423 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
424 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
425 else
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
426 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
427 // If buffer already allocated, reset buffer pointers just to make sure no
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
428 // stale chars are lying around
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
429 this->setg(buffer, buffer, buffer);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
430 this->setp(buffer, buffer + buffer_size - 1);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
431 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
432 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
433
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
434 // Destroy internal buffer
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
435 void
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
436 gzfilebuf::disable_buffer()
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
437 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
438 // If internal buffer exists, deallocate it
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
439 if (own_buffer && buffer)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
440 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
441 // Preserve unbuffered status by zeroing size
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
442 if (!this->pbase())
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
443 buffer_size = 0;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
444 delete[] buffer;
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
445 buffer = 0;
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
446 this->setg(0, 0, 0);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
447 this->setp(0, 0);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
448 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
449 else
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
450 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
451 // Reset buffer pointers to initial state if external buffer exists
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
452 this->setg(buffer, buffer, buffer);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
453 if (buffer)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
454 this->setp(buffer, buffer + buffer_size - 1);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
455 else
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
456 this->setp(0, 0);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
457 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
458 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
459
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
460 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
461
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
462 // Seek functions
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
463 gzfilebuf::pos_type
11586
12df7854fa7c strip trailing whitespace from source files
John W. Eaton <jwe@octave.org>
parents: 11523
diff changeset
464 gzfilebuf::seekoff(off_type off, std::ios_base::seekdir way,
10317
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
465 std::ios_base::openmode)
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
466 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
467 pos_type ret = pos_type (off_type (-1));
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
468
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
469 if (this->is_open())
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
470 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
471 off_type computed_off = off;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
472
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
473 if ((io_mode & std::ios_base::in) && way == std::ios_base::cur)
10317
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
474 computed_off += this->gptr() - this->egptr();
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
475
15510
c1c5b3cc2996 Avoid inefficient seeks in gzfilebuf (bug #37509)
Mike Miller <mtmiller@ieee.org>
parents: 14138
diff changeset
476 // Handle tellg/tellp as a special case up front, no need to seek
c1c5b3cc2996 Avoid inefficient seeks in gzfilebuf (bug #37509)
Mike Miller <mtmiller@ieee.org>
parents: 14138
diff changeset
477 // or invalidate get/put buffers
c1c5b3cc2996 Avoid inefficient seeks in gzfilebuf (bug #37509)
Mike Miller <mtmiller@ieee.org>
parents: 14138
diff changeset
478 if (off == 0 && way == std::ios_base::cur)
c1c5b3cc2996 Avoid inefficient seeks in gzfilebuf (bug #37509)
Mike Miller <mtmiller@ieee.org>
parents: 14138
diff changeset
479 return pos_type (gztell (file) + computed_off);
c1c5b3cc2996 Avoid inefficient seeks in gzfilebuf (bug #37509)
Mike Miller <mtmiller@ieee.org>
parents: 14138
diff changeset
480
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
481 if (way == std::ios_base::beg)
10317
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
482 ret = pos_type (gzseek (file, computed_off, SEEK_SET));
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
483 else if (way == std::ios_base::cur)
10317
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
484 ret = pos_type (gzseek (file, computed_off, SEEK_CUR));
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
485 else
10317
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
486 // Can't seek from end of a gzipped file, so this will give -1
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
487 ret = pos_type (gzseek (file, computed_off, SEEK_END));
11586
12df7854fa7c strip trailing whitespace from source files
John W. Eaton <jwe@octave.org>
parents: 11523
diff changeset
488
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
489 if (io_mode & std::ios_base::in)
10317
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
490 // Invalidates contents of the buffer
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
491 enable_buffer ();
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
492 else
10317
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
493 // flush contents of buffer to file
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
494 overflow ();
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
495 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
496
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
497 return ret;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
498 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
499
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
500 gzfilebuf::pos_type
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
501 gzfilebuf::seekpos(pos_type sp, std::ios_base::openmode)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
502 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
503 pos_type ret = pos_type (off_type (-1));
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
504
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
505 if (this->is_open ())
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
506 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
507 ret = pos_type (gzseek (file, sp, SEEK_SET));
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
508
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
509 if (io_mode & std::ios_base::in)
10317
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
510 // Invalidates contents of the buffer
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
511 enable_buffer ();
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
512 else
10317
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
513 // flush contents of buffer to file
42d098307c30 untabify additional source files
John W. Eaton <jwe@octave.org>
parents: 10160
diff changeset
514 overflow ();
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
515 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
516
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
517 return ret;
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
518 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
519
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
520 /*****************************************************************************/
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
521
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
522 // Default constructor initializes stream buffer
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
523 gzifstream::gzifstream()
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
524 : std::istream(0), sb()
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
525 { this->init(&sb); }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
526
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
527 // Initialize stream buffer and open file
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
528 gzifstream::gzifstream(const char* name,
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
529 std::ios_base::openmode mode)
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
530 : std::istream(0), sb()
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
531 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
532 this->init(&sb);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
533 this->open(name, mode);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
534 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
535
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
536 // Initialize stream buffer and attach to file
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
537 gzifstream::gzifstream(int fd,
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
538 std::ios_base::openmode mode)
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
539 : std::istream(0), sb()
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
540 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
541 this->init(&sb);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
542 this->attach(fd, mode);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
543 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
544
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
545 // Open file and go into fail() state if unsuccessful
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
546 void
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
547 gzifstream::open(const char* name,
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
548 std::ios_base::openmode mode)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
549 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
550 if (!sb.open(name, mode | std::ios_base::in))
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
551 this->setstate(std::ios_base::failbit);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
552 else
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
553 this->clear();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
554 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
555
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
556 // Attach to file and go into fail() state if unsuccessful
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
557 void
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
558 gzifstream::attach(int fd,
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
559 std::ios_base::openmode mode)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
560 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
561 if (!sb.attach(fd, mode | std::ios_base::in))
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
562 this->setstate(std::ios_base::failbit);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
563 else
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
564 this->clear();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
565 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
566
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
567 // Close file
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
568 void
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
569 gzifstream::close()
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
570 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
571 if (!sb.close())
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
572 this->setstate(std::ios_base::failbit);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
573 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
574
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
575 /*****************************************************************************/
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
576
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
577 // Default constructor initializes stream buffer
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
578 gzofstream::gzofstream()
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
579 : std::ostream(0), sb()
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
580 { this->init(&sb); }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
581
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
582 // Initialize stream buffer and open file
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
583 gzofstream::gzofstream(const char* name,
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
584 std::ios_base::openmode mode)
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
585 : std::ostream(0), sb()
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
586 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
587 this->init(&sb);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
588 this->open(name, mode);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
589 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
590
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
591 // Initialize stream buffer and attach to file
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
592 gzofstream::gzofstream(int fd,
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
593 std::ios_base::openmode mode)
7520
b166043585a8 use 0 instead of NULL
John W. Eaton <jwe@octave.org>
parents: 7017
diff changeset
594 : std::ostream(0), sb()
5269
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
595 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
596 this->init(&sb);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
597 this->attach(fd, mode);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
598 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
599
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
600 // Open file and go into fail() state if unsuccessful
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
601 void
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
602 gzofstream::open(const char* name,
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
603 std::ios_base::openmode mode)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
604 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
605 if (!sb.open(name, mode | std::ios_base::out))
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
606 this->setstate(std::ios_base::failbit);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
607 else
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
608 this->clear();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
609 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
610
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
611 // Attach to file and go into fail() state if unsuccessful
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
612 void
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
613 gzofstream::attach(int fd,
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
614 std::ios_base::openmode mode)
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
615 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
616 if (!sb.attach(fd, mode | std::ios_base::out))
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
617 this->setstate(std::ios_base::failbit);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
618 else
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
619 this->clear();
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
620 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
621
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
622 // Close file
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
623 void
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
624 gzofstream::close()
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
625 {
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
626 if (!sb.close())
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
627 this->setstate(std::ios_base::failbit);
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
628 }
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
629
a90ce2dc8b1e [project @ 2005-04-06 19:20:09 by dbateman]
dbateman
parents:
diff changeset
630 #endif // HAVE_ZLIB