Program Listing for File zim.h¶
↰ Return to documentation for file (include/zim/zim.h)
/*
* Copyright (C) 2020-2021 Veloman Yunkan
* Copyright (C) 2018-2020 Matthieu Gautier <mgautier@kymeria.fr>
* Copyright (C) 2006 Tommi Maekitalo
*
* 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_ZIM_H
#define ZIM_ZIM_H
#include <cstdint>
#include <string>
#ifdef __GNUC__
#define DEPRECATED __attribute__((deprecated))
#elif defined(_MSC_VER)
#define DEPRECATED __declspec(deprecated)
#else
#pragma message("WARNING: You need to implement DEPRECATED for this compiler")
#define DEPRECATED
#endif
#include <zim/zim_config.h>
#if defined(_MSC_VER) && defined(LIBZIM_EXPORT_DLL)
#define LIBZIM_API __declspec(dllexport)
#else
#define LIBZIM_API
#endif
namespace zim
{
// An index of an entry (in a zim file)
typedef uint32_t entry_index_type;
// An index of an cluster (in a zim file)
typedef uint32_t cluster_index_type;
// An index of a blog (in a cluster)
typedef uint32_t blob_index_type;
// The size of something (entry, zim, cluster, blob, ...)
typedef uint64_t size_type;
// An offset.
typedef uint64_t offset_type;
struct LIBZIM_API OpenConfig {
OpenConfig();
OpenConfig& preloadXapianDb(bool load) {
m_preloadXapianDb = load;
return *this;
}
OpenConfig preloadXapianDb(bool load) const {
return OpenConfig(*this).preloadXapianDb(load);
}
OpenConfig& preloadDirentRanges(int nbRanges) {
m_preloadDirentRanges = nbRanges;
return *this;
}
OpenConfig preloadDirentRanges(int nbRanges) const {
return OpenConfig(*this).preloadDirentRanges(nbRanges);
}
bool m_preloadXapianDb;
int m_preloadDirentRanges;
};
struct FdInput {
// An open file descriptor
int fd;
// The (absolute) offset of the data "pointed" by FdInput in fd.
offset_type offset;
// The size (length) of the data "pointed" by FdInput
size_type size;
FdInput(int fd, offset_type offset, size_type size):
fd(fd), offset(offset), size(size) {}
};
enum class Compression
{
None = 1,
// intermediate values correspond to compression
// methods that are no longer supported
Zstd = 5
};
static const char MimeHtmlTemplate[] = "text/x-zim-htmltemplate";
enum class IntegrityCheck
{
CHECKSUM,
DIRENT_PTRS,
DIRENT_ORDER,
TITLE_INDEX,
CLUSTER_PTRS,
CLUSTERS_OFFSETS,
DIRENT_MIMETYPES,
// End of integrity check types.
// COUNT must be the last one and denotes the count of all checks
COUNT
};
struct ItemDataDirectAccessInfo {
std::string filename;
offset_type offset;
explicit ItemDataDirectAccessInfo()
: filename(),
offset()
{}
ItemDataDirectAccessInfo(const std::string& filename, offset_type offset)
: filename(filename),
offset(offset)
{}
bool isValid() const {
return !filename.empty();
}
};
}
#endif // ZIM_ZIM_H