Replaced global ResourcesDB with a global UnifiedResourcesProvider which

allows to add several resource directories or online resources.
This commit is contained in:
Tobias Doerffel
2009-02-28 15:55:22 +01:00
parent 75c03f65f2
commit aff61f16b0
2 changed files with 47 additions and 33 deletions

View File

@@ -1,7 +1,7 @@
/*
* engine.h - engine-system of LMMS
*
* Copyright (c) 2006-2008 Tobias Doerffel <tobydox/at/users.sourceforge.net>
* Copyright (c) 2006-2009 Tobias Doerffel <tobydox/at/users.sourceforge.net>
*
* This file is part of Linux MultiMedia Studio - http://lmms.sourceforge.net
*
@@ -44,7 +44,7 @@ class mainWindow;
class mixer;
class pianoRoll;
class projectNotes;
class ResourcesDB;
class UnifiedResourcesProvider;
class song;
class songEditor;
class ladspa2LMMS;
@@ -59,7 +59,7 @@ public:
static bool hasGUI( void )
{
return( s_hasGUI );
return s_hasGUI;
}
static void setSuppressMessages( bool _on )
@@ -75,94 +75,94 @@ public:
// core
static mixer * getMixer( void )
{
return( s_mixer );
return s_mixer;
}
static fxMixer * getFxMixer( void )
{
return( s_fxMixer );
return s_fxMixer;
}
static song * getSong( void )
{
return( s_song );
return s_song;
}
static bbTrackContainer * getBBTrackContainer( void )
{
return( s_bbTrackContainer );
return s_bbTrackContainer;
}
static projectJournal * getProjectJournal( void )
{
return( s_projectJournal );
return s_projectJournal;
}
static ResourcesDB * getResourcesDB( void )
static UnifiedResourcesProvider * getResourcesProvider( void )
{
return( s_resourcesDB );
return s_resourcesProvider;
}
// GUI
static mainWindow * getMainWindow( void )
{
return( s_mainWindow );
return s_mainWindow;
}
static fxMixerView * getFxMixerView( void )
{
return( s_fxMixerView );
return s_fxMixerView;
}
static songEditor * getSongEditor( void )
{
return( s_songEditor );
return s_songEditor;
}
static bbEditor * getBBEditor( void )
{
return( s_bbEditor );
return s_bbEditor;
}
static pianoRoll * getPianoRoll( void )
{
return( s_pianoRoll );
return s_pianoRoll;
}
static projectNotes * getProjectNotes( void )
{
return( s_projectNotes );
return s_projectNotes;
}
static automationEditor * getAutomationEditor( void )
{
return( s_automationEditor );
return s_automationEditor;
}
static ladspa2LMMS * getLADSPAManager( void )
{
return( s_ladspaManager );
return s_ladspaManager;
}
static dummyTrackContainer * getDummyTrackContainer( void )
{
return( s_dummyTC );
return s_dummyTC;
}
static controllerRackView * getControllerRackView( void )
{
return( s_controllerRackView );
return s_controllerRackView;
}
static float framesPerTick( void )
{
return( s_framesPerTick );
return s_framesPerTick;
}
static void updateFramesPerTick( void );
static const QMap<QString, QString> & pluginFileHandling( void )
{
return( s_pluginFileHandling );
return s_pluginFileHandling;
}
static void setLmmsStyle( LmmsStyle * _style )
@@ -184,7 +184,7 @@ private:
static mixer * s_mixer;
static fxMixer * s_fxMixer;
static song * s_song;
static ResourcesDB * s_resourcesDB;
static UnifiedResourcesProvider * s_resourcesProvider;
static bbTrackContainer * s_bbTrackContainer;
static projectJournal * s_projectJournal;
static dummyTrackContainer * s_dummyTC;
@@ -200,7 +200,7 @@ private:
static projectNotes * s_projectNotes;
static ladspa2LMMS * s_ladspaManager;
static LmmsStyle * s_lmmsStyle;
static LmmsStyle * s_lmmsStyle;
static QMap<QString, QString> s_pluginFileHandling;

View File

@@ -3,7 +3,7 @@
/*
* engine.cpp - implementation of LMMS' engine-system
*
* Copyright (c) 2006-2008 Tobias Doerffel <tobydox/at/users.sourceforge.net>
* Copyright (c) 2006-2009 Tobias Doerffel <tobydox/at/users.sourceforge.net>
*
* This file is part of Linux MultiMedia Studio - http://lmms.sourceforge.net
*
@@ -35,7 +35,6 @@
#include "fx_mixer.h"
#include "fx_mixer_view.h"
#include "ladspa_2_lmms.h"
#include "local_resources_provider.h"
#include "main_window.h"
#include "mixer.h"
#include "pattern.h"
@@ -43,10 +42,13 @@
#include "preset_preview_play_handle.h"
#include "project_journal.h"
#include "project_notes.h"
#include "resources_db.h"
#include "song_editor.h"
#include "song.h"
#include "resources_db.h"
#include "local_resources_provider.h"
#include "unified_resources_provider.h"
bool engine::s_hasGUI = true;
bool engine::s_suppressMessages = false;
@@ -57,7 +59,7 @@ fxMixerView * engine::s_fxMixerView = NULL;
mainWindow * engine::s_mainWindow = NULL;
bbTrackContainer * engine::s_bbTrackContainer = NULL;
song * engine::s_song = NULL;
ResourcesDB * engine::s_resourcesDB = NULL;
UnifiedResourcesProvider * engine::s_resourcesProvider = NULL;
songEditor * engine::s_songEditor = NULL;
automationEditor * engine::s_automationEditor = NULL;
bbEditor * engine::s_bbEditor = NULL;
@@ -83,9 +85,21 @@ void engine::init( const bool _has_gui )
s_mixer = new mixer;
s_song = new song;
LocalResourcesProvider * resProv =
new LocalResourcesProvider( ResourcesItem::BaseWorkingDir, QString() );
s_resourcesDB = resProv->database();
// init resources framework
LocalResourcesProvider * workingDirResources =
new LocalResourcesProvider( ResourcesItem::BaseWorkingDir,
QString() );
LocalResourcesProvider * shippedResources =
new LocalResourcesProvider( ResourcesItem::BaseDataDir,
QString() );
UnifiedResourcesProvider * unifiedResources =
new UnifiedResourcesProvider;
unifiedResources->addDatabase( workingDirResources->database() );
unifiedResources->addDatabase( shippedResources->database() );
s_resourcesProvider = unifiedResources;
s_fxMixer = new fxMixer;
s_bbTrackContainer = new bbTrackContainer;
@@ -161,8 +175,8 @@ void engine::destroy( void )
delete s_song;
s_song = NULL;
delete s_resourcesDB;
s_resourcesDB = NULL;
delete s_resourcesProvider;
s_resourcesProvider = NULL;
delete configManager::inst();
}