/* * ResourceDB.h - header file for ResourceDB * * Copyright (c) 2008-2009 Tobias Doerffel * * This file is part of Linux MultiMedia Studio - http://lmms.sourceforge.net * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public * License along with this program (see COPYING); if not, write to the * Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, * Boston, MA 02110-1301 USA. * */ #ifndef _RESOURCE_DB_H #define _RESOURCE_DB_H #include #include #include #include #include #include "ResourceItem.h" class EXPORT ResourceDB : public QObject { Q_OBJECT public: typedef QHash ItemHashMap; ResourceDB( ResourceProvider * _provider ); ~ResourceDB(); void init(); void load( const QString & _file ); void save( const QString & _file ); inline ResourceProvider * provider() { return m_provider; } inline const ItemHashMap & items() const { return m_items; } inline ItemHashMap & items() { return m_items; } inline ResourceItem::Relation * topLevelNode() { return &m_topLevelNode; } // similiar to items()[_hash] but faster and returns NULL if not found const ResourceItem * itemByHash( const QString & _hash ) const; // return a list of ResourceItems who somehow match the given keywords ResourceItemList matchItems( const QStringList & _keyWords ); // return an item which matches a resource desceibed in _item as // good as possible const ResourceItem * nearestMatch( const ResourceItem & _item ); // add given item to DB void addItem( ResourceItem * _newItem ); void recursiveRemoveItems( ResourceItem::Relation * parent, bool removeTopLevelParent = true ); private: void saveRelation( const ResourceItem::Relation * _i, QDomDocument & _doc, QDomElement & _de ); void loadRelation( ResourceItem::Relation * _i, QDomElement & _de ); static inline QString typeName( ResourceItem::Type _t ) { return s_typeNames[_t]; } static inline QString baseDirName( ResourceItem::BaseDirectory _bd ) { return s_baseDirNames[_bd]; } static inline ResourceItem::Type typeFromName( const QString & _n ) { for( TypeStringMap::ConstIterator it = s_typeNames.begin(); it != s_typeNames.end(); ++it ) { if( it.value() == _n ) { return it.key(); } } return ResourceItem::TypeUnknown; } static inline ResourceItem::BaseDirectory baseDirFromName( const QString & _n ) { for( BaseDirStringMap::ConstIterator it = s_baseDirNames.begin(); it != s_baseDirNames.end(); ++it ) { if( it.value() == _n ) { return it.key(); } } return ResourceItem::BaseRoot; } typedef QMap TypeStringMap; typedef QMap BaseDirStringMap; static TypeStringMap s_typeNames; static BaseDirStringMap s_baseDirNames; ResourceProvider * m_provider; ItemHashMap m_items; ResourceItem::Relation m_topLevelNode; signals: void itemsChanged(); void directoryItemAdded( const QString & _path ); void directoryItemRemoved( const QString & _path ); } ; #endif