Files
libreoffice/hwpfilter/source/hgzip.h
Caolán McNamara 74cc187749 ofz#820 oom terminate
comments claim return is len of data, but negative numbers for compressed data errors
are returned. Make things return the amount of successful data read and turn into
unsigned size_t to match ofz#727

Change-Id: Iadddfae67bb5d4960ddf82e169fc2592ded85950
Reviewed-on: https://gerrit.libreoffice.org/35077
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Caolán McNamara <caolanm@redhat.com>
Tested-by: Caolán McNamara <caolanm@redhat.com>
2017-04-04 11:39:12 +00:00

94 lines
2.6 KiB
C++

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
#ifndef INCLUDED_HWPFILTER_SOURCE_HGZIP_H
#define INCLUDED_HWPFILTER_SOURCE_HGZIP_H
#include <zlib.h>
class HStream;
/**
* @short Structure for using z_stream
*/
struct gz_stream
{
z_stream stream;
/**
* The error code of z_stream operation
*/
int z_err;
/**
* EOF of the input file
*/
int z_eof;
/**
* Stream
*/
HStream* _inputstream;
/**
* Input buffer
*/
Byte *inbuf;
/**
* Crc32 of uncompressed data
*/
uLong crc;
/**
* Stream
*/
char *msg;
/**
* 'w' or 'r'
*/
char mode;
};
/**
* Opens a gzipped stream for reading.
* gz_open returns NULL if the stream could not be opened or if there was
* insufficient memory to allocate the (de)compression state; errno
* can be checked to distinguish the two cases (if errno is zero, the
* zlib error is Z_MEM_ERROR).
* @param _stream Reference of stream object having binary data.
*/
gz_stream *gz_open ( HStream& _stream );
/**
* Flushes all pending output if necessary, closes the compressed stream
* and deallocates all the (de)compression state
*/
int gz_close ( gz_stream *file );
/**
* Reads the given number of uncompressed bytes from the compressed stream
* @param file Gzipped stream
* @param buf Buffer to have the data to be read
* @param len Length of data to be read
* @returns The number of bytes actually read
*/
size_t gz_read ( gz_stream *file, voidp buf, unsigned len );
/**
* Flushes all pending output into the compressed file
* gz_flush should be called only when strictly necessary because it can
* degrade compression
* @param flush Is as in the deflate() function
*/
int gz_flush ( gz_stream *file, int flush );
#endif // INCLUDED_HWPFILTER_SOURCE_HGZIP_H
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */