X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=wizard%2Fbertos.py;h=05ecf7af3c927fab08717f255d356d0681fda27c;hb=75fbf8837e509b76d1489d0be4c3471d718cc352;hp=393fc561d95b5062cdabba88947cee84e12f41b7;hpb=dae3da05b3677c4a6b5ea04e93473587005b90c0;p=bertos.git diff --git a/wizard/bertos.py b/wizard/bertos.py index 393fc561..05ecf7af 100755 --- a/wizard/bertos.py +++ b/wizard/bertos.py @@ -1,8 +1,32 @@ -#!/usr/bin/env python +#!/usr/bin/env python # encoding: utf-8 # +# This file is part of BeRTOS. +# +# Bertos is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +# +# As a special exception, you may use this file as part of a free software +# library without restriction. Specifically, if other files instantiate +# templates or use macros or inline functions from this file, or you compile +# this file and link it with other files to produce an executable, this +# file does not by itself cause the resulting executable to be covered by +# the GNU General Public License. This exception does not however +# invalidate any other reasons why the executable file might be covered by +# the GNU General Public License. +# # Copyright 2008 Develer S.r.l. (http://www.develer.com/) -# All rights reserved. # # $Id$ # @@ -16,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 @@ -31,19 +58,59 @@ from BOutputPage import BOutputPage from BCreationPage import BCreationPage from BFinalPage import BFinalPage +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_() + 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(): - page_list = [BOpenPage, BVersionPage, BCpuPage, BToolchainPage, BModulePage, BOutputPage, BCreationPage, BFinalPage] - wizard = BWizard.BWizard(page_list) - wizard.show() - wizard.exec_() +def editProject(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_() def showStartPage(): QApplication.instance().dialog = BStartPage.BStartPage() @@ -57,21 +124,14 @@ def main(): app.settings = QSettings("Develer", "Bertos Configurator") app.project = BProject.BProject() # Development utility lines, to be removed for production - if newer("bertos.qrc", "bertos.rcc"): + 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") - if "--create" in sys.argv and "--edit" not in sys.argv: - newProject() - elif "--edit" in sys.argv and "--create" not in sys.argv: - editProject() - elif "--create" in sys.argv and "--edit" in sys.argv: - # TODO need an explaining message - print " ".join(sys.argv) - print "Invalid usage!" - pass + if len(sys.argv) == 3 and sys.argv[1] == "--edit": + editProject(sys.argv[2]) else: - showStartPage() - sys.exit(app.exec_()) + newProject() + if __name__ == '__main__': main()