2010-05-21 03:13:36 +02:00
|
|
|
// Copyright (c) 2010, Amar Takhar <verm@aegisub.org>
|
|
|
|
//
|
|
|
|
// Permission to use, copy, modify, and distribute this software for any
|
|
|
|
// purpose with or without fee is hereby granted, provided that the above
|
|
|
|
// copyright notice and this permission notice appear in all copies.
|
|
|
|
//
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
|
|
// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
|
|
// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
|
|
// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
|
|
// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
|
|
// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
|
|
// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
|
|
|
|
/// @file mru.h
|
|
|
|
/// @brief Public interface for MRU (Most Recently Used) lists.
|
|
|
|
/// @ingroup libaegisub
|
|
|
|
|
2013-01-04 16:01:50 +01:00
|
|
|
#include <boost/filesystem/path.hpp>
|
2011-10-28 22:15:10 +02:00
|
|
|
#include <deque>
|
2011-07-26 21:51:56 +02:00
|
|
|
#include <list>
|
2010-05-21 03:13:36 +02:00
|
|
|
#include <map>
|
|
|
|
|
|
|
|
#include <libaegisub/exception.h>
|
2013-01-04 16:01:50 +01:00
|
|
|
#include <libaegisub/fs_fwd.h>
|
2010-05-21 03:13:36 +02:00
|
|
|
|
2010-06-11 04:25:07 +02:00
|
|
|
namespace json {
|
2011-10-18 00:00:38 +02:00
|
|
|
class UnknownElement;
|
|
|
|
typedef std::deque<UnknownElement> Array;
|
2010-06-11 04:25:07 +02:00
|
|
|
}
|
|
|
|
|
2012-10-11 18:19:16 +02:00
|
|
|
namespace agi {
|
|
|
|
class Options;
|
|
|
|
}
|
|
|
|
|
2010-05-21 03:13:36 +02:00
|
|
|
namespace agi {
|
|
|
|
|
|
|
|
DEFINE_BASE_EXCEPTION_NOINNER(MRUError,Exception)
|
|
|
|
DEFINE_SIMPLE_EXCEPTION_NOINNER(MRUErrorInvalidKey, MRUError, "mru/invalid")
|
|
|
|
DEFINE_SIMPLE_EXCEPTION_NOINNER(MRUErrorIndexOutOfRange, MRUError, "mru/invalid")
|
|
|
|
|
|
|
|
/// @class MRUManager
|
|
|
|
/// @brief Most Recently Used (MRU) list handling
|
|
|
|
///
|
|
|
|
/// Add() should be called anytime a file is opened, this will either add the
|
|
|
|
/// entry or update it if it already exists.
|
|
|
|
///
|
|
|
|
/// If a file fails to open, Remove() should be called.
|
|
|
|
///
|
|
|
|
class MRUManager {
|
|
|
|
public:
|
|
|
|
/// @brief Map for time->value pairs.
|
2013-01-04 16:01:50 +01:00
|
|
|
typedef std::list<agi::fs::path> MRUListMap;
|
2010-05-21 03:13:36 +02:00
|
|
|
|
|
|
|
/// @brief Constructor
|
|
|
|
/// @param config File to load MRU values from
|
2013-01-04 16:01:50 +01:00
|
|
|
MRUManager(agi::fs::path const& config, std::string const& default_config, agi::Options *options = 0);
|
2010-05-21 03:13:36 +02:00
|
|
|
|
|
|
|
/// Destructor
|
|
|
|
~MRUManager();
|
|
|
|
|
|
|
|
/// @brief Add entry to the list.
|
|
|
|
/// @param key List name
|
|
|
|
/// @param entry Entry to add
|
|
|
|
/// @exception MRUErrorInvalidKey thrown when an invalid key is used.
|
2013-01-04 16:01:50 +01:00
|
|
|
void Add(std::string const& key, agi::fs::path const& entry);
|
2010-05-21 03:13:36 +02:00
|
|
|
|
|
|
|
/// @brief Remove entry from the list.
|
|
|
|
/// @param key List name
|
|
|
|
/// @param entry Entry to add
|
|
|
|
/// @exception MRUErrorInvalidKey thrown when an invalid key is used.
|
2013-01-04 16:01:50 +01:00
|
|
|
void Remove(std::string const& key, agi::fs::path const& entry);
|
2010-05-21 03:13:36 +02:00
|
|
|
|
|
|
|
/// @brief Return list
|
|
|
|
/// @param key List name
|
|
|
|
/// @exception MRUErrorInvalidKey thrown when an invalid key is used.
|
2012-10-11 18:19:16 +02:00
|
|
|
const MRUListMap* Get(std::string const& key);
|
2010-05-21 03:13:36 +02:00
|
|
|
|
|
|
|
/// @brief Return A single entry in a list.
|
|
|
|
/// @param key List name
|
|
|
|
/// @param entry 0-base position of entry
|
|
|
|
/// @exception MRUErrorInvalidKey thrown when an invalid key is used.
|
2013-01-04 16:01:50 +01:00
|
|
|
agi::fs::path const& GetEntry(std::string const& key, const size_t entry);
|
2010-05-21 03:13:36 +02:00
|
|
|
|
|
|
|
/// Write MRU lists to disk.
|
|
|
|
void Flush();
|
|
|
|
|
|
|
|
private:
|
|
|
|
/// Internal name of the config file, set during object construction.
|
2013-01-04 16:01:50 +01:00
|
|
|
const agi::fs::path config_name;
|
2010-05-21 03:13:36 +02:00
|
|
|
|
2012-10-11 18:19:16 +02:00
|
|
|
/// User preferences object for maximum number of items to list
|
|
|
|
agi::Options *const options;
|
|
|
|
|
2010-05-21 03:13:36 +02:00
|
|
|
/// @brief Map for MRUListMap values.
|
|
|
|
/// @param std::string Name
|
|
|
|
/// @param MRUListMap instance.
|
2011-07-26 21:51:56 +02:00
|
|
|
typedef std::map<std::string, MRUListMap> MRUMap;
|
2010-05-21 03:13:36 +02:00
|
|
|
|
|
|
|
/// Internal MRUMap values.
|
|
|
|
MRUMap mru;
|
|
|
|
|
2012-10-11 18:19:16 +02:00
|
|
|
/// Map from MRU name to option name
|
|
|
|
std::map<const std::string, std::string> option_names;
|
|
|
|
|
|
|
|
void Load(std::string const& key, ::json::Array const& array);
|
|
|
|
void Prune(std::string const& key, MRUListMap& map) const;
|
2011-07-26 21:51:56 +02:00
|
|
|
MRUListMap &Find(std::string const& key);
|
2010-05-21 03:13:36 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace agi
|