author | Edouard Tisserant |
Thu, 18 Apr 2019 14:41:21 +0200 | |
branch | fix_PLC_runtime_shutdown |
changeset 2605 | 0615137bf515 |
parent 2551 | 245644bfcd24 |
child 2614 | 6b4061f6ced6 |
permissions | -rw-r--r-- |
814 | 1 |
#!/usr/bin/env python |
2 |
# -*- coding: utf-8 -*- |
|
3 |
||
1571
486f94a8032c
fix license notices in source files and license files under GPLv2+
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1508
diff
changeset
|
4 |
# This file is part of Beremiz, a Integrated Development Environment for |
486f94a8032c
fix license notices in source files and license files under GPLv2+
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1508
diff
changeset
|
5 |
# programming IEC 61131-3 automates supporting plcopen standard and CanFestival. |
814 | 6 |
# |
1571
486f94a8032c
fix license notices in source files and license files under GPLv2+
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1508
diff
changeset
|
7 |
# Copyright (C) 2007: Edouard TISSERANT and Laurent BESSARD |
1680
6db967480b7d
make run Beremiz and PLCOpen Editor, if full path contain non-lating
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1619
diff
changeset
|
8 |
# Copyright (C) 2017: Andrey Skvortsov |
814 | 9 |
# |
1571
486f94a8032c
fix license notices in source files and license files under GPLv2+
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1508
diff
changeset
|
10 |
# See COPYING file for copyrights details. |
814 | 11 |
# |
1571
486f94a8032c
fix license notices in source files and license files under GPLv2+
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1508
diff
changeset
|
12 |
# This program is free software; you can redistribute it and/or |
486f94a8032c
fix license notices in source files and license files under GPLv2+
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1508
diff
changeset
|
13 |
# modify it under the terms of the GNU General Public License |
486f94a8032c
fix license notices in source files and license files under GPLv2+
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1508
diff
changeset
|
14 |
# as published by the Free Software Foundation; either version 2 |
486f94a8032c
fix license notices in source files and license files under GPLv2+
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1508
diff
changeset
|
15 |
# of the License, or (at your option) any later version. |
814 | 16 |
# |
1571
486f94a8032c
fix license notices in source files and license files under GPLv2+
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1508
diff
changeset
|
17 |
# This program is distributed in the hope that it will be useful, |
486f94a8032c
fix license notices in source files and license files under GPLv2+
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1508
diff
changeset
|
18 |
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
486f94a8032c
fix license notices in source files and license files under GPLv2+
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1508
diff
changeset
|
19 |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
486f94a8032c
fix license notices in source files and license files under GPLv2+
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1508
diff
changeset
|
20 |
# GNU General Public License for more details. |
814 | 21 |
# |
1571
486f94a8032c
fix license notices in source files and license files under GPLv2+
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1508
diff
changeset
|
22 |
# You should have received a copy of the GNU General Public License |
486f94a8032c
fix license notices in source files and license files under GPLv2+
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1508
diff
changeset
|
23 |
# along with this program; if not, write to the Free Software |
486f94a8032c
fix license notices in source files and license files under GPLv2+
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1508
diff
changeset
|
24 |
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. |
814 | 25 |
|
1850
614396cbffbf
fix pylint warning '(unused-import), Unused import connectors'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1847
diff
changeset
|
26 |
|
1881
091005ec69c4
fix pylint py3k conversion warning: "(no-absolute-import) import missing `from __future__ import absolute_import`"
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1879
diff
changeset
|
27 |
from __future__ import absolute_import |
2437
105c20fdeb19
python3 support: pylint, W1619 #(old-division) division w/o __future__ statement
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
2418
diff
changeset
|
28 |
from __future__ import division |
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
29 |
from copy import deepcopy |
1732
94ffe74e6895
clean-up: fix PEP8 E401 multiple imports on one line
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1686
diff
changeset
|
30 |
import os |
94ffe74e6895
clean-up: fix PEP8 E401 multiple imports on one line
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1686
diff
changeset
|
31 |
import re |
814 | 32 |
import datetime |
33 |
from time import localtime |
|
2456
7373e3048167
python3 support: pylint,W1610 # (reduce-builtin) reduce built-in referenced
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
2450
diff
changeset
|
34 |
from functools import reduce |
2457
9deec258ab1a
python3 support: pylint, W1633 # (round-builtin) round built-in referenced
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
2456
diff
changeset
|
35 |
from future.builtins import round |
1832
0f1081928d65
fix wrong-import-order. first standard modules are imported, then others
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1831
diff
changeset
|
36 |
|
0f1081928d65
fix wrong-import-order. first standard modules are imported, then others
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1831
diff
changeset
|
37 |
import util.paths as paths |
1313
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
38 |
from plcopen import * |
1944
6162e34fb246
Moved some code from PLCController.py to other modules. Added necessary imports.
Edouard Tisserant <edouard.tisserant@gmail.com>
parents:
1943
diff
changeset
|
39 |
from plcopen.types_enums import * |
1942
a4382ae1ba82
Added /plcopen/InstancesPathCollector.py, to move more model xslt querying code away from PLCController.py.
Edouard Tisserant <edouard.tisserant@gmail.com>
parents:
1940
diff
changeset
|
40 |
from plcopen.InstancesPathCollector import InstancesPathCollector |
1943
9dc0e38552b2
GetPouVariables optimized with XSLTModelQuery
Edouard Tisserant <edouard.tisserant@gmail.com>
parents:
1942
diff
changeset
|
41 |
from plcopen.POUVariablesCollector import POUVariablesCollector |
1950
752ec68da94d
GetPouInstanceTagName optimized with XSLTModelQuery.
Edouard Tisserant
parents:
1948
diff
changeset
|
42 |
from plcopen.InstanceTagnameCollector import InstanceTagnameCollector |
1957
2d1cc4f5e4ef
GetEditedElementInstancesInfos now optimized as well. Forgotten because not using [R.I.P]LibraryResolver, but still XSLT compiling was hapenning on each call.
Edouard Tisserant
parents:
1954
diff
changeset
|
43 |
from plcopen.BlockInstanceCollector import BlockInstanceCollector |
1951
bbd1e1744c91
GetVariableDictionary and GetPouInterfaceReturnType optimized with new VariableInfoCollector based on XSLTModelQuery. Moved corresponding definitions out of PLCControler.py.
Edouard Tisserant
parents:
1950
diff
changeset
|
44 |
from plcopen.VariableInfoCollector import VariableInfoCollector |
814 | 45 |
from graphics.GraphicCommons import * |
46 |
from PLCGenerator import * |
|
47 |
||
2439
f0a040f1de1b
Fix pep8 warning: W605 invalid escape sequence ?x?
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
2437
diff
changeset
|
48 |
duration_model = re.compile(r"(?:([0-9]{1,2})h)?(?:([0-9]{1,2})m(?!s))?(?:([0-9]{1,2})s)?(?:([0-9]{1,3}(?:\.[0-9]*)?)ms)?") |
f0a040f1de1b
Fix pep8 warning: W605 invalid escape sequence ?x?
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
2437
diff
changeset
|
49 |
VARIABLE_NAME_SUFFIX_MODEL = re.compile(r'(\d+)$') |
814 | 50 |
|
1680
6db967480b7d
make run Beremiz and PLCOpen Editor, if full path contain non-lating
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1619
diff
changeset
|
51 |
ScriptDirectory = paths.AbsDir(__file__) |
814 | 52 |
|
53 |
# Length of the buffer |
|
54 |
UNDO_BUFFER_LENGTH = 20 |
|
55 |
||
1736
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
56 |
|
1831
56b48961cc68
fix (old-style-class) Old-style class defined error for most parts of
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1785
diff
changeset
|
57 |
class UndoBuffer(object): |
1736
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
58 |
""" |
1782
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
59 |
Undo Buffer for PLCOpenEditor |
1736
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
60 |
Class implementing a buffer of changes made on the current editing model |
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
61 |
""" |
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
62 |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
63 |
def __init__(self, currentstate, issaved=False): |
1736
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
64 |
""" |
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
65 |
Constructor initialising buffer |
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
66 |
""" |
814 | 67 |
self.Buffer = [] |
68 |
self.CurrentIndex = -1 |
|
69 |
self.MinIndex = -1 |
|
70 |
self.MaxIndex = -1 |
|
71 |
# if current state is defined |
|
72 |
if currentstate: |
|
73 |
self.CurrentIndex = 0 |
|
74 |
self.MinIndex = 0 |
|
75 |
self.MaxIndex = 0 |
|
76 |
# Initialising buffer with currentstate at the first place |
|
77 |
for i in xrange(UNDO_BUFFER_LENGTH): |
|
78 |
if i == 0: |
|
79 |
self.Buffer.append(currentstate) |
|
80 |
else: |
|
81 |
self.Buffer.append(None) |
|
82 |
# Initialising index of state saved |
|
83 |
if issaved: |
|
84 |
self.LastSave = 0 |
|
85 |
else: |
|
86 |
self.LastSave = -1 |
|
1411 | 87 |
|
814 | 88 |
def Buffering(self, currentstate): |
1736
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
89 |
""" |
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
90 |
Add a new state in buffer |
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
91 |
""" |
814 | 92 |
self.CurrentIndex = (self.CurrentIndex + 1) % UNDO_BUFFER_LENGTH |
93 |
self.Buffer[self.CurrentIndex] = currentstate |
|
94 |
# Actualising buffer limits |
|
95 |
self.MaxIndex = self.CurrentIndex |
|
96 |
if self.MinIndex == self.CurrentIndex: |
|
97 |
# If the removed state was the state saved, there is no state saved in the buffer |
|
98 |
if self.LastSave == self.MinIndex: |
|
99 |
self.LastSave = -1 |
|
100 |
self.MinIndex = (self.MinIndex + 1) % UNDO_BUFFER_LENGTH |
|
101 |
self.MinIndex = max(self.MinIndex, 0) |
|
1411 | 102 |
|
814 | 103 |
def Current(self): |
1736
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
104 |
""" |
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
105 |
Return current state of buffer |
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
106 |
""" |
814 | 107 |
return self.Buffer[self.CurrentIndex] |
1411 | 108 |
|
814 | 109 |
# Change current state to previous in buffer and return new current state |
110 |
def Previous(self): |
|
111 |
if self.CurrentIndex != self.MinIndex: |
|
112 |
self.CurrentIndex = (self.CurrentIndex - 1) % UNDO_BUFFER_LENGTH |
|
113 |
return self.Buffer[self.CurrentIndex] |
|
114 |
return None |
|
1411 | 115 |
|
814 | 116 |
# Change current state to next in buffer and return new current state |
117 |
def Next(self): |
|
118 |
if self.CurrentIndex != self.MaxIndex: |
|
119 |
self.CurrentIndex = (self.CurrentIndex + 1) % UNDO_BUFFER_LENGTH |
|
120 |
return self.Buffer[self.CurrentIndex] |
|
121 |
return None |
|
1411 | 122 |
|
814 | 123 |
# Return True if current state is the first in buffer |
124 |
def IsFirst(self): |
|
125 |
return self.CurrentIndex == self.MinIndex |
|
1411 | 126 |
|
814 | 127 |
# Return True if current state is the last in buffer |
128 |
def IsLast(self): |
|
129 |
return self.CurrentIndex == self.MaxIndex |
|
130 |
||
131 |
# Note that current state is saved |
|
132 |
def CurrentSaved(self): |
|
133 |
self.LastSave = self.CurrentIndex |
|
1411 | 134 |
|
814 | 135 |
# Return True if current state is saved |
136 |
def IsCurrentSaved(self): |
|
137 |
return self.LastSave == self.CurrentIndex |
|
138 |
||
139 |
||
1831
56b48961cc68
fix (old-style-class) Old-style class defined error for most parts of
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1785
diff
changeset
|
140 |
class PLCControler(object): |
1736
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
141 |
""" |
1782
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
142 |
Controler for PLCOpenEditor |
1736
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
143 |
Class which controls the operations made on the plcopen model and answers to view requests |
7e61baa047f0
clean-up: fix PEP8 E302 expected 2 blank lines, found 1
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1735
diff
changeset
|
144 |
""" |
1411 | 145 |
|
814 | 146 |
# Create a new PLCControler |
147 |
def __init__(self): |
|
148 |
self.LastNewIndex = 0 |
|
149 |
self.Reset() |
|
1935
f2b0d849ea77
Prevent compiling XSLT on each call of GetInstanceList. To be continued. More optimization needed here. 100x would be fine...
Edouard Tisserant
parents:
1881
diff
changeset
|
150 |
self.InstancesPathCollector = InstancesPathCollector(self) |
1943
9dc0e38552b2
GetPouVariables optimized with XSLTModelQuery
Edouard Tisserant <edouard.tisserant@gmail.com>
parents:
1942
diff
changeset
|
151 |
self.POUVariablesCollector = POUVariablesCollector(self) |
1950
752ec68da94d
GetPouInstanceTagName optimized with XSLTModelQuery.
Edouard Tisserant
parents:
1948
diff
changeset
|
152 |
self.InstanceTagnameCollector = InstanceTagnameCollector(self) |
1957
2d1cc4f5e4ef
GetEditedElementInstancesInfos now optimized as well. Forgotten because not using [R.I.P]LibraryResolver, but still XSLT compiling was hapenning on each call.
Edouard Tisserant
parents:
1954
diff
changeset
|
153 |
self.BlockInstanceCollector = BlockInstanceCollector(self) |
1951
bbd1e1744c91
GetVariableDictionary and GetPouInterfaceReturnType optimized with new VariableInfoCollector based on XSLTModelQuery. Moved corresponding definitions out of PLCControler.py.
Edouard Tisserant
parents:
1950
diff
changeset
|
154 |
self.VariableInfoCollector = VariableInfoCollector(self) |
1411 | 155 |
|
814 | 156 |
# Reset PLCControler internal variables |
157 |
def Reset(self): |
|
158 |
self.Project = None |
|
159 |
self.ProjectBufferEnabled = True |
|
160 |
self.ProjectBuffer = None |
|
161 |
self.ProjectSaved = True |
|
162 |
self.Buffering = False |
|
163 |
self.FilePath = "" |
|
164 |
self.FileName = "" |
|
165 |
self.ProgramChunks = [] |
|
166 |
self.ProgramOffset = 0 |
|
167 |
self.NextCompiledProject = None |
|
168 |
self.CurrentCompiledProject = None |
|
169 |
self.ConfNodeTypes = [] |
|
1283
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
170 |
self.TotalTypesDict = StdBlckDct.copy() |
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
171 |
self.TotalTypes = StdBlckLst[:] |
1284 | 172 |
self.ProgramFilePath = "" |
1411 | 173 |
|
814 | 174 |
def GetQualifierTypes(self): |
1298
f034fb2b1aab
Fixed SFC block edition and SFC to SFC_textual code generating
Laurent Bessard
parents:
1297
diff
changeset
|
175 |
return QualifierList |
814 | 176 |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
177 |
def GetProject(self, debug=False): |
814 | 178 |
if debug and self.CurrentCompiledProject is not None: |
179 |
return self.CurrentCompiledProject |
|
180 |
else: |
|
181 |
return self.Project |
|
182 |
||
1782
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
183 |
# ------------------------------------------------------------------------------- |
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
184 |
# Project management functions |
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
185 |
# ------------------------------------------------------------------------------- |
814 | 186 |
|
187 |
# Return if a project is opened |
|
188 |
def HasOpenedProject(self): |
|
189 |
return self.Project is not None |
|
190 |
||
191 |
# Create a new project by replacing the current one |
|
192 |
def CreateNewProject(self, properties): |
|
193 |
# Create the project |
|
1290
13ee5f4ab612
First stage of xmlclass refactoring using lxml
Laurent Bessard
parents:
1284
diff
changeset
|
194 |
self.Project = PLCOpenParser.CreateRoot() |
814 | 195 |
properties["creationDateTime"] = datetime.datetime(*localtime()[:6]) |
196 |
self.Project.setfileHeader(properties) |
|
197 |
self.Project.setcontentHeader(properties) |
|
198 |
self.SetFilePath("") |
|
1411 | 199 |
|
814 | 200 |
# Initialize the project buffer |
201 |
self.CreateProjectBuffer(False) |
|
202 |
self.ProgramChunks = [] |
|
203 |
self.ProgramOffset = 0 |
|
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
204 |
self.NextCompiledProject = self.Copy(self.Project) |
814 | 205 |
self.CurrentCompiledProject = None |
206 |
self.Buffering = False |
|
1411 | 207 |
|
814 | 208 |
# Return project data type names |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
209 |
def GetProjectDataTypeNames(self, debug=False): |
814 | 210 |
project = self.GetProject(debug) |
211 |
if project is not None: |
|
212 |
return [datatype.getname() for datatype in project.getdataTypes()] |
|
213 |
return [] |
|
1411 | 214 |
|
814 | 215 |
# Return project pou names |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
216 |
def GetProjectPouNames(self, debug=False): |
814 | 217 |
project = self.GetProject(debug) |
218 |
if project is not None: |
|
219 |
return [pou.getname() for pou in project.getpous()] |
|
220 |
return [] |
|
1411 | 221 |
|
814 | 222 |
# Return project pou names |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
223 |
def GetProjectConfigNames(self, debug=False): |
814 | 224 |
project = self.GetProject(debug) |
225 |
if project is not None: |
|
226 |
return [config.getname() for config in project.getconfigurations()] |
|
227 |
return [] |
|
1411 | 228 |
|
1171
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
229 |
# Return project pou variable names |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
230 |
def GetProjectPouVariableNames(self, pou_name=None, debug=False): |
814 | 231 |
variables = [] |
232 |
project = self.GetProject(debug) |
|
233 |
if project is not None: |
|
234 |
for pou in project.getpous(): |
|
235 |
if pou_name is None or pou_name == pou.getname(): |
|
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
236 |
variables.extend([var.Name for var in self.GetPouInterfaceVars(pou, debug=debug)]) |
814 | 237 |
for transition in pou.gettransitionList(): |
238 |
variables.append(transition.getname()) |
|
239 |
for action in pou.getactionList(): |
|
240 |
variables.append(action.getname()) |
|
241 |
return variables |
|
1411 | 242 |
|
814 | 243 |
# Return file path if project is an open file |
244 |
def GetFilePath(self): |
|
245 |
return self.FilePath |
|
1411 | 246 |
|
814 | 247 |
# Return file path if project is an open file |
248 |
def GetProgramFilePath(self): |
|
249 |
return self.ProgramFilePath |
|
1411 | 250 |
|
814 | 251 |
# Return file name and point out if file is up to date |
252 |
def GetFilename(self): |
|
253 |
if self.Project is not None: |
|
254 |
if self.ProjectIsSaved(): |
|
255 |
return self.FileName |
|
256 |
else: |
|
1734
750eeb7230a1
clean-up: fix some PEP8 E228 missing whitespace around modulo operator
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1732
diff
changeset
|
257 |
return "~%s~" % self.FileName |
814 | 258 |
return "" |
1411 | 259 |
|
814 | 260 |
# Change file path and save file name or create a default one if file path not defined |
261 |
def SetFilePath(self, filepath): |
|
262 |
self.FilePath = filepath |
|
263 |
if filepath == "": |
|
264 |
self.LastNewIndex += 1 |
|
1734
750eeb7230a1
clean-up: fix some PEP8 E228 missing whitespace around modulo operator
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1732
diff
changeset
|
265 |
self.FileName = _("Unnamed%d") % self.LastNewIndex |
814 | 266 |
else: |
267 |
self.FileName = os.path.splitext(os.path.basename(filepath))[0] |
|
1411 | 268 |
|
814 | 269 |
# Change project properties |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
270 |
def SetProjectProperties(self, name=None, properties=None, buffer=True): |
814 | 271 |
if self.Project is not None: |
272 |
if name is not None: |
|
273 |
self.Project.setname(name) |
|
274 |
if properties is not None: |
|
275 |
self.Project.setfileHeader(properties) |
|
276 |
self.Project.setcontentHeader(properties) |
|
277 |
if buffer and (name is not None or properties is not None): |
|
278 |
self.BufferProject() |
|
1411 | 279 |
|
814 | 280 |
# Return project name |
281 |
def GetProjectName(self, debug=False): |
|
282 |
project = self.GetProject(debug) |
|
283 |
if project is not None: |
|
284 |
return project.getname() |
|
285 |
return None |
|
1411 | 286 |
|
814 | 287 |
# Return project properties |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
288 |
def GetProjectProperties(self, debug=False): |
814 | 289 |
project = self.GetProject(debug) |
290 |
if project is not None: |
|
291 |
properties = project.getfileHeader() |
|
292 |
properties.update(project.getcontentHeader()) |
|
293 |
return properties |
|
294 |
return None |
|
1411 | 295 |
|
814 | 296 |
# Return project informations |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
297 |
def GetProjectInfos(self, debug=False): |
814 | 298 |
project = self.GetProject(debug) |
299 |
if project is not None: |
|
300 |
infos = {"name": project.getname(), "type": ITEM_PROJECT} |
|
1740
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
301 |
datatypes = {"name": DATA_TYPES, "type": ITEM_DATATYPES, "values": []} |
814 | 302 |
for datatype in project.getdataTypes(): |
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
303 |
datatypes["values"].append({ |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
304 |
"name": datatype.getname(), |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
305 |
"type": ITEM_DATATYPE, |
1948
b9a3f771aaab
Moved some definitions away from controller class, and adaped references them through all code.
Edouard Tisserant
parents:
1944
diff
changeset
|
306 |
"tagname": ComputeDataTypeName(datatype.getname()), |
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
307 |
"values": []}) |
1740
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
308 |
pou_types = { |
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
309 |
"function": { |
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
310 |
"name": FUNCTIONS, |
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
311 |
"type": ITEM_FUNCTION, |
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
312 |
"values": [] |
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
313 |
}, |
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
314 |
"functionBlock": { |
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
315 |
"name": FUNCTION_BLOCKS, |
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
316 |
"type": ITEM_FUNCTIONBLOCK, |
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
317 |
"values": [] |
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
318 |
}, |
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
319 |
"program": { |
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
320 |
"name": PROGRAMS, |
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
321 |
"type": ITEM_PROGRAM, |
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
322 |
"values": [] |
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
323 |
} |
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
324 |
} |
814 | 325 |
for pou in project.getpous(): |
326 |
pou_type = pou.getpouType() |
|
327 |
pou_infos = {"name": pou.getname(), "type": ITEM_POU, |
|
1948
b9a3f771aaab
Moved some definitions away from controller class, and adaped references them through all code.
Edouard Tisserant
parents:
1944
diff
changeset
|
328 |
"tagname": ComputePouName(pou.getname())} |
814 | 329 |
pou_values = [] |
330 |
if pou.getbodyType() == "SFC": |
|
331 |
transitions = [] |
|
332 |
for transition in pou.gettransitionList(): |
|
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
333 |
transitions.append({ |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
334 |
"name": transition.getname(), |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
335 |
"type": ITEM_TRANSITION, |
1948
b9a3f771aaab
Moved some definitions away from controller class, and adaped references them through all code.
Edouard Tisserant
parents:
1944
diff
changeset
|
336 |
"tagname": ComputePouTransitionName(pou.getname(), transition.getname()), |
814 | 337 |
"values": []}) |
338 |
pou_values.append({"name": TRANSITIONS, "type": ITEM_TRANSITIONS, "values": transitions}) |
|
339 |
actions = [] |
|
340 |
for action in pou.getactionList(): |
|
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
341 |
actions.append({ |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
342 |
"name": action.getname(), |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
343 |
"type": ITEM_ACTION, |
1948
b9a3f771aaab
Moved some definitions away from controller class, and adaped references them through all code.
Edouard Tisserant
parents:
1944
diff
changeset
|
344 |
"tagname": ComputePouActionName(pou.getname(), action.getname()), |
814 | 345 |
"values": []}) |
346 |
pou_values.append({"name": ACTIONS, "type": ITEM_ACTIONS, "values": actions}) |
|
347 |
if pou_type in pou_types: |
|
348 |
pou_infos["values"] = pou_values |
|
349 |
pou_types[pou_type]["values"].append(pou_infos) |
|
350 |
configurations = {"name": CONFIGURATIONS, "type": ITEM_CONFIGURATIONS, "values": []} |
|
351 |
for config in project.getconfigurations(): |
|
352 |
config_name = config.getname() |
|
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
353 |
config_infos = { |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
354 |
"name": config_name, |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
355 |
"type": ITEM_CONFIGURATION, |
1948
b9a3f771aaab
Moved some definitions away from controller class, and adaped references them through all code.
Edouard Tisserant
parents:
1944
diff
changeset
|
356 |
"tagname": ComputeConfigurationName(config.getname()), |
814 | 357 |
"values": []} |
358 |
resources = {"name": RESOURCES, "type": ITEM_RESOURCES, "values": []} |
|
359 |
for resource in config.getresource(): |
|
360 |
resource_name = resource.getname() |
|
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
361 |
resource_infos = { |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
362 |
"name": resource_name, |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
363 |
"type": ITEM_RESOURCE, |
1948
b9a3f771aaab
Moved some definitions away from controller class, and adaped references them through all code.
Edouard Tisserant
parents:
1944
diff
changeset
|
364 |
"tagname": ComputeConfigurationResourceName(config.getname(), resource.getname()), |
814 | 365 |
"values": []} |
366 |
resources["values"].append(resource_infos) |
|
367 |
config_infos["values"] = [resources] |
|
368 |
configurations["values"].append(config_infos) |
|
1411 | 369 |
infos["values"] = [datatypes, pou_types["function"], pou_types["functionBlock"], |
814 | 370 |
pou_types["program"], configurations] |
371 |
return infos |
|
372 |
return None |
|
373 |
||
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
374 |
def GetPouVariables(self, tagname, debug=False): |
814 | 375 |
project = self.GetProject(debug) |
376 |
if project is not None: |
|
1348
aee0a7eb833a
Fixed pou variables instance information loading stylesheet
Laurent Bessard
parents:
1347
diff
changeset
|
377 |
obj = None |
814 | 378 |
words = tagname.split("::") |
379 |
if words[0] == "P": |
|
1319
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
380 |
obj = self.GetPou(words[1], debug) |
1348
aee0a7eb833a
Fixed pou variables instance information loading stylesheet
Laurent Bessard
parents:
1347
diff
changeset
|
381 |
elif words[0] != "D": |
1319
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
382 |
obj = self.GetEditedElement(tagname, debug) |
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
383 |
if obj is not None: |
1943
9dc0e38552b2
GetPouVariables optimized with XSLTModelQuery
Edouard Tisserant <edouard.tisserant@gmail.com>
parents:
1942
diff
changeset
|
384 |
return self.POUVariablesCollector.Collect(obj, debug) |
1411 | 385 |
|
1321
83f41ea00b97
Replaced old pou instance type tagname computing by xslt stylesheet
Laurent Bessard
parents:
1319
diff
changeset
|
386 |
return None |
1319
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
387 |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
388 |
def GetInstanceList(self, root, name, debug=False): |
1939
db478d17bc3a
Added a class to speedup all XSLT queries. WIP, now only for instances_path.xslt / GetInstanceList()
Edouard Tisserant <edouard.tisserant@gmail.com>
parents:
1937
diff
changeset
|
389 |
return self.InstancesPathCollector.Collect(root, name, debug) |
1411 | 390 |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
391 |
def SearchPouInstances(self, tagname, debug=False): |
1319
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
392 |
project = self.GetProject(debug) |
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
393 |
if project is not None: |
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
394 |
words = tagname.split("::") |
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
395 |
if words[0] == "P": |
1350
7280349a3375
Fixed pou instance path list computing stylesheet
Laurent Bessard
parents:
1348
diff
changeset
|
396 |
return self.GetInstanceList(project, words[1]) |
814 | 397 |
elif words[0] == 'C': |
398 |
return [words[1]] |
|
399 |
elif words[0] == 'R': |
|
400 |
return ["%s.%s" % (words[1], words[2])] |
|
826
098f822ef308
Adding transition and action in list of instances of SFC POU in PouInstanceVariablesPanel
laurent
parents:
823
diff
changeset
|
401 |
elif words[0] in ['T', 'A']: |
098f822ef308
Adding transition and action in list of instances of SFC POU in PouInstanceVariablesPanel
laurent
parents:
823
diff
changeset
|
402 |
return ["%s.%s" % (instance, words[2]) |
098f822ef308
Adding transition and action in list of instances of SFC POU in PouInstanceVariablesPanel
laurent
parents:
823
diff
changeset
|
403 |
for instance in self.SearchPouInstances( |
1948
b9a3f771aaab
Moved some definitions away from controller class, and adaped references them through all code.
Edouard Tisserant
parents:
1944
diff
changeset
|
404 |
ComputePouName(words[1]), debug)] |
814 | 405 |
return [] |
1411 | 406 |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
407 |
def GetPouInstanceTagName(self, instance_path, debug=False): |
1254
ebc765355536
Fixed bug when trying to add a global function block instance variable to debug variable panel and not connected
Laurent Bessard
parents:
1223
diff
changeset
|
408 |
project = self.GetProject(debug) |
1953
5736d25bb393
PEP8 and PyLint conformance: whitespaces and stuff
Edouard Tisserant
parents:
1951
diff
changeset
|
409 |
if project is not None: |
1950
752ec68da94d
GetPouInstanceTagName optimized with XSLTModelQuery.
Edouard Tisserant
parents:
1948
diff
changeset
|
410 |
return self.InstanceTagnameCollector.Collect(project, |
752ec68da94d
GetPouInstanceTagName optimized with XSLTModelQuery.
Edouard Tisserant
parents:
1948
diff
changeset
|
411 |
debug, |
752ec68da94d
GetPouInstanceTagName optimized with XSLTModelQuery.
Edouard Tisserant
parents:
1948
diff
changeset
|
412 |
instance_path) |
1411 | 413 |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
414 |
def GetInstanceInfos(self, instance_path, debug=False): |
814 | 415 |
tagname = self.GetPouInstanceTagName(instance_path) |
416 |
if tagname is not None: |
|
827
a2ce084fb598
Fix restore project tab layout with transition and action debug tabs
laurent
parents:
826
diff
changeset
|
417 |
infos = self.GetPouVariables(tagname, debug) |
1360
ebfe9c22af2a
Fixed bug when debugging PLC with Graphic Viewer in debug open and re-transfer PLC
Laurent Bessard
parents:
1354
diff
changeset
|
418 |
infos.type = tagname |
827
a2ce084fb598
Fix restore project tab layout with transition and action debug tabs
laurent
parents:
826
diff
changeset
|
419 |
return infos |
814 | 420 |
else: |
421 |
pou_path, var_name = instance_path.rsplit(".", 1) |
|
422 |
tagname = self.GetPouInstanceTagName(pou_path) |
|
423 |
if tagname is not None: |
|
424 |
pou_infos = self.GetPouVariables(tagname, debug) |
|
1360
ebfe9c22af2a
Fixed bug when debugging PLC with Graphic Viewer in debug open and re-transfer PLC
Laurent Bessard
parents:
1354
diff
changeset
|
425 |
for var_infos in pou_infos.variables: |
ebfe9c22af2a
Fixed bug when debugging PLC with Graphic Viewer in debug open and re-transfer PLC
Laurent Bessard
parents:
1354
diff
changeset
|
426 |
if var_infos.name == var_name: |
814 | 427 |
return var_infos |
428 |
return None |
|
1411 | 429 |
|
814 | 430 |
# Return if data type given by name is used by another data type or pou |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
431 |
def DataTypeIsUsed(self, name, debug=False): |
1319
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
432 |
project = self.GetProject(debug) |
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
433 |
if project is not None: |
1354
241c19ea80da
Fixed bug when selecting pou that is not used in project
Laurent Bessard
parents:
1351
diff
changeset
|
434 |
return len(self.GetInstanceList(project, name, debug)) > 0 |
814 | 435 |
return False |
436 |
||
437 |
# Return if pou given by name is used by another pou |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
438 |
def PouIsUsed(self, name, debug=False): |
1319
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
439 |
project = self.GetProject(debug) |
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
440 |
if project is not None: |
1354
241c19ea80da
Fixed bug when selecting pou that is not used in project
Laurent Bessard
parents:
1351
diff
changeset
|
441 |
return len(self.GetInstanceList(project, name, debug)) > 0 |
814 | 442 |
return False |
443 |
||
444 |
# Return if pou given by name is directly or undirectly used by the reference pou |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
445 |
def PouIsUsedBy(self, name, reference, debug=False): |
1319
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
446 |
pou_infos = self.GetPou(reference, debug) |
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
447 |
if pou_infos is not None: |
1354
241c19ea80da
Fixed bug when selecting pou that is not used in project
Laurent Bessard
parents:
1351
diff
changeset
|
448 |
return len(self.GetInstanceList(pou_infos, name, debug)) > 0 |
814 | 449 |
return False |
450 |
||
451 |
def GenerateProgram(self, filepath=None): |
|
452 |
errors = [] |
|
453 |
warnings = [] |
|
454 |
if self.Project is not None: |
|
455 |
try: |
|
456 |
self.ProgramChunks = GenerateCurrentProgram(self, self.Project, errors, warnings) |
|
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
457 |
self.NextCompiledProject = self.Copy(self.Project) |
901
ab43f3e40b9d
Fix bug when compiling project containing non-ascii characters
Laurent Bessard
parents:
887
diff
changeset
|
458 |
program_text = "".join([item[0] for item in self.ProgramChunks]) |
814 | 459 |
if filepath is not None: |
460 |
programfile = open(filepath, "w") |
|
461 |
programfile.write(program_text.encode("utf-8")) |
|
462 |
programfile.close() |
|
463 |
self.ProgramFilePath = filepath |
|
464 |
return program_text, errors, warnings |
|
2418
5587c490a070
Use python 3 compatible exception syntax everywhere
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1973
diff
changeset
|
465 |
except PLCGenException as ex: |
2520
3a1c0c161f80
Fix backtrace on printing localized (non-ascii) error message in PLCGenerator.
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
2457
diff
changeset
|
466 |
errors.append(ex) |
814 | 467 |
else: |
468 |
errors.append("No project opened") |
|
469 |
return "", errors, warnings |
|
470 |
||
471 |
def DebugAvailable(self): |
|
472 |
return self.CurrentCompiledProject is not None |
|
473 |
||
474 |
def ProgramTransferred(self): |
|
475 |
if self.NextCompiledProject is None: |
|
476 |
self.CurrentCompiledProject = self.NextCompiledProject |
|
477 |
else: |
|
478 |
self.CurrentCompiledProject = self.Copy(self.Project) |
|
479 |
||
480 |
def GetChunkInfos(self, from_location, to_location): |
|
481 |
row = self.ProgramOffset + 1 |
|
482 |
col = 1 |
|
483 |
infos = [] |
|
484 |
for chunk, chunk_infos in self.ProgramChunks: |
|
485 |
lines = chunk.split("\n") |
|
486 |
if len(lines) > 1: |
|
487 |
next_row = row + len(lines) - 1 |
|
488 |
next_col = len(lines[-1]) + 1 |
|
489 |
else: |
|
490 |
next_row = row |
|
491 |
next_col = col + len(chunk) |
|
492 |
if (next_row > from_location[0] or next_row == from_location[0] and next_col >= from_location[1]) and len(chunk_infos) > 0: |
|
493 |
infos.append((chunk_infos, (row, col))) |
|
494 |
if next_row == to_location[0] and next_col > to_location[1] or next_row > to_location[0]: |
|
495 |
return infos |
|
496 |
row, col = next_row, next_col |
|
497 |
return infos |
|
1411 | 498 |
|
1782
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
499 |
# ------------------------------------------------------------------------------- |
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
500 |
# Project Pous management functions |
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
501 |
# ------------------------------------------------------------------------------- |
1411 | 502 |
|
814 | 503 |
# Add a Data Type to Project |
504 |
def ProjectAddDataType(self, datatype_name=None): |
|
505 |
if self.Project is not None: |
|
506 |
if datatype_name is None: |
|
507 |
datatype_name = self.GenerateNewName(None, None, "datatype%d") |
|
508 |
# Add the datatype to project |
|
509 |
self.Project.appenddataType(datatype_name) |
|
510 |
self.BufferProject() |
|
1948
b9a3f771aaab
Moved some definitions away from controller class, and adaped references them through all code.
Edouard Tisserant
parents:
1944
diff
changeset
|
511 |
return ComputeDataTypeName(datatype_name) |
814 | 512 |
return None |
1411 | 513 |
|
814 | 514 |
# Remove a Data Type from project |
515 |
def ProjectRemoveDataType(self, datatype_name): |
|
516 |
if self.Project is not None: |
|
517 |
self.Project.removedataType(datatype_name) |
|
518 |
self.BufferProject() |
|
1411 | 519 |
|
814 | 520 |
# Add a Pou to Project |
521 |
def ProjectAddPou(self, pou_name, pou_type, body_type): |
|
522 |
if self.Project is not None: |
|
523 |
# Add the pou to project |
|
524 |
self.Project.appendpou(pou_name, pou_type, body_type) |
|
525 |
if pou_type == "function": |
|
526 |
self.SetPouInterfaceReturnType(pou_name, "BOOL") |
|
527 |
self.BufferProject() |
|
1948
b9a3f771aaab
Moved some definitions away from controller class, and adaped references them through all code.
Edouard Tisserant
parents:
1944
diff
changeset
|
528 |
return ComputePouName(pou_name) |
814 | 529 |
return None |
1411 | 530 |
|
814 | 531 |
def ProjectChangePouType(self, name, pou_type): |
532 |
if self.Project is not None: |
|
533 |
pou = self.Project.getpou(name) |
|
534 |
if pou is not None: |
|
535 |
pou.setpouType(pou_type) |
|
536 |
self.BufferProject() |
|
1411 | 537 |
|
814 | 538 |
def GetPouXml(self, pou_name): |
539 |
if self.Project is not None: |
|
540 |
pou = self.Project.getpou(pou_name) |
|
541 |
if pou is not None: |
|
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
542 |
return pou.tostring() |
814 | 543 |
return None |
1411 | 544 |
|
814 | 545 |
def PastePou(self, pou_type, pou_xml): |
546 |
''' |
|
547 |
Adds the POU defined by 'pou_xml' to the current project with type 'pou_type' |
|
548 |
''' |
|
549 |
try: |
|
1330
96b242e4c59d
Added support for loading XML file even if not following XSD schema (but still following XML syntax), warning user of errors in XML file
Laurent Bessard
parents:
1328
diff
changeset
|
550 |
new_pou, error = LoadPou(pou_xml) |
1780
c52d1460cea8
clean-up: fix PEP8 E722 do not use bare except'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1779
diff
changeset
|
551 |
except Exception: |
1330
96b242e4c59d
Added support for loading XML file even if not following XSD schema (but still following XML syntax), warning user of errors in XML file
Laurent Bessard
parents:
1328
diff
changeset
|
552 |
error = "" |
96b242e4c59d
Added support for loading XML file even if not following XSD schema (but still following XML syntax), warning user of errors in XML file
Laurent Bessard
parents:
1328
diff
changeset
|
553 |
if error is not None: |
814 | 554 |
return _("Couldn't paste non-POU object.") |
1411 | 555 |
|
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
556 |
name = new_pou.getname() |
1411 | 557 |
|
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
558 |
idx = 0 |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
559 |
new_name = name |
1411 | 560 |
while self.Project.getpou(new_name) is not None: |
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
561 |
# a POU with that name already exists. |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
562 |
# make a new name and test if a POU with that name exists. |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
563 |
# append an incrementing numeric suffix to the POU name. |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
564 |
idx += 1 |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
565 |
new_name = "%s%d" % (name, idx) |
1411 | 566 |
|
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
567 |
# we've found a name that does not already exist, use it |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
568 |
new_pou.setname(new_name) |
1411 | 569 |
|
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
570 |
if pou_type is not None: |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
571 |
orig_type = new_pou.getpouType() |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
572 |
|
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
573 |
# prevent violations of POU content restrictions: |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
574 |
# function blocks cannot be pasted as functions, |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
575 |
# programs cannot be pasted as functions or function blocks |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
576 |
if orig_type == 'functionBlock' and pou_type == 'function' or \ |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
577 |
orig_type == 'program' and pou_type in ['function', 'functionBlock']: |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
578 |
msg = _('''{a1} "{a2}" can't be pasted as a {a3}.''').format(a1=orig_type, a2=name, a3=pou_type) |
1581
2295fdc5c271
fix translation strings with multiple parameters
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1571
diff
changeset
|
579 |
return msg |
1411 | 580 |
|
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
581 |
new_pou.setpouType(pou_type) |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
582 |
|
1411 | 583 |
self.Project.insertpou(0, new_pou) |
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
584 |
self.BufferProject() |
1411 | 585 |
|
1948
b9a3f771aaab
Moved some definitions away from controller class, and adaped references them through all code.
Edouard Tisserant
parents:
1944
diff
changeset
|
586 |
return ComputePouName(new_name), |
814 | 587 |
|
588 |
# Remove a Pou from project |
|
589 |
def ProjectRemovePou(self, pou_name): |
|
590 |
if self.Project is not None: |
|
591 |
self.Project.removepou(pou_name) |
|
592 |
self.BufferProject() |
|
1411 | 593 |
|
814 | 594 |
# Return the name of the configuration if only one exist |
595 |
def GetProjectMainConfigurationName(self): |
|
596 |
if self.Project is not None: |
|
597 |
# Found the configuration corresponding to old name and change its name to new name |
|
598 |
configurations = self.Project.getconfigurations() |
|
599 |
if len(configurations) == 1: |
|
600 |
return configurations[0].getname() |
|
601 |
return None |
|
1411 | 602 |
|
814 | 603 |
# Add a configuration to Project |
604 |
def ProjectAddConfiguration(self, config_name=None): |
|
605 |
if self.Project is not None: |
|
606 |
if config_name is None: |
|
607 |
config_name = self.GenerateNewName(None, None, "configuration%d") |
|
608 |
self.Project.addconfiguration(config_name) |
|
609 |
self.BufferProject() |
|
1948
b9a3f771aaab
Moved some definitions away from controller class, and adaped references them through all code.
Edouard Tisserant
parents:
1944
diff
changeset
|
610 |
return ComputeConfigurationName(config_name) |
814 | 611 |
return None |
1411 | 612 |
|
814 | 613 |
# Remove a configuration from project |
614 |
def ProjectRemoveConfiguration(self, config_name): |
|
615 |
if self.Project is not None: |
|
616 |
self.Project.removeconfiguration(config_name) |
|
617 |
self.BufferProject() |
|
1411 | 618 |
|
814 | 619 |
# Add a resource to a configuration of the Project |
620 |
def ProjectAddConfigurationResource(self, config_name, resource_name=None): |
|
621 |
if self.Project is not None: |
|
622 |
if resource_name is None: |
|
623 |
resource_name = self.GenerateNewName(None, None, "resource%d") |
|
624 |
self.Project.addconfigurationResource(config_name, resource_name) |
|
625 |
self.BufferProject() |
|
1948
b9a3f771aaab
Moved some definitions away from controller class, and adaped references them through all code.
Edouard Tisserant
parents:
1944
diff
changeset
|
626 |
return ComputeConfigurationResourceName(config_name, resource_name) |
814 | 627 |
return None |
1411 | 628 |
|
814 | 629 |
# Remove a resource from a configuration of the project |
630 |
def ProjectRemoveConfigurationResource(self, config_name, resource_name): |
|
631 |
if self.Project is not None: |
|
632 |
self.Project.removeconfigurationResource(config_name, resource_name) |
|
633 |
self.BufferProject() |
|
1411 | 634 |
|
814 | 635 |
# Add a Transition to a Project Pou |
636 |
def ProjectAddPouTransition(self, pou_name, transition_name, transition_type): |
|
637 |
if self.Project is not None: |
|
638 |
pou = self.Project.getpou(pou_name) |
|
639 |
if pou is not None: |
|
640 |
pou.addtransition(transition_name, transition_type) |
|
641 |
self.BufferProject() |
|
1948
b9a3f771aaab
Moved some definitions away from controller class, and adaped references them through all code.
Edouard Tisserant
parents:
1944
diff
changeset
|
642 |
return ComputePouTransitionName(pou_name, transition_name) |
814 | 643 |
return None |
1411 | 644 |
|
814 | 645 |
# Remove a Transition from a Project Pou |
646 |
def ProjectRemovePouTransition(self, pou_name, transition_name): |
|
647 |
# Search if the pou removed is currently opened |
|
648 |
if self.Project is not None: |
|
649 |
pou = self.Project.getpou(pou_name) |
|
650 |
if pou is not None: |
|
651 |
pou.removetransition(transition_name) |
|
652 |
self.BufferProject() |
|
1411 | 653 |
|
814 | 654 |
# Add an Action to a Project Pou |
655 |
def ProjectAddPouAction(self, pou_name, action_name, action_type): |
|
656 |
if self.Project is not None: |
|
657 |
pou = self.Project.getpou(pou_name) |
|
658 |
if pou is not None: |
|
659 |
pou.addaction(action_name, action_type) |
|
660 |
self.BufferProject() |
|
1948
b9a3f771aaab
Moved some definitions away from controller class, and adaped references them through all code.
Edouard Tisserant
parents:
1944
diff
changeset
|
661 |
return ComputePouActionName(pou_name, action_name) |
814 | 662 |
return None |
1411 | 663 |
|
814 | 664 |
# Remove an Action from a Project Pou |
665 |
def ProjectRemovePouAction(self, pou_name, action_name): |
|
666 |
# Search if the pou removed is currently opened |
|
667 |
if self.Project is not None: |
|
668 |
pou = self.Project.getpou(pou_name) |
|
669 |
if pou is not None: |
|
670 |
pou.removeaction(action_name) |
|
671 |
self.BufferProject() |
|
1411 | 672 |
|
814 | 673 |
# Change the name of a pou |
674 |
def ChangeDataTypeName(self, old_name, new_name): |
|
675 |
if self.Project is not None: |
|
676 |
# Found the pou corresponding to old name and change its name to new name |
|
677 |
datatype = self.Project.getdataType(old_name) |
|
678 |
if datatype is not None: |
|
679 |
datatype.setname(new_name) |
|
680 |
self.Project.updateElementName(old_name, new_name) |
|
681 |
self.BufferProject() |
|
1411 | 682 |
|
814 | 683 |
# Change the name of a pou |
684 |
def ChangePouName(self, old_name, new_name): |
|
685 |
if self.Project is not None: |
|
686 |
# Found the pou corresponding to old name and change its name to new name |
|
687 |
pou = self.Project.getpou(old_name) |
|
688 |
if pou is not None: |
|
689 |
pou.setname(new_name) |
|
690 |
self.Project.updateElementName(old_name, new_name) |
|
691 |
self.BufferProject() |
|
1411 | 692 |
|
814 | 693 |
# Change the name of a pou transition |
694 |
def ChangePouTransitionName(self, pou_name, old_name, new_name): |
|
695 |
if self.Project is not None: |
|
696 |
# Found the pou transition corresponding to old name and change its name to new name |
|
697 |
pou = self.Project.getpou(pou_name) |
|
698 |
if pou is not None: |
|
699 |
transition = pou.gettransition(old_name) |
|
700 |
if transition is not None: |
|
701 |
transition.setname(new_name) |
|
702 |
pou.updateElementName(old_name, new_name) |
|
703 |
self.BufferProject() |
|
1411 | 704 |
|
814 | 705 |
# Change the name of a pou action |
706 |
def ChangePouActionName(self, pou_name, old_name, new_name): |
|
707 |
if self.Project is not None: |
|
708 |
# Found the pou action corresponding to old name and change its name to new name |
|
709 |
pou = self.Project.getpou(pou_name) |
|
710 |
if pou is not None: |
|
711 |
action = pou.getaction(old_name) |
|
712 |
if action is not None: |
|
713 |
action.setname(new_name) |
|
714 |
pou.updateElementName(old_name, new_name) |
|
715 |
self.BufferProject() |
|
1411 | 716 |
|
814 | 717 |
# Change the name of a pou variable |
718 |
def ChangePouVariableName(self, pou_name, old_name, new_name): |
|
719 |
if self.Project is not None: |
|
720 |
# Found the pou action corresponding to old name and change its name to new name |
|
721 |
pou = self.Project.getpou(pou_name) |
|
722 |
if pou is not None: |
|
1847
6198190bc121
explicitly mark unused variables found by pylint with _ or dummy
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1846
diff
changeset
|
723 |
for _type, varlist in pou.getvars(): |
814 | 724 |
for var in varlist.getvariable(): |
725 |
if var.getname() == old_name: |
|
726 |
var.setname(new_name) |
|
727 |
self.BufferProject() |
|
1411 | 728 |
|
814 | 729 |
# Change the name of a configuration |
730 |
def ChangeConfigurationName(self, old_name, new_name): |
|
731 |
if self.Project is not None: |
|
732 |
# Found the configuration corresponding to old name and change its name to new name |
|
733 |
configuration = self.Project.getconfiguration(old_name) |
|
734 |
if configuration is not None: |
|
735 |
configuration.setname(new_name) |
|
736 |
self.BufferProject() |
|
1411 | 737 |
|
814 | 738 |
# Change the name of a configuration resource |
739 |
def ChangeConfigurationResourceName(self, config_name, old_name, new_name): |
|
740 |
if self.Project is not None: |
|
741 |
# Found the resource corresponding to old name and change its name to new name |
|
742 |
resource = self.Project.getconfigurationResource(config_name, old_name) |
|
743 |
if resource is not None: |
|
744 |
resource.setname(new_name) |
|
745 |
self.BufferProject() |
|
1411 | 746 |
|
814 | 747 |
# Return the description of the pou given by its name |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
748 |
def GetPouDescription(self, name, debug=False): |
814 | 749 |
project = self.GetProject(debug) |
750 |
if project is not None: |
|
751 |
# Found the pou correponding to name and return its type |
|
752 |
pou = project.getpou(name) |
|
753 |
if pou is not None: |
|
754 |
return pou.getdescription() |
|
755 |
return "" |
|
1411 | 756 |
|
814 | 757 |
# Return the description of the pou given by its name |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
758 |
def SetPouDescription(self, name, description, debug=False): |
814 | 759 |
project = self.GetProject(debug) |
760 |
if project is not None: |
|
761 |
# Found the pou correponding to name and return its type |
|
762 |
pou = project.getpou(name) |
|
763 |
if pou is not None: |
|
764 |
pou.setdescription(description) |
|
765 |
self.BufferProject() |
|
1411 | 766 |
|
814 | 767 |
# Return the type of the pou given by its name |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
768 |
def GetPouType(self, name, debug=False): |
814 | 769 |
project = self.GetProject(debug) |
770 |
if project is not None: |
|
771 |
# Found the pou correponding to name and return its type |
|
772 |
pou = project.getpou(name) |
|
773 |
if pou is not None: |
|
774 |
return pou.getpouType() |
|
775 |
return None |
|
1411 | 776 |
|
814 | 777 |
# Return pous with SFC language |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
778 |
def GetSFCPous(self, debug=False): |
814 | 779 |
list = [] |
780 |
project = self.GetProject(debug) |
|
781 |
if project is not None: |
|
782 |
for pou in project.getpous(): |
|
783 |
if pou.getBodyType() == "SFC": |
|
784 |
list.append(pou.getname()) |
|
785 |
return list |
|
1411 | 786 |
|
814 | 787 |
# Return the body language of the pou given by its name |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
788 |
def GetPouBodyType(self, name, debug=False): |
814 | 789 |
project = self.GetProject(debug) |
790 |
if project is not None: |
|
791 |
# Found the pou correponding to name and return its body language |
|
792 |
pou = project.getpou(name) |
|
793 |
if pou is not None: |
|
794 |
return pou.getbodyType() |
|
795 |
return None |
|
1411 | 796 |
|
814 | 797 |
# Return the actions of a pou |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
798 |
def GetPouTransitions(self, pou_name, debug=False): |
814 | 799 |
transitions = [] |
800 |
project = self.GetProject(debug) |
|
801 |
if project is not None: |
|
802 |
# Found the pou correponding to name and return its transitions if SFC |
|
803 |
pou = project.getpou(pou_name) |
|
804 |
if pou is not None and pou.getbodyType() == "SFC": |
|
805 |
for transition in pou.gettransitionList(): |
|
806 |
transitions.append(transition.getname()) |
|
807 |
return transitions |
|
1411 | 808 |
|
814 | 809 |
# Return the body language of the transition given by its name |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
810 |
def GetTransitionBodyType(self, pou_name, pou_transition, debug=False): |
814 | 811 |
project = self.GetProject(debug) |
812 |
if project is not None: |
|
813 |
# Found the pou correponding to name |
|
814 |
pou = project.getpou(pou_name) |
|
815 |
if pou is not None: |
|
816 |
# Found the pou transition correponding to name and return its body language |
|
817 |
transition = pou.gettransition(pou_transition) |
|
818 |
if transition is not None: |
|
819 |
return transition.getbodyType() |
|
820 |
return None |
|
1411 | 821 |
|
814 | 822 |
# Return the actions of a pou |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
823 |
def GetPouActions(self, pou_name, debug=False): |
814 | 824 |
actions = [] |
825 |
project = self.GetProject(debug) |
|
826 |
if project is not None: |
|
827 |
# Found the pou correponding to name and return its actions if SFC |
|
828 |
pou = project.getpou(pou_name) |
|
829 |
if pou.getbodyType() == "SFC": |
|
830 |
for action in pou.getactionList(): |
|
831 |
actions.append(action.getname()) |
|
832 |
return actions |
|
1411 | 833 |
|
814 | 834 |
# Return the body language of the pou given by its name |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
835 |
def GetActionBodyType(self, pou_name, pou_action, debug=False): |
814 | 836 |
project = self.GetProject(debug) |
837 |
if project is not None: |
|
838 |
# Found the pou correponding to name and return its body language |
|
839 |
pou = project.getpou(pou_name) |
|
840 |
if pou is not None: |
|
841 |
action = pou.getaction(pou_action) |
|
842 |
if action is not None: |
|
843 |
return action.getbodyType() |
|
844 |
return None |
|
1411 | 845 |
|
814 | 846 |
# Extract varlists from a list of vars |
847 |
def ExtractVarLists(self, vars): |
|
848 |
varlist_list = [] |
|
849 |
current_varlist = None |
|
850 |
current_type = None |
|
851 |
for var in vars: |
|
1411 | 852 |
next_type = (var.Class, |
853 |
var.Option, |
|
854 |
var.Location in ["", None] or |
|
855 |
# When declaring globals, located |
|
856 |
# and not located variables are |
|
814 | 857 |
# in the same declaration block |
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
858 |
var.Class == "Global") |
814 | 859 |
if current_type != next_type: |
860 |
current_type = next_type |
|
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
861 |
infos = VAR_CLASS_INFOS.get(var.Class, None) |
814 | 862 |
if infos is not None: |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
863 |
current_varlist = PLCOpenParser.CreateElement(infos[0], "interface") |
814 | 864 |
else: |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
865 |
current_varlist = PLCOpenParser.CreateElement("varList") |
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
866 |
varlist_list.append((var.Class, current_varlist)) |
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
867 |
if var.Option == "Constant": |
814 | 868 |
current_varlist.setconstant(True) |
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
869 |
elif var.Option == "Retain": |
814 | 870 |
current_varlist.setretain(True) |
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
871 |
elif var.Option == "Non-Retain": |
814 | 872 |
current_varlist.setnonretain(True) |
873 |
# Create variable and change its properties |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
874 |
tempvar = PLCOpenParser.CreateElement("variable", "varListPlain") |
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
875 |
tempvar.setname(var.Name) |
1411 | 876 |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
877 |
var_type = PLCOpenParser.CreateElement("type", "variable") |
2450
5024c19ca8f0
python3 support: pylint, W1652 # (deprecated-types-field) Accessing a deprecated fields on the types module
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
2447
diff
changeset
|
878 |
if isinstance(var.Type, tuple): |
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
879 |
if var.Type[0] == "array": |
1847
6198190bc121
explicitly mark unused variables found by pylint with _ or dummy
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1846
diff
changeset
|
880 |
_array_type, base_type_name, dimensions = var.Type |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
881 |
array = PLCOpenParser.CreateElement("array", "dataType") |
1306
1ff1cdf6c318
Fixed bug with direct array variable type definition
Laurent Bessard
parents:
1304
diff
changeset
|
882 |
baseType = PLCOpenParser.CreateElement("baseType", "array") |
1ff1cdf6c318
Fixed bug with direct array variable type definition
Laurent Bessard
parents:
1304
diff
changeset
|
883 |
array.setbaseType(baseType) |
814 | 884 |
for i, dimension in enumerate(dimensions): |
1306
1ff1cdf6c318
Fixed bug with direct array variable type definition
Laurent Bessard
parents:
1304
diff
changeset
|
885 |
dimension_range = PLCOpenParser.CreateElement("dimension", "array") |
814 | 886 |
if i == 0: |
887 |
array.setdimension([dimension_range]) |
|
888 |
else: |
|
889 |
array.appenddimension(dimension_range) |
|
1298
f034fb2b1aab
Fixed SFC block edition and SFC to SFC_textual code generating
Laurent Bessard
parents:
1297
diff
changeset
|
890 |
dimension_range.setlower(dimension[0]) |
f034fb2b1aab
Fixed SFC block edition and SFC to SFC_textual code generating
Laurent Bessard
parents:
1297
diff
changeset
|
891 |
dimension_range.setupper(dimension[1]) |
814 | 892 |
if base_type_name in self.GetBaseTypes(): |
1306
1ff1cdf6c318
Fixed bug with direct array variable type definition
Laurent Bessard
parents:
1304
diff
changeset
|
893 |
baseType.setcontent(PLCOpenParser.CreateElement( |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
894 |
base_type_name.lower() |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
895 |
if base_type_name in ["STRING", "WSTRING"] |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
896 |
else base_type_name, "dataType")) |
814 | 897 |
else: |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
898 |
derived_datatype = PLCOpenParser.CreateElement("derived", "dataType") |
814 | 899 |
derived_datatype.setname(base_type_name) |
1306
1ff1cdf6c318
Fixed bug with direct array variable type definition
Laurent Bessard
parents:
1304
diff
changeset
|
900 |
baseType.setcontent(derived_datatype) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
901 |
var_type.setcontent(array) |
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
902 |
elif var.Type in self.GetBaseTypes(): |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
903 |
var_type.setcontent(PLCOpenParser.CreateElement( |
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
904 |
var.Type.lower() |
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
905 |
if var.Type in ["STRING", "WSTRING"] |
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
906 |
else var.Type, "dataType")) |
814 | 907 |
else: |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
908 |
derived_type = PLCOpenParser.CreateElement("derived", "dataType") |
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
909 |
derived_type.setname(var.Type) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
910 |
var_type.setcontent(derived_type) |
814 | 911 |
tempvar.settype(var_type) |
912 |
||
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
913 |
if var.InitialValue != "": |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
914 |
value = PLCOpenParser.CreateElement("initialValue", "variable") |
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
915 |
value.setvalue(var.InitialValue) |
814 | 916 |
tempvar.setinitialValue(value) |
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
917 |
if var.Location != "": |
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
918 |
tempvar.setaddress(var.Location) |
814 | 919 |
else: |
920 |
tempvar.setaddress(None) |
|
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
921 |
if var.Documentation != "": |
1294
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
922 |
ft = PLCOpenParser.CreateElement("documentation", "variable") |
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
923 |
ft.setanyText(var.Documentation) |
814 | 924 |
tempvar.setdocumentation(ft) |
925 |
||
926 |
# Add variable to varList |
|
927 |
current_varlist.appendvariable(tempvar) |
|
928 |
return varlist_list |
|
1411 | 929 |
|
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
930 |
def GetVariableDictionary(self, object_with_vars, tree=False, debug=False): |
1308
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
931 |
variables = [] |
1953
5736d25bb393
PEP8 and PyLint conformance: whitespaces and stuff
Edouard Tisserant
parents:
1951
diff
changeset
|
932 |
self.VariableInfoCollector.Collect(object_with_vars, |
5736d25bb393
PEP8 and PyLint conformance: whitespaces and stuff
Edouard Tisserant
parents:
1951
diff
changeset
|
933 |
debug, variables, tree) |
1308
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
934 |
return variables |
1411 | 935 |
|
1171
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
936 |
# Add a global var to configuration to configuration |
1411 | 937 |
def AddConfigurationGlobalVar(self, config_name, var_type, var_name, |
1767
c74815729afd
clean-up: fix PEP8 E127 continuation line over-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1766
diff
changeset
|
938 |
location="", description=""): |
1171
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
939 |
if self.Project is not None: |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
940 |
# Found the configuration corresponding to name |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
941 |
configuration = self.Project.getconfiguration(config_name) |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
942 |
if configuration is not None: |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
943 |
# Set configuration global vars |
1313
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
944 |
configuration.addglobalVar( |
1411 | 945 |
self.GetVarTypeObject(var_type), |
1313
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
946 |
var_name, location, description) |
814 | 947 |
|
948 |
# Replace the configuration globalvars by those given |
|
949 |
def SetConfigurationGlobalVars(self, name, vars): |
|
950 |
if self.Project is not None: |
|
951 |
# Found the configuration corresponding to name |
|
952 |
configuration = self.Project.getconfiguration(name) |
|
953 |
if configuration is not None: |
|
954 |
# Set configuration global vars |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
955 |
configuration.setglobalVars([ |
1847
6198190bc121
explicitly mark unused variables found by pylint with _ or dummy
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1846
diff
changeset
|
956 |
varlist for _vartype, varlist |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
957 |
in self.ExtractVarLists(vars)]) |
1411 | 958 |
|
814 | 959 |
# Return the configuration globalvars |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
960 |
def GetConfigurationGlobalVars(self, name, debug=False): |
814 | 961 |
project = self.GetProject(debug) |
962 |
if project is not None: |
|
963 |
# Found the configuration corresponding to name |
|
964 |
configuration = project.getconfiguration(name) |
|
965 |
if configuration is not None: |
|
1308
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
966 |
# Extract variables defined in configuration |
1319
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
967 |
return self.GetVariableDictionary(configuration, debug) |
1411 | 968 |
|
1308
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
969 |
return [] |
814 | 970 |
|
1171
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
971 |
# Return configuration variable names |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
972 |
def GetConfigurationVariableNames(self, config_name=None, debug=False): |
1171
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
973 |
variables = [] |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
974 |
project = self.GetProject(debug) |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
975 |
if project is not None: |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
976 |
for configuration in self.Project.getconfigurations(): |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
977 |
if config_name is None or config_name == configuration.getname(): |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
978 |
variables.extend( |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
979 |
[var.getname() for var in reduce( |
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
980 |
lambda x, y: x + y, [ |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
981 |
varlist.getvariable() |
1171
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
982 |
for varlist in configuration.globalVars], |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
983 |
[])]) |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
984 |
return variables |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
985 |
|
814 | 986 |
# Replace the resource globalvars by those given |
987 |
def SetConfigurationResourceGlobalVars(self, config_name, name, vars): |
|
988 |
if self.Project is not None: |
|
989 |
# Found the resource corresponding to name |
|
990 |
resource = self.Project.getconfigurationResource(config_name, name) |
|
991 |
# Set resource global vars |
|
992 |
if resource is not None: |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
993 |
resource.setglobalVars([ |
1847
6198190bc121
explicitly mark unused variables found by pylint with _ or dummy
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1846
diff
changeset
|
994 |
varlist for _vartype, varlist |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
995 |
in self.ExtractVarLists(vars)]) |
1411 | 996 |
|
814 | 997 |
# Return the resource globalvars |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
998 |
def GetConfigurationResourceGlobalVars(self, config_name, name, debug=False): |
814 | 999 |
project = self.GetProject(debug) |
1000 |
if project is not None: |
|
1001 |
# Found the resource corresponding to name |
|
1002 |
resource = project.getconfigurationResource(config_name, name) |
|
1294
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
1003 |
if resource is not None: |
1308
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1004 |
# Extract variables defined in configuration |
1319
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
1005 |
return self.GetVariableDictionary(resource, debug) |
1411 | 1006 |
|
1308
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1007 |
return [] |
1411 | 1008 |
|
1171
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1009 |
# Return resource variable names |
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1010 |
def GetConfigurationResourceVariableNames( |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1011 |
self, config_name=None, resource_name=None, debug=False): |
1171
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1012 |
variables = [] |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1013 |
project = self.GetProject(debug) |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1014 |
if project is not None: |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1015 |
for configuration in self.Project.getconfigurations(): |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1016 |
if config_name is None or config_name == configuration.getname(): |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1017 |
for resource in configuration.getresource(): |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1018 |
if resource_name is None or resource.getname() == resource_name: |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1019 |
variables.extend( |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1020 |
[var.getname() for var in reduce( |
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1021 |
lambda x, y: x + y, [ |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1022 |
varlist.getvariable() |
1171
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1023 |
for varlist in resource.globalVars], |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1024 |
[])]) |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1025 |
return variables |
814 | 1026 |
|
1027 |
# Return the interface for the given pou |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1028 |
def GetPouInterfaceVars(self, pou, tree=False, debug=False): |
1308
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1029 |
interface = pou.interface |
814 | 1030 |
# Verify that the pou has an interface |
1308
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1031 |
if interface is not None: |
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1032 |
# Extract variables defined in interface |
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
1033 |
return self.GetVariableDictionary(interface, tree, debug) |
1308
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1034 |
return [] |
814 | 1035 |
|
1036 |
# Replace the Pou interface by the one given |
|
1037 |
def SetPouInterfaceVars(self, name, vars): |
|
1038 |
if self.Project is not None: |
|
1039 |
# Found the pou corresponding to name and add interface if there isn't one yet |
|
1040 |
pou = self.Project.getpou(name) |
|
1041 |
if pou is not None: |
|
1042 |
if pou.interface is None: |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1043 |
pou.interface = PLCOpenParser.CreateElement("interface", "pou") |
814 | 1044 |
# Set Pou interface |
1847
6198190bc121
explicitly mark unused variables found by pylint with _ or dummy
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1846
diff
changeset
|
1045 |
pou.setvars([varlist for _varlist_type, varlist in self.ExtractVarLists(vars)]) |
1411 | 1046 |
|
814 | 1047 |
# Replace the return type of the pou given by its name (only for functions) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1048 |
def SetPouInterfaceReturnType(self, name, return_type): |
814 | 1049 |
if self.Project is not None: |
1050 |
pou = self.Project.getpou(name) |
|
1051 |
if pou is not None: |
|
1052 |
if pou.interface is None: |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1053 |
pou.interface = PLCOpenParser.CreateElement("interface", "pou") |
814 | 1054 |
# If there isn't any return type yet, add it |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1055 |
return_type_obj = pou.interface.getreturnType() |
1294
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
1056 |
if return_type_obj is None: |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1057 |
return_type_obj = PLCOpenParser.CreateElement("returnType", "interface") |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1058 |
pou.interface.setreturnType(return_type_obj) |
814 | 1059 |
# Change return type |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1060 |
if return_type in self.GetBaseTypes(): |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1061 |
return_type_obj.setcontent(PLCOpenParser.CreateElement( |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1062 |
return_type.lower() |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1063 |
if return_type in ["STRING", "WSTRING"] |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1064 |
else return_type, "dataType")) |
814 | 1065 |
else: |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1066 |
derived_type = PLCOpenParser.CreateElement("derived", "dataType") |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1067 |
derived_type.setname(return_type) |
1418
c97dc5281419
Fixed declaration and ST code gen for IEC function that return derivated types
Edouard Tisserant
parents:
1411
diff
changeset
|
1068 |
return_type_obj.setcontent(derived_type) |
1411 | 1069 |
|
814 | 1070 |
def UpdateProjectUsedPous(self, old_name, new_name): |
1294
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
1071 |
if self.Project is not None: |
814 | 1072 |
self.Project.updateElementName(old_name, new_name) |
1411 | 1073 |
|
814 | 1074 |
def UpdateEditedElementUsedVariable(self, tagname, old_name, new_name): |
1075 |
pou = self.GetEditedElement(tagname) |
|
1294
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
1076 |
if pou is not None: |
814 | 1077 |
pou.updateElementName(old_name, new_name) |
1411 | 1078 |
|
814 | 1079 |
# Return the return type of the given pou |
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
1080 |
def GetPouInterfaceReturnType(self, pou, tree=False, debug=False): |
814 | 1081 |
# Verify that the pou has an interface |
1082 |
if pou.interface is not None: |
|
1083 |
# Return the return type if there is one |
|
1084 |
return_type = pou.interface.getreturnType() |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1085 |
if return_type is not None: |
1953
5736d25bb393
PEP8 and PyLint conformance: whitespaces and stuff
Edouard Tisserant
parents:
1951
diff
changeset
|
1086 |
factory = self.VariableInfoCollector.Collect(return_type, |
1951
bbd1e1744c91
GetVariableDictionary and GetPouInterfaceReturnType optimized with new VariableInfoCollector based on XSLTModelQuery. Moved corresponding definitions out of PLCControler.py.
Edouard Tisserant
parents:
1950
diff
changeset
|
1087 |
debug, [], tree) |
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
1088 |
if tree: |
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
1089 |
return [factory.GetType(), factory.GetTree()] |
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
1090 |
return factory.GetType() |
1411 | 1091 |
|
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
1092 |
if tree: |
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
1093 |
return [None, ([], [])] |
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
1094 |
return None |
814 | 1095 |
|
1096 |
# Function that add a new confnode to the confnode list |
|
1097 |
def AddConfNodeTypesList(self, typeslist): |
|
1098 |
self.ConfNodeTypes.extend(typeslist) |
|
1283
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1099 |
addedcat = [{"name": _("%s POUs") % confnodetypes["name"], |
1302
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1100 |
"list": [pou.getblockInfos() |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1101 |
for pou in confnodetypes["types"].getpous()]} |
1767
c74815729afd
clean-up: fix PEP8 E127 continuation line over-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1766
diff
changeset
|
1102 |
for confnodetypes in typeslist] |
1283
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1103 |
self.TotalTypes.extend(addedcat) |
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1104 |
for cat in addedcat: |
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1105 |
for desc in cat["list"]: |
1740
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
1106 |
BlkLst = self.TotalTypesDict.setdefault(desc["name"], []) |
1283
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1107 |
BlkLst.append((section["name"], desc)) |
1411 | 1108 |
|
814 | 1109 |
# Function that clear the confnode list |
1110 |
def ClearConfNodeTypes(self): |
|
1283
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1111 |
self.ConfNodeTypes = [] |
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1112 |
self.TotalTypesDict = StdBlckDct.copy() |
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1113 |
self.TotalTypes = StdBlckLst[:] |
814 | 1114 |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1115 |
def GetConfNodeDataTypes(self, exclude=None, only_locatables=False): |
814 | 1116 |
return [{"name": _("%s Data Types") % confnodetypes["name"], |
1302
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1117 |
"list": [ |
1878
fb73a6b6622d
fix pylint warning '(bad-continuation) Wrong hanging indentation before block'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1875
diff
changeset
|
1118 |
datatype.getname() |
fb73a6b6622d
fix pylint warning '(bad-continuation) Wrong hanging indentation before block'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1875
diff
changeset
|
1119 |
for datatype in confnodetypes["types"].getdataTypes() |
fb73a6b6622d
fix pylint warning '(bad-continuation) Wrong hanging indentation before block'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1875
diff
changeset
|
1120 |
if not only_locatables or self.IsLocatableDataType(datatype)]} |
814 | 1121 |
for confnodetypes in self.ConfNodeTypes] |
1411 | 1122 |
|
814 | 1123 |
def GetVariableLocationTree(self): |
1124 |
return [] |
|
1125 |
||
883
235a9ec83b95
Adding support for defining specific global variables for ConfTreeNodes
Laurent Bessard
parents:
864
diff
changeset
|
1126 |
def GetConfNodeGlobalInstances(self): |
235a9ec83b95
Adding support for defining specific global variables for ConfTreeNodes
Laurent Bessard
parents:
864
diff
changeset
|
1127 |
return [] |
235a9ec83b95
Adding support for defining specific global variables for ConfTreeNodes
Laurent Bessard
parents:
864
diff
changeset
|
1128 |
|
235a9ec83b95
Adding support for defining specific global variables for ConfTreeNodes
Laurent Bessard
parents:
864
diff
changeset
|
1129 |
def GetConfigurationExtraVariables(self): |
235a9ec83b95
Adding support for defining specific global variables for ConfTreeNodes
Laurent Bessard
parents:
864
diff
changeset
|
1130 |
global_vars = [] |
1096
c9ace6a881c9
Fixed CFileEditor replacing folding panels by variable panel and STC
Laurent Bessard
parents:
901
diff
changeset
|
1131 |
for var_name, var_type, var_initial in self.GetConfNodeGlobalInstances(): |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1132 |
tempvar = PLCOpenParser.CreateElement("variable", "globalVars") |
883
235a9ec83b95
Adding support for defining specific global variables for ConfTreeNodes
Laurent Bessard
parents:
864
diff
changeset
|
1133 |
tempvar.setname(var_name) |
1411 | 1134 |
|
1315
ff14a66bbd12
Fixed Beremiz for working with new xmlclass support using lxml
Laurent Bessard
parents:
1313
diff
changeset
|
1135 |
tempvartype = PLCOpenParser.CreateElement("type", "variable") |
883
235a9ec83b95
Adding support for defining specific global variables for ConfTreeNodes
Laurent Bessard
parents:
864
diff
changeset
|
1136 |
if var_type in self.GetBaseTypes(): |
1315
ff14a66bbd12
Fixed Beremiz for working with new xmlclass support using lxml
Laurent Bessard
parents:
1313
diff
changeset
|
1137 |
tempvartype.setcontent(PLCOpenParser.CreateElement( |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1138 |
var_type.lower() |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1139 |
if var_type in ["STRING", "WSTRING"] |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1140 |
else var_type, "dataType")) |
883
235a9ec83b95
Adding support for defining specific global variables for ConfTreeNodes
Laurent Bessard
parents:
864
diff
changeset
|
1141 |
else: |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1142 |
tempderivedtype = PLCOpenParser.CreateElement("derived", "dataType") |
883
235a9ec83b95
Adding support for defining specific global variables for ConfTreeNodes
Laurent Bessard
parents:
864
diff
changeset
|
1143 |
tempderivedtype.setname(var_type) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1144 |
tempvartype.setcontent(tempderivedtype) |
883
235a9ec83b95
Adding support for defining specific global variables for ConfTreeNodes
Laurent Bessard
parents:
864
diff
changeset
|
1145 |
tempvar.settype(tempvartype) |
1411 | 1146 |
|
1096
c9ace6a881c9
Fixed CFileEditor replacing folding panels by variable panel and STC
Laurent Bessard
parents:
901
diff
changeset
|
1147 |
if var_initial != "": |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1148 |
value = PLCOpenParser.CreateElement("initialValue", "variable") |
1096
c9ace6a881c9
Fixed CFileEditor replacing folding panels by variable panel and STC
Laurent Bessard
parents:
901
diff
changeset
|
1149 |
value.setvalue(var_initial) |
c9ace6a881c9
Fixed CFileEditor replacing folding panels by variable panel and STC
Laurent Bessard
parents:
901
diff
changeset
|
1150 |
tempvar.setinitialValue(value) |
1411 | 1151 |
|
883
235a9ec83b95
Adding support for defining specific global variables for ConfTreeNodes
Laurent Bessard
parents:
864
diff
changeset
|
1152 |
global_vars.append(tempvar) |
235a9ec83b95
Adding support for defining specific global variables for ConfTreeNodes
Laurent Bessard
parents:
864
diff
changeset
|
1153 |
return global_vars |
235a9ec83b95
Adding support for defining specific global variables for ConfTreeNodes
Laurent Bessard
parents:
864
diff
changeset
|
1154 |
|
814 | 1155 |
# Function that returns the block definition associated to the block type given |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1156 |
def GetBlockType(self, typename, inputs=None, debug=False): |
1879
4d81c3bcac82
fix pylint error '(unsubscriptable-object) Value 'X' is unsubscriptable'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1878
diff
changeset
|
1157 |
result_blocktype = {} |
1847
6198190bc121
explicitly mark unused variables found by pylint with _ or dummy
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1846
diff
changeset
|
1158 |
for _sectioname, blocktype in self.TotalTypesDict.get(typename, []): |
1283
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1159 |
if inputs is not None and inputs != "undefined": |
1847
6198190bc121
explicitly mark unused variables found by pylint with _ or dummy
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1846
diff
changeset
|
1160 |
block_inputs = tuple([var_type for _name, var_type, _modifier in blocktype["inputs"]]) |
1283
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1161 |
if reduce(lambda x, y: x and y, map(lambda x: x[0] == "ANY" or self.IsOfType(*x), zip(inputs, block_inputs)), True): |
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1162 |
return blocktype |
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1163 |
else: |
1879
4d81c3bcac82
fix pylint error '(unsubscriptable-object) Value 'X' is unsubscriptable'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1878
diff
changeset
|
1164 |
if result_blocktype: |
1283
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1165 |
if inputs == "undefined": |
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1166 |
return None |
814 | 1167 |
else: |
1283
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1168 |
result_blocktype["inputs"] = [(i[0], "ANY", i[2]) for i in result_blocktype["inputs"]] |
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1169 |
result_blocktype["outputs"] = [(o[0], "ANY", o[2]) for o in result_blocktype["outputs"]] |
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1170 |
return result_blocktype |
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1171 |
result_blocktype = blocktype.copy() |
1879
4d81c3bcac82
fix pylint error '(unsubscriptable-object) Value 'X' is unsubscriptable'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1878
diff
changeset
|
1172 |
if result_blocktype: |
814 | 1173 |
return result_blocktype |
1174 |
project = self.GetProject(debug) |
|
1175 |
if project is not None: |
|
1302
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1176 |
blocktype = project.getpou(typename) |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1177 |
if blocktype is not None: |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1178 |
blocktype_infos = blocktype.getblockInfos() |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1179 |
if inputs in [None, "undefined"]: |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1180 |
return blocktype_infos |
1411 | 1181 |
|
1182 |
if inputs == tuple([var_type |
|
1847
6198190bc121
explicitly mark unused variables found by pylint with _ or dummy
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1846
diff
changeset
|
1183 |
for _name, var_type, _modifier in blocktype_infos["inputs"]]): |
1302
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1184 |
return blocktype_infos |
1411 | 1185 |
|
814 | 1186 |
return None |
1187 |
||
1188 |
# Return Block types checking for recursion |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1189 |
def GetBlockTypes(self, tagname="", debug=False): |
814 | 1190 |
words = tagname.split("::") |
1283
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1191 |
name = None |
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1192 |
project = self.GetProject(debug) |
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1193 |
if project is not None: |
1284 | 1194 |
pou_type = None |
1740
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
1195 |
if words[0] in ["P", "T", "A"]: |
814 | 1196 |
name = words[1] |
1284 | 1197 |
pou_type = self.GetPouType(name, debug) |
1411 | 1198 |
filter = (["function"] |
1199 |
if pou_type == "function" or words[0] == "T" |
|
1302
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1200 |
else ["functionBlock", "function"]) |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1201 |
blocktypes = [ |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1202 |
{"name": category["name"], |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1203 |
"list": [block for block in category["list"] |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1204 |
if block["type"] in filter]} |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1205 |
for category in self.TotalTypes] |
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1206 |
blocktypes.append({ |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1207 |
"name": USER_DEFINED_POUS, |
1302
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1208 |
"list": [pou.getblockInfos() |
1319
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
1209 |
for pou in project.getpous(name, filter) |
1411 | 1210 |
if (name is None or |
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1211 |
len(self.GetInstanceList(pou, name, debug)) == 0)] |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1212 |
}) |
1284 | 1213 |
return blocktypes |
1283
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1214 |
return self.TotalTypes |
814 | 1215 |
|
1216 |
# Return Function Block types checking for recursion |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1217 |
def GetFunctionBlockTypes(self, tagname="", debug=False): |
1319
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
1218 |
project = self.GetProject(debug) |
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
1219 |
words = tagname.split("::") |
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
1220 |
name = None |
1740
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
1221 |
if project is not None and words[0] in ["P", "T", "A"]: |
1319
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
1222 |
name = words[1] |
814 | 1223 |
blocktypes = [] |
1283
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1224 |
for blocks in self.TotalTypesDict.itervalues(): |
1847
6198190bc121
explicitly mark unused variables found by pylint with _ or dummy
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1846
diff
changeset
|
1225 |
for _sectioname, block in blocks: |
814 | 1226 |
if block["type"] == "functionBlock": |
1227 |
blocktypes.append(block["name"]) |
|
1319
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
1228 |
if project is not None: |
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1229 |
blocktypes.extend([ |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1230 |
pou.getname() |
1319
748347102c97
Replaced old list of pou instance in project generating process by xslt stylesheet
Laurent Bessard
parents:
1316
diff
changeset
|
1231 |
for pou in project.getpous(name, ["functionBlock"]) |
1411 | 1232 |
if (name is None or |
1372
ef26fcb7f5d4
Fixed bug in test if block type is used by current edited pou
Laurent Bessard
parents:
1368
diff
changeset
|
1233 |
len(self.GetInstanceList(pou, name, debug)) == 0)]) |
814 | 1234 |
return blocktypes |
1235 |
||
1236 |
# Return Block types checking for recursion |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1237 |
def GetBlockResource(self, debug=False): |
814 | 1238 |
blocktypes = [] |
1283
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1239 |
for category in StdBlckLst[:-1]: |
814 | 1240 |
for blocktype in category["list"]: |
1241 |
if blocktype["type"] == "program": |
|
1242 |
blocktypes.append(blocktype["name"]) |
|
1243 |
project = self.GetProject(debug) |
|
1244 |
if project is not None: |
|
1302
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1245 |
blocktypes.extend( |
1328
a2f2981df9b0
Fixed bug in Resource POU instance type selection
Laurent Bessard
parents:
1326
diff
changeset
|
1246 |
[pou.getname() |
1302
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1247 |
for pou in project.getpous(filter=["program"])]) |
814 | 1248 |
return blocktypes |
1249 |
||
1250 |
# Return Data Types checking for recursion |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1251 |
def GetDataTypes(self, tagname="", basetypes=True, confnodetypes=True, only_locatables=False, debug=False): |
814 | 1252 |
if basetypes: |
1253 |
datatypes = self.GetBaseTypes() |
|
1254 |
else: |
|
1255 |
datatypes = [] |
|
1256 |
project = self.GetProject(debug) |
|
1283
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1257 |
name = None |
f3cfe1ff917e
More optimization attemps in type handling
Edouard Tisserant
parents:
1265
diff
changeset
|
1258 |
if project is not None: |
814 | 1259 |
words = tagname.split("::") |
1260 |
if words[0] in ["D"]: |
|
1261 |
name = words[1] |
|
1302
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1262 |
datatypes.extend([ |
1411 | 1263 |
datatype.getname() |
1302
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1264 |
for datatype in project.getdataTypes(name) |
1785
0ff2a45dcefa
clean-up: fix PEP8 W503 line break before binary operator
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1782
diff
changeset
|
1265 |
if ((not only_locatables or self.IsLocatableDataType(datatype, debug)) and |
0ff2a45dcefa
clean-up: fix PEP8 W503 line break before binary operator
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1782
diff
changeset
|
1266 |
(name is None or len(self.GetInstanceList(datatype, name, debug)) == 0))]) |
863
b1ead41fbd3b
Fix bug in VariablePanel 'Type' cell editor menu entry 'User Data Types' containing ConfNodes data types
Laurent Bessard
parents:
853
diff
changeset
|
1267 |
if confnodetypes: |
b1ead41fbd3b
Fix bug in VariablePanel 'Type' cell editor menu entry 'User Data Types' containing ConfNodes data types
Laurent Bessard
parents:
853
diff
changeset
|
1268 |
for category in self.GetConfNodeDataTypes(name, only_locatables): |
b1ead41fbd3b
Fix bug in VariablePanel 'Type' cell editor menu entry 'User Data Types' containing ConfNodes data types
Laurent Bessard
parents:
853
diff
changeset
|
1269 |
datatypes.extend(category["list"]) |
814 | 1270 |
return datatypes |
1271 |
||
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1272 |
# Return Data Type Object |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1273 |
def GetPou(self, typename, debug=False): |
1308
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1274 |
project = self.GetProject(debug) |
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1275 |
if project is not None: |
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1276 |
result = project.getpou(typename) |
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1277 |
if result is not None: |
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1278 |
return result |
1390 | 1279 |
for standardlibrary in StdBlckLibs.values(): |
1313
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
1280 |
result = standardlibrary.getpou(typename) |
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
1281 |
if result is not None: |
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
1282 |
return result |
1308
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1283 |
for confnodetype in self.ConfNodeTypes: |
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1284 |
result = confnodetype["types"].getpou(typename) |
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1285 |
if result is not None: |
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1286 |
return result |
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1287 |
return None |
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1288 |
|
ad61268dbdb6
Replaced old pou variable list and variable tree generating by xslt stylesheet
Laurent Bessard
parents:
1306
diff
changeset
|
1289 |
# Return Data Type Object |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1290 |
def GetDataType(self, typename, debug=False): |
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1291 |
project = self.GetProject(debug) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1292 |
if project is not None: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1293 |
result = project.getdataType(typename) |
814 | 1294 |
if result is not None: |
1295 |
return result |
|
1296 |
for confnodetype in self.ConfNodeTypes: |
|
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1297 |
result = confnodetype["types"].getdataType(typename) |
814 | 1298 |
if result is not None: |
1299 |
return result |
|
1300 |
return None |
|
1301 |
||
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1302 |
# Return Data Type Object Base Type |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1303 |
def GetDataTypeBaseType(self, datatype): |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1304 |
basetype_content = datatype.baseType.getcontent() |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1305 |
basetype_content_type = basetype_content.getLocalTag() |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1306 |
if basetype_content_type in ["array", "subrangeSigned", "subrangeUnsigned"]: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1307 |
basetype = basetype_content.baseType.getcontent() |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1308 |
basetype_type = basetype.getLocalTag() |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1309 |
return (basetype.getname() if basetype_type == "derived" |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1310 |
else basetype_type.upper()) |
1338
c1e6c712cc35
Replaced old graphic viewer blocks loading process by xslt stylesheet
Laurent Bessard
parents:
1337
diff
changeset
|
1311 |
return (basetype_content.getname() if basetype_content_type == "derived" |
c1e6c712cc35
Replaced old graphic viewer blocks loading process by xslt stylesheet
Laurent Bessard
parents:
1337
diff
changeset
|
1312 |
else basetype_content_type.upper()) |
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1313 |
|
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1314 |
# Return Base Type of given possible derived type |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1315 |
def GetBaseType(self, typename, debug=False): |
1763
bcc07ff2362c
clean-up: fix PEP8 W601 .has_key() is deprecated, use 'in'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1762
diff
changeset
|
1316 |
if typename in TypeHierarchy: |
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1317 |
return typename |
1411 | 1318 |
|
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1319 |
datatype = self.GetDataType(typename, debug) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1320 |
if datatype is not None: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1321 |
basetype = self.GetDataTypeBaseType(datatype) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1322 |
if basetype is not None: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1323 |
return self.GetBaseType(basetype, debug) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1324 |
return typename |
1411 | 1325 |
|
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1326 |
return None |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1327 |
|
814 | 1328 |
def GetBaseTypes(self): |
1329 |
''' |
|
1330 |
return the list of datatypes defined in IEC 61131-3. |
|
1331 |
TypeHierarchy_list has a rough order to it (e.g. SINT, INT, DINT, ...), |
|
1332 |
which makes it easy for a user to find a type in a menu. |
|
1333 |
''' |
|
1847
6198190bc121
explicitly mark unused variables found by pylint with _ or dummy
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1846
diff
changeset
|
1334 |
return [x for x, _y in TypeHierarchy_list if not x.startswith("ANY")] |
814 | 1335 |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1336 |
def IsOfType(self, typename, reference, debug=False): |
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1337 |
if reference is None or typename == reference: |
814 | 1338 |
return True |
1411 | 1339 |
|
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1340 |
basetype = TypeHierarchy.get(typename) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1341 |
if basetype is not None: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1342 |
return self.IsOfType(basetype, reference) |
1411 | 1343 |
|
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1344 |
datatype = self.GetDataType(typename, debug) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1345 |
if datatype is not None: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1346 |
basetype = self.GetDataTypeBaseType(datatype) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1347 |
if basetype is not None: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1348 |
return self.IsOfType(basetype, reference, debug) |
1411 | 1349 |
|
814 | 1350 |
return False |
1411 | 1351 |
|
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1352 |
def IsEndType(self, typename): |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1353 |
if typename is not None: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1354 |
return not typename.startswith("ANY") |
814 | 1355 |
return True |
1356 |
||
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1357 |
def IsLocatableDataType(self, datatype, debug=False): |
1302
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1358 |
basetype_content = datatype.baseType.getcontent() |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1359 |
basetype_content_type = basetype_content.getLocalTag() |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1360 |
if basetype_content_type in ["enum", "struct"]: |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1361 |
return False |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1362 |
elif basetype_content_type == "derived": |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1363 |
return self.IsLocatableType(basetype_content.getname()) |
1321
83f41ea00b97
Replaced old pou instance type tagname computing by xslt stylesheet
Laurent Bessard
parents:
1319
diff
changeset
|
1364 |
elif basetype_content_type == "array": |
1302
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1365 |
array_base_type = basetype_content.baseType.getcontent() |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1366 |
if array_base_type.getLocalTag() == "derived": |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1367 |
return self.IsLocatableType(array_base_type.getname(), debug) |
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1368 |
return True |
1411 | 1369 |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1370 |
def IsLocatableType(self, typename, debug=False): |
2450
5024c19ca8f0
python3 support: pylint, W1652 # (deprecated-types-field) Accessing a deprecated fields on the types module
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
2447
diff
changeset
|
1371 |
if isinstance(typename, tuple) or self.GetBlockType(typename) is not None: |
884
e12228fd8773
Add function block types as data types that are not locatable
Laurent Bessard
parents:
883
diff
changeset
|
1372 |
return False |
1411 | 1373 |
|
1686
85fdcc04da25
disallow setting IEC location addresses for TIME, DATE, DT and TOD variables
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1680
diff
changeset
|
1374 |
# the size of these types is implementation dependend |
85fdcc04da25
disallow setting IEC location addresses for TIME, DATE, DT and TOD variables
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1680
diff
changeset
|
1375 |
if typename in ["TIME", "DATE", "DT", "TOD"]: |
85fdcc04da25
disallow setting IEC location addresses for TIME, DATE, DT and TOD variables
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1680
diff
changeset
|
1376 |
return False |
1735
c02818d7e29f
clean-up: fix PEP8 W293 blank line contains whitespace
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1734
diff
changeset
|
1377 |
|
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1378 |
datatype = self.GetDataType(typename, debug) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1379 |
if datatype is not None: |
1302
7856cd7767d6
Removed dictionaries storing datatypes and pous defined in project and pou and datatype using tree from model
Laurent Bessard
parents:
1301
diff
changeset
|
1380 |
return self.IsLocatableDataType(datatype) |
814 | 1381 |
return True |
1411 | 1382 |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1383 |
def IsEnumeratedType(self, typename, debug=False): |
2450
5024c19ca8f0
python3 support: pylint, W1652 # (deprecated-types-field) Accessing a deprecated fields on the types module
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
2447
diff
changeset
|
1384 |
if isinstance(typename, tuple): |
1306
1ff1cdf6c318
Fixed bug with direct array variable type definition
Laurent Bessard
parents:
1304
diff
changeset
|
1385 |
typename = typename[1] |
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1386 |
datatype = self.GetDataType(typename, debug) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1387 |
if datatype is not None: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1388 |
basetype_content = datatype.baseType.getcontent() |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1389 |
basetype_content_type = basetype_content.getLocalTag() |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1390 |
if basetype_content_type == "derived": |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1391 |
return self.IsEnumeratedType(basetype_content_type, debug) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1392 |
return basetype_content_type == "enum" |
814 | 1393 |
return False |
1394 |
||
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1395 |
def IsSubrangeType(self, typename, exclude=None, debug=False): |
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1396 |
if typename == exclude: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1397 |
return False |
2450
5024c19ca8f0
python3 support: pylint, W1652 # (deprecated-types-field) Accessing a deprecated fields on the types module
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
2447
diff
changeset
|
1398 |
if isinstance(typename, tuple): |
1306
1ff1cdf6c318
Fixed bug with direct array variable type definition
Laurent Bessard
parents:
1304
diff
changeset
|
1399 |
typename = typename[1] |
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1400 |
datatype = self.GetDataType(typename, debug) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1401 |
if datatype is not None: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1402 |
basetype_content = datatype.baseType.getcontent() |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1403 |
basetype_content_type = basetype_content.getLocalTag() |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1404 |
if basetype_content_type == "derived": |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1405 |
return self.IsSubrangeType(basetype_content_type, exclude, debug) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1406 |
elif basetype_content_type in ["subrangeSigned", "subrangeUnsigned"]: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1407 |
return not self.IsOfType( |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1408 |
self.GetDataTypeBaseType(datatype), exclude) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1409 |
return False |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1410 |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1411 |
def IsNumType(self, typename, debug=False): |
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1412 |
return self.IsOfType(typename, "ANY_NUM", debug) or\ |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1413 |
self.IsOfType(typename, "ANY_BIT", debug) |
1411 | 1414 |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1415 |
def GetDataTypeRange(self, typename, debug=False): |
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1416 |
range = DataTypeRange.get(typename) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1417 |
if range is not None: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1418 |
return range |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1419 |
datatype = self.GetDataType(typename, debug) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1420 |
if datatype is not None: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1421 |
basetype_content = datatype.baseType.getcontent() |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1422 |
basetype_content_type = basetype_content.getLocalTag() |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1423 |
if basetype_content_type in ["subrangeSigned", "subrangeUnsigned"]: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1424 |
return (basetype_content.range.getlower(), |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1425 |
basetype_content.range.getupper()) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1426 |
elif basetype_content_type == "derived": |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1427 |
return self.GetDataTypeRange(basetype_content.getname(), debug) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1428 |
return None |
1411 | 1429 |
|
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1430 |
# Return Subrange types |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1431 |
def GetSubrangeBaseTypes(self, exclude, debug=False): |
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1432 |
subrange_basetypes = DataTypeRange.keys() |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1433 |
project = self.GetProject(debug) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1434 |
if project is not None: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1435 |
subrange_basetypes.extend( |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1436 |
[datatype.getname() for datatype in project.getdataTypes() |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1437 |
if self.IsSubrangeType(datatype.getname(), exclude, debug)]) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1438 |
for confnodetype in self.ConfNodeTypes: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1439 |
subrange_basetypes.extend( |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1440 |
[datatype.getname() for datatype in confnodetype["types"].getdataTypes() |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1441 |
if self.IsSubrangeType(datatype.getname(), exclude, debug)]) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1442 |
return subrange_basetypes |
1411 | 1443 |
|
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1444 |
# Return Enumerated Values |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1445 |
def GetEnumeratedDataValues(self, typename=None, debug=False): |
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1446 |
values = [] |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1447 |
if typename is not None: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1448 |
datatype_obj = self.GetDataType(typename, debug) |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1449 |
if datatype_obj is not None: |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1450 |
basetype_content = datatype_obj.baseType.getcontent() |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1451 |
basetype_content_type = basetype_content.getLocalTag() |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1452 |
if basetype_content_type == "enum": |
1411 | 1453 |
return [value.getname() |
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1454 |
for value in basetype_content.xpath( |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1455 |
"ppx:values/ppx:value", |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1456 |
namespaces=PLCOpenParser.NSMAP)] |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1457 |
elif basetype_content_type == "derived": |
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1458 |
return self.GetEnumeratedDataValues(basetype_content.getname(), debug) |
814 | 1459 |
else: |
1460 |
project = self.GetProject(debug) |
|
1461 |
if project is not None: |
|
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1462 |
values.extend(project.GetEnumeratedDataTypeValues()) |
814 | 1463 |
for confnodetype in self.ConfNodeTypes: |
1301
fcca121a000f
Removed dictionaries storing enumerated datatypes values, subrange datatypes range and project datatype hierarchy from model
Laurent Bessard
parents:
1299
diff
changeset
|
1464 |
values.extend(confnodetype["types"].GetEnumeratedDataTypeValues()) |
814 | 1465 |
return values |
1466 |
||
1782
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
1467 |
# ------------------------------------------------------------------------------- |
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
1468 |
# Project opened Data types management functions |
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
1469 |
# ------------------------------------------------------------------------------- |
814 | 1470 |
|
1471 |
# Return the data type informations |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1472 |
def GetDataTypeInfos(self, tagname, debug=False): |
814 | 1473 |
project = self.GetProject(debug) |
1474 |
if project is not None: |
|
1475 |
words = tagname.split("::") |
|
1476 |
if words[0] == "D": |
|
1477 |
infos = {} |
|
1478 |
datatype = project.getdataType(words[1]) |
|
883
235a9ec83b95
Adding support for defining specific global variables for ConfTreeNodes
Laurent Bessard
parents:
864
diff
changeset
|
1479 |
if datatype is None: |
235a9ec83b95
Adding support for defining specific global variables for ConfTreeNodes
Laurent Bessard
parents:
864
diff
changeset
|
1480 |
return None |
814 | 1481 |
basetype_content = datatype.baseType.getcontent() |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1482 |
basetype_content_type = basetype_content.getLocalTag() |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1483 |
if basetype_content_type in ["subrangeSigned", "subrangeUnsigned"]: |
814 | 1484 |
infos["type"] = "Subrange" |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1485 |
infos["min"] = basetype_content.range.getlower() |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1486 |
infos["max"] = basetype_content.range.getupper() |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1487 |
base_type = basetype_content.baseType.getcontent() |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1488 |
base_type_type = base_type.getLocalTag() |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1489 |
infos["base_type"] = (base_type.getname() |
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1490 |
if base_type_type == "derived" |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1491 |
else base_type_type) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1492 |
elif basetype_content_type == "enum": |
814 | 1493 |
infos["type"] = "Enumerated" |
1494 |
infos["values"] = [] |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1495 |
for value in basetype_content.xpath("ppx:values/ppx:value", namespaces=PLCOpenParser.NSMAP): |
814 | 1496 |
infos["values"].append(value.getname()) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1497 |
elif basetype_content_type == "array": |
814 | 1498 |
infos["type"] = "Array" |
1499 |
infos["dimensions"] = [] |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1500 |
for dimension in basetype_content.getdimension(): |
814 | 1501 |
infos["dimensions"].append((dimension.getlower(), dimension.getupper())) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1502 |
base_type = basetype_content.baseType.getcontent() |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1503 |
base_type_type = base_type.getLocalTag() |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1504 |
infos["base_type"] = (base_type.getname() |
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1505 |
if base_type_type == "derived" |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1506 |
else base_type_type.upper()) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1507 |
elif basetype_content_type == "struct": |
814 | 1508 |
infos["type"] = "Structure" |
1509 |
infos["elements"] = [] |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1510 |
for element in basetype_content.getvariable(): |
814 | 1511 |
element_infos = {} |
1512 |
element_infos["Name"] = element.getname() |
|
1513 |
element_type = element.type.getcontent() |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1514 |
element_type_type = element_type.getLocalTag() |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1515 |
if element_type_type == "array": |
864
bf4f7f0801b9
Adding support for direct array declaration in structure element declaration
Laurent Bessard
parents:
863
diff
changeset
|
1516 |
dimensions = [] |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1517 |
for dimension in element_type.getdimension(): |
864
bf4f7f0801b9
Adding support for direct array declaration in structure element declaration
Laurent Bessard
parents:
863
diff
changeset
|
1518 |
dimensions.append((dimension.getlower(), dimension.getupper())) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1519 |
base_type = element_type.baseType.getcontent() |
1502
62eb21aab1fb
fix display of ARRAY fields inside of structure data types.
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1477
diff
changeset
|
1520 |
base_type_type = base_type.getLocalTag() |
1411 | 1521 |
element_infos["Type"] = ("array", |
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1522 |
base_type.getname() |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1523 |
if base_type_type == "derived" |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1524 |
else base_type_type.upper(), |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1525 |
dimensions) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1526 |
elif element_type_type == "derived": |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1527 |
element_infos["Type"] = element_type.getname() |
814 | 1528 |
else: |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1529 |
element_infos["Type"] = element_type_type.upper() |
814 | 1530 |
if element.initialValue is not None: |
1508
4c645e6b8c98
fix error if non-latin character was entered in initial value in
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1505
diff
changeset
|
1531 |
element_infos["Initial Value"] = element.initialValue.getvalue() |
814 | 1532 |
else: |
1533 |
element_infos["Initial Value"] = "" |
|
1534 |
infos["elements"].append(element_infos) |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1535 |
else: |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1536 |
infos["type"] = "Directly" |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1537 |
infos["base_type"] = (basetype_content.getname() |
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1538 |
if basetype_content_type == "derived" |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1539 |
else basetype_content_type.upper()) |
1411 | 1540 |
|
814 | 1541 |
if datatype.initialValue is not None: |
1508
4c645e6b8c98
fix error if non-latin character was entered in initial value in
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1505
diff
changeset
|
1542 |
infos["initial"] = datatype.initialValue.getvalue() |
814 | 1543 |
else: |
1544 |
infos["initial"] = "" |
|
1545 |
return infos |
|
1546 |
return None |
|
1411 | 1547 |
|
814 | 1548 |
# Change the data type informations |
1549 |
def SetDataTypeInfos(self, tagname, infos): |
|
1550 |
words = tagname.split("::") |
|
1551 |
if self.Project is not None and words[0] == "D": |
|
1552 |
datatype = self.Project.getdataType(words[1]) |
|
1553 |
if infos["type"] == "Directly": |
|
1554 |
if infos["base_type"] in self.GetBaseTypes(): |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1555 |
datatype.baseType.setcontent(PLCOpenParser.CreateElement( |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1556 |
infos["base_type"].lower() |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1557 |
if infos["base_type"] in ["STRING", "WSTRING"] |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1558 |
else infos["base_type"], "dataType")) |
814 | 1559 |
else: |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1560 |
derived_datatype = PLCOpenParser.CreateElement("derived", "dataType") |
814 | 1561 |
derived_datatype.setname(infos["base_type"]) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1562 |
datatype.baseType.setcontent(derived_datatype) |
814 | 1563 |
elif infos["type"] == "Subrange": |
1294
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
1564 |
subrange = PLCOpenParser.CreateElement( |
1411 | 1565 |
"subrangeUnsigned" |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1566 |
if infos["base_type"] in GetSubTypes("ANY_UINT") |
1294
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
1567 |
else "subrangeSigned", "dataType") |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
1568 |
datatype.baseType.setcontent(subrange) |
814 | 1569 |
subrange.range.setlower(infos["min"]) |
1570 |
subrange.range.setupper(infos["max"]) |
|
1571 |
if infos["base_type"] in self.GetBaseTypes(): |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1572 |
subrange.baseType.setcontent( |
1294
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
1573 |
PLCOpenParser.CreateElement(infos["base_type"], "dataType")) |
814 | 1574 |
else: |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1575 |
derived_datatype = PLCOpenParser.CreateElement("derived", "dataType") |
814 | 1576 |
derived_datatype.setname(infos["base_type"]) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1577 |
subrange.baseType.setcontent(derived_datatype) |
814 | 1578 |
elif infos["type"] == "Enumerated": |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1579 |
enumerated = PLCOpenParser.CreateElement("enum", "dataType") |
1294
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
1580 |
datatype.baseType.setcontent(enumerated) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1581 |
values = PLCOpenParser.CreateElement("values", "enum") |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1582 |
enumerated.setvalues(values) |
814 | 1583 |
for i, enum_value in enumerate(infos["values"]): |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1584 |
value = PLCOpenParser.CreateElement("value", "values") |
814 | 1585 |
value.setname(enum_value) |
1586 |
if i == 0: |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1587 |
values.setvalue([value]) |
814 | 1588 |
else: |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1589 |
values.appendvalue(value) |
814 | 1590 |
elif infos["type"] == "Array": |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1591 |
array = PLCOpenParser.CreateElement("array", "dataType") |
1294
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
1592 |
datatype.baseType.setcontent(array) |
814 | 1593 |
for i, dimension in enumerate(infos["dimensions"]): |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1594 |
dimension_range = PLCOpenParser.CreateElement("dimension", "array") |
814 | 1595 |
dimension_range.setlower(dimension[0]) |
1596 |
dimension_range.setupper(dimension[1]) |
|
1597 |
if i == 0: |
|
1598 |
array.setdimension([dimension_range]) |
|
1599 |
else: |
|
1600 |
array.appenddimension(dimension_range) |
|
1601 |
if infos["base_type"] in self.GetBaseTypes(): |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1602 |
array.baseType.setcontent(PLCOpenParser.CreateElement( |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1603 |
infos["base_type"].lower() |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1604 |
if infos["base_type"] in ["STRING", "WSTRING"] |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1605 |
else infos["base_type"], "dataType")) |
814 | 1606 |
else: |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1607 |
derived_datatype = PLCOpenParser.CreateElement("derived", "dataType") |
814 | 1608 |
derived_datatype.setname(infos["base_type"]) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1609 |
array.baseType.setcontent(derived_datatype) |
814 | 1610 |
elif infos["type"] == "Structure": |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1611 |
struct = PLCOpenParser.CreateElement("struct", "dataType") |
1294
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
1612 |
datatype.baseType.setcontent(struct) |
814 | 1613 |
for i, element_infos in enumerate(infos["elements"]): |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1614 |
element = PLCOpenParser.CreateElement("variable", "struct") |
814 | 1615 |
element.setname(element_infos["Name"]) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1616 |
element_type = PLCOpenParser.CreateElement("type", "variable") |
2450
5024c19ca8f0
python3 support: pylint, W1652 # (deprecated-types-field) Accessing a deprecated fields on the types module
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
2447
diff
changeset
|
1617 |
if isinstance(element_infos["Type"], tuple): |
864
bf4f7f0801b9
Adding support for direct array declaration in structure element declaration
Laurent Bessard
parents:
863
diff
changeset
|
1618 |
if element_infos["Type"][0] == "array": |
1847
6198190bc121
explicitly mark unused variables found by pylint with _ or dummy
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1846
diff
changeset
|
1619 |
_array_type, base_type_name, dimensions = element_infos["Type"] |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1620 |
array = PLCOpenParser.CreateElement("array", "dataType") |
1477
270dba8bf87b
fix issue, when structure data type with array field is created
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1418
diff
changeset
|
1621 |
baseType = PLCOpenParser.CreateElement("baseType", "array") |
270dba8bf87b
fix issue, when structure data type with array field is created
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1418
diff
changeset
|
1622 |
array.setbaseType(baseType) |
1294
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
1623 |
element_type.setcontent(array) |
864
bf4f7f0801b9
Adding support for direct array declaration in structure element declaration
Laurent Bessard
parents:
863
diff
changeset
|
1624 |
for j, dimension in enumerate(dimensions): |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1625 |
dimension_range = PLCOpenParser.CreateElement("dimension", "array") |
864
bf4f7f0801b9
Adding support for direct array declaration in structure element declaration
Laurent Bessard
parents:
863
diff
changeset
|
1626 |
dimension_range.setlower(dimension[0]) |
bf4f7f0801b9
Adding support for direct array declaration in structure element declaration
Laurent Bessard
parents:
863
diff
changeset
|
1627 |
dimension_range.setupper(dimension[1]) |
bf4f7f0801b9
Adding support for direct array declaration in structure element declaration
Laurent Bessard
parents:
863
diff
changeset
|
1628 |
if j == 0: |
bf4f7f0801b9
Adding support for direct array declaration in structure element declaration
Laurent Bessard
parents:
863
diff
changeset
|
1629 |
array.setdimension([dimension_range]) |
bf4f7f0801b9
Adding support for direct array declaration in structure element declaration
Laurent Bessard
parents:
863
diff
changeset
|
1630 |
else: |
bf4f7f0801b9
Adding support for direct array declaration in structure element declaration
Laurent Bessard
parents:
863
diff
changeset
|
1631 |
array.appenddimension(dimension_range) |
bf4f7f0801b9
Adding support for direct array declaration in structure element declaration
Laurent Bessard
parents:
863
diff
changeset
|
1632 |
if base_type_name in self.GetBaseTypes(): |
1477
270dba8bf87b
fix issue, when structure data type with array field is created
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1418
diff
changeset
|
1633 |
baseType.setcontent(PLCOpenParser.CreateElement( |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1634 |
base_type_name.lower() |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1635 |
if base_type_name in ["STRING", "WSTRING"] |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1636 |
else base_type_name, "dataType")) |
864
bf4f7f0801b9
Adding support for direct array declaration in structure element declaration
Laurent Bessard
parents:
863
diff
changeset
|
1637 |
else: |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1638 |
derived_datatype = PLCOpenParser.CreateElement("derived", "dataType") |
864
bf4f7f0801b9
Adding support for direct array declaration in structure element declaration
Laurent Bessard
parents:
863
diff
changeset
|
1639 |
derived_datatype.setname(base_type_name) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1640 |
array.baseType.setcontent(derived_datatype) |
864
bf4f7f0801b9
Adding support for direct array declaration in structure element declaration
Laurent Bessard
parents:
863
diff
changeset
|
1641 |
elif element_infos["Type"] in self.GetBaseTypes(): |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1642 |
element_type.setcontent( |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1643 |
PLCOpenParser.CreateElement( |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1644 |
element_infos["Type"].lower() |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1645 |
if element_infos["Type"] in ["STRING", "WSTRING"] |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1646 |
else element_infos["Type"], "dataType")) |
814 | 1647 |
else: |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1648 |
derived_datatype = PLCOpenParser.CreateElement("derived", "dataType") |
814 | 1649 |
derived_datatype.setname(element_infos["Type"]) |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1650 |
element_type.setcontent(derived_datatype) |
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1651 |
element.settype(element_type) |
814 | 1652 |
if element_infos["Initial Value"] != "": |
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1653 |
value = PLCOpenParser.CreateElement("initialValue", "variable") |
814 | 1654 |
value.setvalue(element_infos["Initial Value"]) |
1655 |
element.setinitialValue(value) |
|
1656 |
if i == 0: |
|
1657 |
struct.setvariable([element]) |
|
1658 |
else: |
|
1659 |
struct.appendvariable(element) |
|
1660 |
if infos["initial"] != "": |
|
1661 |
if datatype.initialValue is None: |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
1662 |
datatype.initialValue = PLCOpenParser.CreateElement("initialValue", "dataType") |
814 | 1663 |
datatype.initialValue.setvalue(infos["initial"]) |
1664 |
else: |
|
1665 |
datatype.initialValue = None |
|
1666 |
self.BufferProject() |
|
1411 | 1667 |
|
1782
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
1668 |
# ------------------------------------------------------------------------------- |
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
1669 |
# Project opened Pous management functions |
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
1670 |
# ------------------------------------------------------------------------------- |
814 | 1671 |
|
1672 |
# Return edited element |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1673 |
def GetEditedElement(self, tagname, debug=False): |
814 | 1674 |
project = self.GetProject(debug) |
1675 |
if project is not None: |
|
1676 |
words = tagname.split("::") |
|
1677 |
if words[0] == "D": |
|
1678 |
return project.getdataType(words[1]) |
|
1679 |
elif words[0] == "P": |
|
1680 |
return project.getpou(words[1]) |
|
1681 |
elif words[0] in ['T', 'A']: |
|
1682 |
pou = project.getpou(words[1]) |
|
1683 |
if pou is not None: |
|
1684 |
if words[0] == 'T': |
|
1685 |
return pou.gettransition(words[2]) |
|
1686 |
elif words[0] == 'A': |
|
1687 |
return pou.getaction(words[2]) |
|
1688 |
elif words[0] == 'C': |
|
1689 |
return project.getconfiguration(words[1]) |
|
1690 |
elif words[0] == 'R': |
|
1691 |
return project.getconfigurationResource(words[1], words[2]) |
|
1692 |
return None |
|
1411 | 1693 |
|
814 | 1694 |
# Return edited element name |
1695 |
def GetEditedElementName(self, tagname): |
|
1696 |
words = tagname.split("::") |
|
1740
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
1697 |
if words[0] in ["P", "C", "D"]: |
814 | 1698 |
return words[1] |
1699 |
else: |
|
1700 |
return words[2] |
|
1701 |
return None |
|
1411 | 1702 |
|
814 | 1703 |
# Return edited element name and type |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1704 |
def GetEditedElementType(self, tagname, debug=False): |
814 | 1705 |
words = tagname.split("::") |
1740
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
1706 |
if words[0] in ["P", "T", "A"]: |
814 | 1707 |
return words[1], self.GetPouType(words[1], debug) |
1708 |
return None, None |
|
1709 |
||
1710 |
# Return language in which edited element is written |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1711 |
def GetEditedElementBodyType(self, tagname, debug=False): |
814 | 1712 |
words = tagname.split("::") |
1713 |
if words[0] == "P": |
|
1714 |
return self.GetPouBodyType(words[1], debug) |
|
1715 |
elif words[0] == 'T': |
|
1716 |
return self.GetTransitionBodyType(words[1], words[2], debug) |
|
1717 |
elif words[0] == 'A': |
|
1718 |
return self.GetActionBodyType(words[1], words[2], debug) |
|
1719 |
return None |
|
1720 |
||
1721 |
# Return the edited element variables |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1722 |
def GetEditedElementInterfaceVars(self, tagname, tree=False, debug=False): |
814 | 1723 |
words = tagname.split("::") |
1740
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
1724 |
if words[0] in ["P", "T", "A"]: |
814 | 1725 |
project = self.GetProject(debug) |
1726 |
if project is not None: |
|
1727 |
pou = project.getpou(words[1]) |
|
1728 |
if pou is not None: |
|
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
1729 |
return self.GetPouInterfaceVars(pou, tree, debug) |
814 | 1730 |
return [] |
1731 |
||
1732 |
# Return the edited element return type |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1733 |
def GetEditedElementInterfaceReturnType(self, tagname, tree=False, debug=False): |
814 | 1734 |
words = tagname.split("::") |
1735 |
if words[0] == "P": |
|
1736 |
project = self.GetProject(debug) |
|
1737 |
if project is not None: |
|
1738 |
pou = self.Project.getpou(words[1]) |
|
1739 |
if pou is not None: |
|
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
1740 |
return self.GetPouInterfaceReturnType(pou, tree, debug) |
814 | 1741 |
elif words[0] == 'T': |
1616
3638463d6e02
fix issue with creating SFC transitions using ST and IL
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1581
diff
changeset
|
1742 |
return ["BOOL", ([], [])] |
814 | 1743 |
return None |
1411 | 1744 |
|
814 | 1745 |
# Change the edited element text |
1746 |
def SetEditedElementText(self, tagname, text): |
|
1747 |
if self.Project is not None: |
|
1748 |
element = self.GetEditedElement(tagname) |
|
1749 |
if element is not None: |
|
1750 |
element.settext(text) |
|
1411 | 1751 |
|
814 | 1752 |
# Return the edited element text |
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1753 |
def GetEditedElementText(self, tagname, debug=False): |
814 | 1754 |
element = self.GetEditedElement(tagname, debug) |
1755 |
if element is not None: |
|
1756 |
return element.gettext() |
|
1757 |
return "" |
|
1758 |
||
1759 |
# Return the edited element transitions |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1760 |
def GetEditedElementTransitions(self, tagname, debug=False): |
814 | 1761 |
pou = self.GetEditedElement(tagname, debug) |
1762 |
if pou is not None and pou.getbodyType() == "SFC": |
|
1763 |
transitions = [] |
|
1764 |
for transition in pou.gettransitionList(): |
|
1765 |
transitions.append(transition.getname()) |
|
1766 |
return transitions |
|
1767 |
return [] |
|
1768 |
||
1769 |
# Return edited element transitions |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1770 |
def GetEditedElementActions(self, tagname, debug=False): |
814 | 1771 |
pou = self.GetEditedElement(tagname, debug) |
1772 |
if pou is not None and pou.getbodyType() == "SFC": |
|
1773 |
actions = [] |
|
1774 |
for action in pou.getactionList(): |
|
1775 |
actions.append(action.getname()) |
|
1776 |
return actions |
|
1777 |
return [] |
|
1778 |
||
1779 |
# Return the names of the pou elements |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1780 |
def GetEditedElementVariables(self, tagname, debug=False): |
814 | 1781 |
words = tagname.split("::") |
1740
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
1782 |
if words[0] in ["P", "T", "A"]: |
1171
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1783 |
return self.GetProjectPouVariableNames(words[1], debug) |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1784 |
elif words[0] in ["C", "R"]: |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1785 |
names = self.GetConfigurationVariableNames(words[1], debug) |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1786 |
if words[0] == "R": |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1787 |
names.extend(self.GetConfigurationResourceVariableNames( |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1788 |
words[1], words[2], debug)) |
a506e4de8f84
Add support for Drag'n dropping located variables to function block creating global located variable in configuration and external variable in function block
Laurent Bessard
parents:
1127
diff
changeset
|
1789 |
return names |
814 | 1790 |
return [] |
1791 |
||
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1792 |
def GetEditedElementCopy(self, tagname, debug=False): |
814 | 1793 |
element = self.GetEditedElement(tagname, debug) |
1794 |
if element is not None: |
|
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1795 |
return element.tostring() |
814 | 1796 |
return "" |
1411 | 1797 |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1798 |
def GetEditedElementInstancesCopy(self, tagname, blocks_id=None, wires=None, debug=False): |
814 | 1799 |
element = self.GetEditedElement(tagname, debug) |
1800 |
text = "" |
|
1801 |
if element is not None: |
|
1411 | 1802 |
wires = dict([(wire, True) |
1803 |
for wire in wires |
|
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1804 |
if wire[0] in blocks_id and wire[1] in blocks_id]) |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1805 |
copy_body = PLCOpenParser.CreateElement("body", "pou") |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1806 |
element.append(copy_body) |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1807 |
copy_body.setcontent( |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1808 |
PLCOpenParser.CreateElement(element.getbodyType(), "body")) |
814 | 1809 |
for id in blocks_id: |
1810 |
instance = element.getinstance(id) |
|
1811 |
if instance is not None: |
|
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1812 |
copy_body.appendcontentInstance(self.Copy(instance)) |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1813 |
instance_copy = copy_body.getcontentInstance(id) |
814 | 1814 |
instance_copy.filterConnections(wires) |
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1815 |
text += instance_copy.tostring() |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1816 |
element.remove(copy_body) |
814 | 1817 |
return text |
1411 | 1818 |
|
1852
70c1cc354a8f
fix pylint warning '(dangerous-default-value) Dangerous default value {} as argument'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1850
diff
changeset
|
1819 |
def GenerateNewName(self, tagname, name, format, start_idx=0, exclude=None, debug=False): |
1968
64827679f3f1
add fields autocomplete when adding task or instance in resources
Surkov Sergey <surkovsv93@gmail.com>
parents:
1881
diff
changeset
|
1820 |
if name is not None: |
64827679f3f1
add fields autocomplete when adding task or instance in resources
Surkov Sergey <surkovsv93@gmail.com>
parents:
1881
diff
changeset
|
1821 |
result = re.search(VARIABLE_NAME_SUFFIX_MODEL, name) |
64827679f3f1
add fields autocomplete when adding task or instance in resources
Surkov Sergey <surkovsv93@gmail.com>
parents:
1881
diff
changeset
|
1822 |
if result is not None: |
64827679f3f1
add fields autocomplete when adding task or instance in resources
Surkov Sergey <surkovsv93@gmail.com>
parents:
1881
diff
changeset
|
1823 |
format = name[:result.start(1)] + '%d' |
64827679f3f1
add fields autocomplete when adding task or instance in resources
Surkov Sergey <surkovsv93@gmail.com>
parents:
1881
diff
changeset
|
1824 |
start_idx = int(result.group(1)) |
64827679f3f1
add fields autocomplete when adding task or instance in resources
Surkov Sergey <surkovsv93@gmail.com>
parents:
1881
diff
changeset
|
1825 |
else: |
64827679f3f1
add fields autocomplete when adding task or instance in resources
Surkov Sergey <surkovsv93@gmail.com>
parents:
1881
diff
changeset
|
1826 |
format = name + '%d' |
64827679f3f1
add fields autocomplete when adding task or instance in resources
Surkov Sergey <surkovsv93@gmail.com>
parents:
1881
diff
changeset
|
1827 |
|
1852
70c1cc354a8f
fix pylint warning '(dangerous-default-value) Dangerous default value {} as argument'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1850
diff
changeset
|
1828 |
names = {} if exclude is None else exclude.copy() |
814 | 1829 |
if tagname is not None: |
1411 | 1830 |
names.update(dict([(varname.upper(), True) |
1122
84de51ab40d2
Adding support for using current selected variable for generate newly added variable informations in VariablePanel
Laurent Bessard
parents:
1096
diff
changeset
|
1831 |
for varname in self.GetEditedElementVariables(tagname, debug)])) |
1127
5315f26642e0
Fixed bug when generating new name for configuration and resource variable in VariablePanel
Laurent Bessard
parents:
1122
diff
changeset
|
1832 |
words = tagname.split("::") |
1740
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
1833 |
if words[0] in ["P", "T", "A"]: |
1127
5315f26642e0
Fixed bug when generating new name for configuration and resource variable in VariablePanel
Laurent Bessard
parents:
1122
diff
changeset
|
1834 |
element = self.GetEditedElement(tagname, debug) |
5315f26642e0
Fixed bug when generating new name for configuration and resource variable in VariablePanel
Laurent Bessard
parents:
1122
diff
changeset
|
1835 |
if element is not None and element.getbodyType() not in ["ST", "IL"]: |
5315f26642e0
Fixed bug when generating new name for configuration and resource variable in VariablePanel
Laurent Bessard
parents:
1122
diff
changeset
|
1836 |
for instance in element.getinstances(): |
1768
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1837 |
if isinstance( |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1838 |
instance, |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1839 |
(PLCOpenParser.GetElementClass("step", "sfcObjects"), |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1840 |
PLCOpenParser.GetElementClass("connector", "commonObjects"), |
691083b5682a
clean-up: fix PEP8 E128 continuation line under-indented for visual indent
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1767
diff
changeset
|
1841 |
PLCOpenParser.GetElementClass("continuation", "commonObjects"))): |
1127
5315f26642e0
Fixed bug when generating new name for configuration and resource variable in VariablePanel
Laurent Bessard
parents:
1122
diff
changeset
|
1842 |
names[instance.getname().upper()] = True |
1968
64827679f3f1
add fields autocomplete when adding task or instance in resources
Surkov Sergey <surkovsv93@gmail.com>
parents:
1881
diff
changeset
|
1843 |
elif words[0] == 'R': |
64827679f3f1
add fields autocomplete when adding task or instance in resources
Surkov Sergey <surkovsv93@gmail.com>
parents:
1881
diff
changeset
|
1844 |
element = self.GetEditedElement(tagname, debug) |
64827679f3f1
add fields autocomplete when adding task or instance in resources
Surkov Sergey <surkovsv93@gmail.com>
parents:
1881
diff
changeset
|
1845 |
for task in element.gettask(): |
64827679f3f1
add fields autocomplete when adding task or instance in resources
Surkov Sergey <surkovsv93@gmail.com>
parents:
1881
diff
changeset
|
1846 |
names[task.getname().upper()] = True |
64827679f3f1
add fields autocomplete when adding task or instance in resources
Surkov Sergey <surkovsv93@gmail.com>
parents:
1881
diff
changeset
|
1847 |
for instance in task.getpouInstance(): |
64827679f3f1
add fields autocomplete when adding task or instance in resources
Surkov Sergey <surkovsv93@gmail.com>
parents:
1881
diff
changeset
|
1848 |
names[instance.getname().upper()] = True |
64827679f3f1
add fields autocomplete when adding task or instance in resources
Surkov Sergey <surkovsv93@gmail.com>
parents:
1881
diff
changeset
|
1849 |
for instance in element.getpouInstance(): |
64827679f3f1
add fields autocomplete when adding task or instance in resources
Surkov Sergey <surkovsv93@gmail.com>
parents:
1881
diff
changeset
|
1850 |
names[instance.getname().upper()] = True |
814 | 1851 |
else: |
1852 |
project = self.GetProject(debug) |
|
1853 |
if project is not None: |
|
1854 |
for datatype in project.getdataTypes(): |
|
1855 |
names[datatype.getname().upper()] = True |
|
1856 |
for pou in project.getpous(): |
|
1857 |
names[pou.getname().upper()] = True |
|
1347
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
1858 |
for var in self.GetPouInterfaceVars(pou, debug=debug): |
533741e5075c
Fixed pou variables information loading stylesheet
Laurent Bessard
parents:
1341
diff
changeset
|
1859 |
names[var.Name.upper()] = True |
814 | 1860 |
for transition in pou.gettransitionList(): |
1861 |
names[transition.getname().upper()] = True |
|
1862 |
for action in pou.getactionList(): |
|
1863 |
names[action.getname().upper()] = True |
|
1864 |
for config in project.getconfigurations(): |
|
1865 |
names[config.getname().upper()] = True |
|
1866 |
for resource in config.getresource(): |
|
1867 |
names[resource.getname().upper()] = True |
|
1411 | 1868 |
|
1122
84de51ab40d2
Adding support for using current selected variable for generate newly added variable informations in VariablePanel
Laurent Bessard
parents:
1096
diff
changeset
|
1869 |
i = start_idx |
814 | 1870 |
while name is None or names.get(name.upper(), False): |
1734
750eeb7230a1
clean-up: fix some PEP8 E228 missing whitespace around modulo operator
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1732
diff
changeset
|
1871 |
name = (format % i) |
814 | 1872 |
i += 1 |
1873 |
return name |
|
1411 | 1874 |
|
814 | 1875 |
def PasteEditedElementInstances(self, tagname, text, new_pos, middle=False, debug=False): |
1876 |
element = self.GetEditedElement(tagname, debug) |
|
1847
6198190bc121
explicitly mark unused variables found by pylint with _ or dummy
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1846
diff
changeset
|
1877 |
_element_name, element_type = self.GetEditedElementType(tagname, debug) |
814 | 1878 |
if element is not None: |
1879 |
bodytype = element.getbodyType() |
|
1411 | 1880 |
|
814 | 1881 |
# Get edited element type scaling |
1882 |
scaling = None |
|
1883 |
project = self.GetProject(debug) |
|
1884 |
if project is not None: |
|
1885 |
properties = project.getcontentHeader() |
|
1886 |
scaling = properties["scaling"][bodytype] |
|
1411 | 1887 |
|
814 | 1888 |
# Get ids already by all the instances in edited element |
1889 |
used_id = dict([(instance.getlocalId(), True) for instance in element.getinstances()]) |
|
1890 |
new_id = {} |
|
1411 | 1891 |
|
814 | 1892 |
try: |
1505
5ecb16be9a3c
fix copying elements with non-latin content like comment element, or
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1502
diff
changeset
|
1893 |
instances, error = LoadPouInstances(text, bodytype) |
1780
c52d1460cea8
clean-up: fix PEP8 E722 do not use bare except'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1779
diff
changeset
|
1894 |
except Exception: |
1330
96b242e4c59d
Added support for loading XML file even if not following XSD schema (but still following XML syntax), warning user of errors in XML file
Laurent Bessard
parents:
1328
diff
changeset
|
1895 |
instances, error = [], "" |
96b242e4c59d
Added support for loading XML file even if not following XSD schema (but still following XML syntax), warning user of errors in XML file
Laurent Bessard
parents:
1328
diff
changeset
|
1896 |
if error is not None or len(instances) == 0: |
814 | 1897 |
return _("Invalid plcopen element(s)!!!") |
1411 | 1898 |
|
814 | 1899 |
exclude = {} |
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1900 |
for instance in instances: |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1901 |
element.addinstance(instance) |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1902 |
instance_type = instance.getLocalTag() |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1903 |
if instance_type == "block": |
1337
204ef2daa33c
Fixed bug with Copy/Paste function instance block when previously edited
Laurent Bessard
parents:
1331
diff
changeset
|
1904 |
blocktype = instance.gettypeName() |
204ef2daa33c
Fixed bug with Copy/Paste function instance block when previously edited
Laurent Bessard
parents:
1331
diff
changeset
|
1905 |
blocktype_infos = self.GetBlockType(blocktype) |
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1906 |
blockname = instance.getinstanceName() |
1337
204ef2daa33c
Fixed bug with Copy/Paste function instance block when previously edited
Laurent Bessard
parents:
1331
diff
changeset
|
1907 |
if blocktype_infos["type"] != "function" and blockname is not None: |
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1908 |
if element_type == "function": |
1734
750eeb7230a1
clean-up: fix some PEP8 E228 missing whitespace around modulo operator
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1732
diff
changeset
|
1909 |
return _("FunctionBlock \"%s\" can't be pasted in a Function!!!") % blocktype |
1411 | 1910 |
blockname = self.GenerateNewName(tagname, |
1911 |
blockname, |
|
1734
750eeb7230a1
clean-up: fix some PEP8 E228 missing whitespace around modulo operator
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1732
diff
changeset
|
1912 |
"%s%%d" % blocktype, |
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1913 |
debug=debug) |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1914 |
exclude[blockname] = True |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1915 |
instance.setinstanceName(blockname) |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1916 |
self.AddEditedElementPouVar(tagname, blocktype, blockname) |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1917 |
elif instance_type == "step": |
1411 | 1918 |
stepname = self.GenerateNewName(tagname, |
1919 |
instance.getname(), |
|
1920 |
"Step%d", |
|
1921 |
exclude=exclude, |
|
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1922 |
debug=debug) |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1923 |
exclude[stepname] = True |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1924 |
instance.setname(stepname) |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1925 |
localid = instance.getlocalId() |
1775
b45f2768fab1
clean-up: fix PEP8 E713 test for membership should be 'not in'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1774
diff
changeset
|
1926 |
if localid not in used_id: |
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1927 |
new_id[localid] = True |
1411 | 1928 |
|
814 | 1929 |
idx = 1 |
1930 |
translate_id = {} |
|
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1931 |
bbox = rect() |
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1932 |
for instance in instances: |
814 | 1933 |
localId = instance.getlocalId() |
1934 |
bbox.union(instance.getBoundingBox()) |
|
1763
bcc07ff2362c
clean-up: fix PEP8 W601 .has_key() is deprecated, use 'in'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1762
diff
changeset
|
1935 |
if localId in used_id: |
bcc07ff2362c
clean-up: fix PEP8 W601 .has_key() is deprecated, use 'in'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1762
diff
changeset
|
1936 |
while (idx in used_id) or (idx in new_id): |
814 | 1937 |
idx += 1 |
1938 |
new_id[idx] = True |
|
1939 |
instance.setlocalId(idx) |
|
1940 |
translate_id[localId] = idx |
|
1411 | 1941 |
|
814 | 1942 |
x, y, width, height = bbox.bounding_box() |
1943 |
if middle: |
|
2437
105c20fdeb19
python3 support: pylint, W1619 #(old-division) division w/o __future__ statement
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
2418
diff
changeset
|
1944 |
new_pos[0] -= width // 2 |
105c20fdeb19
python3 support: pylint, W1619 #(old-division) division w/o __future__ statement
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
2418
diff
changeset
|
1945 |
new_pos[1] -= height // 2 |
814 | 1946 |
else: |
1947 |
new_pos = map(lambda x: x + 30, new_pos) |
|
1948 |
if scaling[0] != 0 and scaling[1] != 0: |
|
1949 |
min_pos = map(lambda x: 30 / x, scaling) |
|
1950 |
minx = round(min_pos[0]) |
|
1951 |
if int(min_pos[0]) == round(min_pos[0]): |
|
1952 |
minx += 1 |
|
1953 |
miny = round(min_pos[1]) |
|
1954 |
if int(min_pos[1]) == round(min_pos[1]): |
|
1955 |
miny += 1 |
|
1956 |
minx *= scaling[0] |
|
1957 |
miny *= scaling[1] |
|
1958 |
new_pos = (max(minx, round(new_pos[0] / scaling[0]) * scaling[0]), |
|
1959 |
max(miny, round(new_pos[1] / scaling[1]) * scaling[1])) |
|
1960 |
else: |
|
1961 |
new_pos = (max(30, new_pos[0]), max(30, new_pos[1])) |
|
1367
324767a092dc
Fixed bug when pasting element with an odd width or height
Laurent Bessard
parents:
1361
diff
changeset
|
1962 |
diff = (int(new_pos[0] - x), int(new_pos[1] - y)) |
1411 | 1963 |
|
814 | 1964 |
connections = {} |
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
1965 |
for instance in instances: |
814 | 1966 |
connections.update(instance.updateConnectionsId(translate_id)) |
1967 |
if getattr(instance, "setexecutionOrderId", None) is not None: |
|
1968 |
instance.setexecutionOrderId(0) |
|
1969 |
instance.translate(*diff) |
|
1411 | 1970 |
|
814 | 1971 |
return new_id, connections |
1411 | 1972 |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
1973 |
def GetEditedElementInstancesInfos(self, tagname, debug=False): |
1331
38c5de794e62
Added support for speed-up loading of graphic POU tabs
Laurent Bessard
parents:
1330
diff
changeset
|
1974 |
element = self.GetEditedElement(tagname, debug) |
38c5de794e62
Added support for speed-up loading of graphic POU tabs
Laurent Bessard
parents:
1330
diff
changeset
|
1975 |
if element is not None: |
1957
2d1cc4f5e4ef
GetEditedElementInstancesInfos now optimized as well. Forgotten because not using [R.I.P]LibraryResolver, but still XSLT compiling was hapenning on each call.
Edouard Tisserant
parents:
1954
diff
changeset
|
1976 |
return self.BlockInstanceCollector.Collect(element, debug) |
2d1cc4f5e4ef
GetEditedElementInstancesInfos now optimized as well. Forgotten because not using [R.I.P]LibraryResolver, but still XSLT compiling was hapenning on each call.
Edouard Tisserant
parents:
1954
diff
changeset
|
1977 |
return {} |
1411 | 1978 |
|
814 | 1979 |
def ClearEditedElementExecutionOrder(self, tagname): |
1980 |
element = self.GetEditedElement(tagname) |
|
1981 |
if element is not None: |
|
1982 |
element.resetexecutionOrder() |
|
1411 | 1983 |
|
814 | 1984 |
def ResetEditedElementExecutionOrder(self, tagname): |
1985 |
element = self.GetEditedElement(tagname) |
|
1986 |
if element is not None: |
|
1987 |
element.compileexecutionOrder() |
|
1411 | 1988 |
|
814 | 1989 |
def SetConnectionWires(self, connection, connector): |
1990 |
wires = connector.GetWires() |
|
1991 |
idx = 0 |
|
1992 |
for wire, handle in wires: |
|
1993 |
points = wire.GetPoints(handle != 0) |
|
1994 |
if handle == 0: |
|
1995 |
result = wire.GetConnectedInfos(-1) |
|
1996 |
else: |
|
1997 |
result = wire.GetConnectedInfos(0) |
|
1743
c3c3d1318130
clean-up: fix PEP8 E711 comparison to None should be 'if cond is not None:'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1741
diff
changeset
|
1998 |
if result is not None: |
814 | 1999 |
refLocalId, formalParameter = result |
2000 |
connections = connection.getconnections() |
|
2001 |
if connections is None or len(connection.getconnections()) <= idx: |
|
2002 |
connection.addconnection() |
|
2003 |
connection.setconnectionId(idx, refLocalId) |
|
2004 |
connection.setconnectionPoints(idx, points) |
|
2005 |
if formalParameter != "": |
|
2006 |
connection.setconnectionParameter(idx, formalParameter) |
|
2007 |
else: |
|
2008 |
connection.setconnectionParameter(idx, None) |
|
2009 |
idx += 1 |
|
1411 | 2010 |
|
1313
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
2011 |
def GetVarTypeObject(self, var_type): |
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
2012 |
var_type_obj = PLCOpenParser.CreateElement("type", "variable") |
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
2013 |
if not var_type.startswith("ANY") and TypeHierarchy.get(var_type): |
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
2014 |
var_type_obj.setcontent(PLCOpenParser.CreateElement( |
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
2015 |
var_type.lower() if var_type in ["STRING", "WSTRING"] |
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
2016 |
else var_type, "dataType")) |
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
2017 |
else: |
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
2018 |
derived_type = PLCOpenParser.CreateElement("derived", "dataType") |
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
2019 |
derived_type.setname(var_type) |
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
2020 |
var_type_obj.setcontent(derived_type) |
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
2021 |
return var_type_obj |
1411 | 2022 |
|
1740
b789b695b5c6
clean-up: fix PEP8 E231 missing whitespace after ':' or ','
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1739
diff
changeset
|
2023 |
def AddEditedElementPouVar(self, tagname, var_type, name, **args): |
814 | 2024 |
if self.Project is not None: |
2025 |
words = tagname.split("::") |
|
2026 |
if words[0] in ['P', 'T', 'A']: |
|
2027 |
pou = self.Project.getpou(words[1]) |
|
2028 |
if pou is not None: |
|
1313
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
2029 |
pou.addpouLocalVar( |
1411 | 2030 |
self.GetVarTypeObject(var_type), |
1406
82db84fe88ea
Added 'NamedConstant' drag'n'drop in programs. It does create a simple variable with initial value and is usefull for drag'n'drop constants from extensions while keeping a name associated with constant
Edouard Tisserant
parents:
1390
diff
changeset
|
2031 |
name, **args) |
1411 | 2032 |
|
1313
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
2033 |
def AddEditedElementPouExternalVar(self, tagname, var_type, name): |
814 | 2034 |
if self.Project is not None: |
2035 |
words = tagname.split("::") |
|
2036 |
if words[0] in ['P', 'T', 'A']: |
|
2037 |
pou = self.Project.getpou(words[1]) |
|
2038 |
if pou is not None: |
|
1313
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
2039 |
pou.addpouExternalVar( |
85c167bfff93
Replaced standard function blocks library definition from dictionary to plcopen xml files
Laurent Bessard
parents:
1311
diff
changeset
|
2040 |
self.GetVarTypeObject(var_type), name) |
1411 | 2041 |
|
814 | 2042 |
def ChangeEditedElementPouVar(self, tagname, old_type, old_name, new_type, new_name): |
2043 |
if self.Project is not None: |
|
2044 |
words = tagname.split("::") |
|
2045 |
if words[0] in ['P', 'T', 'A']: |
|
2046 |
pou = self.Project.getpou(words[1]) |
|
2047 |
if pou is not None: |
|
2048 |
pou.changepouVar(old_type, old_name, new_type, new_name) |
|
1411 | 2049 |
|
814 | 2050 |
def RemoveEditedElementPouVar(self, tagname, type, name): |
2051 |
if self.Project is not None: |
|
2052 |
words = tagname.split("::") |
|
2053 |
if words[0] in ['P', 'T', 'A']: |
|
2054 |
pou = self.Project.getpou(words[1]) |
|
2055 |
if pou is not None: |
|
2056 |
pou.removepouVar(type, name) |
|
1411 | 2057 |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
2058 |
def AddEditedElementBlock(self, tagname, id, blocktype, blockname=None): |
814 | 2059 |
element = self.GetEditedElement(tagname) |
2060 |
if element is not None: |
|
1291
42ea51d083ce
Second stage of xmlclass refactoring using lxml , project are loaded and displayed successfully
Laurent Bessard
parents:
1290
diff
changeset
|
2061 |
block = PLCOpenParser.CreateElement("block", "fbdObjects") |
814 | 2062 |
block.setlocalId(id) |
2063 |
block.settypeName(blocktype) |
|
2064 |
blocktype_infos = self.GetBlockType(blocktype) |
|
2065 |
if blocktype_infos["type"] != "function" and blockname is not None: |
|
2066 |
block.setinstanceName(blockname) |
|
2067 |
self.AddEditedElementPouVar(tagname, blocktype, blockname) |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2068 |
element.addinstance(block) |
1411 | 2069 |
|
814 | 2070 |
def SetEditedElementBlockInfos(self, tagname, id, infos): |
2071 |
element = self.GetEditedElement(tagname) |
|
2072 |
if element is not None: |
|
2073 |
block = element.getinstance(id) |
|
2074 |
if block is None: |
|
1411 | 2075 |
return |
814 | 2076 |
old_name = block.getinstanceName() |
2077 |
old_type = block.gettypeName() |
|
2078 |
new_name = infos.get("name", old_name) |
|
2079 |
new_type = infos.get("type", old_type) |
|
2080 |
if new_type != old_type: |
|
2081 |
old_typeinfos = self.GetBlockType(old_type) |
|
2082 |
new_typeinfos = self.GetBlockType(new_type) |
|
2083 |
if old_typeinfos is None or new_typeinfos is None: |
|
2084 |
self.ChangeEditedElementPouVar(tagname, old_type, old_name, new_type, new_name) |
|
2085 |
elif new_typeinfos["type"] != old_typeinfos["type"]: |
|
2086 |
if new_typeinfos["type"] == "function": |
|
2087 |
self.RemoveEditedElementPouVar(tagname, old_type, old_name) |
|
2088 |
else: |
|
2089 |
self.AddEditedElementPouVar(tagname, new_type, new_name) |
|
2090 |
elif new_typeinfos["type"] != "function": |
|
2091 |
self.ChangeEditedElementPouVar(tagname, old_type, old_name, new_type, new_name) |
|
2092 |
elif new_name != old_name: |
|
2093 |
self.ChangeEditedElementPouVar(tagname, old_type, old_name, new_type, new_name) |
|
2094 |
for param, value in infos.items(): |
|
2095 |
if param == "name": |
|
1337
204ef2daa33c
Fixed bug with Copy/Paste function instance block when previously edited
Laurent Bessard
parents:
1331
diff
changeset
|
2096 |
if value != "": |
204ef2daa33c
Fixed bug with Copy/Paste function instance block when previously edited
Laurent Bessard
parents:
1331
diff
changeset
|
2097 |
block.setinstanceName(value) |
204ef2daa33c
Fixed bug with Copy/Paste function instance block when previously edited
Laurent Bessard
parents:
1331
diff
changeset
|
2098 |
else: |
204ef2daa33c
Fixed bug with Copy/Paste function instance block when previously edited
Laurent Bessard
parents:
1331
diff
changeset
|
2099 |
block.attrib.pop("instanceName", None) |
814 | 2100 |
elif param == "type": |
2101 |
block.settypeName(value) |
|
2102 |
elif param == "executionOrder" and block.getexecutionOrderId() != value: |
|
2103 |
element.setelementExecutionOrder(block, value) |
|
2104 |
elif param == "height": |
|
2105 |
block.setheight(value) |
|
2106 |
elif param == "width": |
|
2107 |
block.setwidth(value) |
|
2108 |
elif param == "x": |
|
2109 |
block.setx(value) |
|
2110 |
elif param == "y": |
|
2111 |
block.sety(value) |
|
2112 |
elif param == "connectors": |
|
2113 |
block.inputVariables.setvariable([]) |
|
2114 |
block.outputVariables.setvariable([]) |
|
2115 |
for connector in value["inputs"]: |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2116 |
variable = PLCOpenParser.CreateElement("variable", "inputVariables") |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2117 |
block.inputVariables.appendvariable(variable) |
814 | 2118 |
variable.setformalParameter(connector.GetName()) |
2119 |
if connector.IsNegated(): |
|
2120 |
variable.setnegated(True) |
|
2121 |
if connector.GetEdge() != "none": |
|
2122 |
variable.setedge(connector.GetEdge()) |
|
2123 |
position = connector.GetRelPosition() |
|
2124 |
variable.connectionPointIn.setrelPositionXY(position.x, position.y) |
|
2125 |
self.SetConnectionWires(variable.connectionPointIn, connector) |
|
2126 |
for connector in value["outputs"]: |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2127 |
variable = PLCOpenParser.CreateElement("variable", "outputVariables") |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2128 |
block.outputVariables.appendvariable(variable) |
814 | 2129 |
variable.setformalParameter(connector.GetName()) |
2130 |
if connector.IsNegated(): |
|
2131 |
variable.setnegated(True) |
|
2132 |
if connector.GetEdge() != "none": |
|
2133 |
variable.setedge(connector.GetEdge()) |
|
2134 |
position = connector.GetRelPosition() |
|
2135 |
variable.addconnectionPointOut() |
|
2136 |
variable.connectionPointOut.setrelPositionXY(position.x, position.y) |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2137 |
block.tostring() |
1411 | 2138 |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2139 |
def AddEditedElementVariable(self, tagname, id, var_type): |
814 | 2140 |
element = self.GetEditedElement(tagname) |
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2141 |
if element is not None: |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2142 |
variable = PLCOpenParser.CreateElement( |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2143 |
{INPUT: "inVariable", |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2144 |
OUTPUT: "outVariable", |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2145 |
INOUT: "inOutVariable"}[var_type], "fbdObjects") |
814 | 2146 |
variable.setlocalId(id) |
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2147 |
element.addinstance(variable) |
1411 | 2148 |
|
814 | 2149 |
def SetEditedElementVariableInfos(self, tagname, id, infos): |
2150 |
element = self.GetEditedElement(tagname) |
|
2151 |
if element is not None: |
|
2152 |
variable = element.getinstance(id) |
|
2153 |
if variable is None: |
|
1411 | 2154 |
return |
814 | 2155 |
for param, value in infos.items(): |
2156 |
if param == "name": |
|
1322
0a9227f743b3
Fixed xmlclass for working with included files, adding support for SimpleType elements and solving ambiguity in extension class when different elements share the same name and parent name
Laurent Bessard
parents:
1321
diff
changeset
|
2157 |
variable.setexpression(value) |
814 | 2158 |
elif param == "executionOrder" and variable.getexecutionOrderId() != value: |
2159 |
element.setelementExecutionOrder(variable, value) |
|
2160 |
elif param == "height": |
|
2161 |
variable.setheight(value) |
|
2162 |
elif param == "width": |
|
2163 |
variable.setwidth(value) |
|
2164 |
elif param == "x": |
|
2165 |
variable.setx(value) |
|
2166 |
elif param == "y": |
|
2167 |
variable.sety(value) |
|
2168 |
elif param == "connectors": |
|
2169 |
if len(value["outputs"]) > 0: |
|
2170 |
output = value["outputs"][0] |
|
2171 |
if len(value["inputs"]) > 0: |
|
2172 |
variable.setnegatedOut(output.IsNegated()) |
|
2173 |
variable.setedgeOut(output.GetEdge()) |
|
2174 |
else: |
|
2175 |
variable.setnegated(output.IsNegated()) |
|
2176 |
variable.setedge(output.GetEdge()) |
|
2177 |
position = output.GetRelPosition() |
|
2178 |
variable.addconnectionPointOut() |
|
2179 |
variable.connectionPointOut.setrelPositionXY(position.x, position.y) |
|
2180 |
if len(value["inputs"]) > 0: |
|
2181 |
input = value["inputs"][0] |
|
2182 |
if len(value["outputs"]) > 0: |
|
2183 |
variable.setnegatedIn(input.IsNegated()) |
|
2184 |
variable.setedgeIn(input.GetEdge()) |
|
2185 |
else: |
|
2186 |
variable.setnegated(input.IsNegated()) |
|
2187 |
variable.setedge(input.GetEdge()) |
|
2188 |
position = input.GetRelPosition() |
|
2189 |
variable.addconnectionPointIn() |
|
2190 |
variable.connectionPointIn.setrelPositionXY(position.x, position.y) |
|
2191 |
self.SetConnectionWires(variable.connectionPointIn, input) |
|
2192 |
||
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2193 |
def AddEditedElementConnection(self, tagname, id, connection_type): |
814 | 2194 |
element = self.GetEditedElement(tagname) |
2195 |
if element is not None: |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2196 |
connection = PLCOpenParser.CreateElement( |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2197 |
{CONNECTOR: "connector", |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2198 |
CONTINUATION: "continuation"}[connection_type], "commonObjects") |
814 | 2199 |
connection.setlocalId(id) |
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2200 |
element.addinstance(connection) |
1411 | 2201 |
|
814 | 2202 |
def SetEditedElementConnectionInfos(self, tagname, id, infos): |
2203 |
element = self.GetEditedElement(tagname) |
|
2204 |
if element is not None: |
|
2205 |
connection = element.getinstance(id) |
|
2206 |
if connection is None: |
|
2207 |
return |
|
2208 |
for param, value in infos.items(): |
|
2209 |
if param == "name": |
|
1411 | 2210 |
connection.setname(value) |
814 | 2211 |
elif param == "height": |
2212 |
connection.setheight(value) |
|
2213 |
elif param == "width": |
|
2214 |
connection.setwidth(value) |
|
2215 |
elif param == "x": |
|
2216 |
connection.setx(value) |
|
2217 |
elif param == "y": |
|
2218 |
connection.sety(value) |
|
2219 |
elif param == "connector": |
|
2220 |
position = value.GetRelPosition() |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2221 |
if isinstance(connection, PLCOpenParser.GetElementClass("continuation", "commonObjects")): |
814 | 2222 |
connection.addconnectionPointOut() |
2223 |
connection.connectionPointOut.setrelPositionXY(position.x, position.y) |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2224 |
elif isinstance(connection, PLCOpenParser.GetElementClass("connector", "commonObjects")): |
814 | 2225 |
connection.addconnectionPointIn() |
2226 |
connection.connectionPointIn.setrelPositionXY(position.x, position.y) |
|
2227 |
self.SetConnectionWires(connection.connectionPointIn, value) |
|
2228 |
||
2229 |
def AddEditedElementComment(self, tagname, id): |
|
2230 |
element = self.GetEditedElement(tagname) |
|
2231 |
if element is not None: |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2232 |
comment = PLCOpenParser.CreateElement("comment", "commonObjects") |
814 | 2233 |
comment.setlocalId(id) |
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2234 |
element.addinstance(comment) |
1411 | 2235 |
|
814 | 2236 |
def SetEditedElementCommentInfos(self, tagname, id, infos): |
2237 |
element = self.GetEditedElement(tagname) |
|
2238 |
if element is not None: |
|
2239 |
comment = element.getinstance(id) |
|
2240 |
for param, value in infos.items(): |
|
2241 |
if param == "content": |
|
2242 |
comment.setcontentText(value) |
|
2243 |
elif param == "height": |
|
2244 |
comment.setheight(value) |
|
2245 |
elif param == "width": |
|
2246 |
comment.setwidth(value) |
|
2247 |
elif param == "x": |
|
2248 |
comment.setx(value) |
|
2249 |
elif param == "y": |
|
2250 |
comment.sety(value) |
|
2251 |
||
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2252 |
def AddEditedElementPowerRail(self, tagname, id, powerrail_type): |
814 | 2253 |
element = self.GetEditedElement(tagname) |
2254 |
if element is not None: |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2255 |
powerrail = PLCOpenParser.CreateElement( |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2256 |
{LEFTRAIL: "leftPowerRail", |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2257 |
RIGHTRAIL: "rightPowerRail"}[powerrail_type], "ldObjects") |
814 | 2258 |
powerrail.setlocalId(id) |
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2259 |
element.addinstance(powerrail) |
1411 | 2260 |
|
814 | 2261 |
def SetEditedElementPowerRailInfos(self, tagname, id, infos): |
2262 |
element = self.GetEditedElement(tagname) |
|
2263 |
if element is not None: |
|
2264 |
powerrail = element.getinstance(id) |
|
2265 |
if powerrail is None: |
|
2266 |
return |
|
2267 |
for param, value in infos.items(): |
|
2268 |
if param == "height": |
|
2269 |
powerrail.setheight(value) |
|
2270 |
elif param == "width": |
|
2271 |
powerrail.setwidth(value) |
|
2272 |
elif param == "x": |
|
2273 |
powerrail.setx(value) |
|
2274 |
elif param == "y": |
|
2275 |
powerrail.sety(value) |
|
2276 |
elif param == "connectors": |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2277 |
if isinstance(powerrail, PLCOpenParser.GetElementClass("leftPowerRail", "ldObjects")): |
814 | 2278 |
powerrail.setconnectionPointOut([]) |
2279 |
for connector in value["outputs"]: |
|
2280 |
position = connector.GetRelPosition() |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2281 |
connection = PLCOpenParser.CreateElement("connectionPointOut", "leftPowerRail") |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2282 |
powerrail.appendconnectionPointOut(connection) |
814 | 2283 |
connection.setrelPositionXY(position.x, position.y) |
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2284 |
elif isinstance(powerrail, PLCOpenParser.GetElementClass("rightPowerRail", "ldObjects")): |
814 | 2285 |
powerrail.setconnectionPointIn([]) |
2286 |
for connector in value["inputs"]: |
|
2287 |
position = connector.GetRelPosition() |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2288 |
connection = PLCOpenParser.CreateElement("connectionPointIn", "rightPowerRail") |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2289 |
powerrail.appendconnectionPointIn(connection) |
814 | 2290 |
connection.setrelPositionXY(position.x, position.y) |
2291 |
self.SetConnectionWires(connection, connector) |
|
1411 | 2292 |
|
814 | 2293 |
def AddEditedElementContact(self, tagname, id): |
2294 |
element = self.GetEditedElement(tagname) |
|
2295 |
if element is not None: |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2296 |
contact = PLCOpenParser.CreateElement("contact", "ldObjects") |
814 | 2297 |
contact.setlocalId(id) |
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2298 |
element.addinstance(contact) |
814 | 2299 |
|
2300 |
def SetEditedElementContactInfos(self, tagname, id, infos): |
|
2301 |
element = self.GetEditedElement(tagname) |
|
2302 |
if element is not None: |
|
2303 |
contact = element.getinstance(id) |
|
2304 |
if contact is None: |
|
2305 |
return |
|
2306 |
for param, value in infos.items(): |
|
2307 |
if param == "name": |
|
1322
0a9227f743b3
Fixed xmlclass for working with included files, adding support for SimpleType elements and solving ambiguity in extension class when different elements share the same name and parent name
Laurent Bessard
parents:
1321
diff
changeset
|
2308 |
contact.setvariable(value) |
814 | 2309 |
elif param == "type": |
1294
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2310 |
negated, edge = { |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2311 |
CONTACT_NORMAL: (False, "none"), |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2312 |
CONTACT_REVERSE: (True, "none"), |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2313 |
CONTACT_RISING: (False, "rising"), |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2314 |
CONTACT_FALLING: (False, "falling")}[value] |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2315 |
contact.setnegated(negated) |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2316 |
contact.setedge(edge) |
814 | 2317 |
elif param == "height": |
2318 |
contact.setheight(value) |
|
2319 |
elif param == "width": |
|
2320 |
contact.setwidth(value) |
|
2321 |
elif param == "x": |
|
2322 |
contact.setx(value) |
|
2323 |
elif param == "y": |
|
2324 |
contact.sety(value) |
|
2325 |
elif param == "connectors": |
|
2326 |
input_connector = value["inputs"][0] |
|
2327 |
position = input_connector.GetRelPosition() |
|
2328 |
contact.addconnectionPointIn() |
|
2329 |
contact.connectionPointIn.setrelPositionXY(position.x, position.y) |
|
2330 |
self.SetConnectionWires(contact.connectionPointIn, input_connector) |
|
2331 |
output_connector = value["outputs"][0] |
|
2332 |
position = output_connector.GetRelPosition() |
|
2333 |
contact.addconnectionPointOut() |
|
2334 |
contact.connectionPointOut.setrelPositionXY(position.x, position.y) |
|
2335 |
||
2336 |
def AddEditedElementCoil(self, tagname, id): |
|
2337 |
element = self.GetEditedElement(tagname) |
|
2338 |
if element is not None: |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2339 |
coil = PLCOpenParser.CreateElement("coil", "ldObjects") |
814 | 2340 |
coil.setlocalId(id) |
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2341 |
element.addinstance(coil) |
814 | 2342 |
|
2343 |
def SetEditedElementCoilInfos(self, tagname, id, infos): |
|
2344 |
element = self.GetEditedElement(tagname) |
|
2345 |
if element is not None: |
|
2346 |
coil = element.getinstance(id) |
|
2347 |
if coil is None: |
|
2348 |
return |
|
2349 |
for param, value in infos.items(): |
|
2350 |
if param == "name": |
|
1322
0a9227f743b3
Fixed xmlclass for working with included files, adding support for SimpleType elements and solving ambiguity in extension class when different elements share the same name and parent name
Laurent Bessard
parents:
1321
diff
changeset
|
2351 |
coil.setvariable(value) |
814 | 2352 |
elif param == "type": |
1294
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2353 |
negated, storage, edge = { |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2354 |
COIL_NORMAL: (False, "none", "none"), |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2355 |
COIL_REVERSE: (True, "none", "none"), |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2356 |
COIL_SET: (False, "set", "none"), |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2357 |
COIL_RESET: (False, "reset", "none"), |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2358 |
COIL_RISING: (False, "none", "rising"), |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2359 |
COIL_FALLING: (False, "none", "falling")}[value] |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2360 |
coil.setnegated(negated) |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2361 |
coil.setstorage(storage) |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2362 |
coil.setedge(edge) |
814 | 2363 |
elif param == "height": |
2364 |
coil.setheight(value) |
|
2365 |
elif param == "width": |
|
2366 |
coil.setwidth(value) |
|
2367 |
elif param == "x": |
|
2368 |
coil.setx(value) |
|
2369 |
elif param == "y": |
|
2370 |
coil.sety(value) |
|
2371 |
elif param == "connectors": |
|
2372 |
input_connector = value["inputs"][0] |
|
2373 |
position = input_connector.GetRelPosition() |
|
2374 |
coil.addconnectionPointIn() |
|
2375 |
coil.connectionPointIn.setrelPositionXY(position.x, position.y) |
|
2376 |
self.SetConnectionWires(coil.connectionPointIn, input_connector) |
|
2377 |
output_connector = value["outputs"][0] |
|
2378 |
position = output_connector.GetRelPosition() |
|
2379 |
coil.addconnectionPointOut() |
|
2380 |
coil.connectionPointOut.setrelPositionXY(position.x, position.y) |
|
2381 |
||
2382 |
def AddEditedElementStep(self, tagname, id): |
|
2383 |
element = self.GetEditedElement(tagname) |
|
2384 |
if element is not None: |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2385 |
step = PLCOpenParser.CreateElement("step", "sfcObjects") |
814 | 2386 |
step.setlocalId(id) |
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2387 |
element.addinstance(step) |
1411 | 2388 |
|
814 | 2389 |
def SetEditedElementStepInfos(self, tagname, id, infos): |
2390 |
element = self.GetEditedElement(tagname) |
|
2391 |
if element is not None: |
|
2392 |
step = element.getinstance(id) |
|
2393 |
if step is None: |
|
2394 |
return |
|
2395 |
for param, value in infos.items(): |
|
2396 |
if param == "name": |
|
2397 |
step.setname(value) |
|
2398 |
elif param == "initial": |
|
2399 |
step.setinitialStep(value) |
|
2400 |
elif param == "height": |
|
2401 |
step.setheight(value) |
|
2402 |
elif param == "width": |
|
2403 |
step.setwidth(value) |
|
2404 |
elif param == "x": |
|
2405 |
step.setx(value) |
|
2406 |
elif param == "y": |
|
2407 |
step.sety(value) |
|
2408 |
elif param == "connectors": |
|
2409 |
if len(value["inputs"]) > 0: |
|
2410 |
input_connector = value["inputs"][0] |
|
2411 |
position = input_connector.GetRelPosition() |
|
2412 |
step.addconnectionPointIn() |
|
2413 |
step.connectionPointIn.setrelPositionXY(position.x, position.y) |
|
2414 |
self.SetConnectionWires(step.connectionPointIn, input_connector) |
|
2415 |
else: |
|
2416 |
step.deleteconnectionPointIn() |
|
2417 |
if len(value["outputs"]) > 0: |
|
2418 |
output_connector = value["outputs"][0] |
|
2419 |
position = output_connector.GetRelPosition() |
|
2420 |
step.addconnectionPointOut() |
|
2421 |
step.connectionPointOut.setrelPositionXY(position.x, position.y) |
|
2422 |
else: |
|
2423 |
step.deleteconnectionPointOut() |
|
2424 |
elif param == "action": |
|
2425 |
if value: |
|
2426 |
position = value.GetRelPosition() |
|
2427 |
step.addconnectionPointOutAction() |
|
2428 |
step.connectionPointOutAction.setrelPositionXY(position.x, position.y) |
|
2429 |
else: |
|
2430 |
step.deleteconnectionPointOutAction() |
|
1411 | 2431 |
|
814 | 2432 |
def AddEditedElementTransition(self, tagname, id): |
2433 |
element = self.GetEditedElement(tagname) |
|
2434 |
if element is not None: |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2435 |
transition = PLCOpenParser.CreateElement("transition", "sfcObjects") |
814 | 2436 |
transition.setlocalId(id) |
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2437 |
element.addinstance(transition) |
1411 | 2438 |
|
814 | 2439 |
def SetEditedElementTransitionInfos(self, tagname, id, infos): |
2440 |
element = self.GetEditedElement(tagname) |
|
2441 |
if element is not None: |
|
2442 |
transition = element.getinstance(id) |
|
2443 |
if transition is None: |
|
2444 |
return |
|
2445 |
for param, value in infos.items(): |
|
2446 |
if param == "type" and value != "connection": |
|
2447 |
transition.setconditionContent(value, infos["condition"]) |
|
2448 |
elif param == "height": |
|
2449 |
transition.setheight(value) |
|
2450 |
elif param == "width": |
|
2451 |
transition.setwidth(value) |
|
2452 |
elif param == "x": |
|
2453 |
transition.setx(value) |
|
2454 |
elif param == "y": |
|
2455 |
transition.sety(value) |
|
2456 |
elif param == "priority": |
|
2457 |
if value != 0: |
|
2458 |
transition.setpriority(value) |
|
2459 |
else: |
|
2460 |
transition.setpriority(None) |
|
2461 |
elif param == "connectors": |
|
2462 |
input_connector = value["inputs"][0] |
|
2463 |
position = input_connector.GetRelPosition() |
|
2464 |
transition.addconnectionPointIn() |
|
2465 |
transition.connectionPointIn.setrelPositionXY(position.x, position.y) |
|
2466 |
self.SetConnectionWires(transition.connectionPointIn, input_connector) |
|
2467 |
output_connector = value["outputs"][0] |
|
2468 |
position = output_connector.GetRelPosition() |
|
2469 |
transition.addconnectionPointOut() |
|
2470 |
transition.connectionPointOut.setrelPositionXY(position.x, position.y) |
|
2471 |
elif infos.get("type", None) == "connection" and param == "connection" and value: |
|
2472 |
transition.setconditionContent("connection", None) |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2473 |
self.SetConnectionWires(transition.condition.content, value) |
1411 | 2474 |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2475 |
def AddEditedElementDivergence(self, tagname, id, divergence_type): |
814 | 2476 |
element = self.GetEditedElement(tagname) |
2477 |
if element is not None: |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2478 |
divergence = PLCOpenParser.CreateElement( |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2479 |
{SELECTION_DIVERGENCE: "selectionDivergence", |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2480 |
SELECTION_CONVERGENCE: "selectionConvergence", |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2481 |
SIMULTANEOUS_DIVERGENCE: "simultaneousDivergence", |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2482 |
SIMULTANEOUS_CONVERGENCE: "simultaneousConvergence"}.get( |
1878
fb73a6b6622d
fix pylint warning '(bad-continuation) Wrong hanging indentation before block'
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1875
diff
changeset
|
2483 |
divergence_type), "sfcObjects") |
814 | 2484 |
divergence.setlocalId(id) |
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2485 |
element.addinstance(divergence) |
1411 | 2486 |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2487 |
DivergenceTypes = [ |
1411 | 2488 |
(divergence_type, |
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2489 |
PLCOpenParser.GetElementClass(divergence_type, "sfcObjects")) |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2490 |
for divergence_type in ["selectionDivergence", "simultaneousDivergence", |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2491 |
"selectionConvergence", "simultaneousConvergence"]] |
1411 | 2492 |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2493 |
def GetDivergenceType(self, divergence): |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2494 |
for divergence_type, divergence_class in self.DivergenceTypes: |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2495 |
if isinstance(divergence, divergence_class): |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2496 |
return divergence_type |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2497 |
return None |
1411 | 2498 |
|
814 | 2499 |
def SetEditedElementDivergenceInfos(self, tagname, id, infos): |
2500 |
element = self.GetEditedElement(tagname) |
|
2501 |
if element is not None: |
|
2502 |
divergence = element.getinstance(id) |
|
2503 |
if divergence is None: |
|
2504 |
return |
|
2505 |
for param, value in infos.items(): |
|
2506 |
if param == "height": |
|
2507 |
divergence.setheight(value) |
|
2508 |
elif param == "width": |
|
2509 |
divergence.setwidth(value) |
|
2510 |
elif param == "x": |
|
2511 |
divergence.setx(value) |
|
2512 |
elif param == "y": |
|
2513 |
divergence.sety(value) |
|
2514 |
elif param == "connectors": |
|
2515 |
input_connectors = value["inputs"] |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2516 |
divergence_type = self.GetDivergenceType(divergence) |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2517 |
if divergence_type in ["selectionDivergence", "simultaneousDivergence"]: |
814 | 2518 |
position = input_connectors[0].GetRelPosition() |
2519 |
divergence.addconnectionPointIn() |
|
2520 |
divergence.connectionPointIn.setrelPositionXY(position.x, position.y) |
|
2521 |
self.SetConnectionWires(divergence.connectionPointIn, input_connectors[0]) |
|
2522 |
else: |
|
2523 |
divergence.setconnectionPointIn([]) |
|
2524 |
for input_connector in input_connectors: |
|
2525 |
position = input_connector.GetRelPosition() |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2526 |
connection = PLCOpenParser.CreateElement("connectionPointIn", divergence_type) |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2527 |
divergence.appendconnectionPointIn(connection) |
814 | 2528 |
connection.setrelPositionXY(position.x, position.y) |
2529 |
self.SetConnectionWires(connection, input_connector) |
|
2530 |
output_connectors = value["outputs"] |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2531 |
if divergence_type in ["selectionConvergence", "simultaneousConvergence"]: |
814 | 2532 |
position = output_connectors[0].GetRelPosition() |
2533 |
divergence.addconnectionPointOut() |
|
2534 |
divergence.connectionPointOut.setrelPositionXY(position.x, position.y) |
|
2535 |
else: |
|
2536 |
divergence.setconnectionPointOut([]) |
|
2537 |
for output_connector in output_connectors: |
|
2538 |
position = output_connector.GetRelPosition() |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2539 |
connection = PLCOpenParser.CreateElement("connectionPointOut", divergence_type) |
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2540 |
divergence.appendconnectionPointOut(connection) |
814 | 2541 |
connection.setrelPositionXY(position.x, position.y) |
1411 | 2542 |
|
814 | 2543 |
def AddEditedElementJump(self, tagname, id): |
2544 |
element = self.GetEditedElement(tagname) |
|
2545 |
if element is not None: |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2546 |
jump = PLCOpenParser.CreateElement("jumpStep", "sfcObjects") |
814 | 2547 |
jump.setlocalId(id) |
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2548 |
element.addinstance(jump) |
1411 | 2549 |
|
814 | 2550 |
def SetEditedElementJumpInfos(self, tagname, id, infos): |
2551 |
element = self.GetEditedElement(tagname) |
|
2552 |
if element is not None: |
|
2553 |
jump = element.getinstance(id) |
|
2554 |
if jump is None: |
|
2555 |
return |
|
2556 |
for param, value in infos.items(): |
|
2557 |
if param == "target": |
|
2558 |
jump.settargetName(value) |
|
2559 |
elif param == "height": |
|
2560 |
jump.setheight(value) |
|
2561 |
elif param == "width": |
|
2562 |
jump.setwidth(value) |
|
2563 |
elif param == "x": |
|
2564 |
jump.setx(value) |
|
2565 |
elif param == "y": |
|
2566 |
jump.sety(value) |
|
2567 |
elif param == "connector": |
|
2568 |
position = value.GetRelPosition() |
|
2569 |
jump.addconnectionPointIn() |
|
2570 |
jump.connectionPointIn.setrelPositionXY(position.x, position.y) |
|
2571 |
self.SetConnectionWires(jump.connectionPointIn, value) |
|
1411 | 2572 |
|
814 | 2573 |
def AddEditedElementActionBlock(self, tagname, id): |
2574 |
element = self.GetEditedElement(tagname) |
|
2575 |
if element is not None: |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2576 |
actionBlock = PLCOpenParser.CreateElement("actionBlock", "commonObjects") |
814 | 2577 |
actionBlock.setlocalId(id) |
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2578 |
element.addinstance(actionBlock) |
1411 | 2579 |
|
814 | 2580 |
def SetEditedElementActionBlockInfos(self, tagname, id, infos): |
2581 |
element = self.GetEditedElement(tagname) |
|
2582 |
if element is not None: |
|
2583 |
actionBlock = element.getinstance(id) |
|
2584 |
if actionBlock is None: |
|
2585 |
return |
|
2586 |
for param, value in infos.items(): |
|
2587 |
if param == "actions": |
|
2588 |
actionBlock.setactions(value) |
|
2589 |
elif param == "height": |
|
2590 |
actionBlock.setheight(value) |
|
2591 |
elif param == "width": |
|
2592 |
actionBlock.setwidth(value) |
|
2593 |
elif param == "x": |
|
2594 |
actionBlock.setx(value) |
|
2595 |
elif param == "y": |
|
2596 |
actionBlock.sety(value) |
|
2597 |
elif param == "connector": |
|
2598 |
position = value.GetRelPosition() |
|
2599 |
actionBlock.addconnectionPointIn() |
|
2600 |
actionBlock.connectionPointIn.setrelPositionXY(position.x, position.y) |
|
2601 |
self.SetConnectionWires(actionBlock.connectionPointIn, value) |
|
1411 | 2602 |
|
814 | 2603 |
def RemoveEditedElementInstance(self, tagname, id): |
2604 |
element = self.GetEditedElement(tagname) |
|
2605 |
if element is not None: |
|
2606 |
instance = element.getinstance(id) |
|
1293
40117d02601b
Fixed diagram editing in xmlclass refactoring
Laurent Bessard
parents:
1291
diff
changeset
|
2607 |
if isinstance(instance, PLCOpenParser.GetElementClass("block", "fbdObjects")): |
814 | 2608 |
self.RemoveEditedElementPouVar(tagname, instance.gettypeName(), instance.getinstanceName()) |
2609 |
element.removeinstance(id) |
|
2610 |
||
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
2611 |
def GetEditedResourceVariables(self, tagname, debug=False): |
814 | 2612 |
varlist = [] |
2613 |
words = tagname.split("::") |
|
2614 |
for var in self.GetConfigurationGlobalVars(words[1], debug): |
|
1361
7158aa054226
Fixed bugs when editing resource variables and tasks
Laurent Bessard
parents:
1360
diff
changeset
|
2615 |
if var.Type == "BOOL": |
7158aa054226
Fixed bugs when editing resource variables and tasks
Laurent Bessard
parents:
1360
diff
changeset
|
2616 |
varlist.append(var.Name) |
814 | 2617 |
for var in self.GetConfigurationResourceGlobalVars(words[1], words[2], debug): |
1361
7158aa054226
Fixed bugs when editing resource variables and tasks
Laurent Bessard
parents:
1360
diff
changeset
|
2618 |
if var.Type == "BOOL": |
7158aa054226
Fixed bugs when editing resource variables and tasks
Laurent Bessard
parents:
1360
diff
changeset
|
2619 |
varlist.append(var.Name) |
814 | 2620 |
return varlist |
2621 |
||
2622 |
def SetEditedResourceInfos(self, tagname, tasks, instances): |
|
2623 |
resource = self.GetEditedElement(tagname) |
|
2624 |
if resource is not None: |
|
2625 |
resource.settask([]) |
|
2626 |
resource.setpouInstance([]) |
|
2627 |
task_list = {} |
|
2628 |
for task in tasks: |
|
1294
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2629 |
new_task = PLCOpenParser.CreateElement("task", "resource") |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2630 |
resource.appendtask(new_task) |
814 | 2631 |
new_task.setname(task["Name"]) |
2632 |
if task["Triggering"] == "Interrupt": |
|
2633 |
new_task.setsingle(task["Single"]) |
|
1753
19f19c66b67e
clean-up: fix most PEP8 E266 too many leading '#' for block comment
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1751
diff
changeset
|
2634 |
# result = duration_model.match(task["Interval"]).groups() |
19f19c66b67e
clean-up: fix most PEP8 E266 too many leading '#' for block comment
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1751
diff
changeset
|
2635 |
# if reduce(lambda x, y: x or y != None, result): |
19f19c66b67e
clean-up: fix most PEP8 E266 too many leading '#' for block comment
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1751
diff
changeset
|
2636 |
# values = [] |
19f19c66b67e
clean-up: fix most PEP8 E266 too many leading '#' for block comment
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1751
diff
changeset
|
2637 |
# for value in result[:-1]: |
19f19c66b67e
clean-up: fix most PEP8 E266 too many leading '#' for block comment
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1751
diff
changeset
|
2638 |
# if value != None: |
19f19c66b67e
clean-up: fix most PEP8 E266 too many leading '#' for block comment
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1751
diff
changeset
|
2639 |
# values.append(int(value)) |
19f19c66b67e
clean-up: fix most PEP8 E266 too many leading '#' for block comment
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1751
diff
changeset
|
2640 |
# else: |
19f19c66b67e
clean-up: fix most PEP8 E266 too many leading '#' for block comment
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1751
diff
changeset
|
2641 |
# values.append(0) |
19f19c66b67e
clean-up: fix most PEP8 E266 too many leading '#' for block comment
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1751
diff
changeset
|
2642 |
# if result[-1] is not None: |
19f19c66b67e
clean-up: fix most PEP8 E266 too many leading '#' for block comment
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1751
diff
changeset
|
2643 |
# values.append(int(float(result[-1]) * 1000)) |
19f19c66b67e
clean-up: fix most PEP8 E266 too many leading '#' for block comment
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1751
diff
changeset
|
2644 |
# new_task.setinterval(datetime.time(*values)) |
814 | 2645 |
if task["Triggering"] == "Cyclic": |
2646 |
new_task.setinterval(task["Interval"]) |
|
2647 |
new_task.setpriority(int(task["Priority"])) |
|
2648 |
if task["Name"] != "": |
|
2649 |
task_list[task["Name"]] = new_task |
|
2650 |
for instance in instances: |
|
1294
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2651 |
task = task_list.get(instance["Task"]) |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2652 |
if task is not None: |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2653 |
new_instance = PLCOpenParser.CreateElement("pouInstance", "task") |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2654 |
task.appendpouInstance(new_instance) |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2655 |
else: |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2656 |
new_instance = PLCOpenParser.CreateElement("pouInstance", "resource") |
f02ba5b83811
Fixed datatype and configuration editing in xmlclass refactoring
Laurent Bessard
parents:
1293
diff
changeset
|
2657 |
resource.appendpouInstance(new_instance) |
814 | 2658 |
new_instance.setname(instance["Name"]) |
2659 |
new_instance.settypeName(instance["Type"]) |
|
2660 |
||
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
2661 |
def GetEditedResourceInfos(self, tagname, debug=False): |
814 | 2662 |
resource = self.GetEditedElement(tagname, debug) |
2663 |
if resource is not None: |
|
2664 |
tasks = resource.gettask() |
|
2665 |
instances = resource.getpouInstance() |
|
2666 |
tasks_data = [] |
|
2667 |
instances_data = [] |
|
2668 |
for task in tasks: |
|
2669 |
new_task = {} |
|
2670 |
new_task["Name"] = task.getname() |
|
2671 |
single = task.getsingle() |
|
2672 |
if single is not None: |
|
2673 |
new_task["Single"] = single |
|
2674 |
else: |
|
2675 |
new_task["Single"] = "" |
|
2676 |
interval = task.getinterval() |
|
2677 |
if interval is not None: |
|
1779
6cf16e5bfbf9
clean-up: fix PEP8 E115 expected an indented block (comment)
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1777
diff
changeset
|
2678 |
# text = "" |
6cf16e5bfbf9
clean-up: fix PEP8 E115 expected an indented block (comment)
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1777
diff
changeset
|
2679 |
# if interval.hour != 0: |
6cf16e5bfbf9
clean-up: fix PEP8 E115 expected an indented block (comment)
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1777
diff
changeset
|
2680 |
# text += "%dh"%interval.hour |
6cf16e5bfbf9
clean-up: fix PEP8 E115 expected an indented block (comment)
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1777
diff
changeset
|
2681 |
# if interval.minute != 0: |
6cf16e5bfbf9
clean-up: fix PEP8 E115 expected an indented block (comment)
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1777
diff
changeset
|
2682 |
# text += "%dm"%interval.minute |
6cf16e5bfbf9
clean-up: fix PEP8 E115 expected an indented block (comment)
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1777
diff
changeset
|
2683 |
# if interval.second != 0: |
6cf16e5bfbf9
clean-up: fix PEP8 E115 expected an indented block (comment)
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1777
diff
changeset
|
2684 |
# text += "%ds"%interval.second |
6cf16e5bfbf9
clean-up: fix PEP8 E115 expected an indented block (comment)
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1777
diff
changeset
|
2685 |
# if interval.microsecond != 0: |
6cf16e5bfbf9
clean-up: fix PEP8 E115 expected an indented block (comment)
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1777
diff
changeset
|
2686 |
# if interval.microsecond % 1000 != 0: |
6cf16e5bfbf9
clean-up: fix PEP8 E115 expected an indented block (comment)
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1777
diff
changeset
|
2687 |
# text += "%.3fms"%(float(interval.microsecond) / 1000) |
6cf16e5bfbf9
clean-up: fix PEP8 E115 expected an indented block (comment)
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1777
diff
changeset
|
2688 |
# else: |
6cf16e5bfbf9
clean-up: fix PEP8 E115 expected an indented block (comment)
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1777
diff
changeset
|
2689 |
# text += "%dms"%(interval.microsecond / 1000) |
6cf16e5bfbf9
clean-up: fix PEP8 E115 expected an indented block (comment)
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1777
diff
changeset
|
2690 |
# new_task["Interval"] = text |
814 | 2691 |
new_task["Interval"] = interval |
2692 |
else: |
|
2693 |
new_task["Interval"] = "" |
|
2694 |
if single is not None and interval is None: |
|
2695 |
new_task["Triggering"] = "Interrupt" |
|
2696 |
elif interval is not None and single is None: |
|
2697 |
new_task["Triggering"] = "Cyclic" |
|
2698 |
else: |
|
2699 |
new_task["Triggering"] = "" |
|
2700 |
new_task["Priority"] = str(task.getpriority()) |
|
2701 |
tasks_data.append(new_task) |
|
2702 |
for instance in task.getpouInstance(): |
|
2703 |
new_instance = {} |
|
2704 |
new_instance["Name"] = instance.getname() |
|
2705 |
new_instance["Type"] = instance.gettypeName() |
|
2706 |
new_instance["Task"] = task.getname() |
|
2707 |
instances_data.append(new_instance) |
|
2708 |
for instance in instances: |
|
2709 |
new_instance = {} |
|
2710 |
new_instance["Name"] = instance.getname() |
|
2711 |
new_instance["Type"] = instance.gettypeName() |
|
2712 |
new_instance["Task"] = "" |
|
2713 |
instances_data.append(new_instance) |
|
2714 |
return tasks_data, instances_data |
|
2715 |
||
2716 |
def OpenXMLFile(self, filepath): |
|
1330
96b242e4c59d
Added support for loading XML file even if not following XSD schema (but still following XML syntax), warning user of errors in XML file
Laurent Bessard
parents:
1328
diff
changeset
|
2717 |
self.Project, error = LoadProject(filepath) |
96b242e4c59d
Added support for loading XML file even if not following XSD schema (but still following XML syntax), warning user of errors in XML file
Laurent Bessard
parents:
1328
diff
changeset
|
2718 |
if self.Project is None: |
96b242e4c59d
Added support for loading XML file even if not following XSD schema (but still following XML syntax), warning user of errors in XML file
Laurent Bessard
parents:
1328
diff
changeset
|
2719 |
return _("Project file syntax error:\n\n") + error |
1290
13ee5f4ab612
First stage of xmlclass refactoring using lxml
Laurent Bessard
parents:
1284
diff
changeset
|
2720 |
self.SetFilePath(filepath) |
13ee5f4ab612
First stage of xmlclass refactoring using lxml
Laurent Bessard
parents:
1284
diff
changeset
|
2721 |
self.CreateProjectBuffer(True) |
13ee5f4ab612
First stage of xmlclass refactoring using lxml
Laurent Bessard
parents:
1284
diff
changeset
|
2722 |
self.ProgramChunks = [] |
13ee5f4ab612
First stage of xmlclass refactoring using lxml
Laurent Bessard
parents:
1284
diff
changeset
|
2723 |
self.ProgramOffset = 0 |
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
2724 |
self.NextCompiledProject = self.Copy(self.Project) |
1290
13ee5f4ab612
First stage of xmlclass refactoring using lxml
Laurent Bessard
parents:
1284
diff
changeset
|
2725 |
self.CurrentCompiledProject = None |
13ee5f4ab612
First stage of xmlclass refactoring using lxml
Laurent Bessard
parents:
1284
diff
changeset
|
2726 |
self.Buffering = False |
13ee5f4ab612
First stage of xmlclass refactoring using lxml
Laurent Bessard
parents:
1284
diff
changeset
|
2727 |
self.CurrentElementEditing = None |
1330
96b242e4c59d
Added support for loading XML file even if not following XSD schema (but still following XML syntax), warning user of errors in XML file
Laurent Bessard
parents:
1328
diff
changeset
|
2728 |
return error |
1411 | 2729 |
|
1744
69dfdb26f600
clean-up: fix PEP8 E251 unexpected spaces around keyword / parameter equals
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1743
diff
changeset
|
2730 |
def SaveXMLFile(self, filepath=None): |
814 | 2731 |
if not filepath and self.FilePath == "": |
2732 |
return False |
|
2733 |
else: |
|
2734 |
contentheader = {"modificationDateTime": datetime.datetime(*localtime()[:6])} |
|
2735 |
self.Project.setcontentHeader(contentheader) |
|
1411 | 2736 |
|
1290
13ee5f4ab612
First stage of xmlclass refactoring using lxml
Laurent Bessard
parents:
1284
diff
changeset
|
2737 |
if filepath: |
13ee5f4ab612
First stage of xmlclass refactoring using lxml
Laurent Bessard
parents:
1284
diff
changeset
|
2738 |
SaveProject(self.Project, filepath) |
13ee5f4ab612
First stage of xmlclass refactoring using lxml
Laurent Bessard
parents:
1284
diff
changeset
|
2739 |
else: |
13ee5f4ab612
First stage of xmlclass refactoring using lxml
Laurent Bessard
parents:
1284
diff
changeset
|
2740 |
SaveProject(self.Project, self.FilePath) |
1411 | 2741 |
|
814 | 2742 |
self.MarkProjectAsSaved() |
2743 |
if filepath: |
|
2744 |
self.SetFilePath(filepath) |
|
2745 |
return True |
|
2746 |
||
1782
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
2747 |
# ------------------------------------------------------------------------------- |
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
2748 |
# Search in Current Project Functions |
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
2749 |
# ------------------------------------------------------------------------------- |
814 | 2750 |
|
2751 |
def SearchInProject(self, criteria): |
|
2551
245644bfcd24
Make spaghetti-code-quality great again.
Edouard Tisserant
parents:
2529
diff
changeset
|
2752 |
project_matches = self.Project.Search(criteria) |
245644bfcd24
Make spaghetti-code-quality great again.
Edouard Tisserant
parents:
2529
diff
changeset
|
2753 |
ctn_matches = self.CTNSearch(criteria) |
2523
aa7f138648f3
WIP adding searching capabilities in python files:
Edouard Tisserant
parents:
2520
diff
changeset
|
2754 |
return project_matches + ctn_matches |
814 | 2755 |
|
2756 |
def SearchInPou(self, tagname, criteria, debug=False): |
|
2757 |
pou = self.GetEditedElement(tagname, debug) |
|
2758 |
if pou is not None: |
|
1619
163d3a883575
fix local search in actions and transitions
Surkov Sergey <surkovsv93@gmail.com>
parents:
1616
diff
changeset
|
2759 |
search_results = pou.Search(criteria, [tagname]) |
163d3a883575
fix local search in actions and transitions
Surkov Sergey <surkovsv93@gmail.com>
parents:
1616
diff
changeset
|
2760 |
if tagname.split("::")[0] in ['A', 'T']: |
163d3a883575
fix local search in actions and transitions
Surkov Sergey <surkovsv93@gmail.com>
parents:
1616
diff
changeset
|
2761 |
parent_pou_tagname = "P::%s" % (tagname.split("::")[-2]) |
163d3a883575
fix local search in actions and transitions
Surkov Sergey <surkovsv93@gmail.com>
parents:
1616
diff
changeset
|
2762 |
parent_pou = self.GetEditedElement(parent_pou_tagname, debug) |
163d3a883575
fix local search in actions and transitions
Surkov Sergey <surkovsv93@gmail.com>
parents:
1616
diff
changeset
|
2763 |
for infos, start, end, text in parent_pou.Search(criteria): |
163d3a883575
fix local search in actions and transitions
Surkov Sergey <surkovsv93@gmail.com>
parents:
1616
diff
changeset
|
2764 |
if infos[1] in ["var_local", "var_input", "var_output", "var_inout"]: |
163d3a883575
fix local search in actions and transitions
Surkov Sergey <surkovsv93@gmail.com>
parents:
1616
diff
changeset
|
2765 |
search_results.append((infos, start, end, text)) |
163d3a883575
fix local search in actions and transitions
Surkov Sergey <surkovsv93@gmail.com>
parents:
1616
diff
changeset
|
2766 |
return search_results |
814 | 2767 |
return [] |
2768 |
||
1782
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
2769 |
# ------------------------------------------------------------------------------- |
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
2770 |
# Current Buffering Management Functions |
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
2771 |
# ------------------------------------------------------------------------------- |
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
2772 |
|
814 | 2773 |
def Copy(self, model): |
1782
5b6ad7a7fd9d
clean-up: fix PEP8 E265 block comment should start with '# '
Andrey Skvortsov <andrej.skvortzov@gmail.com>
parents:
1780
diff
changeset
|
2774 |
"""Return a copy of the project""" |
1299
9ffc49bfdf9d
Fixed copy/paste with xmlclass refactoring
Laurent Bessard
parents:
1298
diff
changeset
|
2775 |
return deepcopy(model) |
814 | 2776 |
|
2777 |
def CreateProjectBuffer(self, saved): |
|
2778 |
if self.ProjectBufferEnabled: |
|
1304 | 2779 |
self.ProjectBuffer = UndoBuffer(PLCOpenParser.Dumps(self.Project), saved) |
814 | 2780 |
else: |
2781 |
self.ProjectBuffer = None |
|
2782 |
self.ProjectSaved = saved |
|
2783 |
||
2784 |
def IsProjectBufferEnabled(self): |
|
2785 |
return self.ProjectBufferEnabled |
|
2786 |
||
2787 |
def EnableProjectBuffer(self, enable): |
|
2788 |
self.ProjectBufferEnabled = enable |
|
2789 |
if self.Project is not None: |
|
2790 |
if enable: |
|
2791 |
current_saved = self.ProjectSaved |
|
2792 |
else: |
|
2793 |
current_saved = self.ProjectBuffer.IsCurrentSaved() |
|
2794 |
self.CreateProjectBuffer(current_saved) |
|
2795 |
||
2796 |
def BufferProject(self): |
|
2797 |
if self.ProjectBuffer is not None: |
|
1304 | 2798 |
self.ProjectBuffer.Buffering(PLCOpenParser.Dumps(self.Project)) |
814 | 2799 |
else: |
2800 |
self.ProjectSaved = False |
|
2801 |
||
2802 |
def StartBuffering(self): |
|
2803 |
if self.ProjectBuffer is not None: |
|
2804 |
self.Buffering = True |
|
2805 |
else: |
|
2806 |
self.ProjectSaved = False |
|
1411 | 2807 |
|
814 | 2808 |
def EndBuffering(self): |
2809 |
if self.ProjectBuffer is not None and self.Buffering: |
|
1304 | 2810 |
self.ProjectBuffer.Buffering(PLCOpenParser.Dumps(self.Project)) |
814 | 2811 |
self.Buffering = False |
2812 |
||
2813 |
def MarkProjectAsSaved(self): |
|
2814 |
self.EndBuffering() |
|
2815 |
if self.ProjectBuffer is not None: |
|
2816 |
self.ProjectBuffer.CurrentSaved() |
|
2817 |
else: |
|
2818 |
self.ProjectSaved = True |
|
1411 | 2819 |
|
814 | 2820 |
# Return if project is saved |
2821 |
def ProjectIsSaved(self): |
|
2822 |
if self.ProjectBuffer is not None: |
|
2823 |
return self.ProjectBuffer.IsCurrentSaved() and not self.Buffering |
|
2824 |
else: |
|
2825 |
return self.ProjectSaved |
|
2826 |
||
2827 |
def LoadPrevious(self): |
|
2828 |
self.EndBuffering() |
|
2829 |
if self.ProjectBuffer is not None: |
|
1304 | 2830 |
self.Project = PLCOpenParser.Loads(self.ProjectBuffer.Previous()) |
1411 | 2831 |
|
814 | 2832 |
def LoadNext(self): |
2833 |
if self.ProjectBuffer is not None: |
|
1304 | 2834 |
self.Project = PLCOpenParser.Loads(self.ProjectBuffer.Next()) |
1411 | 2835 |
|
814 | 2836 |
def GetBufferState(self): |
2837 |
if self.ProjectBuffer is not None: |
|
2838 |
first = self.ProjectBuffer.IsFirst() and not self.Buffering |
|
2839 |
last = self.ProjectBuffer.IsLast() |
|
2840 |
return not first, not last |
|
2841 |
return False, False |