libreoffice-online/loolwsd/TileCache.hpp

94 lines
3.4 KiB
C++
Raw Normal View History

2015-03-12 09:18:35 -05:00
/* -*- 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/.
*/
#ifndef INCLUDED_TILECACHE_HPP
#define INCLUDED_TILECACHE_HPP
#include <fstream>
#include <memory>
#include <set>
#include <string>
2015-03-12 09:18:35 -05:00
#include <Poco/File.h>
2015-03-12 18:34:42 -05:00
#include <Poco/Timestamp.h>
/** Handles the cache for tiles of one document.
The cache consists of 2 cache directories:
* persistent - that always represents the document as is saved
* editing - that represents the document in the current state (with edits)
The editing cache is cleared on startup, and copied to the persistent on each save.
*/
2015-03-12 18:34:42 -05:00
class TileCache
2015-03-12 09:18:35 -05:00
{
2015-03-12 18:34:42 -05:00
public:
/// When the docURL is a non-file:// url, the timestamp has to be provided by the caller.
/// For file:// url's, it's ignored.
/// When it is missing for non-file:// url, it is assumed the document must be read, and no cached value used.
TileCache(const std::string& docURL, const std::string& timestamp);
2015-03-12 18:34:42 -05:00
std::unique_ptr<std::fstream> lookupTile(int part, int width, int height, int tilePosX, int tilePosY, int tileWidth, int tileHeight);
void saveTile(int part, int width, int height, int tilePosX, int tilePosY, int tileWidth, int tileHeight, const char *data, size_t size);
2015-03-13 07:17:51 -05:00
std::string getStatus();
/// Notify the cache that the document was saved - to copy tiles from the Editing cache to Persistent.
void documentSaved();
/// Notify whether we need to use the Editing cache.
void setEditing(bool editing = true);
// The parameter is a status: message
2015-03-13 07:17:51 -05:00
void saveStatus(const std::string& status);
2015-03-12 18:34:42 -05:00
// The tiles parameter is an invalidatetiles: message as sent by the child process
void invalidateTiles(const std::string& tiles);
void invalidateTiles(int part, int x, int y, int width, int height);
2015-03-12 18:34:42 -05:00
private:
/// Toplevel cache dirname.
std::string toplevelCacheDirName();
/// Path of the (sub-)cache dir, the parameter specifies which (sub-)cache to use.
std::string cacheDirName(bool useEditingCache);
std::string cacheFileName(int part, int width, int height, int tilePosX, int tilePosY, int tileWidth, int tileHeight);
bool parseCacheFileName(std::string& fileName, int& part, int& width, int& height, int& tilePosX, int& tilePosY, int& tileWidth, int& tileHeight);
/// Extract location from fileName, and check if it intersects with [x, y, width, height].
bool intersectsTile(std::string& fileName, int part, int x, int y, int width, int height);
/// Load the timestamp from modtime.txt.
2015-03-12 18:34:42 -05:00
Poco::Timestamp getLastModified();
/// Store the timestamp to modtime.txt.
void saveLastModified(const Poco::Timestamp& timestamp);
/// Create or cleanup the cache directory.
/// For non-file:// protocols, the timestamp has to be provided externally.
void setup(const std::string& timestamp);
2015-03-12 18:34:42 -05:00
const std::string& _docURL;
/// The document is being edited.
bool _isEditing;
/// We have some unsaved changes => use the Editing cache.
bool _hasUnsavedChanges;
/// Set of tiles that we want to remove from the Persistent cache on the next save.
std::set<std::string> _toBeRemoved;
2015-03-12 09:18:35 -05:00
};
#endif
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */