#!/usr/bin/env python
# encoding: utf-8
#
-# This file is part of slimqc.
+# 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
# Author: Lorenzo Berni <duplo@develer.com>
#
+import os
+
from PyQt4.QtCore import *
from PyQt4.QtGui import *
from BCpuPage import BCpuPage
from BOutputPage import BOutputPage
+from BRoutePage import BRoutePage
import const
import qvariant_converter
"""
Overload of the QWizardPage isComplete method.
"""
- return self.pageContent.boardList.currentItem() is not None
+ if self.selected:
+ _info_dict = qvariant_converter.getDict(self.selected.data(0, Qt.UserRole))
+ _type = _info_dict["type"]
+ type = qvariant_converter.getString(_type)
+ if type == "project":
+ self.setProjectInfo("PROJECT_PRESET", qvariant_converter.getString(_info_dict["path"]))
+ return True
+ else:
+ return False
+ else:
+ return False
def nextId(self):
"""
Overload of the QWizardPage nextId method.
"""
- # Stub of nextId logic
- if self.advanced:
- self.setProjectInfo("PRESET_ADVANCED_CONFIG", True)
- return self.wizard().pageIndex(BCpuPage)
- # Search for suitable toolchains. If there isn't one return
- # BToolchainPage id (BToolchainPage should then route to BOutputPage
- # instead of BModulePage).
-
- # If a suitable toolchain is found the user has to be prompted
- # directly to the BOutputPage
- else:
- return self.wizard().pageIndex(BOutputPage)
+ return self.wizard().pageIndex(BRoutePage)
####
"""
Overload of the BWizardPage connectSignals method.
"""
- self.connect(self.pageContent.boardList, SIGNAL('itemSelectionChanged()'), self.itemSelectionChanged)
+ self.connect(self.pageContent.boardTree, SIGNAL("itemSelectionChanged()"), self, SIGNAL("completeChanged()"))
def reloadData(self):
"""
Overload of the BWizardPage reloadData method.
"""
- presets = presetList("/Users/duplo/Development/bertos")
- self.setProjectInfo("PRESETS", presets)
- self.populatePresetList()
-
- def populatePresetList(self):
- self.pageContent.boardList.clear()
- presets = self.projectInfo("PRESETS")
- for preset, info in presets.items():
- board_list = self.pageContent.boardList
- item = QListWidgetItem(info["PRESET_NAME"], board_list)
- item.setData(Qt.UserRole, qvariant_converter.convertString(preset))
- if self._last_selected == preset:
- self.pageContent.boardList.setCurrentItem(item)
- if not self._last_selected and self.pageContent.boardList.count():
- self.pageContent.boardList.setCurrentRow(0)
+ self._fillPresetTree()
####
## Slots ##
- def itemSelectionChanged(self):
- preset_path = qvariant_converter.getString(self.pageContent.boardList.currentItem().data(Qt.UserRole))
- presets = self.projectInfo("PRESETS")
- selected_preset = presets[preset_path]
- text_components = [
- "Board: %s" %selected_preset["PRESET_NAME"],
- "CPU: %s" %selected_preset["CPU_NAME"],
- ]
- if selected_preset["PRESET_DESCRIPTION"]:
- text_components.append("Description: %s" %selected_preset["PRESET_DESCRIPTION"])
- text = "\n".join(text_components)
- self.pageContent.descriptionLabel.setText(text)
- self._last_selected = preset_path
- self.emit(SIGNAL("completeChanged()"))
####
@property
- def advanced(self):
- return self.pageContent.advancedCheckBox.isChecked()
\ No newline at end of file
+ def selected(self):
+ # We can only take the selected item list (not the single item)
+ _selected_items = self.pageContent.boardTree.selectedItems()
+ if _selected_items:
+ return _selected_items[0]
+ else:
+ return None
+
+ def _fillPresetTree(self):
+ self.pageContent.boardTree.clear()
+ self.project.loadProjectPresets()
+ preset_tree = self.project.info("PRESET_TREE")
+ for obj in preset_tree["children"]:
+ self._createPresetNode(self.pageContent.boardTree, obj)
+
+ def _createPresetNode(self, parent, obj):
+ item_name = obj["info"].get("name", obj["info"]["filename"])
+ item = QTreeWidgetItem(parent, [item_name])
+ item.setIcon(0, QIcon(self._getNodeIcon(obj)))
+ children_dict = obj["children"]
+ item.setData(0, Qt.UserRole, qvariant_converter.convertDict(obj["info"]))
+ for child in children_dict:
+ self._createPresetNode(item, child)
+
+ def _getNodeIcon(self, obj):
+ icon_file = os.path.join(obj["info"]["path"], const.PREDEFINED_BOARD_ICON_FILE)
+ if os.path.exists(icon_file):
+ return icon_file
+ elif obj["info"]["type"] == "dir":
+ return const.PREDEFINED_BOARD_DEFAULT_DIR_ICON
+ else:
+ return const.PREDEFINED_BOARD_DEFAULT_PROJECT_ICON