Files
lmms/include/Plugin.h
Tobias Doerffel 8c9a9dd14c File and class renames part 1
Most files and most of the core classes and their methods have been
renamed to match new coding style conventions:

391 files changed, 25400 insertions(+), 25598 deletions(-)

Furthermore splitted some files where model and view classes were
declared or implemented together in the same file.

Should be tested thoroughly as I might have missed renaming some virtual
methods or SIGNAL/SLOT parameters.
2009-08-24 17:59:28 +02:00

215 lines
5.1 KiB
C++

/*
* Plugin.h - class plugin, the base-class and generic interface for all plugins
*
* Copyright (c) 2005-2009 Tobias Doerffel <tobydox/at/users.sourceforge.net>
*
* 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 _PLUGIN_H
#define _PLUGIN_H
#include <QtCore/QString>
#include <QtCore/QStringList>
#include <QtCore/QVector>
#include <QtXml/QDomDocument>
#include "JournallingObject.h"
#include "Model.h"
#include "base64.h"
class QWidget;
class ResourceItem;
class PixmapLoader;
class PluginView;
class AutomatableModel;
class EXPORT Plugin : public JournallingObject, public Model
{
public:
enum PluginTypes
{
Instrument, // instrument being used in channel-track
Effect, // effect-plugin for effect-board
ImportFilter, // filter for importing a file
ExportFilter, // filter for exporting a file
Tool, // additional tool (level-meter etc)
Library, // simple library holding a code-base for
// several other plugins (e.g. VST-support)
Other,
Undefined = 255
} ;
// descriptor holds information about a plugin - every external plugin
// has to instantiate such a descriptor in an extern "C"-section so that
// the plugin-loader is able to access information about the plugin
struct Descriptor
{
const char * name;
const char * displayName;
const char * description;
const char * author;
int version;
PluginTypes type;
const PixmapLoader * logo;
const char * * supportedFileTypes;
inline bool supportsFileType( const QString & _type ) const
{
if( !supportedFileTypes )
{
return false;
}
for( const char * * i = supportedFileTypes; *i; ++i )
{
if( *i == _type )
{
return true;
}
}
return false;
}
class EXPORT SubPluginFeatures
{
public:
struct Key
{
typedef QMap<QString, QString> AttributeMap;
inline Key( Plugin::Descriptor * _desc = NULL,
const QString & _name = QString(),
const AttributeMap & _am = AttributeMap() )
:
desc( _desc ),
name( _name ),
attributes( _am )
{
}
Key( const QDomElement & _key );
QDomElement saveXML( QDomDocument & _doc ) const;
inline bool isValid() const
{
return desc != NULL &&
name != QString::null;
}
Plugin::Descriptor * desc;
QString name;
AttributeMap attributes;
} ;
typedef QList<Key> KeyList;
SubPluginFeatures( Plugin::PluginTypes _type ) :
m_type( _type )
{
}
virtual ~SubPluginFeatures()
{
}
virtual void fillDescriptionWidget( QWidget *, const Key * )
{
}
virtual void listSubPluginKeys( Plugin::Descriptor *, KeyList & )
{
}
protected:
const Plugin::PluginTypes m_type;
} ;
SubPluginFeatures * sub_plugin_features;
} ;
// contructor of a plugin
Plugin( const Descriptor * _descriptor, Model * _parent );
virtual ~Plugin();
// returns display-name out of descriptor
virtual QString displayName() const
{
return Model::displayName().isEmpty() ?
m_descriptor->displayName :
Model::displayName();
}
// return plugin-type
inline PluginTypes type() const
{
return m_descriptor->type;
}
// return plugin-descriptor for further information
inline const Descriptor * descriptor() const
{
return m_descriptor;
}
// can be called if a resource supported by this plugin should be
// loaded/processed by this plugin
virtual void loadResource( const ResourceItem * _resourceItem );
// Called if external source needs to change something but we cannot
// reference the class header. Should return null if not key not found.
virtual AutomatableModel * childModel( const QString & _modelName );
// returns an instance of a plugin whose name matches to given one
// if specified plugin couldn't be loaded, it creates a dummy-plugin
static Plugin * instantiate( const QString & _plugin_name,
Model * _parent, void * _data );
// fills given vector with descriptors of all available plugins
static void getDescriptorsOfAvailPlugins(
QVector<Descriptor> & _plugin_descs );
// create a view for the model
PluginView * createView( QWidget * _parent );
protected:
// create a view for the model
virtual PluginView * instantiateView( QWidget * ) = 0;
private:
const Descriptor * m_descriptor;
// pointer to instantiation-function in plugin
typedef Plugin * ( * instantiationHook )( Model *, void * );
} ;
#endif
/* vim: set tw=0 noexpandtab: */