Make stem export export from right before any processors.
[ardour.git] / libs / ardour / audio_library.cc
index c5240988a8cd186d2c65c169a48cb029c9b3724c..662b8cb33e66f844dac4fa63231f76c3d89dc789 100644 (file)
 #include <libxml/uri.h>
 
 #include <lrdf.h>
+#include <glibmm/miscutils.h>
 
 #include <glibmm/convert.h>
 
-#include <pbd/compose.h>
+#include "pbd/compose.h"
 
-#include <ardour/audio_library.h>
-#include <ardour/utils.h>
-#include <ardour/filesystem_paths.h>
+#include "ardour/audio_library.h"
+#include "ardour/utils.h"
+#include "ardour/filesystem_paths.h"
 
 #include "i18n.h"
 
 using namespace std;
+using namespace PBD;
 using namespace ARDOUR;
 
 namespace {
        const char* const sfdb_file_name = "sfdb";
 } // anonymous namespace
 
-static char* TAG = "http://ardour.org/ontology/Tag";
+static const char* TAG = "http://ardour.org/ontology/Tag";
 
 AudioLibrary::AudioLibrary ()
 {
@@ -49,9 +51,10 @@ AudioLibrary::AudioLibrary ()
        sfdb_file_path /= sfdb_file_name;
 
        src = Glib::filename_to_uri (sfdb_file_path.to_string ());
-       
+
        // workaround for possible bug in raptor that crashes when saving to a
        // non-existant file.
+
        touch_file(sfdb_file_path.to_string());
 
        lrdf_read_file(src.c_str());
@@ -74,11 +77,11 @@ AudioLibrary::set_tags (string member, vector<string> tags)
 {
        sort (tags.begin(), tags.end());
        tags.erase (unique(tags.begin(), tags.end()), tags.end());
-       
+
        const string file_uri(Glib::filename_to_uri (member));
-       
+
        lrdf_remove_uri_matches (file_uri.c_str());
-       
+
        for (vector<string>::iterator i = tags.begin(); i != tags.end(); ++i) {
                lrdf_add_triple (src.c_str(), file_uri.c_str(), TAG, (*i).c_str(), lrdf_literal);
        }
@@ -88,32 +91,32 @@ vector<string>
 AudioLibrary::get_tags (string member)
 {
        vector<string> tags;
-       
+
        lrdf_statement pattern;
        pattern.subject = strdup(Glib::filename_to_uri(member).c_str());
-       pattern.predicate = TAG;
+       pattern.predicate = (char*)TAG;
        pattern.object = 0;
        pattern.object_type = lrdf_literal;
-       
+
        lrdf_statement* matches = lrdf_matches (&pattern);
        free (pattern.subject);
-       
+
        lrdf_statement* current = matches;
        while (current != 0) {
                tags.push_back (current->object);
-               
+
                current = current->next;
        }
-       
+
        lrdf_free_statements (matches);
-       
+
        sort (tags.begin(), tags.end());
-       
+
        return tags;
 }
 
 void
-AudioLibrary::search_members_and (vector<string>& members, const vector<string> tags)
+AudioLibrary::search_members_and (vector<string>& members, const vector<string>& tags)
 {
        lrdf_statement **head;
        lrdf_statement* pattern = 0;
@@ -123,8 +126,8 @@ AudioLibrary::search_members_and (vector<string>& members, const vector<string>
        vector<string>::const_iterator i;
        for (i = tags.begin(); i != tags.end(); ++i){
                pattern = new lrdf_statement;
-               pattern->subject = "?";
-               pattern->predicate = TAG;
+               pattern->subject = (char*)"?";
+               pattern->predicate = (char*)TAG;
                pattern->object = strdup((*i).c_str());
                pattern->next = old;
 
@@ -134,7 +137,6 @@ AudioLibrary::search_members_and (vector<string>& members, const vector<string>
        if (*head != 0) {
                lrdf_uris* ulist = lrdf_match_multi(*head);
                for (uint32_t j = 0; ulist && j < ulist->count; ++j) {
-//                     cerr << "AND: " << Glib::filename_from_uri(ulist->items[j]) << endl;
                        members.push_back(Glib::filename_from_uri(ulist->items[j]));
                }
                lrdf_free_uris(ulist);