X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=wizard%2Fbertos.py;h=34b59839094c7b10a36d62c2362928fdd046ee4a;hb=a256e501c16b63a423267f8621d6bdcda20d3f3a;hp=edb131d67663c3f27282f592222dbefe158febf5;hpb=efa322fd22f708abb3cb46c750908b065ba6290e;p=bertos.git diff --git a/wizard/bertos.py b/wizard/bertos.py index edb131d6..34b59839 100755 --- a/wizard/bertos.py +++ b/wizard/bertos.py @@ -42,12 +42,14 @@ 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 BRoutePage import BRoutePage from BOpenPage import BOpenPage from BVersionPage import BVersionPage from BCpuPage import BCpuPage @@ -59,13 +61,14 @@ from BFinalPage import BFinalPage from BEditingDialog import BEditingDialog, BVersionDialog, BToolchainDialog -import bertos_utils +from const import DATA_DIR from LoadException import VersionException, ToolchainException def newProject(): - page_list = [BFolderPage, BVersionPage, BCpuPage, BToolchainPage, BModulePage, BOutputPage, BCreationPage, BFinalPage] - wizard = BWizard.BWizard(page_list) + QApplication.instance().project = BProject() + page_list = [BIntroPage, BFolderPage, BVersionPage, BBoardPage, BRoutePage, BCpuPage, BToolchainPage, BModulePage, BOutputPage, BCreationPage, BFinalPage] + wizard = BWizard(page_list) wizard.show() wizard.exec_() project = QApplication.instance().project @@ -78,12 +81,14 @@ def newProject(): relevant_file = relevant_files[ide] QProcess.startDetached(command_line, [relevant_file,]) sys.exit() - + def editProject(project_file): info_dict = {} while(True): + # Empty project is the default fallback. + QApplication.instance().project = BProject() try: - QApplication.instance().project = bertos_utils.loadBertosProject(project_file, info_dict) + QApplication.instance().project = BProject(project_file, info_dict) except VersionException: QMessageBox.critical( None, @@ -93,7 +98,7 @@ def editProject(project_file): dialog = BVersionDialog() if dialog.exec_(): version = dialog.version_page.currentVersion() - info_dict["SOURCES_PATH"] = version + info_dict["BERTOS_PATH"] = version continue except ToolchainException, exc: QMessageBox.critical( @@ -111,26 +116,20 @@ def editProject(project_file): dialog = BEditingDialog() 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(): - os.chdir(os.path.dirname(os.path.abspath(sys.argv[0]))) app = QApplication(sys.argv) app.settings = QSettings("Develer", "Bertos Configurator") - app.project = BProject.BProject() # Development utility lines, to be removed for production - if not (hasattr(sys, "frozen") and sys.frozen) and newer("bertos.qrc", "bertos.rcc"): - os.system("rcc -binary bertos.qrc -o bertos.rcc") - QResource.registerResource("bertos.rcc") + datadir = 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) if len(sys.argv) == 3 and sys.argv[1] == "--edit": - editProject(sys.argv[2]) + editProject(os.path.abspath(sys.argv[2])) else: newProject() - + if __name__ == '__main__': main()