2023-05-27 04:12:16 +00:00
|
|
|
/*
|
|
|
|
* 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>
|
|
|
|
|
|
|
|
#ifdef __GNUC__
|
2024-04-06 06:20:56 +00:00
|
|
|
#define DEPRECATED __attribute__((deprecated))
|
|
|
|
#elif defined(_MSC_VER)
|
|
|
|
#define DEPRECATED __declspec(deprecated)
|
2023-05-27 04:12:16 +00:00
|
|
|
#else
|
2024-04-06 06:20:56 +00:00
|
|
|
#praga message("WARNING: You need to implement DEPRECATED for this compiler")
|
|
|
|
#define DEPRECATED
|
2023-05-27 04:12:16 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <zim/zim_config.h>
|
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
#if defined(_WIN32) && defined(LIBZIM_EXPORT_DLL)
|
|
|
|
#define LIBZIM_API __declspec(dllexport)
|
|
|
|
#elif defined(_WIN32) && 1
|
|
|
|
#define LIBZIM_API __declspec(dllimport)
|
2023-05-27 04:12:16 +00:00
|
|
|
#else
|
2024-04-06 06:20:56 +00:00
|
|
|
#define LIBZIM_API
|
2023-05-27 04:12:16 +00:00
|
|
|
#endif
|
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
namespace zim
|
|
|
|
{
|
|
|
|
// An index of an entry (in a zim file)
|
|
|
|
typedef uint32_t entry_index_type;
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
// An index of an cluster (in a zim file)
|
|
|
|
typedef uint32_t cluster_index_type;
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
// An index of a blog (in a cluster)
|
|
|
|
typedef uint32_t blob_index_type;
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
// The size of something (entry, zim, cluster, blob, ...)
|
|
|
|
typedef uint64_t size_type;
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
// An offset.
|
|
|
|
typedef uint64_t offset_type;
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
enum class Compression
|
|
|
|
{
|
|
|
|
None = 1,
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
// intermediate values correspond to compression
|
|
|
|
// methods that are no longer supported
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
Zstd = 5
|
|
|
|
};
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
static const char MimeHtmlTemplate[] = "text/x-zim-htmltemplate";
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* Various types of integrity checks performed by `zim::validate()`.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
enum class IntegrityCheck
|
|
|
|
{
|
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* Validates the checksum of the ZIM file.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
CHECKSUM,
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* Checks that offsets in UrlPtrList are valid.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
DIRENT_PTRS,
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* Checks that dirents are properly sorted.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
DIRENT_ORDER,
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* Checks that entries in the title index are valid and properly sorted.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
TITLE_INDEX,
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* Checks that offsets in ClusterPtrList are valid.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
CLUSTER_PTRS,
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* Checks that mime-type values in dirents are valid.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
DIRENT_MIMETYPES,
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
////////////////////////////////////////////////////////////////////////////
|
|
|
|
// End of integrity check types.
|
|
|
|
// COUNT must be the last one and denotes the count of all checks
|
|
|
|
////////////////////////////////////////////////////////////////////////////
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* `COUNT` is not a valid integrity check type. It exists to tell the
|
|
|
|
* number of all supported integrity checks.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
COUNT
|
|
|
|
};
|
|
|
|
}
|
2023-05-27 04:12:16 +00:00
|
|
|
|
|
|
|
#endif // ZIM_ZIM_H
|
2024-04-06 06:20:56 +00:00
|
|
|
|