X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=wizard%2Fbertos.py;h=24d61e03ff14f1cf49201535889d6adffdfdbd99;hb=4b501c175222af60573616b51e00adf00c13830f;hp=57dbe8af3ba1503bc8cad068efc7c84fc8b8686b;hpb=d6134e332db05f7591dd8f0c2d05c95425def2b1;p=bertos.git diff --git a/wizard/bertos.py b/wizard/bertos.py index 57dbe8af..24d61e03 100755 --- a/wizard/bertos.py +++ b/wizard/bertos.py @@ -40,11 +40,14 @@ from distutils.dep_util import newer from PyQt4.QtCore import * from PyQt4.QtGui import * +import exception_handler + import BProject import BStartPage import BWizard +from BIntroPage import BIntroPage from BFolderPage import BFolderPage from BOpenPage import BOpenPage from BVersionPage import BVersionPage @@ -55,12 +58,14 @@ from BOutputPage import BOutputPage from BCreationPage import BCreationPage from BFinalPage import BFinalPage -from BEditingDialog import BEditingDialog +from BEditingDialog import BEditingDialog, BVersionDialog, BToolchainDialog import bertos_utils +from LoadException import VersionException, ToolchainException + def newProject(): - page_list = [BFolderPage, BVersionPage, BCpuPage, BToolchainPage, BModulePage, BOutputPage, BCreationPage, BFinalPage] + page_list = [BIntroPage, BFolderPage, BVersionPage, BCpuPage, BToolchainPage, BModulePage, BOutputPage, BCreationPage, BFinalPage] wizard = BWizard.BWizard(page_list) wizard.show() wizard.exec_() @@ -76,7 +81,34 @@ def newProject(): sys.exit() def editProject(project_file): - QApplication.instance().project = bertos_utils.loadBertosProject(project_file) + info_dict = {} + while(True): + try: + QApplication.instance().project = bertos_utils.loadBertosProject(project_file, info_dict) + except VersionException: + QMessageBox.critical( + None, + QObject().tr("BeRTOS version not found!"), + QObject().tr("The selected BeRTOS version is not found, please select an existing one...") + ) + dialog = BVersionDialog() + if dialog.exec_(): + version = dialog.version_page.currentVersion() + info_dict["SOURCES_PATH"] = version + continue + except ToolchainException, exc: + QMessageBox.critical( + None, + QObject().tr("Toolchain not found!"), + QObject().tr("The selected toolchain is not found, please select an existing one...") + ) + QApplication.instance().project = exc.partial_project + dialog = BToolchainDialog() + if dialog.exec_(): + toolchain = dialog.toolchain_page.currentToolchain() + info_dict["TOOLCHAIN"] = toolchain + continue + break dialog = BEditingDialog() dialog.exec_() @@ -87,6 +119,7 @@ def showStartPage(): QApplication.instance().dialog.show() def main(): + rundir = os.getcwd() os.chdir(os.path.dirname(os.path.abspath(sys.argv[0]))) app = QApplication(sys.argv) app.settings = QSettings("Develer", "Bertos Configurator") @@ -96,7 +129,7 @@ def main(): os.system("rcc -binary bertos.qrc -o bertos.rcc") QResource.registerResource("bertos.rcc") if len(sys.argv) == 3 and sys.argv[1] == "--edit": - editProject(sys.argv[2]) + editProject(os.path.join(rundir, sys.argv[2])) else: newProject()