From 899c0f9cd230bc36fc006e54bf88f598ab725257 Mon Sep 17 00:00:00 2001 From: rubidium Date: Thu, 2 Jan 2014 22:48:32 +0000 Subject: [PATCH] (svn r26210) -Codechange: add infrastructure for not registering a blitter --- src/blitter/factory.hpp | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/src/blitter/factory.hpp b/src/blitter/factory.hpp index 7fe498a67d..83edd99aa7 100644 --- a/src/blitter/factory.hpp +++ b/src/blitter/factory.hpp @@ -57,15 +57,25 @@ protected: * Construct the blitter, and register it. * @param name The name of the blitter. * @param description A longer description for the blitter. + * @param usable Whether the blitter is usable (on the current computer). For example for disabling SSE blitters when the CPU can't handle them. * @pre name != NULL. * @pre description != NULL. * @pre There is no blitter registered with this name. */ - BlitterFactory(const char *name, const char *description) : + BlitterFactory(const char *name, const char *description, bool usable = true) : name(strdup(name)), description(strdup(description)) { - std::pair P = GetBlitters().insert(Blitters::value_type(this->name, this)); - assert(P.second); + if (usable) { + /* + * Only add when the blitter is usable. Do not bail out or + * do more special things since the blitters are always + * instantiated upon start anyhow and freed upon shutdown. + */ + std::pair P = GetBlitters().insert(Blitters::value_type(this->name, this)); + assert(P.second); + } else { + DEBUG(driver, 1, "Not registering blitter %s as it is not usable", name); + } } public: