SVGHMI: detachable and discardable elements sets, Reworked geometric intersection, toward more accurate page content detection.
Moved page's widget/element dependency crawling functions so that it is possible to compute a global detachable and discardable elements sets.
Reworked geometric intersection detection logic to distinguish ovelapping and inclusion.
Goal is to include englobing and overlapping graphical elements, but not groups (would then include everything around...). Intermediate commit, to be continued.
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# See COPYING file for copyrights details.
from __future__ import absolute_import
from itertools import repeat, islice, chain
from connectors.SchemeEditor import SchemeEditor
Schemes = ["WAMP", "WAMPS"]
model = [('host', _("Host:")),
('path', _("Path:")),
('port', _("Port:")),
('realm', _("Realm:"))]
class WAMP_dialog(SchemeEditor):
def __init__(self, *args, **kwargs):
self.model = model
self.EnableIDSelector = True
SchemeEditor.__init__(self, *args, **kwargs)
# pylint: disable=unused-variable
def SetLoc(self, loc):
hostportpath, realm, ID = list(islice(chain(loc.split("#"), repeat("")), 3))
hostport, path = list(islice(chain(hostportpath.split("/"), repeat("")), 2))
host, port = list(islice(chain(hostport.split(":"), repeat("")), 2))
self.SetFields(locals())
def GetLoc(self):
fields = self.GetFields()
# TODO : input validation test
template = "{host}" + \
(":{port}" if fields['port'] else '') +\
("/{path}" if fields['path'] else '') +\
"#{realm}#{ID}"
return template.format(**fields)