author | Edouard Tisserant |
Wed, 06 Mar 2013 11:39:35 +0900 | |
changeset 772 | 7cb6e71d6331 |
parent 761 | efff55931763 |
child 782 | c0869429c72a |
permissions | -rw-r--r-- |
205 | 1 |
#!/usr/bin/env python |
2 |
# -*- coding: utf-8 -*- |
|
3 |
||
4 |
#This file is part of CanFestival, a library implementing CanOpen Stack. |
|
5 |
# |
|
6 |
#Copyright (C): Edouard TISSERANT, Francis DUPIN and Laurent BESSARD |
|
7 |
# |
|
8 |
#See COPYING file for copyrights details. |
|
9 |
# |
|
10 |
#This library is free software; you can redistribute it and/or |
|
11 |
#modify it under the terms of the GNU Lesser General Public |
|
12 |
#License as published by the Free Software Foundation; either |
|
13 |
#version 2.1 of the License, or (at your option) any later version. |
|
14 |
# |
|
15 |
#This library is distributed in the hope that it will be useful, |
|
16 |
#but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
17 |
#MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|
18 |
#Lesser General Public License for more details. |
|
19 |
# |
|
20 |
#You should have received a copy of the GNU Lesser General Public |
|
21 |
#License along with this library; if not, write to the Free Software |
|
22 |
#Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
|
23 |
||
24 |
import wx |
|
25 |
import wx.grid |
|
26 |
||
27 |
from types import * |
|
281
685d9a26e4f9
Obsolete example files in objdictgen/examples replaced by some new equivalents
lbessard
parents:
277
diff
changeset
|
28 |
from commondialogs import * |
205 | 29 |
|
206 | 30 |
from node import OD_Subindex, OD_MultipleSubindexes, OD_IdenticalSubindexes, OD_IdenticalIndexes |
205 | 31 |
|
32 |
ColSizes = [75, 250, 150, 125, 100, 60, 250] |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
33 |
ColAlignements = [wx.ALIGN_CENTER, wx.ALIGN_LEFT, wx.ALIGN_CENTER, wx.ALIGN_RIGHT, wx.ALIGN_CENTER, wx.ALIGN_CENTER, wx.ALIGN_LEFT] |
580 | 34 |
|
35 |
def GetAccessList(write=True): |
|
36 |
_ = lambda x : x |
|
37 |
if write: |
|
38 |
return [_("Read Only"), _("Write Only"), _("Read/Write")] |
|
39 |
return [_("Read Only"), _("Read/Write")] |
|
584
e23359f62023
Bug with in access value translation and modification on subindex 0 of PDOmapping entries fixed
laurent
parents:
580
diff
changeset
|
40 |
AccessList = ",".join(map(_, GetAccessList())) |
e23359f62023
Bug with in access value translation and modification on subindex 0 of PDOmapping entries fixed
laurent
parents:
580
diff
changeset
|
41 |
RAccessList = ",".join(map(_, GetAccessList(False))) |
580 | 42 |
ACCESS_LIST_DICT = dict([(_(access), access) for access in GetAccessList()]) |
43 |
||
44 |
def GetBoolList(): |
|
45 |
_ = lambda x : x |
|
46 |
return [_("True"), _("False")] |
|
584
e23359f62023
Bug with in access value translation and modification on subindex 0 of PDOmapping entries fixed
laurent
parents:
580
diff
changeset
|
47 |
BoolList = ",".join(map(_, GetBoolList())) |
580 | 48 |
BOOL_LIST_DICT = dict([(_(bool), bool) for bool in GetBoolList()]) |
49 |
||
50 |
def GetOptionList(): |
|
51 |
_ = lambda x : x |
|
52 |
return [_("Yes"), _("No")] |
|
584
e23359f62023
Bug with in access value translation and modification on subindex 0 of PDOmapping entries fixed
laurent
parents:
580
diff
changeset
|
53 |
OptionList = ",".join(map(_, GetOptionList())) |
580 | 54 |
OPTION_LIST_DICT = dict([(_(option), option) for option in GetOptionList()]) |
55 |
||
56 |
[USER_TYPE, SDO_SERVER, SDO_CLIENT, |
|
57 |
PDO_TRANSMIT, PDO_RECEIVE, MAP_VARIABLE] = range(6) |
|
58 |
||
59 |
INDEXCHOICE_OPTIONS = { |
|
60 |
USER_TYPE: (_("User Type"), 0, "AddUserType"), |
|
61 |
SDO_SERVER: (_("SDO Server"), 1, "AddSDOServerToCurrent"), |
|
62 |
SDO_CLIENT: (_("SDO Client"), 1, "AddSDOClientToCurrent"), |
|
63 |
PDO_RECEIVE: (_("PDO Receive"), 1, "AddPDOReceiveToCurrent"), |
|
64 |
PDO_TRANSMIT: (_("PDO Transmit"), 1, "AddPDOTransmitToCurrent"), |
|
65 |
MAP_VARIABLE: (_("Map Variable"), 0, "AddMapVariable") |
|
66 |
} |
|
67 |
||
68 |
INDEXCHOICE_OPTIONS_DICT = dict([(translation, option) for option, (translation, object, function) in INDEXCHOICE_OPTIONS.iteritems()]) |
|
69 |
||
70 |
INDEXCHOICE_SECTIONS = { |
|
71 |
0 : [USER_TYPE], |
|
72 |
2 : [SDO_SERVER, SDO_CLIENT], |
|
73 |
3 : [PDO_RECEIVE], |
|
74 |
4 : [PDO_RECEIVE], |
|
75 |
5 : [PDO_TRANSMIT], |
|
76 |
6 : [PDO_TRANSMIT], |
|
77 |
8 : [MAP_VARIABLE], |
|
78 |
} |
|
79 |
||
80 |
def GetSubindexTableColnames(): |
|
81 |
_ = lambda x : x |
|
82 |
return [_("subindex"), _("name"), _("type"), _("value"), _("access"), _("save"), _("comment")] |
|
205 | 83 |
|
84 |
DictionaryOrganisation = [ |
|
85 |
{"minIndex" : 0x0001, "maxIndex" : 0x0FFF, "name" : "Data Type Definitions"}, |
|
86 |
{"minIndex" : 0x1000, "maxIndex" : 0x1029, "name" : "Communication Parameters"}, |
|
87 |
{"minIndex" : 0x1200, "maxIndex" : 0x12FF, "name" : "SDO Parameters"}, |
|
88 |
{"minIndex" : 0x1400, "maxIndex" : 0x15FF, "name" : "Receive PDO Parameters"}, |
|
89 |
{"minIndex" : 0x1600, "maxIndex" : 0x17FF, "name" : "Receive PDO Mapping"}, |
|
90 |
{"minIndex" : 0x1800, "maxIndex" : 0x19FF, "name" : "Transmit PDO Parameters"}, |
|
91 |
{"minIndex" : 0x1A00, "maxIndex" : 0x1BFF, "name" : "Transmit PDO Mapping"}, |
|
92 |
{"minIndex" : 0x1C00, "maxIndex" : 0x1FFF, "name" : "Other Communication Parameters"}, |
|
93 |
{"minIndex" : 0x2000, "maxIndex" : 0x5FFF, "name" : "Manufacturer Specific"}, |
|
94 |
{"minIndex" : 0x6000, "maxIndex" : 0x9FFF, "name" : "Standardized Device Profile"}, |
|
95 |
{"minIndex" : 0xA000, "maxIndex" : 0xBFFF, "name" : "Standardized Interface Profile"}] |
|
96 |
||
747
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
97 |
IECTypeConversion = { |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
98 |
"BOOLEAN": "BOOL", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
99 |
"INTEGER8": "SINT", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
100 |
"INTEGER16": "INT", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
101 |
"INTEGER32": "DINT", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
102 |
"UNSIGNED8": "USINT", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
103 |
"UNSIGNED16": "UINT", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
104 |
"UNSIGNED32": "UDINT", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
105 |
"REAL32": "REAL", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
106 |
"VISIBLE_STRING": "STRING", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
107 |
"OCTET_STRING": "STRING", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
108 |
"UNICODE_STRING": "WSTRING", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
109 |
"DOMAIN": "STRING", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
110 |
"INTEGER24": "DINT", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
111 |
"REAL64": "LREAL", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
112 |
"INTEGER40": "LINT", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
113 |
"INTEGER48": "LINT", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
114 |
"INTEGER56": "LINT", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
115 |
"INTEGER64": "LINT", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
116 |
"UNSIGNED24": "UDINT", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
117 |
"UNSIGNED40": "ULINT", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
118 |
"UNSIGNED48": "ULINT", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
119 |
"UNSIGNED56": "ULINT", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
120 |
"UNSIGNED64": "ULINT", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
121 |
} |
242
4864f7f01e1d
Changes in networkedit for integration with beremiz
lbessard
parents:
237
diff
changeset
|
122 |
SizeConversion = {1 : "X", 8 : "B", 16 : "W", 24 : "D", 32 : "D", 40 : "L", 48 : "L", 56 : "L", 64 : "L"} |
4864f7f01e1d
Changes in networkedit for integration with beremiz
lbessard
parents:
237
diff
changeset
|
123 |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
124 |
class SubindexTable(wx.grid.PyGridTableBase): |
205 | 125 |
|
126 |
""" |
|
127 |
A custom wxGrid Table using user supplied data |
|
128 |
""" |
|
129 |
def __init__(self, parent, data, editors, colnames): |
|
130 |
# The base class must be initialized *first* |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
131 |
wx.grid.PyGridTableBase.__init__(self) |
205 | 132 |
self.data = data |
133 |
self.editors = editors |
|
134 |
self.CurrentIndex = 0 |
|
135 |
self.colnames = colnames |
|
136 |
self.Parent = parent |
|
137 |
self.Editable = True |
|
138 |
# XXX |
|
139 |
# we need to store the row length and collength to |
|
140 |
# see if the table has changed size |
|
141 |
self._rows = self.GetNumberRows() |
|
142 |
self._cols = self.GetNumberCols() |
|
143 |
||
144 |
def Disable(self): |
|
145 |
self.Editable = False |
|
146 |
||
147 |
def Enable(self): |
|
148 |
self.Editable = True |
|
149 |
||
150 |
def GetNumberCols(self): |
|
151 |
return len(self.colnames) |
|
152 |
||
153 |
def GetNumberRows(self): |
|
154 |
return len(self.data) |
|
155 |
||
580 | 156 |
def GetColLabelValue(self, col, translate=True): |
205 | 157 |
if col < len(self.colnames): |
580 | 158 |
if translate: |
159 |
return _(self.colnames[col]) |
|
205 | 160 |
return self.colnames[col] |
161 |
||
580 | 162 |
def GetRowLabelValues(self, row, translate=True): |
205 | 163 |
return row |
164 |
||
584
e23359f62023
Bug with in access value translation and modification on subindex 0 of PDOmapping entries fixed
laurent
parents:
580
diff
changeset
|
165 |
def GetValue(self, row, col, translate=True): |
205 | 166 |
if row < self.GetNumberRows(): |
580 | 167 |
colname = self.GetColLabelValue(col, False) |
168 |
value = unicode(self.data[row].get(colname, "")) |
|
584
e23359f62023
Bug with in access value translation and modification on subindex 0 of PDOmapping entries fixed
laurent
parents:
580
diff
changeset
|
169 |
if translate and (colname == "access" or |
e23359f62023
Bug with in access value translation and modification on subindex 0 of PDOmapping entries fixed
laurent
parents:
580
diff
changeset
|
170 |
self.editors[row][colname] in ["bool", "option"] or |
e23359f62023
Bug with in access value translation and modification on subindex 0 of PDOmapping entries fixed
laurent
parents:
580
diff
changeset
|
171 |
self.editors[row][colname] == "map" and value == "None"): |
580 | 172 |
value = _(value) |
173 |
return value |
|
266 | 174 |
|
205 | 175 |
def GetEditor(self, row, col): |
176 |
if row < self.GetNumberRows(): |
|
580 | 177 |
return self.editors[row].get(self.GetColLabelValue(col, False), "") |
205 | 178 |
|
179 |
def GetValueByName(self, row, colname): |
|
180 |
return self.data[row].get(colname) |
|
181 |
||
182 |
def SetValue(self, row, col, value): |
|
183 |
if col < len(self.colnames): |
|
580 | 184 |
colname = self.GetColLabelValue(col, False) |
584
e23359f62023
Bug with in access value translation and modification on subindex 0 of PDOmapping entries fixed
laurent
parents:
580
diff
changeset
|
185 |
if colname == "access": |
580 | 186 |
value = ACCESS_LIST_DICT[value] |
187 |
elif self.editors[row][colname] == "bool": |
|
188 |
value = BOOL_LIST_DICT[value] |
|
189 |
elif self.editors[row][colname] == "option": |
|
190 |
value = OPTION_LIST_DICT[value] |
|
584
e23359f62023
Bug with in access value translation and modification on subindex 0 of PDOmapping entries fixed
laurent
parents:
580
diff
changeset
|
191 |
elif self.editors[row][colname] == "map" and value == _("None"): |
e23359f62023
Bug with in access value translation and modification on subindex 0 of PDOmapping entries fixed
laurent
parents:
580
diff
changeset
|
192 |
value = "None" |
580 | 193 |
self.data[row][colname] = value |
205 | 194 |
|
195 |
def ResetView(self, grid): |
|
196 |
""" |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
197 |
(wx.grid.Grid) -> Reset the grid view. Call this to |
205 | 198 |
update the grid if rows and columns have been added or deleted |
199 |
""" |
|
200 |
grid.BeginBatch() |
|
201 |
for current, new, delmsg, addmsg in [ |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
202 |
(self._rows, self.GetNumberRows(), wx.grid.GRIDTABLE_NOTIFY_ROWS_DELETED, wx.grid.GRIDTABLE_NOTIFY_ROWS_APPENDED), |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
203 |
(self._cols, self.GetNumberCols(), wx.grid.GRIDTABLE_NOTIFY_COLS_DELETED, wx.grid.GRIDTABLE_NOTIFY_COLS_APPENDED), |
205 | 204 |
]: |
205 |
if new < current: |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
206 |
msg = wx.grid.GridTableMessage(self,delmsg,new,current-new) |
205 | 207 |
grid.ProcessTableMessage(msg) |
208 |
elif new > current: |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
209 |
msg = wx.grid.GridTableMessage(self,addmsg,new-current) |
205 | 210 |
grid.ProcessTableMessage(msg) |
211 |
self.UpdateValues(grid) |
|
212 |
grid.EndBatch() |
|
213 |
||
214 |
self._rows = self.GetNumberRows() |
|
215 |
self._cols = self.GetNumberCols() |
|
216 |
# update the column rendering scheme |
|
217 |
self._updateColAttrs(grid) |
|
218 |
||
219 |
# update the scrollbars and the displayed part of the grid |
|
220 |
grid.AdjustScrollbars() |
|
221 |
grid.ForceRefresh() |
|
222 |
||
223 |
||
224 |
def UpdateValues(self, grid): |
|
225 |
"""Update all displayed values""" |
|
226 |
# This sends an event to the grid table to update all of the values |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
227 |
msg = wx.grid.GridTableMessage(self, wx.grid.GRIDTABLE_REQUEST_VIEW_GET_VALUES) |
205 | 228 |
grid.ProcessTableMessage(msg) |
229 |
||
230 |
def _updateColAttrs(self, grid): |
|
231 |
""" |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
232 |
wx.grid.Grid -> update the column attributes to add the |
205 | 233 |
appropriate renderer given the column name. |
234 |
||
235 |
Otherwise default to the default renderer. |
|
236 |
""" |
|
237 |
||
238 |
for col in range(self.GetNumberCols()): |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
239 |
attr = wx.grid.GridCellAttr() |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
240 |
attr.SetAlignment(ColAlignements[col], wx.ALIGN_CENTRE) |
205 | 241 |
grid.SetColAttr(col, attr) |
580 | 242 |
grid.SetColMinimalWidth(col, ColSizes[col]) |
243 |
grid.AutoSizeColumn(col, False) |
|
205 | 244 |
|
245 |
typelist = None |
|
246 |
maplist = None |
|
247 |
for row in range(self.GetNumberRows()): |
|
248 |
editors = self.editors[row] |
|
757
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
249 |
if wx.Platform == '__WXMSW__': |
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
250 |
grid.SetRowMinimalHeight(row, 20) |
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
251 |
else: |
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
252 |
grid.SetRowMinimalHeight(row, 28) |
585
d62424ba12bf
Replacing wx.Choice controls by wx.ComboBox controls
laurent
parents:
584
diff
changeset
|
253 |
grid.AutoSizeRow(row, False) |
205 | 254 |
for col in range(self.GetNumberCols()): |
255 |
editor = None |
|
256 |
renderer = None |
|
257 |
||
580 | 258 |
colname = self.GetColLabelValue(col, False) |
205 | 259 |
editortype = editors[colname] |
757
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
260 |
if editortype == "dcf": |
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
261 |
editor = wx.grid.GridCellTextEditor() |
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
262 |
renderer = wx.grid.GridCellStringRenderer() |
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
263 |
elif editortype and self.Editable: |
205 | 264 |
grid.SetReadOnly(row, col, False) |
265 |
if editortype == "string": |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
266 |
editor = wx.grid.GridCellTextEditor() |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
267 |
renderer = wx.grid.GridCellStringRenderer() |
205 | 268 |
if colname == "value" and "length" in editors: |
269 |
editor.SetParameters(editors["length"]) |
|
270 |
elif editortype == "number": |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
271 |
editor = wx.grid.GridCellNumberEditor() |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
272 |
renderer = wx.grid.GridCellNumberRenderer() |
205 | 273 |
if colname == "value" and "min" in editors and "max" in editors: |
274 |
editor.SetParameters("%s,%s"%(editors["min"],editors["max"])) |
|
453 | 275 |
elif editortype == "float": |
276 |
editor = wx.grid.GridCellTextEditor() |
|
277 |
renderer = wx.grid.GridCellStringRenderer() |
|
205 | 278 |
elif editortype == "bool": |
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
279 |
editor = wx.grid.GridCellChoiceEditor() |
205 | 280 |
editor.SetParameters(BoolList) |
281 |
elif editortype == "access": |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
282 |
editor = wx.grid.GridCellChoiceEditor() |
205 | 283 |
editor.SetParameters(AccessList) |
284 |
elif editortype == "raccess": |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
285 |
editor = wx.grid.GridCellChoiceEditor() |
205 | 286 |
editor.SetParameters(RAccessList) |
287 |
elif editortype == "option": |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
288 |
editor = wx.grid.GridCellChoiceEditor() |
205 | 289 |
editor.SetParameters(OptionList) |
290 |
elif editortype == "type": |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
291 |
editor = wx.grid.GridCellChoiceEditor() |
205 | 292 |
if typelist == None: |
293 |
typelist = self.Parent.Manager.GetCurrentTypeList() |
|
294 |
editor.SetParameters(typelist) |
|
295 |
elif editortype == "map": |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
296 |
editor = wx.grid.GridCellChoiceEditor() |
205 | 297 |
if maplist == None: |
298 |
maplist = self.Parent.Manager.GetCurrentMapList() |
|
299 |
editor.SetParameters(maplist) |
|
300 |
elif editortype == "time": |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
301 |
editor = wx.grid.GridCellTextEditor() |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
302 |
renderer = wx.grid.GridCellStringRenderer() |
205 | 303 |
elif editortype == "domain": |
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
304 |
editor = wx.grid.GridCellTextEditor() |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
305 |
renderer = wx.grid.GridCellStringRenderer() |
205 | 306 |
else: |
307 |
grid.SetReadOnly(row, col, True) |
|
308 |
||
309 |
grid.SetCellEditor(row, col, editor) |
|
310 |
grid.SetCellRenderer(row, col, renderer) |
|
311 |
||
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
312 |
grid.SetCellBackgroundColour(row, col, wx.WHITE) |
205 | 313 |
|
314 |
def SetData(self, data): |
|
315 |
self.data = data |
|
316 |
||
317 |
def SetEditors(self, editors): |
|
318 |
self.editors = editors |
|
319 |
||
320 |
def GetCurrentIndex(self): |
|
321 |
return self.CurrentIndex |
|
322 |
||
323 |
def SetCurrentIndex(self, index): |
|
324 |
self.CurrentIndex = index |
|
325 |
||
326 |
def AppendRow(self, row_content): |
|
327 |
self.data.append(row_content) |
|
328 |
||
329 |
def Empty(self): |
|
330 |
self.data = [] |
|
331 |
self.editors = [] |
|
332 |
||
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
333 |
[ID_EDITINGPANEL, ID_EDITINGPANELADDBUTTON, ID_EDITINGPANELINDEXCHOICE, |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
334 |
ID_EDITINGPANELINDEXLIST, ID_EDITINGPANELINDEXLISTPANEL, ID_EDITINGPANELPARTLIST, |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
335 |
ID_EDITINGPANELSECONDSPLITTER, ID_EDITINGPANELSUBINDEXGRID, |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
336 |
ID_EDITINGPANELSUBINDEXGRIDPANEL, ID_EDITINGPANELCALLBACKCHECK, |
205 | 337 |
] = [wx.NewId() for _init_ctrls in range(10)] |
338 |
||
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
339 |
[ID_EDITINGPANELINDEXLISTMENUITEMS0, ID_EDITINGPANELINDEXLISTMENUITEMS1, |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
340 |
ID_EDITINGPANELINDEXLISTMENUITEMS2, |
205 | 341 |
] = [wx.NewId() for _init_coll_IndexListMenu_Items in range(3)] |
342 |
||
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
343 |
[ID_EDITINGPANELMENU1ITEMS0, ID_EDITINGPANELMENU1ITEMS1, |
327 | 344 |
ID_EDITINGPANELMENU1ITEMS3, ID_EDITINGPANELMENU1ITEMS4, |
345 |
] = [wx.NewId() for _init_coll_SubindexGridMenu_Items in range(4)] |
|
205 | 346 |
|
347 |
class EditingPanel(wx.SplitterWindow): |
|
348 |
def _init_coll_AddToListSizer_Items(self, parent): |
|
349 |
parent.AddWindow(self.AddButton, 0, border=0, flag=0) |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
350 |
parent.AddWindow(self.IndexChoice, 0, border=0, flag=wx.GROW) |
205 | 351 |
|
352 |
def _init_coll_SubindexGridSizer_Items(self, parent): |
|
353 |
parent.AddWindow(self.CallbackCheck, 0, border=0, flag=0) |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
354 |
parent.AddWindow(self.SubindexGrid, 0, border=0, flag=wx.GROW) |
205 | 355 |
|
356 |
def _init_coll_IndexListSizer_Items(self, parent): |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
357 |
parent.AddWindow(self.IndexList, 0, border=0, flag=wx.GROW) |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
358 |
parent.AddSizer(self.AddToListSizer, 0, border=0, flag=wx.GROW) |
205 | 359 |
|
360 |
def _init_coll_AddToListSizer_Growables(self, parent): |
|
361 |
parent.AddGrowableCol(1) |
|
362 |
||
363 |
def _init_coll_SubindexGridSizer_Growables(self, parent): |
|
364 |
parent.AddGrowableCol(0) |
|
365 |
parent.AddGrowableRow(1) |
|
366 |
||
367 |
def _init_coll_IndexListSizer_Growables(self, parent): |
|
368 |
parent.AddGrowableCol(0) |
|
369 |
parent.AddGrowableRow(0) |
|
370 |
||
371 |
def _init_coll_SubindexGridMenu_Items(self, parent): |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
372 |
parent.Append(help='', id=ID_EDITINGPANELMENU1ITEMS0, |
580 | 373 |
kind=wx.ITEM_NORMAL, text=_('Add subindexes')) |
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
374 |
parent.Append(help='', id=ID_EDITINGPANELMENU1ITEMS1, |
580 | 375 |
kind=wx.ITEM_NORMAL, text=_('Delete subindexes')) |
299 | 376 |
parent.AppendSeparator() |
377 |
parent.Append(help='', id=ID_EDITINGPANELMENU1ITEMS3, |
|
580 | 378 |
kind=wx.ITEM_NORMAL, text=_('Default value')) |
327 | 379 |
if not self.Editable: |
380 |
parent.Append(help='', id=ID_EDITINGPANELMENU1ITEMS4, |
|
580 | 381 |
kind=wx.ITEM_NORMAL, text=_('Add to DCF')) |
205 | 382 |
self.Bind(wx.EVT_MENU, self.OnAddSubindexMenu, |
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
383 |
id=ID_EDITINGPANELMENU1ITEMS0) |
205 | 384 |
self.Bind(wx.EVT_MENU, self.OnDeleteSubindexMenu, |
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
385 |
id=ID_EDITINGPANELMENU1ITEMS1) |
299 | 386 |
self.Bind(wx.EVT_MENU, self.OnDefaultValueSubindexMenu, |
387 |
id=ID_EDITINGPANELMENU1ITEMS3) |
|
327 | 388 |
if not self.Editable: |
389 |
self.Bind(wx.EVT_MENU, self.OnAddToDCFSubindexMenu, |
|
390 |
id=ID_EDITINGPANELMENU1ITEMS4) |
|
205 | 391 |
|
392 |
def _init_coll_IndexListMenu_Items(self, parent): |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
393 |
parent.Append(help='', id=ID_EDITINGPANELINDEXLISTMENUITEMS0, |
580 | 394 |
kind=wx.ITEM_NORMAL, text=_('Rename')) |
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
395 |
parent.Append(help='', id=ID_EDITINGPANELINDEXLISTMENUITEMS2, |
580 | 396 |
kind=wx.ITEM_NORMAL, text=_('Modify')) |
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
397 |
parent.Append(help='', id=ID_EDITINGPANELINDEXLISTMENUITEMS1, |
580 | 398 |
kind=wx.ITEM_NORMAL, text=_('Delete')) |
205 | 399 |
self.Bind(wx.EVT_MENU, self.OnRenameIndexMenu, |
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
400 |
id=ID_EDITINGPANELINDEXLISTMENUITEMS0) |
205 | 401 |
self.Bind(wx.EVT_MENU, self.OnDeleteIndexMenu, |
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
402 |
id=ID_EDITINGPANELINDEXLISTMENUITEMS1) |
205 | 403 |
self.Bind(wx.EVT_MENU, self.OnModifyIndexMenu, |
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
404 |
id=ID_EDITINGPANELINDEXLISTMENUITEMS2) |
205 | 405 |
|
406 |
def _init_utils(self): |
|
407 |
self.IndexListMenu = wx.Menu(title='') |
|
408 |
self.SubindexGridMenu = wx.Menu(title='') |
|
409 |
||
410 |
self._init_coll_IndexListMenu_Items(self.IndexListMenu) |
|
411 |
self._init_coll_SubindexGridMenu_Items(self.SubindexGridMenu) |
|
412 |
||
413 |
def _init_sizers(self): |
|
414 |
self.IndexListSizer = wx.FlexGridSizer(cols=1, hgap=0, rows=2, vgap=0) |
|
415 |
self.SubindexGridSizer = wx.FlexGridSizer(cols=1, hgap=0, rows=2, vgap=0) |
|
416 |
self.AddToListSizer = wx.FlexGridSizer(cols=2, hgap=0, rows=1, vgap=0) |
|
417 |
||
418 |
self._init_coll_IndexListSizer_Growables(self.IndexListSizer) |
|
419 |
self._init_coll_IndexListSizer_Items(self.IndexListSizer) |
|
420 |
self._init_coll_SubindexGridSizer_Growables(self.SubindexGridSizer) |
|
421 |
self._init_coll_SubindexGridSizer_Items(self.SubindexGridSizer) |
|
422 |
self._init_coll_AddToListSizer_Growables(self.AddToListSizer) |
|
423 |
self._init_coll_AddToListSizer_Items(self.AddToListSizer) |
|
424 |
||
425 |
self.SubindexGridPanel.SetSizer(self.SubindexGridSizer) |
|
426 |
self.IndexListPanel.SetSizer(self.IndexListSizer) |
|
427 |
||
428 |
def _init_ctrls(self, prnt): |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
429 |
wx.SplitterWindow.__init__(self, id=ID_EDITINGPANEL, |
205 | 430 |
name='MainSplitter', parent=prnt, point=wx.Point(0, 0), |
431 |
size=wx.Size(-1, -1), style=wx.SP_3D) |
|
432 |
self._init_utils() |
|
433 |
self.SetNeedUpdating(True) |
|
757
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
434 |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
435 |
self.PartList = wx.ListBox(choices=[], id=ID_EDITINGPANELPARTLIST, |
205 | 436 |
name='PartList', parent=self, pos=wx.Point(0, 0), |
437 |
size=wx.Size(-1, -1), style=0) |
|
438 |
self.PartList.Bind(wx.EVT_LISTBOX, self.OnPartListBoxClick, |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
439 |
id=ID_EDITINGPANELPARTLIST) |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
440 |
|
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
441 |
self.SecondSplitter = wx.SplitterWindow(id=ID_EDITINGPANELSECONDSPLITTER, |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
442 |
name='SecondSplitter', parent=self, point=wx.Point(0, 0), |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
443 |
size=wx.Size(-1, -1), style=wx.SP_3D) |
757
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
444 |
self.SplitHorizontally(self.PartList, self.SecondSplitter, 110) |
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
445 |
self.SetMinimumPaneSize(1) |
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
446 |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
447 |
self.SubindexGridPanel = wx.Panel(id=ID_EDITINGPANELSUBINDEXGRIDPANEL, |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
448 |
name='SubindexGridPanel', parent=self.SecondSplitter, |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
449 |
pos=wx.Point(0, 0), size=wx.Size(-1, -1), style=wx.TAB_TRAVERSAL) |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
450 |
|
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
451 |
self.IndexListPanel = wx.Panel(id=ID_EDITINGPANELINDEXLISTPANEL, |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
452 |
name='IndexListPanel', parent=self.SecondSplitter, |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
453 |
pos=wx.Point(0, 0), size=wx.Size(-1, -1), style=wx.TAB_TRAVERSAL) |
757
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
454 |
self.SecondSplitter.SplitVertically(self.IndexListPanel, self.SubindexGridPanel, 280) |
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
455 |
self.SecondSplitter.SetMinimumPaneSize(1) |
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
456 |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
457 |
self.SubindexGrid = wx.grid.Grid(id=ID_EDITINGPANELSUBINDEXGRID, |
205 | 458 |
name='SubindexGrid', parent=self.SubindexGridPanel, pos=wx.Point(0, |
459 |
0), size=wx.Size(-1, -1), style=0) |
|
460 |
self.SubindexGrid.SetFont(wx.Font(12, 77, wx.NORMAL, wx.NORMAL, False, |
|
461 |
'Sans')) |
|
462 |
self.SubindexGrid.SetLabelFont(wx.Font(10, 77, wx.NORMAL, wx.NORMAL, |
|
463 |
False, 'Sans')) |
|
464 |
self.SubindexGrid.Bind(wx.grid.EVT_GRID_CELL_CHANGE, |
|
465 |
self.OnSubindexGridCellChange) |
|
466 |
self.SubindexGrid.Bind(wx.grid.EVT_GRID_CELL_RIGHT_CLICK, |
|
467 |
self.OnSubindexGridRightClick) |
|
468 |
self.SubindexGrid.Bind(wx.grid.EVT_GRID_SELECT_CELL, |
|
469 |
self.OnSubindexGridSelectCell) |
|
324 | 470 |
self.SubindexGrid.Bind(wx.grid.EVT_GRID_CELL_LEFT_CLICK, |
471 |
self.OnSubindexGridCellLeftClick) |
|
327 | 472 |
self.SubindexGrid.Bind(wx.grid.EVT_GRID_EDITOR_SHOWN, |
473 |
self.OnSubindexGridEditorShown) |
|
205 | 474 |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
475 |
self.CallbackCheck = wx.CheckBox(id=ID_EDITINGPANELCALLBACKCHECK, |
580 | 476 |
label=_('Have Callbacks'), name='CallbackCheck', |
205 | 477 |
parent=self.SubindexGridPanel, pos=wx.Point(0, 0), size=wx.Size(152, |
478 |
24), style=0) |
|
479 |
self.CallbackCheck.Bind(wx.EVT_CHECKBOX, self.OnCallbackCheck, |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
480 |
id=ID_EDITINGPANELCALLBACKCHECK) |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
481 |
|
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
482 |
self.IndexList = wx.ListBox(choices=[], id=ID_EDITINGPANELINDEXLIST, |
205 | 483 |
name='IndexList', parent=self.IndexListPanel, pos=wx.Point(0, 0), |
484 |
size=wx.Size(-1, -1), style=0) |
|
485 |
self.IndexList.Bind(wx.EVT_LISTBOX, self.OnIndexListClick, |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
486 |
id=ID_EDITINGPANELINDEXLIST) |
205 | 487 |
self.IndexList.Bind(wx.EVT_RIGHT_UP, self.OnIndexListRightUp) |
488 |
||
580 | 489 |
self.AddButton = wx.Button(id=ID_EDITINGPANELADDBUTTON, label=_('Add'), |
205 | 490 |
name='AddButton', parent=self.IndexListPanel, pos=wx.Point(0, 0), |
580 | 491 |
size=wx.DefaultSize, style=0) |
205 | 492 |
self.AddButton.Bind(wx.EVT_BUTTON, self.OnAddButtonClick, |
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
493 |
id=ID_EDITINGPANELADDBUTTON) |
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
494 |
|
585
d62424ba12bf
Replacing wx.Choice controls by wx.ComboBox controls
laurent
parents:
584
diff
changeset
|
495 |
self.IndexChoice = wx.ComboBox(choices=[], id=ID_EDITINGPANELINDEXCHOICE, |
205 | 496 |
name='IndexChoice', parent=self.IndexListPanel, pos=wx.Point(50, |
585
d62424ba12bf
Replacing wx.Choice controls by wx.ComboBox controls
laurent
parents:
584
diff
changeset
|
497 |
0), size=wx.Size(-1, 30), style=wx.CB_READONLY) |
205 | 498 |
|
499 |
self._init_sizers() |
|
500 |
||
299 | 501 |
def __init__(self, parent, window, manager, editable = True): |
327 | 502 |
self.Editable = editable |
299 | 503 |
self._init_ctrls(parent) |
504 |
self.ParentWindow = window |
|
205 | 505 |
self.Manager = manager |
506 |
self.ListIndex = [] |
|
507 |
self.ChoiceIndex = [] |
|
508 |
self.FirstCall = False |
|
509 |
self.Index = None |
|
510 |
||
511 |
for values in DictionaryOrganisation: |
|
299 | 512 |
text = " 0x%04X-0x%04X %s"%(values["minIndex"], values["maxIndex"], values["name"]) |
205 | 513 |
self.PartList.Append(text) |
580 | 514 |
self.Table = SubindexTable(self, [], [], GetSubindexTableColnames()) |
205 | 515 |
self.SubindexGrid.SetTable(self.Table) |
516 |
self.SubindexGrid.SetRowLabelSize(0) |
|
517 |
self.CallbackCheck.Disable() |
|
518 |
self.Table.ResetView(self.SubindexGrid) |
|
519 |
||
520 |
if not self.Editable: |
|
521 |
self.AddButton.Disable() |
|
522 |
self.IndexChoice.Disable() |
|
523 |
self.CallbackCheck.Disable() |
|
524 |
self.Table.Disable() |
|
525 |
||
526 |
def GetIndex(self): |
|
527 |
return self.Index |
|
528 |
||
529 |
def SetIndex(self, index): |
|
530 |
self.Index = index |
|
531 |
||
532 |
def GetSelection(self): |
|
533 |
selected = self.IndexList.GetSelection() |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
534 |
if selected != wx.NOT_FOUND: |
205 | 535 |
index = self.ListIndex[selected] |
536 |
subIndex = self.SubindexGrid.GetGridCursorRow() |
|
537 |
return index, subIndex |
|
538 |
return None |
|
539 |
||
242
4864f7f01e1d
Changes in networkedit for integration with beremiz
lbessard
parents:
237
diff
changeset
|
540 |
def OnSubindexGridCellLeftClick(self, event): |
324 | 541 |
if not self.ParentWindow.ModeSolo: |
542 |
col = event.GetCol() |
|
485
24b506ea314b
Added embedded mode in objdictedit, for integration in Beremiz.
etisserant
parents:
453
diff
changeset
|
543 |
if self.Editable and col == 0: |
24b506ea314b
Added embedded mode in objdictedit, for integration in Beremiz.
etisserant
parents:
453
diff
changeset
|
544 |
selected = self.IndexList.GetSelection() |
24b506ea314b
Added embedded mode in objdictedit, for integration in Beremiz.
etisserant
parents:
453
diff
changeset
|
545 |
if selected != wx.NOT_FOUND: |
24b506ea314b
Added embedded mode in objdictedit, for integration in Beremiz.
etisserant
parents:
453
diff
changeset
|
546 |
index = self.ListIndex[selected] |
24b506ea314b
Added embedded mode in objdictedit, for integration in Beremiz.
etisserant
parents:
453
diff
changeset
|
547 |
subindex = event.GetRow() |
24b506ea314b
Added embedded mode in objdictedit, for integration in Beremiz.
etisserant
parents:
453
diff
changeset
|
548 |
entry_infos = self.Manager.GetEntryInfos(index) |
24b506ea314b
Added embedded mode in objdictedit, for integration in Beremiz.
etisserant
parents:
453
diff
changeset
|
549 |
if not entry_infos["struct"] & OD_MultipleSubindexes or subindex != 0: |
24b506ea314b
Added embedded mode in objdictedit, for integration in Beremiz.
etisserant
parents:
453
diff
changeset
|
550 |
subentry_infos = self.Manager.GetSubentryInfos(index, subindex) |
24b506ea314b
Added embedded mode in objdictedit, for integration in Beremiz.
etisserant
parents:
453
diff
changeset
|
551 |
typeinfos = self.Manager.GetEntryInfos(subentry_infos["type"]) |
24b506ea314b
Added embedded mode in objdictedit, for integration in Beremiz.
etisserant
parents:
453
diff
changeset
|
552 |
if typeinfos: |
24b506ea314b
Added embedded mode in objdictedit, for integration in Beremiz.
etisserant
parents:
453
diff
changeset
|
553 |
bus_id = '.'.join(map(str, self.ParentWindow.GetBusId())) |
748
18ed0f3b030a
Fixing networkedit to deal with non-null master nodeid
Laurent Bessard
parents:
747
diff
changeset
|
554 |
var_name = "%s_%04x_%02x" % (self.Manager.GetCurrentNodeName(), index, subindex) |
485
24b506ea314b
Added embedded mode in objdictedit, for integration in Beremiz.
etisserant
parents:
453
diff
changeset
|
555 |
size = typeinfos["size"] |
747
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
556 |
data = wx.TextDataObject(str( |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
557 |
("%s%s.%d.%d"%(SizeConversion[size], bus_id, index, subindex), |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
558 |
"location", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
559 |
IECTypeConversion.get(typeinfos["name"]), |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
560 |
var_name, ""))) |
485
24b506ea314b
Added embedded mode in objdictedit, for integration in Beremiz.
etisserant
parents:
453
diff
changeset
|
561 |
dragSource = wx.DropSource(self.SubindexGrid) |
24b506ea314b
Added embedded mode in objdictedit, for integration in Beremiz.
etisserant
parents:
453
diff
changeset
|
562 |
dragSource.SetData(data) |
24b506ea314b
Added embedded mode in objdictedit, for integration in Beremiz.
etisserant
parents:
453
diff
changeset
|
563 |
dragSource.DoDragDrop() |
761
efff55931763
Fix bug when Drag'n Dropping located variables on Windows
Laurent Bessard
parents:
757
diff
changeset
|
564 |
return |
485
24b506ea314b
Added embedded mode in objdictedit, for integration in Beremiz.
etisserant
parents:
453
diff
changeset
|
565 |
elif col == 0: |
324 | 566 |
selected = self.IndexList.GetSelection() |
757
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
567 |
node_id = self.ParentWindow.GetCurrentNodeId() |
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
568 |
if selected != wx.NOT_FOUND and node_id is not None: |
324 | 569 |
index = self.ListIndex[selected] |
570 |
subindex = event.GetRow() |
|
571 |
entry_infos = self.Manager.GetEntryInfos(index) |
|
572 |
if not entry_infos["struct"] & OD_MultipleSubindexes or subindex != 0: |
|
573 |
subentry_infos = self.Manager.GetSubentryInfos(index, subindex) |
|
574 |
typeinfos = self.Manager.GetEntryInfos(subentry_infos["type"]) |
|
575 |
if subentry_infos["pdo"] and typeinfos: |
|
576 |
bus_id = '.'.join(map(str, self.ParentWindow.GetBusId())) |
|
741
b1a73ddc514b
Adding informations in data send when drag'n dropping locations
Laurent Bessard
parents:
622
diff
changeset
|
577 |
var_name = "%s_%04x_%02x" % (self.Manager.GetSlaveName(node_id), index, subindex) |
324 | 578 |
size = typeinfos["size"] |
747
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
579 |
data = wx.TextDataObject(str( |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
580 |
("%s%s.%d.%d.%d"%(SizeConversion[size], bus_id, node_id, index, subindex), |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
581 |
"location", |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
582 |
IECTypeConversion.get(typeinfos["name"]), |
4725d8f909ff
Adding support for translating CANOpen type to corresponding IEC type for location drag'n drop
Laurent Bessard
parents:
741
diff
changeset
|
583 |
var_name, ""))) |
324 | 584 |
dragSource = wx.DropSource(self.SubindexGrid) |
585 |
dragSource.SetData(data) |
|
586 |
dragSource.DoDragDrop() |
|
761
efff55931763
Fix bug when Drag'n Dropping located variables on Windows
Laurent Bessard
parents:
757
diff
changeset
|
587 |
return |
242
4864f7f01e1d
Changes in networkedit for integration with beremiz
lbessard
parents:
237
diff
changeset
|
588 |
event.Skip() |
4864f7f01e1d
Changes in networkedit for integration with beremiz
lbessard
parents:
237
diff
changeset
|
589 |
|
205 | 590 |
def OnAddButtonClick(self, event): |
591 |
if self.Editable: |
|
592 |
self.SubindexGrid.SetGridCursor(0, 0) |
|
593 |
selected = self.IndexChoice.GetStringSelection() |
|
594 |
if selected != "": |
|
580 | 595 |
choice = INDEXCHOICE_OPTIONS_DICT.get(selected, None) |
596 |
if choice is not None: |
|
597 |
if INDEXCHOICE_OPTIONS[choice][1] == 0: |
|
598 |
getattr(self.ParentWindow, INDEXCHOICE_OPTIONS[choice][2])() |
|
599 |
elif INDEXCHOICE_OPTIONS[choice][1] == 1: |
|
600 |
getattr(self.Manager, INDEXCHOICE_OPTIONS[choice][2])() |
|
205 | 601 |
elif selected in [menu for menu, indexes in self.Manager.GetCurrentSpecificMenu()]: |
602 |
self.Manager.AddSpecificEntryToCurrent(selected) |
|
603 |
else: |
|
604 |
index = self.ChoiceIndex[self.IndexChoice.GetSelection()] |
|
605 |
self.Manager.ManageEntriesOfCurrent([index], []) |
|
271 | 606 |
self.ParentWindow.RefreshBufferState() |
205 | 607 |
self.RefreshIndexList() |
608 |
event.Skip() |
|
609 |
||
610 |
def OnPartListBoxClick(self, event): |
|
491 | 611 |
if not self.ParentWindow.IsClosing(): |
612 |
self.SubindexGrid.SetGridCursor(0, 0) |
|
613 |
self.RefreshIndexList() |
|
205 | 614 |
event.Skip() |
615 |
||
616 |
def OnIndexListClick(self, event): |
|
491 | 617 |
if not self.ParentWindow.IsClosing(): |
618 |
self.SubindexGrid.SetGridCursor(0, 0) |
|
619 |
self.RefreshTable() |
|
205 | 620 |
event.Skip() |
621 |
||
622 |
def OnSubindexGridSelectCell(self, event): |
|
491 | 623 |
if not self.ParentWindow.IsClosing(): |
624 |
wx.CallAfter(self.ParentWindow.RefreshStatusBar) |
|
205 | 625 |
event.Skip() |
626 |
||
627 |
#------------------------------------------------------------------------------- |
|
628 |
# Refresh Functions |
|
629 |
#------------------------------------------------------------------------------- |
|
630 |
||
631 |
def RefreshIndexList(self): |
|
632 |
selected = self.IndexList.GetSelection() |
|
633 |
choice = self.IndexChoice.GetStringSelection() |
|
634 |
choiceindex = self.IndexChoice.GetSelection() |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
635 |
if selected != wx.NOT_FOUND: |
205 | 636 |
selectedindex = self.ListIndex[selected] |
637 |
self.IndexList.Clear() |
|
638 |
self.IndexChoice.Clear() |
|
639 |
i = self.PartList.GetSelection() |
|
640 |
if i < len(DictionaryOrganisation): |
|
641 |
values = DictionaryOrganisation[i] |
|
642 |
self.ListIndex = [] |
|
643 |
for name, index in self.Manager.GetCurrentValidIndexes(values["minIndex"], values["maxIndex"]): |
|
644 |
self.IndexList.Append("0x%04X %s"%(index, name)) |
|
645 |
self.ListIndex.append(index) |
|
646 |
if self.Editable: |
|
647 |
self.ChoiceIndex = [] |
|
580 | 648 |
choices = INDEXCHOICE_SECTIONS.get(i, None) |
649 |
if choices is not None: |
|
650 |
for c in choices: |
|
651 |
self.IndexChoice.Append(INDEXCHOICE_OPTIONS[c][0]) |
|
652 |
if len(choices) > 1: |
|
653 |
if choiceindex != wx.NOT_FOUND and choice == self.IndexChoice.GetString(choiceindex): |
|
654 |
self.IndexChoice.SetStringSelection(choice) |
|
655 |
else: |
|
656 |
self.IndexChoice.SetSelection(0) |
|
205 | 657 |
else: |
658 |
for name, index in self.Manager.GetCurrentValidChoices(values["minIndex"], values["maxIndex"]): |
|
659 |
if index: |
|
660 |
self.IndexChoice.Append("0x%04X %s"%(index, name)) |
|
661 |
else: |
|
662 |
self.IndexChoice.Append(name) |
|
663 |
self.ChoiceIndex.append(index) |
|
312 | 664 |
if choiceindex != wx.NOT_FOUND and choiceindex < self.IndexChoice.GetCount() and choice == self.IndexChoice.GetString(choiceindex): |
205 | 665 |
self.IndexChoice.SetStringSelection(choice) |
666 |
if self.Editable: |
|
667 |
self.IndexChoice.Enable(self.IndexChoice.GetCount() != 0) |
|
668 |
self.AddButton.Enable(self.IndexChoice.GetCount() != 0) |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
669 |
if selected == wx.NOT_FOUND or selected >= len(self.ListIndex) or selectedindex != self.ListIndex[selected]: |
205 | 670 |
self.Table.Empty() |
671 |
self.CallbackCheck.SetValue(False) |
|
672 |
self.CallbackCheck.Disable() |
|
673 |
self.Table.ResetView(self.SubindexGrid) |
|
271 | 674 |
self.ParentWindow.RefreshStatusBar() |
205 | 675 |
else: |
676 |
self.IndexList.SetSelection(selected) |
|
677 |
self.RefreshTable() |
|
678 |
||
679 |
def RefreshTable(self): |
|
680 |
selected = self.IndexList.GetSelection() |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
681 |
if selected != wx.NOT_FOUND: |
205 | 682 |
index = self.ListIndex[selected] |
683 |
if index > 0x260 and self.Editable: |
|
684 |
self.CallbackCheck.Enable() |
|
685 |
self.CallbackCheck.SetValue(self.Manager.HasCurrentEntryCallbacks(index)) |
|
686 |
result = self.Manager.GetCurrentEntryValues(index) |
|
687 |
if result != None: |
|
688 |
self.Table.SetCurrentIndex(index) |
|
689 |
data, editors = result |
|
690 |
self.Table.SetData(data) |
|
691 |
self.Table.SetEditors(editors) |
|
692 |
self.Table.ResetView(self.SubindexGrid) |
|
271 | 693 |
self.ParentWindow.RefreshStatusBar() |
205 | 694 |
|
695 |
#------------------------------------------------------------------------------- |
|
696 |
# Editing Table value function |
|
697 |
#------------------------------------------------------------------------------- |
|
698 |
||
327 | 699 |
def OnSubindexGridEditorShown(self, event): |
700 |
row, col = event.GetRow(), event.GetCol() |
|
701 |
if self.Table.GetEditor(row, col) == "dcf": |
|
702 |
wx.CallAfter(self.ShowDCFEntryDialog, row, col) |
|
703 |
event.Veto() |
|
704 |
else: |
|
705 |
event.Skip() |
|
706 |
||
707 |
def ShowDCFEntryDialog(self, row, col): |
|
757
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
708 |
if self.Editable or self.ParentWindow.GetCurrentNodeId() is None: |
327 | 709 |
selected = self.IndexList.GetSelection() |
710 |
if selected != wx.NOT_FOUND: |
|
711 |
index = self.ListIndex[selected] |
|
712 |
if self.Manager.IsCurrentEntry(index): |
|
757
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
713 |
dialog = DCFEntryValuesDialog(self, self.Editable) |
327 | 714 |
dialog.SetValues(self.Table.GetValue(row, col).decode("hex_codec")) |
757
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
715 |
if dialog.ShowModal() == wx.ID_OK and self.Editable: |
327 | 716 |
value = dialog.GetValues() |
717 |
self.Manager.SetCurrentEntry(index, row, value, "value", "dcf") |
|
718 |
self.ParentWindow.RefreshBufferState() |
|
719 |
wx.CallAfter(self.RefreshTable) |
|
720 |
||
205 | 721 |
def OnSubindexGridCellChange(self, event): |
722 |
if self.Editable: |
|
723 |
index = self.Table.GetCurrentIndex() |
|
724 |
subIndex = event.GetRow() |
|
725 |
col = event.GetCol() |
|
584
e23359f62023
Bug with in access value translation and modification on subindex 0 of PDOmapping entries fixed
laurent
parents:
580
diff
changeset
|
726 |
name = self.Table.GetColLabelValue(col, False) |
e23359f62023
Bug with in access value translation and modification on subindex 0 of PDOmapping entries fixed
laurent
parents:
580
diff
changeset
|
727 |
value = self.Table.GetValue(subIndex, col, False) |
205 | 728 |
editor = self.Table.GetEditor(subIndex, col) |
729 |
self.Manager.SetCurrentEntry(index, subIndex, value, name, editor) |
|
271 | 730 |
self.ParentWindow.RefreshBufferState() |
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
731 |
wx.CallAfter(self.RefreshTable) |
205 | 732 |
event.Skip() |
733 |
||
734 |
def OnCallbackCheck(self, event): |
|
735 |
if self.Editable: |
|
736 |
index = self.Table.GetCurrentIndex() |
|
737 |
self.Manager.SetCurrentEntryCallbacks(index, self.CallbackCheck.GetValue()) |
|
271 | 738 |
self.ParentWindow.RefreshBufferState() |
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
739 |
wx.CallAfter(self.RefreshTable) |
205 | 740 |
event.Skip() |
741 |
||
742 |
#------------------------------------------------------------------------------- |
|
743 |
# Contextual Menu functions |
|
744 |
#------------------------------------------------------------------------------- |
|
745 |
||
746 |
def OnIndexListRightUp(self, event): |
|
747 |
if self.Editable: |
|
748 |
if not self.FirstCall: |
|
749 |
self.FirstCall = True |
|
750 |
selected = self.IndexList.GetSelection() |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
751 |
if selected != wx.NOT_FOUND: |
205 | 752 |
index = self.ListIndex[selected] |
753 |
if index < 0x260: |
|
754 |
self.IndexListMenu.FindItemByPosition(0).Enable(False) |
|
755 |
self.IndexListMenu.FindItemByPosition(1).Enable(True) |
|
756 |
self.PopupMenu(self.IndexListMenu) |
|
273 | 757 |
elif 0x1000 <= index <= 0x1FFF: |
205 | 758 |
self.IndexListMenu.FindItemByPosition(0).Enable(False) |
759 |
self.IndexListMenu.FindItemByPosition(1).Enable(False) |
|
760 |
self.PopupMenu(self.IndexListMenu) |
|
761 |
elif 0x2000 <= index <= 0x5FFF: |
|
762 |
self.IndexListMenu.FindItemByPosition(0).Enable(True) |
|
763 |
self.IndexListMenu.FindItemByPosition(1).Enable(False) |
|
764 |
self.PopupMenu(self.IndexListMenu) |
|
765 |
elif index >= 0x6000: |
|
766 |
self.IndexListMenu.FindItemByPosition(0).Enable(False) |
|
767 |
self.IndexListMenu.FindItemByPosition(1).Enable(False) |
|
768 |
self.PopupMenu(self.IndexListMenu) |
|
769 |
else: |
|
770 |
self.FirstCall = False |
|
771 |
event.Skip() |
|
772 |
||
773 |
def OnSubindexGridRightClick(self, event): |
|
299 | 774 |
self.SubindexGrid.SetGridCursor(event.GetRow(), event.GetCol()) |
205 | 775 |
if self.Editable: |
776 |
selected = self.IndexList.GetSelection() |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
777 |
if selected != wx.NOT_FOUND: |
205 | 778 |
index = self.ListIndex[selected] |
779 |
if self.Manager.IsCurrentEntry(index): |
|
299 | 780 |
showpopup = False |
205 | 781 |
infos = self.Manager.GetEntryInfos(index) |
310 | 782 |
if 0x2000 <= index <= 0x5FFF and infos["struct"] & OD_MultipleSubindexes or infos["struct"] & OD_IdenticalSubindexes: |
299 | 783 |
showpopup = True |
784 |
self.SubindexGridMenu.FindItemByPosition(0).Enable(True) |
|
785 |
self.SubindexGridMenu.FindItemByPosition(1).Enable(True) |
|
786 |
else: |
|
787 |
self.SubindexGridMenu.FindItemByPosition(0).Enable(False) |
|
788 |
self.SubindexGridMenu.FindItemByPosition(1).Enable(False) |
|
622 | 789 |
if self.Table.GetColLabelValue(event.GetCol(), False) == "value": |
299 | 790 |
showpopup = True |
791 |
self.SubindexGridMenu.FindItemByPosition(3).Enable(True) |
|
792 |
else: |
|
793 |
self.SubindexGridMenu.FindItemByPosition(3).Enable(False) |
|
794 |
if showpopup: |
|
242
4864f7f01e1d
Changes in networkedit for integration with beremiz
lbessard
parents:
237
diff
changeset
|
795 |
self.PopupMenu(self.SubindexGridMenu) |
757
8150518de469
Fix bug when using not editable EditingPanel for displaying nodelist generated master
Laurent Bessard
parents:
748
diff
changeset
|
796 |
elif self.Table.GetColLabelValue(event.GetCol(), False) == "value" and self.ParentWindow.GetCurrentNodeId() is not None: |
327 | 797 |
selected = self.IndexList.GetSelection() |
798 |
if selected != wx.NOT_FOUND: |
|
799 |
index = self.ListIndex[selected] |
|
800 |
if self.Manager.IsCurrentEntry(index): |
|
801 |
infos = self.Manager.GetEntryInfos(index) |
|
802 |
if not infos["struct"] & OD_MultipleSubindexes or event.GetRow() > 0: |
|
803 |
self.SubindexGridMenu.FindItemByPosition(0).Enable(False) |
|
804 |
self.SubindexGridMenu.FindItemByPosition(1).Enable(False) |
|
805 |
self.SubindexGridMenu.FindItemByPosition(3).Enable(False) |
|
806 |
self.SubindexGridMenu.FindItemByPosition(4).Enable(True) |
|
807 |
self.PopupMenu(self.SubindexGridMenu) |
|
808 |
event.Skip() |
|
809 |
||
810 |
def OnAddToDCFSubindexMenu(self, event): |
|
811 |
if not self.Editable: |
|
812 |
selected = self.IndexList.GetSelection() |
|
813 |
if selected != wx.NOT_FOUND: |
|
814 |
index = self.ListIndex[selected] |
|
815 |
subindex = self.SubindexGrid.GetGridCursorRow() |
|
816 |
entry_infos = self.Manager.GetEntryInfos(index) |
|
817 |
if not entry_infos["struct"] & OD_MultipleSubindexes or subindex != 0: |
|
818 |
subentry_infos = self.Manager.GetSubentryInfos(index, subindex) |
|
819 |
typeinfos = self.Manager.GetEntryInfos(subentry_infos["type"]) |
|
820 |
if typeinfos: |
|
821 |
node_id = self.ParentWindow.GetCurrentNodeId() |
|
336 | 822 |
value = self.Table.GetValueByName(subindex, "value") |
823 |
if value == "True": |
|
340 | 824 |
value = 1 |
825 |
elif value == "False": |
|
336 | 826 |
value = 0 |
827 |
elif value.isdigit(): |
|
828 |
value = int(value) |
|
829 |
elif value.startswith("0x"): |
|
830 |
value = int(value, 16) |
|
831 |
else: |
|
832 |
value = int(value.encode("hex_codec"), 16) |
|
833 |
self.Manager.AddToMasterDCF(node_id, index, subindex, max(1, typeinfos["size"] / 8), value) |
|
327 | 834 |
self.ParentWindow.OpenMasterDCFDialog(node_id) |
835 |
||
336 | 836 |
def OpenDCFDialog(self, node_id): |
327 | 837 |
self.PartList.SetSelection(7) |
838 |
self.RefreshIndexList() |
|
839 |
self.IndexList.SetSelection(self.ListIndex.index(0x1F22)) |
|
840 |
self.RefreshTable() |
|
841 |
self.SubindexGrid.SetGridCursor(node_id, 3) |
|
842 |
self.ShowDCFEntryDialog(node_id, 3) |
|
205 | 843 |
|
844 |
def OnRenameIndexMenu(self, event): |
|
845 |
if self.Editable: |
|
846 |
selected = self.IndexList.GetSelection() |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
847 |
if selected != wx.NOT_FOUND: |
205 | 848 |
index = self.ListIndex[selected] |
849 |
if self.Manager.IsCurrentEntry(index): |
|
850 |
infos = self.Manager.GetEntryInfos(index) |
|
580 | 851 |
dialog = wx.TextEntryDialog(self, _("Give a new name for index 0x%04X")%index, |
852 |
_("Rename an index"), infos["name"], wx.OK|wx.CANCEL) |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
853 |
if dialog.ShowModal() == wx.ID_OK: |
205 | 854 |
self.Manager.SetCurrentEntryName(index, dialog.GetValue()) |
271 | 855 |
self.ParentWindow.RefreshBufferState() |
205 | 856 |
self.RefreshIndexList() |
857 |
dialog.Destroy() |
|
608 | 858 |
|
205 | 859 |
def OnModifyIndexMenu(self, event): |
860 |
if self.Editable: |
|
861 |
selected = self.IndexList.GetSelection() |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
862 |
if selected != wx.NOT_FOUND: |
205 | 863 |
index = self.ListIndex[selected] |
864 |
if self.Manager.IsCurrentEntry(index) and index < 0x260: |
|
865 |
values, valuetype = self.Manager.GetCustomisedTypeValues(index) |
|
866 |
dialog = UserTypeDialog(self) |
|
867 |
dialog.SetTypeList(self.Manager.GetCustomisableTypes(), values[1]) |
|
868 |
if valuetype == 0: |
|
869 |
dialog.SetValues(min = values[2], max = values[3]) |
|
870 |
elif valuetype == 1: |
|
871 |
dialog.SetValues(length = values[2]) |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
872 |
if dialog.ShowModal() == wx.ID_OK: |
205 | 873 |
type, min, max, length = dialog.GetValues() |
874 |
self.Manager.SetCurrentUserType(index, type, min, max, length) |
|
271 | 875 |
self.ParentWindow.RefreshBufferState() |
205 | 876 |
self.RefreshIndexList() |
877 |
||
878 |
def OnDeleteIndexMenu(self, event): |
|
879 |
if self.Editable: |
|
880 |
selected = self.IndexList.GetSelection() |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
881 |
if selected != wx.NOT_FOUND: |
205 | 882 |
index = self.ListIndex[selected] |
883 |
if self.Manager.IsCurrentEntry(index): |
|
884 |
self.Manager.ManageEntriesOfCurrent([],[index]) |
|
271 | 885 |
self.ParentWindow.RefreshBufferState() |
205 | 886 |
self.RefreshIndexList() |
608 | 887 |
|
205 | 888 |
def OnAddSubindexMenu(self, event): |
889 |
if self.Editable: |
|
890 |
selected = self.IndexList.GetSelection() |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
891 |
if selected != wx.NOT_FOUND: |
205 | 892 |
index = self.ListIndex[selected] |
893 |
if self.Manager.IsCurrentEntry(index): |
|
580 | 894 |
dialog = wx.TextEntryDialog(self, _("Number of subindexes to add:"), |
895 |
_("Add subindexes"), "1", wx.OK|wx.CANCEL) |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
896 |
if dialog.ShowModal() == wx.ID_OK: |
205 | 897 |
try: |
898 |
number = int(dialog.GetValue()) |
|
899 |
self.Manager.AddSubentriesToCurrent(index, number) |
|
271 | 900 |
self.ParentWindow.RefreshBufferState() |
205 | 901 |
self.RefreshIndexList() |
902 |
except: |
|
580 | 903 |
message = wx.MessageDialog(self, _("An integer is required!"), _("ERROR"), wx.OK|wx.ICON_ERROR) |
205 | 904 |
message.ShowModal() |
905 |
message.Destroy() |
|
906 |
dialog.Destroy() |
|
608 | 907 |
|
205 | 908 |
def OnDeleteSubindexMenu(self, event): |
909 |
if self.Editable: |
|
910 |
selected = self.IndexList.GetSelection() |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
911 |
if selected != wx.NOT_FOUND: |
205 | 912 |
index = self.ListIndex[selected] |
913 |
if self.Manager.IsCurrentEntry(index): |
|
580 | 914 |
dialog = wx.TextEntryDialog(self, _("Number of subindexes to delete:"), |
915 |
_("Delete subindexes"), "1", wx.OK|wx.CANCEL) |
|
254
f2b0acb54e65
Cleaning code for using only wxPython 2.6 class naming
lbessard
parents:
243
diff
changeset
|
916 |
if dialog.ShowModal() == wx.ID_OK: |
205 | 917 |
try: |
918 |
number = int(dialog.GetValue()) |
|
919 |
self.Manager.RemoveSubentriesFromCurrent(index, number) |
|
271 | 920 |
self.ParentWindow.RefreshBufferState() |
205 | 921 |
self.RefreshIndexList() |
922 |
except: |
|
580 | 923 |
message = wx.MessageDialog(self, _("An integer is required!"), _("ERROR"), wx.OK|wx.ICON_ERROR) |
205 | 924 |
message.ShowModal() |
925 |
message.Destroy() |
|
926 |
dialog.Destroy() |
|
608 | 927 |
|
299 | 928 |
def OnDefaultValueSubindexMenu(self, event): |
929 |
if self.Editable: |
|
930 |
selected = self.IndexList.GetSelection() |
|
931 |
if selected != wx.NOT_FOUND: |
|
932 |
index = self.ListIndex[selected] |
|
933 |
if self.Manager.IsCurrentEntry(index): |
|
934 |
row = self.SubindexGrid.GetGridCursorRow() |
|
935 |
self.Manager.SetCurrentEntryToDefault(index, row) |
|
936 |
self.ParentWindow.RefreshBufferState() |
|
937 |
self.RefreshIndexList() |