#ifndef _movie__hpp__included__ #define _movie__hpp__included__ #include #include #include #include "core/controllerframe.hpp" #include "core/moviefile.hpp" #include "library/rrdata.hpp" #include "library/movie.hpp" /** * Class encapsulating bridge logic between core interface and movie code. */ class movie_logic { public: /** * Create new bridge. */ movie_logic() throw(); /** * Has movie? */ operator bool() throw() { return mov; } bool operator!() throw() { return !mov; } /** * Get the movie instance associated. * * returns: The movie instance. */ movie& get_movie() throw(std::runtime_error); /** * Set the movie instance associated. */ void set_movie(movie& _mov, bool free_old = false) throw(); /** * Get the current movie file. */ moviefile& get_mfile() throw(std::runtime_error); /** * Set the current movie file. */ void set_mfile(moviefile& _mf, bool free_old = false) throw(); /** * Get current rrdata. */ rrdata_set& get_rrdata() throw(std::runtime_error); /** * Set current rrdata. */ void set_rrdata(rrdata_set& _rrd, bool free_old = false) throw(); /** * Notify about new frame starting. */ void new_frame_starting(bool dont_poll) throw(std::bad_alloc, std::runtime_error); /** * Poll for input. * * parameter port: The port number. * parameter dev: The controller index. * parameter id: Control id. * returns: Value for polled input. * throws std::bad_alloc: Not enough memory. * throws std::runtime_error: Error polling for input. */ short input_poll(unsigned port, unsigned dev, unsigned id) throw(std::bad_alloc, std::runtime_error); /** * Called when movie code needs new controls snapshot. * * parameter subframe: True if this is for subframe update, false if for frame update. */ controller_frame update_controls(bool subframe) throw(std::bad_alloc, std::runtime_error); /** * Release memory for mov, mf and rrd. */ void release_memory(); private: movie_logic(const movie_logic&); movie_logic& operator=(const movie_logic&); movie* mov; moviefile* mf; rrdata_set* rrd; }; #endif