--- Vago/trunk/Vago/mainwindow.cpp 2013/04/06 23:30:00 793 +++ Vago/trunk/Vago/mainwindow.cpp 2013/04/07 15:36:17 801 @@ -9,19 +9,21 @@ MainWindow::MainWindow(QWidget *parent) { ui->setupUi(this); + this->AppDir=getOSIndependentAppPath(); + this->setWindowTitle("Vago v"+GlobalVars::AppVersion); - if(!QFile::exists(QDir::currentPath()+"/"+GlobalVars::OniSplitString)){ + if(!QFile::exists(this->AppDir+"/"+GlobalVars::OniSplitString)){ Util::showErrorPopUp("OniSplit not found. Please download it at "+GlobalVars::ModsDomain+" and put it in the same folder of Vago. \n\nProgram will now exit."); exit(1); } - if(!QFile::exists(QDir::currentPath()+"/"+GlobalVars::XmlToolsString)){ + if(!QFile::exists(this->AppDir+"/"+GlobalVars::XmlToolsString)){ Util::showErrorPopUp("xmlTools not found. Please download it at "+GlobalVars::ModsDomain+" and put it in the same folder of Vago. \n\nProgram will now exit."); exit(1); } - this->vagoSettings = new QSettings(QDir::currentPath() + "/" + this->VagoSettingsName, QSettings::IniFormat); + this->vagoSettings = new QSettings(this->AppDir + "/" + this->VagoSettingsName, QSettings::IniFormat); //First Execution? Old configuration? Settings missed? bool iniChanged=false; @@ -30,7 +32,7 @@ MainWindow::MainWindow(QWidget *parent) iniChanged=true; } if(!this->vagoSettings->contains("Workspace")){ - this->vagoSettings->setValue("Workspace", QDir::currentPath()+"/VagoWorkspace"); + this->vagoSettings->setValue("Workspace", this->AppDir+"/VagoWorkspace"); iniChanged=true; } if(!this->vagoSettings->contains("AeFolder")){ @@ -119,6 +121,8 @@ MainWindow::MainWindow(QWidget *parent) ui->actionMac_Windows_demo->setChecked(true); resize(800,600); // Mac OS pcs should be able to render this resolution without any problem. It's also better // because the components on mac use more space +#else + resize(640,480); #endif connectSlots(); @@ -158,7 +162,7 @@ void MainWindow::on_actionAE_Package_Cre void MainWindow::on_actionSound_Wizard_triggered() { - SoundWizard myWizard (this->workspaceWizardsLocation, this->myLogger, &this->commandMap); + SoundWizard myWizard (this->AppDir, this->workspaceWizardsLocation, this->myLogger, &this->commandMap); myWizard.exec(); } @@ -1497,6 +1501,22 @@ void MainWindow::setConverterButtonsSize ui->pbConvertMisc->setMinimumHeight(height); } +/** + Gets application directory. In mac os gets the .app directory + **/ +QString MainWindow::getOSIndependentAppPath(){ +#ifdef Q_WS_MAC + QDir dir = QDir::current(); + if(dir.absolutePath().contains(".app")){ // include bundle, but we don't want it + dir.cdUp(); + dir.cdUp(); + } + return dir.absolutePath(); +#else + return QDir::currentPath(); +#endif +} + void MainWindow::connectSlots(){ //This signal is for thread that is working setup the progress bar (make it visible and set it's min-max)