X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fresources.cpp;h=06fa44cf0c502867a1ecb255bea5de9251cc6314;hb=6deafc9f236b90175a303944815f7c0eac1c95c1;hp=aad671c393729adc4608d3d6024378bcf44bbe35;hpb=131ac8ff2c06f94d40f4bf98d4a6ec0d113cdffc;p=libs%2Fgltk.git diff --git a/source/resources.cpp b/source/resources.cpp index aad671c..06fa44c 100644 --- a/source/resources.cpp +++ b/source/resources.cpp @@ -1,4 +1,6 @@ -#include +#include +#include +#include #include "resources.h" using namespace std; @@ -6,116 +8,129 @@ using namespace std; namespace Msp { namespace GLtk { -Resources::Resources(): - default_font(0) -{ } +Resources::Resources() +{ + init(); +} -Resources::~Resources() +Resources::Resources(const FS::Path &fn) { - for(FontMap::iterator i=fonts.begin(); i!=fonts.end(); ++i) - delete i->second; - for(TextureMap::iterator i=textures.begin(); i!=textures.end(); ++i) - delete i->second; + init(); + + dir_src = new DataFile::DirectorySource; + dir_src->add_directory(FS::dirname(fn)); + add_source(*dir_src); + + DataFile::load(*this, fn.str()); } -const GL::Font &Resources::get_font(const string &name) const +void Resources::init() { - FontMap::const_iterator i=fonts.find(name); - if(i==fonts.end()) - throw KeyError("Unknown font "+name); + default_font = 0; + dir_src = 0; + add_type().keyword("graphic"); + add_type().creator([this](const string &n){ return create_module(n); }); + add_type().creator([this](const string &n){ return create_sampler(n); }); + add_type().creator([this](const string &n){ return create_program(n); }); + add_type().keyword("texture").creator([this](const string &n){ return create_texture(n); }); + add_type().keyword("font"); + add_type