Mime type based filter loading
[kworship.git] / kworship / KwFilterManager.cpp
blob96e0867379438e50d94880bb5a1584a71fea8c58
1 /***************************************************************************
2 * This file is part of KWorship. *
3 * Copyright 2008 James Hogan <james@albanarts.com> *
4 * *
5 * KWorship is free software: you can redistribute it and/or modify *
6 * it under the terms of the GNU General Public License as published by *
7 * the Free Software Foundation, either version 2 of the License, or *
8 * (at your option) any later version. *
9 * *
10 * KWorship is distributed in the hope that it will be useful, *
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13 * GNU General Public License for more details. *
14 * *
15 * You should have received a copy of the GNU General Public License *
16 * along with KWorship. If not, write to the Free Software Foundation, *
17 * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
18 ***************************************************************************/
20 /**
21 * @file KwFilterManager.cpp
22 * @brief Manages file filters.
23 * @author James Hogan <james@albanarts.com>
26 #include "KwFilterManager.h"
27 #include "KwLoadSaveFilter.h"
30 * Constructors + destructor
33 /// Primary constructor.
34 KwFilterManager::KwFilterManager()
35 : m_defaultLoadSaveFilter(0)
36 , m_loadSaveFilters()
37 , m_importFilters()
38 , m_exportFilters()
39 , m_loadMimeFilters()
40 , m_saveMimeFilters()
41 , m_importMimeFilters()
42 , m_exportMimeFilters()
46 /// Destructor.
47 KwFilterManager::~KwFilterManager()
49 // Delete all filters.
50 foreach (KwLoadSaveFilter* filter, m_loadSaveFilters)
52 delete filter;
54 foreach (KwImportFilter* filter, m_importFilters)
56 delete filter;
58 foreach (KwExportFilter* filter, m_exportFilters)
60 delete filter;
65 * Main interface
68 /// Add a load save filter.
69 void KwFilterManager::addLoadSaveFilter(KwLoadSaveFilter* loadSaveFilter, bool makeDefault)
71 m_loadSaveFilters += loadSaveFilter;
72 if (makeDefault)
74 m_defaultLoadSaveFilter = loadSaveFilter;
77 // Update hashes of filters for each mime type
78 QStringList mimes = loadSaveFilter->importMimeTypes();
79 foreach (QString mime, mimes)
81 m_loadMimeFilters[mime] = loadSaveFilter;
83 mimes = loadSaveFilter->exportMimeTypes();
84 foreach (QString mime, mimes)
86 m_saveMimeFilters[mime] = loadSaveFilter;
90 /// Add an import filter.
91 void KwFilterManager::addImportFilter(KwImportFilter* importFilter)
93 m_importFilters += importFilter;
95 // Update hash of import filters for each mime type
96 QStringList mimes = importFilter->importMimeTypes();
97 foreach (QString mime, mimes)
99 m_importMimeFilters[mime] = importFilter;
103 /// Add an export filter.
104 void KwFilterManager::addExportFilter(KwExportFilter* exportFilter)
106 m_exportFilters += exportFilter;
108 // Update hash of export filters for each mime type
109 QStringList mimes = exportFilter->exportMimeTypes();
110 foreach (QString mime, mimes)
112 m_exportMimeFilters[mime] = exportFilter;
116 /// Get load mime types.
117 QStringList KwFilterManager::loadMimeTypes() const
119 return m_loadMimeFilters.keys();
122 /// Get save mime types.
123 QStringList KwFilterManager::saveMimeTypes() const
125 return m_saveMimeFilters.keys();
128 /// Get import mime types.
129 QStringList KwFilterManager::importMimeTypes() const
131 return m_importMimeFilters.keys();
134 /// Get export mime types.
135 QStringList KwFilterManager::exportMimeTypes() const
137 return m_exportMimeFilters.keys();
140 /// Get the load filter for a mime type.
141 KwLoadSaveFilter* KwFilterManager::loadFilterFromMimeType(const QString& mimeType)
143 if (m_loadMimeFilters.contains(mimeType))
145 return m_loadMimeFilters[mimeType];
147 else
149 return 0;
153 /// Get the save filter for a mime type.
154 KwLoadSaveFilter* KwFilterManager::saveFilterFromMimeType(const QString& mimeType)
156 if (m_saveMimeFilters.contains(mimeType))
158 return m_saveMimeFilters[mimeType];
160 else
162 return 0;
166 /// Get the import filter for a mime type.
167 KwImportFilter* KwFilterManager::importFilterFromMimeType(const QString& mimeType)
169 if (m_importMimeFilters.contains(mimeType))
171 return m_importMimeFilters[mimeType];
173 else
175 return 0;
179 /// Get the export filter for a mime type.
180 KwExportFilter* KwFilterManager::exportFilterFromMimeType(const QString& mimeType)
182 if (m_exportMimeFilters.contains(mimeType))
184 return m_exportMimeFilters[mimeType];
186 else
188 return 0;