zipios 2.3.4
Zipios -- a small C++ library providing easy access to .zip files.
zipinputstreambuf.cpp
Go to the documentation of this file.
1/*
2 Zipios -- a small C++ library that provides easy access to .zip files.
3
4 Copyright (C) 2000-2007 Thomas Sondergaard
5 Copyright (c) 2015-2022 Made to Order Software Corp. All Rights Reserved
6
7 This library is free software; you can redistribute it and/or
8 modify it under the terms of the GNU Lesser General Public
9 License as published by the Free Software Foundation; either
10 version 2.1 of the License, or (at your option) any later version.
11
12 This library is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 Lesser General Public License for more details.
16
17 You should have received a copy of the GNU Lesser General Public
18 License along with this library; if not, write to the Free Software
19 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20*/
21
28#include "zipinputstreambuf.hpp"
29
31
32#include <algorithm>
33
34
35namespace zipios
36{
37
38
57ZipInputStreambuf::ZipInputStreambuf(std::streambuf * inbuf, offset_t start_pos)
58 : InflateInputStreambuf(inbuf, start_pos)
59{
60 // read the zip local header
61 std::istream is(m_inbuf); // istream does not destroy the streambuf.
62 is.exceptions(std::ios::eofbit | std::ios::failbit | std::ios::badbit);
63
64 // if the read fails in any way it will throw
67 {
68 throw FileCollectionException("Trailing data descriptor in zip file not supported");
69 }
70
72 {
74 reset() ; // reset inflatestream data structures
75//std::cerr << "deflated" << std::endl;
76 break;
77
80 // Force underflow on first read:
81 setg(&m_outvec[0], &m_outvec[0] + getBufferSize(), &m_outvec[0] + getBufferSize());
82//std::cerr << "stored" << std::endl;
83 break;
84
85 default:
86 // file not supported... sorry!
87 throw FileCollectionException("Unsupported compression format");
88
89 }
90}
91
92
111
112
122std::streambuf::int_type ZipInputStreambuf::underflow()
123{
124 switch(m_current_entry.getMethod())
125 {
127 // inflate class takes care of it in this case
129
131 {
132 // Ok, we are STORED, so we handle it ourselves.
133 offset_t const num_b(std::min(m_remain, static_cast<offset_t>(getBufferSize())));
134 std::streamsize const g(m_inbuf->sgetn(&m_outvec[0], num_b));
135 setg(&m_outvec[0], &m_outvec[0], &m_outvec[0] + g);
136 m_remain -= g;
137 if(g > 0)
138 {
139 // we got some data, return it
140 return traits_type::to_int_type(*gptr());
141 }
142
143 // documentation says to return EOF if no data available
144 return traits_type::eof();
145 }
146
147 default: // LCOV_EXCL_LINE
148 // This should NEVER be reached or the constructor let something
149 // go through that should not have gone through
150 throw std::logic_error("ZipInputStreambuf::underflow(): unknown storage method"); // LCOV_EXCL_LINE
151
152 }
153}
154
155
156} // namespace
157
158// Local Variables:
159// mode: cpp
160// indent-tabs-mode: nil
161// c-basic-offset: 4
162// tab-width: 4
163// End:
164
165// vim: ts=4 sw=4 et
FileCollectionException is used to signal a FileCollection problem.
virtual std::size_t getSize() const
Retrieve the size of the file when uncompressed.
virtual bool isValid() const
Check whether this entry is valid.
virtual StorageMethod getMethod() const
Return the method used to create this entry.
A stream buffer to inflate data previous compressed with zlib.
virtual std::streambuf::int_type underflow() override
Called when more data is required.
bool reset(offset_t stream_position=-1)
Initializes the stream buffer.
virtual ~ZipInputStreambuf() override
Clean up a ZipInputStreambuf object.
virtual std::streambuf::int_type underflow() override
Called when more data is required.
ZipInputStreambuf(std::streambuf *inbuf, offset_t start_pos=-1)
Initialize a ZipInputStreambuf.
virtual void read(std::istream &is) override
Read one local entry from is.
bool hasTrailingDataDescriptor() const
Is there a trailing data descriptor?
The zipios namespace includes the Zipios library definitions.
std::streamoff offset_t
size_t getBufferSize()
Define the zipios::ZipInputStreambuf class.
Various exceptions used throughout the Zipios library, all based on zipios::Exception.