X-Git-Url: https://git.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fspl.h;h=d7c746d1e39d1121bdbfdd3886682d4d05aa7d1e;hp=18892993fcb1575cd8695339fa10ce03a0e1c7b7;hb=bf471e4e6d2502bb3b4e2eb4b1309d87e1003070;hpb=25b1934f24206b6dda5ce5a7686930d605ff6ccc diff --git a/src/lib/spl.h b/src/lib/spl.h index 18892993f..d7c746d1e 100644 --- a/src/lib/spl.h +++ b/src/lib/spl.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2018 Carl Hetherington + Copyright (C) 2018-2020 Carl Hetherington This file is part of DCP-o-matic. @@ -18,14 +18,20 @@ */ + #ifndef DCPOMATIC_SPL_H #define DCPOMATIC_SPL_H + #include "spl_entry.h" #include +#include +#include + class ContentStore; + class SPL { public: @@ -34,6 +40,13 @@ public: , _missing (false) {} + SPL (std::string name) + : _id (dcp::make_uuid()) + , _name (name) + , _missing (false) + {} + + void add (SPLEntry e) { _spl.push_back (e); } @@ -52,6 +65,8 @@ public: SPLEntry const & operator[] (std::size_t index) const { return _spl[index]; + void swap(size_t a, size_t b) { + std::iter_swap(_spl.begin() + a, _spl.begin() + b); } void read (boost::filesystem::path path, ContentStore* store); @@ -61,52 +76,47 @@ public: return _id; } - boost::optional path () const { - return _path; + std::string name () const { + return _name; } - std::string name () const { - if (!_path) { - return ""; - } - return _path->filename().string(); + void set_name (std::string name) { + _name = name; } bool missing () const { return _missing; } - boost::optional allowed_shows () const { - return _allowed_shows; - } +private: + std::string _id; + std::string _name; + std::vector _spl; + /** true if any content was missing when read() was last called on this SPL */ + bool _missing; +}; - bool have_allowed_shows () const { - return !_allowed_shows || *_allowed_shows > 0; - } - void set_allowed_shows (int s) { - _allowed_shows = s; - } +class SignalSPL : public SPL +{ +public: + enum class Change { + NAME, + CONTENT, + }; - void unset_allowed_shows () { - _allowed_shows = boost::optional(); - } + SignalSPL () {} - void decrement_allowed_shows () { - if (_allowed_shows) { - (*_allowed_shows)--; - } + SignalSPL (std::string name) + : SPL (name) + {} + void set_name (std::string name) { + SPL::set_name (name); + Changed(Change::NAME); } -private: - std::string _id; - mutable boost::optional _path; - std::vector _spl; - /** true if any content was missing when read() was last called on this SPL */ - bool _missing; - /** number of times left that the player will allow this playlist to be played (unset means infinite shows) */ - boost::optional _allowed_shows; + boost::signals2::signal Changed; }; #endif