2023-05-27 04:12:16 +00:00
|
|
|
/*
|
|
|
|
* 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_WRITER_CONTENTPROVIDER_H
|
|
|
|
#define ZIM_WRITER_CONTENTPROVIDER_H
|
|
|
|
|
|
|
|
#include <stdexcept>
|
|
|
|
#include <zim/blob.h>
|
|
|
|
#include <zim/zim.h>
|
|
|
|
#include <string>
|
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
namespace zim
|
|
|
|
{
|
2023-05-27 04:12:16 +00:00
|
|
|
#ifdef _WIN32
|
|
|
|
#define DEFAULTFD zim::windows::FD
|
2024-04-06 06:20:56 +00:00
|
|
|
namespace windows {
|
2023-05-27 04:12:16 +00:00
|
|
|
#else
|
|
|
|
#define DEFAULTFD zim::unix::FD
|
2024-04-06 06:20:56 +00:00
|
|
|
namespace unix {
|
2023-05-27 04:12:16 +00:00
|
|
|
#endif
|
2024-04-06 06:20:56 +00:00
|
|
|
class FD;
|
|
|
|
}
|
|
|
|
namespace writer
|
|
|
|
{
|
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* `ContentProvider` is an abstract class in charge of providing the content to
|
|
|
|
* add in the archive to the creator.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
class LIBZIM_API ContentProvider {
|
|
|
|
public:
|
|
|
|
virtual ~ContentProvider() = default;
|
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* The size of the content to add into the archive.
|
|
|
|
*
|
|
|
|
* @return the total size of the content.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
virtual zim::size_type getSize() const = 0;
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* Return a blob to add to the archive.
|
|
|
|
*
|
|
|
|
* The returned blob doesn't have to represent the whole content.
|
|
|
|
* The feed method can return the whole content chunk by chunk or in
|
|
|
|
* one step.
|
|
|
|
* When the whole content has been returned, feed must return an empty blob
|
|
|
|
* (size == 0).
|
|
|
|
*
|
|
|
|
* This method will be called several times (at least twice) for
|
|
|
|
* each content to add.
|
|
|
|
*
|
|
|
|
* It is up to the implementation to manage correctly the data pointed by
|
|
|
|
* the returned blob.
|
|
|
|
* It may (re)use the same buffer between calls (rewriting its content),
|
|
|
|
* create a new buffer each time or make the blob point to a new region of
|
|
|
|
* a big buffer.
|
|
|
|
* It is up to the implementation to free any allocated memory.
|
|
|
|
*
|
|
|
|
* The data pointed by the blob must stay valid until the next call to feed.
|
|
|
|
* A call to feed ensure that the data returned by a previous call will not
|
|
|
|
* be used anymore.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
virtual Blob feed() = 0;
|
|
|
|
};
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* StringProvider provide the content stored in a string.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
class LIBZIM_API StringProvider : public ContentProvider {
|
|
|
|
public:
|
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* Create a provider using a string as content.
|
|
|
|
* The string content is copied and the reference don't have to be "keep" alive.
|
|
|
|
*
|
|
|
|
* @param content the content to serve.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
explicit StringProvider(const std::string& content)
|
|
|
|
: content(content),
|
|
|
|
feeded(false)
|
|
|
|
{}
|
|
|
|
zim::size_type getSize() const { return content.size(); }
|
|
|
|
Blob feed();
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
protected:
|
|
|
|
std::string content;
|
|
|
|
bool feeded;
|
|
|
|
};
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* SharedStringProvider provide the content stored in a shared string.
|
|
|
|
*
|
|
|
|
* It is mostly the same thing that `StringProvider` but use a shared_ptr
|
|
|
|
* to avoid copy.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
class LIBZIM_API SharedStringProvider : public ContentProvider {
|
|
|
|
public:
|
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* Create a provider using a string as content.
|
|
|
|
* The string content is not copied.
|
|
|
|
*
|
|
|
|
* @param content the content to serve.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
explicit SharedStringProvider(std::shared_ptr<const std::string> content)
|
|
|
|
: content(content),
|
|
|
|
feeded(false)
|
|
|
|
{}
|
|
|
|
zim::size_type getSize() const { return content->size(); }
|
|
|
|
Blob feed();
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
protected:
|
|
|
|
std::shared_ptr<const std::string> content;
|
|
|
|
bool feeded;
|
|
|
|
};
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* FileProvider provide the content stored in file.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
class LIBZIM_API FileProvider : public ContentProvider {
|
|
|
|
public:
|
|
|
|
/**
|
2023-05-27 04:12:16 +00:00
|
|
|
* Create a provider using file as content.
|
|
|
|
*
|
|
|
|
* @param filepath the path to the file to serve.
|
|
|
|
*/
|
2024-04-06 06:20:56 +00:00
|
|
|
explicit FileProvider(const std::string& filepath);
|
|
|
|
~FileProvider();
|
|
|
|
zim::size_type getSize() const { return size; }
|
|
|
|
Blob feed();
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
protected:
|
|
|
|
std::string filepath;
|
|
|
|
zim::size_type size;
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
private:
|
|
|
|
std::unique_ptr<char[]> buffer;
|
|
|
|
std::unique_ptr<DEFAULTFD> fd;
|
|
|
|
zim::offset_type offset;
|
|
|
|
};
|
2023-05-27 04:12:16 +00:00
|
|
|
|
2024-04-06 06:20:56 +00:00
|
|
|
}
|
|
|
|
}
|
2023-05-27 04:12:16 +00:00
|
|
|
|
|
|
|
#undef DEFAULTFD
|
|
|
|
|
|
|
|
#endif // ZIM_WRITER_CONTENTPROVIDER_H
|