1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #include <package/Inflater.hxx>
24 using namespace com::sun::star::uno
;
25 using namespace ZipUtils
;
27 /** Provides general purpose decompression using the ZLIB library */
29 Inflater::Inflater(bool bNoWrap
)
36 pStream
.reset(new z_stream
);
37 /* memset to 0 to set zalloc/opaque etc */
38 memset (pStream
.get(), 0, sizeof(*pStream
));
40 nRes
= inflateInit2(pStream
.get(), bNoWrap
? -MAX_WBITS
: MAX_WBITS
);
61 void Inflater::setInput( const Sequence
< sal_Int8
>& rBuffer
)
65 nLength
= rBuffer
.getLength();
69 sal_Int32
Inflater::doInflateSegment( Sequence
< sal_Int8
>& rBuffer
, sal_Int32 nNewOffset
, sal_Int32 nNewLength
)
71 if (nNewOffset
< 0 || nNewLength
< 0 || nNewOffset
+ nNewLength
> rBuffer
.getLength())
75 return doInflateBytes(rBuffer
, nNewOffset
, nNewLength
);
83 inflateEnd(pStream
.get());
85 z_inflateEnd(pStream
.get());
91 sal_Int32
Inflater::doInflateBytes (Sequence
< sal_Int8
> &rBuffer
, sal_Int32 nNewOffset
, sal_Int32 nNewLength
)
95 nLastInflateError
= Z_STREAM_ERROR
;
99 nLastInflateError
= 0;
101 pStream
->next_in
= reinterpret_cast<const unsigned char*>( sInBuffer
.getConstArray() + nOffset
);
102 pStream
->avail_in
= nLength
;
103 pStream
->next_out
= reinterpret_cast < unsigned char* > ( rBuffer
.getArray() + nNewOffset
);
104 pStream
->avail_out
= nNewLength
;
106 #if !defined Z_PREFIX
107 sal_Int32 nResult
= ::inflate(pStream
.get(), Z_PARTIAL_FLUSH
);
109 sal_Int32 nResult
= ::z_inflate(pStream
.get(), Z_PARTIAL_FLUSH
);
118 nOffset
+= nLength
- pStream
->avail_in
;
119 nLength
= pStream
->avail_in
;
120 return nNewLength
- pStream
->avail_out
;
124 nOffset
+= nLength
- pStream
->avail_in
;
125 nLength
= pStream
->avail_in
;
129 // it is no error, if there is no input or no output
130 if ( nLength
&& nNewLength
)
131 nLastInflateError
= nResult
;
137 InflaterBytes::InflaterBytes(bool bNoWrap
)
143 pStream
.reset(new z_stream
);
144 /* memset to 0 to set zalloc/opaque etc */
145 memset (pStream
.get(), 0, sizeof(*pStream
));
147 nRes
= inflateInit2(pStream
.get(), bNoWrap
? -MAX_WBITS
: MAX_WBITS
);
163 InflaterBytes::~InflaterBytes()
168 void InflaterBytes::setInput( const sal_Int8
* rBuffer
, sal_Int32 nBufLen
)
176 sal_Int32
InflaterBytes::doInflateSegment( sal_Int8
* pOutBuffer
, sal_Int32 nBufLen
, sal_Int32 nNewOffset
, sal_Int32 nNewLength
)
178 if (nNewOffset
< 0 || nNewLength
< 0 || nNewOffset
+ nNewLength
> nBufLen
)
182 return doInflateBytes(pOutBuffer
, nNewOffset
, nNewLength
);
185 void InflaterBytes::end( )
189 #if !defined Z_PREFIX
190 inflateEnd(pStream
.get());
192 z_inflateEnd(pStream
.get());
198 sal_Int32
InflaterBytes::doInflateBytes (sal_Int8
* pOutBuffer
, sal_Int32 nNewOffset
, sal_Int32 nNewLength
)
205 pStream
->next_in
= reinterpret_cast<const unsigned char*>( sInBuffer
+ nOffset
);
206 pStream
->avail_in
= nLength
;
207 pStream
->next_out
= reinterpret_cast < unsigned char* > ( pOutBuffer
+ nNewOffset
);
208 pStream
->avail_out
= nNewLength
;
210 #if !defined Z_PREFIX
211 sal_Int32 nResult
= ::inflate(pStream
.get(), Z_PARTIAL_FLUSH
);
213 sal_Int32 nResult
= ::z_inflate(pStream
.get(), Z_PARTIAL_FLUSH
);
222 nOffset
+= nLength
- pStream
->avail_in
;
223 nLength
= pStream
->avail_in
;
224 return nNewLength
- pStream
->avail_out
;
227 nOffset
+= nLength
- pStream
->avail_in
;
228 nLength
= pStream
->avail_in
;
232 // it is no error, if there is no input or no output
239 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */