X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=image_input.h;h=3b3c1873763577c2250a48b883cc214b04620592;hb=2068106ac4d44719e78d2931ccbe2fe67947b381;hp=fbda72de6c36ddf69f660db77b78024afb5fc8cb;hpb=cfa98a26d7b16b97a406c82930a1fc61a119183f;p=nageru diff --git a/image_input.h b/image_input.h index fbda72d..3b3c187 100644 --- a/image_input.h +++ b/image_input.h @@ -16,26 +16,28 @@ // from disk about every second. class ImageInput : public movit::FlatInput { public: - ImageInput(const std::string &filename); + ImageInput(const std::string &pathname); std::string effect_type_id() const override { return "ImageInput"; } void set_gl_state(GLuint glsl_program_num, const std::string& prefix, unsigned *sampler_num) override; - + static void shutdown_updaters(); + private: struct Image { std::unique_ptr pixels; timespec last_modified; }; - std::string filename; + std::string pathname; std::shared_ptr current_image; - static std::shared_ptr load_image(const std::string &filename); - static std::shared_ptr load_image_raw(const std::string &filename); - static void update_thread_func(const std::string &filename, const timespec &first_modified); + static std::shared_ptr load_image(const std::string &pathname); + static std::shared_ptr load_image_raw(const std::string &pathname); + static void update_thread_func(const std::string &pathname, const timespec &first_modified); static std::mutex all_images_lock; static std::map> all_images; static std::map update_threads; + static volatile bool threads_should_quit; }; #endif // !defined(_IMAGE_INPUT_H)