Slight refactor of the mod edit dialog constructor

Also some other insignificant refactors
This commit is contained in:
Petr Mrázek 2013-08-27 20:29:27 +02:00
parent 73f534939a
commit a266e5d0cc
3 changed files with 43 additions and 26 deletions

View File

@ -28,29 +28,46 @@ LegacyModEditDialog::LegacyModEditDialog( LegacyInstance* inst, QWidget* parent
ui(new Ui::LegacyModEditDialog) ui(new Ui::LegacyModEditDialog)
{ {
ui->setupUi(this); ui->setupUi(this);
ensureFolderPathExists(m_inst->coreModsDir());
ensureFolderPathExists(m_inst->mlModsDir());
ensureFolderPathExists(m_inst->jarModsDir());
m_mods = m_inst->loaderModList(); // Jar mods
m_coremods = m_inst->coreModList(); {
m_jarmods = m_inst->jarModList(); ensureFolderPathExists(m_inst->jarModsDir());
m_texturepacks = m_inst->texturePackList(); m_jarmods = m_inst->jarModList();
ui->jarModsTreeView->setModel(m_jarmods.data());
ui->jarModsTreeView->setModel(m_jarmods.data()); /*
//ui->jarModsTreeView->setDragDropMode(QAbstractItemView::DragDrop); // FIXME: internal DnD causes segfaults later
ui->coreModsTreeView->setModel(m_coremods.data()); ui->jarModsTreeView->setDragDropMode(QAbstractItemView::DragDrop);
ui->mlModTreeView->setModel(m_mods.data()); // FIXME: DnD is glitched with contiguous (we move only first item in selection)
ui->texPackTreeView->setModel(m_texturepacks.data()); ui->jarModsTreeView->setSelectionMode(QAbstractItemView::SingleSelection);
*/
ui->jarModsTreeView->installEventFilter( this ); ui->jarModsTreeView->installEventFilter( this );
ui->coreModsTreeView->installEventFilter( this ); m_jarmods->startWatching();
ui->mlModTreeView->installEventFilter( this ); }
ui->texPackTreeView->installEventFilter( this ); // Core mods
m_mods->startWatching(); {
m_coremods->startWatching(); ensureFolderPathExists(m_inst->coreModsDir());
m_jarmods->startWatching(); m_coremods = m_inst->coreModList();
m_texturepacks->startWatching(); ui->coreModsTreeView->setModel(m_coremods.data());
ui->coreModsTreeView->installEventFilter( this );
m_coremods->startWatching();
}
// Loader mods
{
ensureFolderPathExists(m_inst->loaderModsDir());
m_mods = m_inst->loaderModList();
ui->mlModTreeView->setModel(m_mods.data());
ui->mlModTreeView->installEventFilter( this );
m_mods->startWatching();
}
// texture packs
{
m_texturepacks = m_inst->texturePackList();
ui->texPackTreeView->setModel(m_texturepacks.data());
ui->texPackTreeView->installEventFilter( this );
m_texturepacks->startWatching();
}
} }
LegacyModEditDialog::~LegacyModEditDialog() LegacyModEditDialog::~LegacyModEditDialog()
@ -294,7 +311,7 @@ void LegacyModEditDialog::on_viewCoreBtn_clicked()
} }
void LegacyModEditDialog::on_viewModBtn_clicked() void LegacyModEditDialog::on_viewModBtn_clicked()
{ {
openDirInDefaultProgram(m_inst->mlModsDir(), true); openDirInDefaultProgram(m_inst->loaderModsDir(), true);
} }
void LegacyModEditDialog::on_viewTexPackBtn_clicked() void LegacyModEditDialog::on_viewTexPackBtn_clicked()
{ {

View File

@ -124,7 +124,7 @@ QSharedPointer< ModList > LegacyInstance::loaderModList()
I_D(LegacyInstance); I_D(LegacyInstance);
if(!d->loader_mod_list) if(!d->loader_mod_list)
{ {
d->loader_mod_list.reset(new ModList(mlModsDir())); d->loader_mod_list.reset(new ModList(loaderModsDir()));
} }
else else
d->loader_mod_list->update(); d->loader_mod_list->update();
@ -171,7 +171,7 @@ QString LegacyInstance::savesDir() const
return PathCombine(minecraftRoot(), "saves"); return PathCombine(minecraftRoot(), "saves");
} }
QString LegacyInstance::mlModsDir() const QString LegacyInstance::loaderModsDir() const
{ {
return PathCombine(minecraftRoot(), "mods"); return PathCombine(minecraftRoot(), "mods");
} }

View File

@ -29,7 +29,7 @@ public:
QString texturePackDir() const; QString texturePackDir() const;
QString jarModsDir() const; QString jarModsDir() const;
QString binDir() const; QString binDir() const;
QString mlModsDir() const; QString loaderModsDir() const;
QString coreModsDir() const; QString coreModsDir() const;
QString resourceDir() const; QString resourceDir() const;
virtual QString instanceConfigFolder() const; virtual QString instanceConfigFolder() const;