2023-05-27 04:12:16 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2021 Veloman Yunkan
|
|
|
|
* Copyright (C) 2020 Matthieu Gautier <mgautier@kymeria.fr>
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License as
|
|
|
|
* published by the Free Software Foundation; either version 2 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
* is provided AS IS, WITHOUT ANY WARRANTY; without even the implied
|
|
|
|
* warranty of MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, and
|
|
|
|
* NON-INFRINGEMENT. See the GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ZIM_ITEM_H
|
|
|
|
#define ZIM_ITEM_H
|
|
|
|
|
|
|
|
#include "zim.h"
|
|
|
|
#include "blob.h"
|
2024-04-06 06:20:56 +00:00
|
|
|
#include "entry.h"
|
2023-05-27 04:12:16 +00:00
|
|
|
#include <string>
|
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
namespace zim
|
|
|
|
{
|
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* An `Item` in an `Archive`
|
|
|
|
*
|
2024-04-06 06:20:56 +00:00
|
|
|
* There is no public constructor - the only way to obtain an `Item`
|
|
|
|
* is via `Entry::getItem()` or `Entry::getRedirect()`.
|
|
|
|
*
|
2023-05-27 04:12:16 +00:00
|
|
|
* All `Item`'s methods are threadsafe.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
class LIBZIM_API Item : private Entry
|
|
|
|
{
|
|
|
|
public: // types
|
|
|
|
typedef std::pair<std::string, offset_type> DirectAccessInfo;
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
public: // functions
|
|
|
|
std::string getTitle() const { return Entry::getTitle(); }
|
|
|
|
std::string getPath() const { return Entry::getPath(); }
|
|
|
|
std::string getMimetype() const;
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
/** Get the data associated to the item
|
2023-05-27 04:12:16 +00:00
|
|
|
*
|
|
|
|
* Get the data of the item, starting at offset.
|
|
|
|
*
|
|
|
|
* @param offset The number of byte to skip at begining of the data.
|
|
|
|
* @return A blob corresponding to the data.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
Blob getData(offset_type offset=0) const;
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
/** Get the data associated to the item
|
2023-05-27 04:12:16 +00:00
|
|
|
*
|
|
|
|
* Get the `size` bytes of data of the item, starting at offset.
|
|
|
|
*
|
|
|
|
* @param offset The number of byte to skip at begining of the data.
|
|
|
|
* @param size The number of byte to read.
|
|
|
|
* @return A blob corresponding to the data.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
Blob getData(offset_type offset, size_type size) const;
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
/** The size of the item.
|
2023-05-27 04:12:16 +00:00
|
|
|
*
|
|
|
|
* @return The size (in byte) of the item.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
size_type getSize() const;
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
/** Direct access information.
|
2023-05-27 04:12:16 +00:00
|
|
|
*
|
|
|
|
* Some item are stored raw in the zim file.
|
|
|
|
* If possible, this function give information about which file
|
|
|
|
* and at which to read to get the data.
|
|
|
|
*
|
|
|
|
* It can be usefull as an optimisation when interacting with other system
|
|
|
|
* by reopeing the file and reading the content bypassing the libzim.
|
|
|
|
*
|
|
|
|
* @return A pair of filename/offset specifying where read the content.
|
|
|
|
* If it is not possible to have direct access for this item,
|
|
|
|
* return a pair of `{"", 0}`
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
DirectAccessInfo getDirectAccessInformation() const;
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
entry_index_type getIndex() const { return Entry::getIndex(); }
|
2023-05-27 04:12:16 +00:00
|
|
|
|
|
|
|
#ifdef ZIM_PRIVATE
|
2024-04-06 06:20:56 +00:00
|
|
|
cluster_index_type getClusterIndex() const;
|
2023-05-27 04:12:16 +00:00
|
|
|
#endif
|
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
private: // functions
|
|
|
|
explicit Item(const Entry& entry);
|
|
|
|
friend class Entry;
|
|
|
|
};
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
}
|
2023-05-27 04:12:16 +00:00
|
|
|
|
|
|
|
#endif // ZIM_ITEM_H
|
2024-04-06 06:20:56 +00:00
|
|
|
|