Skip to content

Commit

Permalink
Fix setting number parameters to expressions
Browse files Browse the repository at this point in the history
  • Loading branch information
nyalldawson committed Jul 7, 2017
1 parent 82ef7d2 commit 3f9cfe0
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 17 deletions.
24 changes: 8 additions & 16 deletions python/plugins/processing/gui/NumberInputPanel.py
Expand Up @@ -89,30 +89,20 @@ def showExpressionsBuilder(self):

def getValue(self):
value = self.leText.text()
values = []
#for param in self.modelParametersDialog.model.parameterDefinitions():
# if isinstance(param, QgsProcessingParameterNumber):
# if "@" + param.name() in value:
# values.append(ValueFromInput(param.name()))
#for alg in list(self.modelParametersDialog.model.algs.values()):
# for out in alg.algorithm.outputDefinitions():
# if isinstance(out, QgsProcessingOutputNumber) and "@%s_%s" % (alg.modeler_name, out.name) in value:
# values.append(ValueFromOutput(alg.modeler_name, out.name()))

for param in self.modelParametersDialog.model.parameterDefinitions():
if isinstance(param, QgsProcessingParameterNumber):
if "@" + param.name() == value:
if "@" + param.name() == value.strip():
return QgsProcessingModelAlgorithm.ChildParameterSource.fromModelParameter(param.name())

for alg in list(self.modelParametersDialog.model.childAlgorithms().values()):
for out in alg.algorithm().outputDefinitions():
if isinstance(out, QgsProcessingOutputNumber) and "@%s_%s" % (alg.childId(), out.name()) == value:
if isinstance(out, QgsProcessingOutputNumber) and "@%s_%s" % (alg.childId(), out.name()) == value.strip():
return QgsProcessingModelAlgorithm.ChildParameterSource.fromChildOutput(alg.childId(), out.outputName())

if values:
return CompoundValue(values, value)
else:
return value
try:
return float(value.strip())
except:
return QgsProcessingModelAlgorithm.ChildParameterSource.fromExpression(self.leText.text())

def setValue(self, value):
if isinstance(value, QgsProcessingModelAlgorithm.ChildParameterSource):
Expand All @@ -121,6 +111,8 @@ def setValue(self, value):
elif value.source() == QgsProcessingModelAlgorithm.ChildParameterSource.ChildOutput:
name = "%s_%s" % (value.outputChildId(), value.outputName())
self.leText.setText(name)
elif value.source() == QgsProcessingModelAlgorithm.ChildParameterSource.Expression:
self.leText.setText(value.expression())
else:
self.leText.setText(str(value.staticValue()))
else:
Expand Down
3 changes: 2 additions & 1 deletion python/plugins/processing/modeler/ModelerScene.py
Expand Up @@ -29,7 +29,8 @@
from qgis.PyQt.QtCore import QPointF, Qt
from qgis.PyQt.QtWidgets import QGraphicsItem, QGraphicsScene
from qgis.core import (QgsProcessingParameterDefinition,
QgsProcessingModelAlgorithm)
QgsProcessingModelAlgorithm,
QgsExpression)
from processing.modeler.ModelerGraphicItem import ModelerGraphicItem
from processing.modeler.ModelerArrowItem import ModelerArrowItem

Expand Down

0 comments on commit 3f9cfe0

Please sign in to comment.