X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;ds=sidebyside;f=source%2Fgraphics%2Fimageloader.h;h=f0b8d52c36412ec6cf3e9901d5b2a43c51aefdd6;hb=d3bc6c9;hp=031ecb411667da36a505da084fad0ff2d66ba341;hpb=e1f6dad834fb043f22a57dbaa65016ee1f65a43a;p=libs%2Fgui.git diff --git a/source/graphics/imageloader.h b/source/graphics/imageloader.h index 031ecb4..f0b8d52 100644 --- a/source/graphics/imageloader.h +++ b/source/graphics/imageloader.h @@ -27,7 +27,7 @@ protected: class RegisterBase { protected: - RegisterBase(); + RegisterBase() { } public: virtual ~RegisterBase() { } @@ -36,13 +36,27 @@ protected: virtual ImageLoader *create(IO::Seekable &) const = 0; }; + template + class RegisteredLoader: public RegisterBase + { + public: + virtual unsigned get_signature_size() const { return T::get_signature_size(); } + virtual bool detect(const std::string &s) const { return T::detect(s); } + virtual ImageLoader *create(IO::Seekable &io) const { return new T(io); } + }; + + struct Registry + { + std::list loaders; + bool changed; + + Registry(); + ~Registry(); + }; + private: IO::Base *source; - static std::list &get_registered_loaders(); - static bool registered_loaders_changed; - static bool signature_size_compare(RegisterBase *, RegisterBase *); - protected: ImageLoader(); public: @@ -51,32 +65,25 @@ public: static ImageLoader *open_file(const std::string &); static ImageLoader *open_io(IO::Seekable &); - virtual void load(Image::Data &) = 0; -}; - - -template -class RegisteredImageLoader: public ImageLoader -{ - friend class ImageLoader; + virtual void load(Image::Data &); + virtual void load_headers(Image::Data &) { } + virtual void load_data(Image::Data &) { } + template + static void register_loader(); private: - class Register: public RegisterBase - { - public: - virtual unsigned get_signature_size() const { return T::get_signature_size(); } - virtual bool detect(const std::string &s) const { return T::detect(s); } - virtual ImageLoader *create(IO::Seekable &io) const { return new T(io); } - }; - - static Register reg; + static Registry &get_registry(); -protected: - RegisteredImageLoader() { (void)reg; } + static bool signature_size_compare(RegisterBase *, RegisterBase *); }; template -typename RegisteredImageLoader::Register RegisteredImageLoader::reg; +void ImageLoader::register_loader() +{ + Registry ®istry = get_registry(); + registry.loaders.push_back(new RegisteredLoader); + registry.changed = true; +} } // namespace Graphics } // namespace Msp