- if wizard.exec_():
- prj = wizard.project()
- output = prj.info("OUTPUT")
- if output == "makefile":
- ## Now only supports the BeRTOS build system
- bertos_utils.createBertosProject(prj)
-
-def editProject():
- print "editProject"
-
-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()
+ wizard.exec_()
+ project = QApplication.instance().project
+ to_be_opened = project.info("TO_BE_OPENED")
+ command_lines = project.info("COMMAND_LINES")
+ relevant_files = project.info("RELEVANT_FILES")
+ if to_be_opened:
+ for ide in to_be_opened:
+ command_line = command_lines[ide]
+ 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 = BProject(project_file, info_dict)
+ except VersionException:
+ QMessageBox.critical(
+ None,
+ QObject().tr("BeRTOS version not found!"),
+ 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["BERTOS_PATH"] = version
+ continue
+ except ToolchainException, exc:
+ QMessageBox.critical(
+ None,
+ QObject().tr("Toolchain not found!"),
+ QObject().tr("The selected toolchain was not found, please select another 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_()