X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=wizard%2Fbertos.py;h=1608334c57c2904a32362d09194982cae1c72f2d;hb=57dfb183e24175bc782647d4e6aebe31063f3881;hp=91646b7487983b0fdaa1c83df673c8a47f2f62d6;hpb=df9d729fb8f0f2d34197215920576381b895c7f7;p=bertos.git diff --git a/wizard/bertos.py b/wizard/bertos.py index 91646b74..1608334c 100755 --- a/wizard/bertos.py +++ b/wizard/bertos.py @@ -28,7 +28,6 @@ # # Copyright 2008 Develer S.r.l. (http://www.develer.com/) # -# $Id$ # # Author: Lorenzo Berni # @@ -42,33 +41,32 @@ from PyQt4.QtGui import * import exception_handler -import BProject +from BProject import BProject -import BStartPage -import BWizard +from BWizard import BWizard from BIntroPage import BIntroPage from BFolderPage import BFolderPage from BBoardPage import BBoardPage +from BProjectPresets import BProjectPresets from BOpenPage import BOpenPage from BVersionPage import BVersionPage from BCpuPage import BCpuPage from BToolchainPage import BToolchainPage from BModulePage import BModulePage -from BOutputPage import BOutputPage from BCreationPage import BCreationPage from BFinalPage import BFinalPage from BEditingDialog import BEditingDialog, BVersionDialog, BToolchainDialog -import bertos_utils -import const +from const import DATA_DIR from LoadException import VersionException, ToolchainException def newProject(): - page_list = [BIntroPage, BFolderPage, BBoardPage, BVersionPage, BCpuPage, BToolchainPage, BModulePage, BOutputPage, BCreationPage, BFinalPage] - wizard = BWizard.BWizard(page_list) + QApplication.instance().project = BProject() + page_list = [BIntroPage, BFolderPage, BVersionPage, BBoardPage, BProjectPresets, BCpuPage, BToolchainPage, BModulePage, BCreationPage, BFinalPage] + wizard = BWizard(page_list) wizard.show() wizard.exec_() project = QApplication.instance().project @@ -84,25 +82,32 @@ def newProject(): def editProject(project_file): info_dict = {} + # Progress dialog. + p_dialog = QProgressDialog(QApplication.instance().tr("Wait project loading"), QApplication.instance().tr("Cancel"), 0, 0) while(True): + p_dialog.show() + # Empty project is the default fallback. + QApplication.instance().project = BProject() try: - QApplication.instance().project = BProject.BProject(project_file, info_dict) + QApplication.instance().project = BProject(project_file, info_dict) except VersionException: + p_dialog.hide() QMessageBox.critical( None, QObject().tr("BeRTOS version not found!"), - QObject().tr("The selected BeRTOS version is not found, please select an existing one...") + QObject().tr("The selected BeRTOS version was not found, please select another one...") ) dialog = BVersionDialog() if dialog.exec_(): version = dialog.version_page.currentVersion() - info_dict["SOURCES_PATH"] = version + info_dict["BERTOS_PATH"] = version continue except ToolchainException, exc: + p_dialog.hide() QMessageBox.critical( None, QObject().tr("Toolchain not found!"), - QObject().tr("The selected toolchain is not found, please select an existing one...") + QObject().tr("The selected toolchain was not found, please select another one...") ) QApplication.instance().project = exc.partial_project dialog = BToolchainDialog() @@ -112,24 +117,29 @@ def editProject(project_file): continue break dialog = BEditingDialog() + p_dialog.hide() dialog.exec_() -def showStartPage(): - QApplication.instance().dialog = BStartPage.BStartPage() - QApplication.instance().connect(QApplication.instance().dialog, SIGNAL("newProject"), newProject) - QApplication.instance().connect(QApplication.instance().dialog, SIGNAL("editProject"), editProject) - QApplication.instance().dialog.show() - def main(): app = QApplication(sys.argv) app.settings = QSettings("Develer", "Bertos Configurator") - app.project = BProject.BProject() # Development utility lines, to be removed for production - datadir = const.DATA_DIR - qrc, rcc = os.path.join(datadir, 'bertos.qrc'), os.path.join(datadir, 'bertos.rcc') - if not (hasattr(sys, "frozen") and sys.frozen) and newer(qrc, rcc): - os.system("rcc -binary %s -o %s" %(qrc, rcc)) - QResource.registerResource(rcc) + datadir = DATA_DIR + + # Something seems to not work, on Windows, using pyrcc4 with BeRTOS Wizard + # resources. So I'm restoring the old rcc-based resource generation + # system. + # + # qrc, bertos_rc = os.path.join(datadir, 'bertos.qrc'), os.path.join(datadir, 'bertos_rc.py') + # if not (hasattr(sys, "frozen") and sys.frozen) and newer(qrc, bertos_rc): + # os.system("pyrcc4 \"%s\" -o \"%s\"" %(qrc, bertos_rc)) + # import bertos_rc + + qrc, rcc = os.path.join(datadir, 'bertos.qrc'), os.path.join(datadir, 'bertos.rcc') + if not (hasattr(sys, "frozen") and sys.frozen) and newer(qrc, rcc): + os.system("rcc -binary \"%s\" -o \"%s\"" %(qrc, rcc)) + QResource.registerResource(rcc) + if len(sys.argv) == 3 and sys.argv[1] == "--edit": editProject(os.path.abspath(sys.argv[2])) else: