X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fgraphics%2Fimageloader.cpp;h=859a34c12894a1a0460b439e230a0fe9154d1385;hb=eddae342dd069589319029b48986b14dbbe5165b;hp=b2a126e79df5de3f64864fc5942f6f51a13ffc5b;hpb=7672cbffb3efd3cce448f85a5e0acd4bed7ec0dd;p=libs%2Fgui.git diff --git a/source/graphics/imageloader.cpp b/source/graphics/imageloader.cpp index b2a126e..859a34c 100644 --- a/source/graphics/imageloader.cpp +++ b/source/graphics/imageloader.cpp @@ -1,6 +1,7 @@ #include #include #include +#include #include "bmploader.h" #include "imageloader.h" #ifdef WITH_LIBPNG @@ -22,7 +23,8 @@ namespace Msp { namespace Graphics { ImageLoader::ImageLoader(): - source(0) + source(0), + state(INITIAL) { } ImageLoader::~ImageLoader() @@ -30,6 +32,15 @@ ImageLoader::~ImageLoader() delete source; } +bool ImageLoader::detect_signature(const std::string &sig) +{ + Registry ®istry = get_registry(); + for(list::const_iterator i=registry.loaders.begin(); i!=registry.loaders.end(); ++i) + if((*i)->detect(sig)) + return true; + return false; +} + ImageLoader *ImageLoader::open_file(const string &fn) { try @@ -57,9 +68,8 @@ ImageLoader *ImageLoader::open_io(IO::Seekable &io) if(registry.loaders.empty()) throw unsupported_image_format("no loaders"); - vector sig_buf(registry.loaders.back()->get_signature_size()); - unsigned sig_len = io.read(&sig_buf[0], sig_buf.size()); - string signature(sig_buf.begin(), sig_buf.end()); + string signature(registry.loaders.back()->get_signature_size(), 0); + unsigned sig_len = io.read(&signature[0], signature.size()); ImageLoader *loader = 0; for(list::const_iterator i=registry.loaders.begin(); (!loader && i!=registry.loaders.end()); ++i) @@ -72,17 +82,35 @@ ImageLoader *ImageLoader::open_io(IO::Seekable &io) { string sig_hex; for(unsigned i=0; i(sig_buf[i])); - } + append(sig_hex, " ", format("%02X", static_cast(signature[i]))); throw unsupported_image_format(sig_hex); } return loader; } +void ImageLoader::load(Image::Data &data) +{ + if(state>=FINISHED) + throw logic_error("already loaded"); + + if(state=HEADERS_LOADED) + throw logic_error("headers already loaded"); + + load_headers_(data); + state = HEADERS_LOADED; +} + ImageLoader::Registry &ImageLoader::get_registry() { static Registry registry;