Mercurial > hg > svcore
annotate rdf/RDFImporter.h @ 489:82ab61fa9223
* Reorganise our sparql queries on the basis that Redland must be
available, not only optional. So for anything querying the pool
of data about plugins, we use a single datastore and model which
is initialised at the outset by PluginRDFIndexer and then queried
directly; for anything that "reads from a file" (e.g. loading
annotations) we query directly using Rasqal, going to the
datastore when we need additional plugin-related information.
This may improve performance, but mostly it simplifies the code
and fixes a serious issue with RDF import in the previous versions
(namely that multiple sequential RDF imports would end up sharing
the same RDF data pool!)
author | Chris Cannam |
---|---|
date | Fri, 21 Nov 2008 16:12:29 +0000 |
parents | beb2948baa77 |
children | c3fb8258e34d |
rev | line source |
---|---|
Chris@439 | 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ |
Chris@439 | 2 |
Chris@439 | 3 /* |
Chris@439 | 4 Sonic Visualiser |
Chris@439 | 5 An audio file viewer and annotation editor. |
Chris@439 | 6 Centre for Digital Music, Queen Mary, University of London. |
Chris@439 | 7 This file copyright 2008 QMUL. |
Chris@439 | 8 |
Chris@439 | 9 This program is free software; you can redistribute it and/or |
Chris@439 | 10 modify it under the terms of the GNU General Public License as |
Chris@439 | 11 published by the Free Software Foundation; either version 2 of the |
Chris@439 | 12 License, or (at your option) any later version. See the file |
Chris@439 | 13 COPYING included with this distribution for more information. |
Chris@439 | 14 */ |
Chris@439 | 15 |
Chris@439 | 16 #ifndef _RDF_IMPORTER_H_ |
Chris@439 | 17 #define _RDF_IMPORTER_H_ |
Chris@439 | 18 |
Chris@439 | 19 #include <QObject> |
Chris@439 | 20 #include <QString> |
Chris@439 | 21 |
Chris@439 | 22 #include <vector> |
Chris@439 | 23 |
Chris@439 | 24 class Model; |
Chris@439 | 25 class RDFImporterImpl; |
Chris@439 | 26 class ProgressReporter; |
Chris@439 | 27 |
Chris@439 | 28 class RDFImporter : public QObject |
Chris@439 | 29 { |
Chris@439 | 30 Q_OBJECT |
Chris@439 | 31 |
Chris@439 | 32 public: |
Chris@439 | 33 /** |
Chris@439 | 34 * Return the file extensions that we have data file readers for, |
Chris@439 | 35 * in a format suitable for use with QFileDialog. For example, |
Chris@439 | 36 * "*.rdf *.n3". |
Chris@439 | 37 */ |
Chris@439 | 38 static QString getKnownExtensions(); |
Chris@439 | 39 |
Chris@439 | 40 RDFImporter(QString url, int sampleRate); |
Chris@439 | 41 virtual ~RDFImporter(); |
Chris@439 | 42 |
Chris@439 | 43 bool isOK(); |
Chris@439 | 44 QString getErrorString() const; |
Chris@439 | 45 |
Chris@439 | 46 std::vector<Model *> getDataModels(ProgressReporter *reporter); |
Chris@439 | 47 |
Chris@439 | 48 protected: |
Chris@439 | 49 RDFImporterImpl *m_d; |
Chris@439 | 50 }; |
Chris@439 | 51 |
Chris@439 | 52 #endif |