da0bbf33b07c — Chris Cannam 9 years ago
Fixes and docs
3 files changed, 106 insertions(+), 2 deletions(-)

A => COPYING
A => README.txt
M bqthingfactory/ThingFactory.h
A => COPYING +26 -0
@@ 0,0 1,26 @@ 
+
+    Copyright 2007-2015 Particular Programs Ltd.
+
+    Permission is hereby granted, free of charge, to any person
+    obtaining a copy of this software and associated documentation
+    files (the "Software"), to deal in the Software without
+    restriction, including without limitation the rights to use, copy,
+    modify, merge, publish, distribute, sublicense, and/or sell copies
+    of the Software, and to permit persons to whom the Software is
+    furnished to do so, subject to the following conditions:
+
+    The above copyright notice and this permission notice shall be
+    included in all copies or substantial portions of the Software.
+
+    THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+    EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+    MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+    NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR
+    ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
+    CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+    WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+
+    Except as contained in this notice, the names of Chris Cannam and
+    Particular Programs Ltd shall not be used in advertising or
+    otherwise to promote the sale, use or other dealings in this
+    Software without prior written authorization.

          
A => README.txt +74 -0
@@ 0,0 1,74 @@ 
+
+bqthingfactory
+==============
+
+A single-header C++ library providing a factory for objects from
+classes that share a common base class, have identical single-argument
+constructors, can be identified by URI, and that can register their
+existence with the factory, so that the factory does not have to know
+in advance about all buildable classes.
+
+C++ standard required: C++98 (does not use C++11)
+
+Copyright 2007-2015 Particular Programs Ltd.  Under a permissive
+BSD/MIT-style licence: see the file COPYING for details.
+
+
+How to use these classes
+------------------------
+
+Given a base class A with many subclasses B, C, D, etc, all of
+which need to be passed parameters class P in their constructor:
+
+ -- in a header associated with A,
+
+    - Create a template class ABuilder<T> which inherits from
+      ConcreteThingBuilder<T, A, P>.  This is your class which will
+      be specialised to provide a builder for each subclass of A.
+      Its constructor must accept a std::string containing the URI
+      that identifies the class of object being built, which is
+      passed to the parent class's constructor.  Optionally, it may
+      also accept and pass to the parent class a vector<string> of
+      "tags", which are strings used to identify the sorts of
+      facility this builder's object supports -- for example, file
+      extensions or MIME types that the object can parse.  If two
+      builders register support for the same tag, only the first to
+      register will be used (note that which one this is may depend
+      on static object construction ordering, so it's generally
+      better if tags are unique to a builder).
+
+    - You may also wish to typedef ThingFactory<A, P> to something
+      like AFactory, for convenience.
+
+ -- in a .cpp file associated with each of B, C, D etc,
+
+    - Define a static variable of class ABuilder<B>, ABuilder<C>,
+      ABuilder<D>, etc, passing the class's identifying URI and
+      optional supported tag list to its constructor.  (If you
+      like, this could be a static member of some class.)
+
+You can then do the following:
+
+ -- call AFactory::getInstance()->getURIs() to retrieve a list of
+    all registered URIs for this factory.
+
+ -- call AFactory::getInstance()->create(uri, parameters), where
+    parameters is an object of type P, to construct a new object
+    whose class is that associated with the URI uri.
+
+ -- call AFactory::getInstance()->getTags() to retrieve a list of
+    all tags known to be supported by some builder.  Remember that
+    builders do not have to support any tags and many builders
+    could support the same tag, so you cannot retrieve all builders
+    by starting from the tags list: use getURIs for that.
+
+ -- call AFactory::getInstance()->getURIFor(tag), where tag is a
+    std::string corresponding to one of the tags supported by some
+    builder, to obtain the URI of the first builder to have
+    registered its support for the given tag.
+ 
+ -- call AFactory::getInstance()->createFor(tag, parameters), where
+    tag is a std::string corresponding to one of the tags supported by
+    some builder and parameters is an object of type P, to
+    construct a new object whose class is that built by the first
+    builder to have registered its support for the given tag. 

          
M bqthingfactory/ThingFactory.h +6 -2
@@ 123,14 123,18 @@ public:
     }
     
     std::vector<std::string> getTags() const {
-        return m_tags.keys();
+        std::vector<std::string> tags;
+        for (TagURIMap::const_iterator i = m_tags.begin(); i != m_tags.end(); ++i) {
+            tags.push_back(i->first);
+        }
+        return tags;
     }
     
     std::string getURIFor(std::string tag) const {
         if (m_tags.find(tag) == m_tags.end()) {
             throw UnknownTagException(tag);
         }
-        return m_tags[tag];
+        return m_tags.at(tag);
     }
 
     Thing *create(std::string uri, Parameters p) const {