2012-10-05 23:28:47 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
"""
|
|
|
|
***************************************************************************
|
2013-08-12 20:44:27 +02:00
|
|
|
Processing.py
|
2012-10-05 23:28:47 +02:00
|
|
|
---------------------
|
|
|
|
Date : August 2012
|
|
|
|
Copyright : (C) 2012 by Victor Olaya
|
|
|
|
Email : volayaf at gmail dot com
|
|
|
|
***************************************************************************
|
|
|
|
* *
|
|
|
|
* This program is free software; you can redistribute it and/or modify *
|
|
|
|
* it under the terms of the GNU General Public License as published by *
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or *
|
|
|
|
* (at your option) any later version. *
|
|
|
|
* *
|
|
|
|
***************************************************************************
|
|
|
|
"""
|
2016-08-04 09:10:08 +02:00
|
|
|
from __future__ import print_function
|
2016-09-21 18:24:26 +02:00
|
|
|
from builtins import str
|
|
|
|
from builtins import object
|
2014-08-22 11:27:57 +02:00
|
|
|
|
2012-10-05 23:28:47 +02:00
|
|
|
__author__ = 'Victor Olaya'
|
|
|
|
__date__ = 'August 2012'
|
|
|
|
__copyright__ = '(C) 2012, Victor Olaya'
|
2013-10-01 20:52:22 +03:00
|
|
|
|
2012-10-05 23:28:47 +02:00
|
|
|
# This will get replaced with a git SHA1 when you do a git archive
|
2013-10-01 20:52:22 +03:00
|
|
|
|
2012-10-05 23:28:47 +02:00
|
|
|
__revision__ = '$Format:%H$'
|
|
|
|
|
2016-05-23 16:57:59 +02:00
|
|
|
import os
|
2016-04-26 08:29:15 +02:00
|
|
|
import traceback
|
2014-10-03 14:44:01 +03:00
|
|
|
|
2017-03-04 19:41:23 +01:00
|
|
|
from qgis.PyQt.QtCore import Qt, QCoreApplication
|
2016-04-22 10:38:48 +02:00
|
|
|
from qgis.PyQt.QtWidgets import QApplication
|
|
|
|
from qgis.PyQt.QtGui import QCursor
|
2014-10-03 14:44:01 +03:00
|
|
|
|
2014-05-20 16:30:59 +02:00
|
|
|
from qgis.utils import iface
|
2017-01-09 09:59:35 +10:00
|
|
|
from qgis.core import (QgsMessageLog,
|
2017-04-04 12:58:25 +10:00
|
|
|
QgsApplication,
|
2017-04-24 14:35:50 +10:00
|
|
|
QgsProcessingProvider,
|
2017-05-15 16:19:46 +10:00
|
|
|
QgsProcessingUtils,
|
|
|
|
QgsProcessingParameterDefinition)
|
2014-10-03 14:44:01 +03:00
|
|
|
|
|
|
|
import processing
|
2016-05-23 16:57:59 +02:00
|
|
|
from processing.script.ScriptUtils import ScriptUtils
|
2013-08-12 20:44:27 +02:00
|
|
|
from processing.core.ProcessingConfig import ProcessingConfig
|
|
|
|
from processing.core.GeoAlgorithm import GeoAlgorithm
|
2013-10-01 20:52:22 +03:00
|
|
|
from processing.gui.MessageBarProgress import MessageBarProgress
|
2013-08-12 20:44:27 +02:00
|
|
|
from processing.gui.RenderingStyles import RenderingStyles
|
2014-06-08 23:15:33 +02:00
|
|
|
from processing.gui.Postprocessing import handleAlgorithmResults
|
2017-03-22 17:17:14 +02:00
|
|
|
from processing.gui.AlgorithmExecutor import execute
|
2017-04-25 20:03:39 +10:00
|
|
|
from processing.tools import dataobjects
|
2016-05-19 12:25:04 +02:00
|
|
|
|
2017-03-04 19:41:23 +01:00
|
|
|
from processing.modeler.ModelerAlgorithmProvider import ModelerAlgorithmProvider # NOQA
|
2017-05-19 10:17:59 +10:00
|
|
|
#from processing.algs.qgis.QGISAlgorithmProvider import QGISAlgorithmProvider # NOQA
|
|
|
|
#from processing.algs.grass7.Grass7AlgorithmProvider import Grass7AlgorithmProvider # NOQA
|
|
|
|
#from processing.algs.gdal.GdalAlgorithmProvider import GdalAlgorithmProvider # NOQA
|
|
|
|
#from processing.algs.saga.SagaAlgorithmProvider import SagaAlgorithmProvider # NOQA
|
|
|
|
#from processing.script.ScriptAlgorithmProvider import ScriptAlgorithmProvider # NOQA
|
|
|
|
#from processing.preconfigured.PreconfiguredAlgorithmProvider import PreconfiguredAlgorithmProvider # NOQA
|
2016-04-27 15:40:56 +03:00
|
|
|
|
2016-05-27 19:04:25 +03:00
|
|
|
|
2016-09-21 18:24:26 +02:00
|
|
|
class Processing(object):
|
2017-04-04 14:34:00 +10:00
|
|
|
BASIC_PROVIDERS = []
|
|
|
|
|
2016-06-02 09:45:20 +02:00
|
|
|
@staticmethod
|
|
|
|
def activateProvider(providerOrName, activate=True):
|
2017-04-04 12:58:25 +10:00
|
|
|
provider_id = providerOrName.id() if isinstance(providerOrName, QgsProcessingProvider) else providerOrName
|
2017-04-04 11:28:28 +10:00
|
|
|
provider = QgsApplication.processingRegistry().providerById(provider_id)
|
2017-04-04 12:22:29 +10:00
|
|
|
try:
|
|
|
|
provider.setActive(True)
|
2017-04-04 11:28:28 +10:00
|
|
|
provider.refreshAlgorithms()
|
2017-04-04 12:22:29 +10:00
|
|
|
except:
|
|
|
|
# provider could not be activated
|
|
|
|
QgsMessageLog.logMessage(Processing.tr('Error: Provider {0} could not be activated\n').format(provider_id),
|
|
|
|
Processing.tr("Processing"))
|
2016-06-02 09:45:20 +02:00
|
|
|
|
2012-09-15 18:25:25 +03:00
|
|
|
@staticmethod
|
|
|
|
def initialize():
|
2017-04-04 11:04:36 +10:00
|
|
|
if "model" in [p.id() for p in QgsApplication.processingRegistry().providers()]:
|
2016-05-23 16:57:59 +02:00
|
|
|
return
|
2013-10-01 20:52:22 +03:00
|
|
|
# Add the basic providers
|
2017-04-04 12:58:25 +10:00
|
|
|
for c in QgsProcessingProvider.__subclasses__():
|
2017-04-04 13:28:44 +10:00
|
|
|
p = c()
|
2017-04-04 14:34:00 +10:00
|
|
|
Processing.BASIC_PROVIDERS.append(p)
|
2017-04-04 13:28:44 +10:00
|
|
|
QgsApplication.processingRegistry().addProvider(p)
|
2013-10-01 20:52:22 +03:00
|
|
|
# And initialize
|
2013-08-12 20:44:27 +02:00
|
|
|
ProcessingConfig.initialize()
|
2014-04-23 18:24:23 +02:00
|
|
|
ProcessingConfig.readSettings()
|
2013-02-28 22:08:32 +01:00
|
|
|
RenderingStyles.loadStyles()
|
2016-05-27 19:04:25 +03:00
|
|
|
|
2017-04-04 13:28:44 +10:00
|
|
|
@staticmethod
|
|
|
|
def deinitialize():
|
2017-04-04 14:34:00 +10:00
|
|
|
for p in Processing.BASIC_PROVIDERS:
|
2017-04-04 13:28:44 +10:00
|
|
|
QgsApplication.processingRegistry().removeProvider(p)
|
|
|
|
|
2017-04-04 14:34:00 +10:00
|
|
|
Processing.BASIC_PROVIDERS = []
|
|
|
|
|
2016-05-27 19:04:25 +03:00
|
|
|
@staticmethod
|
2016-05-23 16:57:59 +02:00
|
|
|
def addScripts(folder):
|
|
|
|
Processing.initialize()
|
2017-01-09 09:59:35 +10:00
|
|
|
provider = QgsApplication.processingRegistry().providerById("qgis")
|
2016-05-23 16:57:59 +02:00
|
|
|
scripts = ScriptUtils.loadFromFolder(folder)
|
2016-08-04 09:10:08 +02:00
|
|
|
# fix_print_with_import
|
|
|
|
print(scripts)
|
2016-05-23 16:57:59 +02:00
|
|
|
for script in scripts:
|
|
|
|
script.allowEdit = False
|
|
|
|
script._icon = provider._icon
|
2016-05-27 19:04:25 +03:00
|
|
|
provider.externalAlgs.extend(scripts)
|
2017-04-04 11:28:28 +10:00
|
|
|
provider.refreshAlgorithms()
|
2016-05-27 19:04:25 +03:00
|
|
|
|
2016-05-24 10:27:38 +02:00
|
|
|
@staticmethod
|
2016-05-23 16:57:59 +02:00
|
|
|
def removeScripts(folder):
|
2017-01-09 09:59:35 +10:00
|
|
|
provider = QgsApplication.processingRegistry().providerById("qgis")
|
2016-05-24 10:27:38 +02:00
|
|
|
for alg in provider.externalAlgs[::-1]:
|
|
|
|
path = os.path.dirname(alg.descriptionFile)
|
|
|
|
if path == folder:
|
2016-05-27 19:04:25 +03:00
|
|
|
provider.externalAlgs.remove(alg)
|
2017-04-04 11:28:28 +10:00
|
|
|
provider.refreshAlgorithms()
|
2012-09-15 18:25:25 +03:00
|
|
|
|
|
|
|
@staticmethod
|
2015-08-14 14:12:01 +02:00
|
|
|
def runAlgorithm(algOrName, onFinish, *args, **kwargs):
|
2012-09-15 18:25:25 +03:00
|
|
|
if isinstance(algOrName, GeoAlgorithm):
|
|
|
|
alg = algOrName
|
|
|
|
else:
|
2017-04-04 11:04:36 +10:00
|
|
|
alg = QgsApplication.processingRegistry().algorithmById(algOrName)
|
2013-10-01 20:52:22 +03:00
|
|
|
if alg is None:
|
2016-08-04 09:10:08 +02:00
|
|
|
# fix_print_with_import
|
|
|
|
print('Error: Algorithm not found\n')
|
2017-04-07 13:38:24 +10:00
|
|
|
QgsMessageLog.logMessage(Processing.tr('Error: Algorithm {0} not found\n').format(algOrName),
|
|
|
|
Processing.tr("Processing"))
|
2012-09-15 18:25:25 +03:00
|
|
|
return
|
2014-07-02 07:46:03 +02:00
|
|
|
|
2017-05-15 16:19:46 +10:00
|
|
|
parameters = {}
|
2014-06-26 16:09:00 +02:00
|
|
|
if len(args) == 1 and isinstance(args[0], dict):
|
2014-07-02 07:46:03 +02:00
|
|
|
# Set params by name and try to run the alg even if not all parameter values are provided,
|
2014-06-26 16:09:00 +02:00
|
|
|
# by using the default values instead.
|
2016-09-21 18:24:26 +02:00
|
|
|
for (name, value) in list(args[0].items()):
|
2017-05-15 16:19:46 +10:00
|
|
|
param = alg.parameterDefinition(name)
|
|
|
|
if param:
|
|
|
|
# TODO
|
|
|
|
# and param.setValue(value):
|
|
|
|
parameters[param.name()] = value
|
2013-10-01 20:52:22 +03:00
|
|
|
continue
|
2014-06-26 16:09:00 +02:00
|
|
|
output = alg.getOutputFromName(name)
|
|
|
|
if output and output.setValue(value):
|
2013-10-01 20:52:22 +03:00
|
|
|
continue
|
2016-08-04 09:10:08 +02:00
|
|
|
# fix_print_with_import
|
|
|
|
print('Error: Wrong parameter value %s for parameter %s.' % (value, name))
|
2017-04-07 13:38:24 +10:00
|
|
|
QgsMessageLog.logMessage(
|
|
|
|
Processing.tr('Error: Wrong parameter value {0} for parameter {1}.').format(value, name),
|
|
|
|
Processing.tr("Processing"))
|
2017-04-26 12:52:23 +10:00
|
|
|
QgsMessageLog.logMessage(Processing.tr('Error in {0}. Wrong parameter value {1} for parameter {2}.').format(
|
|
|
|
alg.name(), value, name
|
|
|
|
), Processing.tr("Processing"),
|
|
|
|
QgsMessageLog.CRITICAL
|
fix python pep8 warnings and fix some revealed errors
pep8 --ignore=E111,E128,E201,E202,E203,E211,E221,E222,E225,E226,E227,E231,E241,E261,E265,E272,E302,E303,E501,E701 \
--exclude="ui_*.py,debian/*,python/ext-libs/*" \
.
2015-02-01 14:15:42 +01:00
|
|
|
)
|
2012-09-15 18:25:25 +03:00
|
|
|
return
|
2017-05-15 16:19:46 +10:00
|
|
|
# check for any manadatory parameters which were not specified
|
|
|
|
for param in alg.parameterDefinitions():
|
|
|
|
if param.name() not in parameters:
|
|
|
|
if not param.flags() & QgsProcessingParameterDefinition.FlagOptional:
|
2016-08-04 09:10:08 +02:00
|
|
|
# fix_print_with_import
|
2017-05-15 16:19:46 +10:00
|
|
|
print('Error: Missing parameter value for parameter %s.' % param.name())
|
2017-04-07 13:38:24 +10:00
|
|
|
QgsMessageLog.logMessage(
|
2017-05-15 16:19:46 +10:00
|
|
|
Processing.tr('Error: Missing parameter value for parameter {0}.').format(param.name()),
|
2017-04-07 13:38:24 +10:00
|
|
|
Processing.tr("Processing"))
|
2014-06-26 16:09:00 +02:00
|
|
|
return
|
2012-09-15 18:25:25 +03:00
|
|
|
else:
|
2017-05-15 12:29:44 +10:00
|
|
|
if len(args) != alg.countVisibleParameters():
|
2016-08-04 09:10:08 +02:00
|
|
|
# fix_print_with_import
|
|
|
|
print('Error: Wrong number of parameters')
|
2017-04-07 13:38:24 +10:00
|
|
|
QgsMessageLog.logMessage(Processing.tr('Error: Wrong number of parameters'),
|
|
|
|
Processing.tr("Processing"))
|
2017-03-22 15:25:12 +02:00
|
|
|
processing.algorithmHelp(algOrName)
|
2014-06-26 16:09:00 +02:00
|
|
|
return
|
2012-09-15 18:25:25 +03:00
|
|
|
i = 0
|
2017-05-15 16:19:46 +10:00
|
|
|
for param in alg.parameterDefinitions():
|
|
|
|
if not param.flags() & QgsProcessingParameterDefinition.FlagHidden:
|
|
|
|
if not True: # TODO param.setValue(args[i]):
|
2016-08-04 09:10:08 +02:00
|
|
|
# fix_print_with_import
|
2016-09-21 18:24:26 +02:00
|
|
|
print('Error: Wrong parameter value: ' + str(args[i]))
|
2017-04-07 13:38:24 +10:00
|
|
|
QgsMessageLog.logMessage(Processing.tr('Error: Wrong parameter value: ') + str(args[i]),
|
|
|
|
Processing.tr("Processing"))
|
2012-09-15 18:25:25 +03:00
|
|
|
return
|
2017-05-15 16:19:46 +10:00
|
|
|
else:
|
|
|
|
parameters[param.name()] = args[i]
|
2013-10-01 20:52:22 +03:00
|
|
|
i = i + 1
|
2012-09-15 18:25:25 +03:00
|
|
|
|
|
|
|
for output in alg.outputs:
|
2017-05-16 16:36:00 +10:00
|
|
|
if not output.flags() & QgsProcessingParameterDefinition.FlagHidden:
|
2012-09-15 18:25:25 +03:00
|
|
|
if not output.setValue(args[i]):
|
2016-08-04 09:10:08 +02:00
|
|
|
# fix_print_with_import
|
2016-09-21 18:24:26 +02:00
|
|
|
print('Error: Wrong output value: ' + str(args[i]))
|
2017-04-07 13:38:24 +10:00
|
|
|
QgsMessageLog.logMessage(Processing.tr('Error: Wrong output value: ') + str(args[i]),
|
|
|
|
Processing.tr("Processing"))
|
2012-09-15 18:25:25 +03:00
|
|
|
return
|
2013-10-01 20:52:22 +03:00
|
|
|
i = i + 1
|
2012-09-15 18:25:25 +03:00
|
|
|
|
2017-04-29 12:14:53 +02:00
|
|
|
context = None
|
|
|
|
if kwargs is not None and 'context' in list(kwargs.keys()):
|
|
|
|
context = kwargs["context"]
|
|
|
|
else:
|
|
|
|
context = dataobjects.createContext()
|
|
|
|
|
2017-05-16 15:21:41 +10:00
|
|
|
ok, msg = alg.checkParameterValues(parameters, context)
|
|
|
|
if not ok:
|
2016-08-04 09:10:08 +02:00
|
|
|
# fix_print_with_import
|
2016-09-21 18:24:26 +02:00
|
|
|
print('Unable to execute algorithm\n' + str(msg))
|
2017-04-07 13:38:24 +10:00
|
|
|
QgsMessageLog.logMessage(Processing.tr('Unable to execute algorithm\n{0}').format(msg),
|
|
|
|
Processing.tr("Processing"))
|
2013-02-06 21:00:26 +01:00
|
|
|
return
|
2012-09-15 18:25:25 +03:00
|
|
|
|
2017-04-29 12:14:53 +02:00
|
|
|
if not alg.checkInputCRS(context):
|
2017-03-04 19:41:23 +01:00
|
|
|
print('Warning: Not all input layers use the same CRS.\n' +
|
|
|
|
'This can cause unexpected results.')
|
2017-04-07 13:38:24 +10:00
|
|
|
QgsMessageLog.logMessage(
|
|
|
|
Processing.tr('Warning: Not all input layers use the same CRS.\nThis can cause unexpected results.'),
|
|
|
|
Processing.tr("Processing"))
|
2013-02-07 01:09:39 +01:00
|
|
|
|
2015-08-20 14:30:12 +02:00
|
|
|
# Don't set the wait cursor twice, because then when you
|
|
|
|
# restore it, it will still be a wait cursor.
|
|
|
|
overrideCursor = False
|
2014-10-03 10:35:07 +02:00
|
|
|
if iface is not None:
|
2015-08-22 14:29:41 +02:00
|
|
|
cursor = QApplication.overrideCursor()
|
|
|
|
if cursor is None or cursor == 0:
|
|
|
|
QApplication.setOverrideCursor(QCursor(Qt.WaitCursor))
|
2015-08-14 14:12:01 +02:00
|
|
|
overrideCursor = True
|
2015-08-22 14:29:41 +02:00
|
|
|
elif cursor.shape() != Qt.WaitCursor:
|
|
|
|
QApplication.setOverrideCursor(QCursor(Qt.WaitCursor))
|
2015-08-14 14:12:01 +02:00
|
|
|
overrideCursor = True
|
2012-12-10 00:12:07 +01:00
|
|
|
|
2017-01-06 20:04:00 +10:00
|
|
|
feedback = None
|
|
|
|
if kwargs is not None and "feedback" in list(kwargs.keys()):
|
|
|
|
feedback = kwargs["feedback"]
|
2015-11-10 20:21:10 +00:00
|
|
|
elif iface is not None:
|
2017-03-29 12:51:59 +10:00
|
|
|
feedback = MessageBarProgress(alg.displayName())
|
2015-11-10 20:21:10 +00:00
|
|
|
|
2017-05-15 16:19:46 +10:00
|
|
|
ret = execute(alg, parameters, context, feedback)
|
2015-06-23 08:30:17 +02:00
|
|
|
if ret:
|
|
|
|
if onFinish is not None:
|
2017-04-26 14:33:53 +10:00
|
|
|
onFinish(alg, context, feedback)
|
2015-06-23 08:30:17 +02:00
|
|
|
else:
|
2017-04-07 13:38:24 +10:00
|
|
|
QgsMessageLog.logMessage(Processing.tr("There were errors executing the algorithm."),
|
|
|
|
Processing.tr("Processing"))
|
2014-10-03 10:35:07 +02:00
|
|
|
|
2015-08-20 14:30:12 +02:00
|
|
|
if overrideCursor:
|
2015-08-22 14:29:41 +02:00
|
|
|
QApplication.restoreOverrideCursor()
|
2017-01-06 20:04:00 +10:00
|
|
|
if isinstance(feedback, MessageBarProgress):
|
|
|
|
feedback.close()
|
2012-09-15 18:25:25 +03:00
|
|
|
return alg
|
2014-10-03 14:44:01 +03:00
|
|
|
|
2014-10-09 10:51:50 +03:00
|
|
|
@staticmethod
|
|
|
|
def tr(string, context=''):
|
2014-10-03 14:44:01 +03:00
|
|
|
if context == '':
|
|
|
|
context = 'Processing'
|
2014-10-09 10:51:50 +03:00
|
|
|
return QCoreApplication.translate(context, string)
|