+ return Glib::build_filename (user_config_directory(), templates_dir_name);
+}
+
+std::string
+user_route_template_directory ()
+{
+ return Glib::build_filename (user_config_directory(), route_templates_dir_name);
+}
+
+static bool
+template_filter (const string &str, void* /*arg*/)
+{
+ if (!Glib::file_test (str, Glib::FILE_TEST_IS_DIR)) {
+ return false;
+ }
+
+ return true;
+}
+
+static bool
+route_template_filter (const string &str, void* /*arg*/)
+{
+ if (str.find (template_suffix) == str.length() - strlen (template_suffix)) {
+ return true;
+ }
+
+ return false;
+}
+
+string
+session_template_dir_to_file (string const & dir)
+{
+ return Glib::build_filename (dir, Glib::path_get_basename(dir) + template_suffix);
+}
+
+
+void
+find_session_templates (vector<TemplateInfo>& template_names)
+{
+ vector<string *> *templates;
+ PathScanner scanner;
+ Searchpath spath (template_search_path());
+
+ templates = scanner (spath.to_string(), template_filter, 0, true, true);
+
+ if (!templates) {
+ cerr << "Found nothing along " << spath.to_string() << endl;
+ return;
+ }
+
+ cerr << "Found " << templates->size() << " along " << spath.to_string() << endl;
+
+ for (vector<string*>::iterator i = templates->begin(); i != templates->end(); ++i) {
+ string file = session_template_dir_to_file (**i);
+
+ XMLTree tree;
+
+ if (!tree.read (file.c_str())) {
+ continue;
+ }
+
+ TemplateInfo rti;
+
+ rti.name = basename_nosuffix (**i);
+ rti.path = **i;
+
+ template_names.push_back (rti);
+ }
+
+ delete templates;
+}
+
+void
+find_route_templates (vector<TemplateInfo>& template_names)
+{
+ vector<string *> *templates;
+ PathScanner scanner;
+ Searchpath spath (route_template_search_path());
+
+ templates = scanner (spath.to_string(), route_template_filter, 0, false, true);
+
+ if (!templates) {
+ return;
+ }
+
+ for (vector<string*>::iterator i = templates->begin(); i != templates->end(); ++i) {
+ string fullpath = *(*i);
+
+ XMLTree tree;