From 1878bbaf78d0ef582d79b880aaa96f44e32d91c2 Mon Sep 17 00:00:00 2001 From: randomdan Date: Sat, 23 Mar 2013 14:19:49 +0000 Subject: Allow script components to declare themselves uncacheable --- project2/common/scriptLoader.cpp | 9 ++++++--- project2/common/scriptLoader.h | 1 + project2/common/scriptStorage.h | 4 ++++ 3 files changed, 11 insertions(+), 3 deletions(-) diff --git a/project2/common/scriptLoader.cpp b/project2/common/scriptLoader.cpp index bd6495b..1f5243e 100644 --- a/project2/common/scriptLoader.cpp +++ b/project2/common/scriptLoader.cpp @@ -99,18 +99,21 @@ LoaderBase::collectAll(ScriptNodePtr node, bool childrenOnly, const StorerPtrs & catch (const NotSupported &) { } } + if (!node->obj) { + throw NotSupported(node->get_name()); + } } else { if (SourceObjectPtr p = boost::dynamic_pointer_cast(node->obj)) { LoaderBase::loadedObjects.insert(p.get()); } } - if (!node->obj) { - throw NotSupported(node->get_name()); - } BOOST_FOREACH(const StorerPtr & s, sts) { if (s->save(node->obj, node)) { stored += 1; + if (!s->cacheable(node)) { + node->obj.reset(); + } break; } } diff --git a/project2/common/scriptLoader.h b/project2/common/scriptLoader.h index 2582a52..2b1057b 100644 --- a/project2/common/scriptLoader.h +++ b/project2/common/scriptLoader.h @@ -131,6 +131,7 @@ class ComponentLoader { virtual void onPeriodic(); // When the app engine feels like it virtual void onConfigLoad(); // When the environment reloads the configuration virtual const Options * options() const; // Options to be populated from the common config file/env/etc + virtual bool cacheable() const { return true; } // The component can be cached for next run }; template diff --git a/project2/common/scriptStorage.h b/project2/common/scriptStorage.h index 12cf3a6..2859a28 100644 --- a/project2/common/scriptStorage.h +++ b/project2/common/scriptStorage.h @@ -38,6 +38,7 @@ class Storer : public virtual IntrusivePtrBase { virtual boost::intrusive_ptr create(ScriptNodePtr) const = 0; virtual bool save(boost::intrusive_ptr, ScriptNodePtr) = 0; + virtual bool cacheable(ScriptNodePtr) const { return true; } }; template @@ -51,6 +52,9 @@ class StorerBase : public Storer { boost::intrusive_ptr create(ScriptNodePtr p) const { return creator(LoaderBase::getLoader(p->get_name()).get(), p); } + bool cacheable(ScriptNodePtr p) const { + return LoaderBase::getLoader(p->get_name())->cacheable(); + } bool save(boost::intrusive_ptr o, ScriptNodePtr name) { boost::intrusive_ptr O = boost::dynamic_pointer_cast(o); if (O) { -- cgit v1.2.3