QGIS API Documentation  3.20.0-Odense (decaadbb31)
qgsrunprocess.h
Go to the documentation of this file.
1 /***************************************************************************
2  qgsrunprocess.h
3 
4  A class that runs an external program
5 
6  -------------------
7  begin : Jan 2005
8  copyright : (C) 2005 by Gavin Macaulay
9  email : gavin at macaulay dot co dot nz
10  ***************************************************************************/
11 
12 /***************************************************************************
13  * *
14  * This program is free software; you can redistribute it and/or modify *
15  * it under the terms of the GNU General Public License as published by *
16  * the Free Software Foundation; either version 2 of the License, or *
17  * (at your option) any later version. *
18  * *
19  ***************************************************************************/
20 
21 #ifndef QGSRUNPROCESS_H
22 #define QGSRUNPROCESS_H
23 
24 #include <QObject>
25 #if QT_CONFIG(process)
26 #include <QProcess>
27 #endif
28 
29 #include <QThread>
30 
31 #include "qgis_core.h"
32 #include "qgis_sip.h"
33 
34 class QgsFeedback;
35 class QgsMessageOutput;
36 
47 class CORE_EXPORT QgsRunProcess: public QObject SIP_NODEFAULTCTORS
48 {
49  Q_OBJECT
50 
51  public:
52  // This class deletes itself, so to ensure that it is only created
53  // using new, the Named Constructor Idiom is used, and one needs to
54  // use the create() static function to get an instance of this class.
55 
56  // The action argument contains string with the command.
57  // If capture is true, the standard output and error from the process
58  // will be sent to QgsMessageOutput - usually a dialog box.
59  static QgsRunProcess *create( const QString &action, bool capture ) SIP_FACTORY
60  { return new QgsRunProcess( action, capture ); }
61 
71  static QStringList splitCommand( const QString &command );
72 
73  private:
74  QgsRunProcess( const QString &action, bool capture ) SIP_FORCE;
75  ~QgsRunProcess() override SIP_FORCE;
76 
77 #if QT_CONFIG(process)
78  // Deletes the instance of the class
79  void die();
80 
81  QProcess *mProcess = nullptr;
82  QgsMessageOutput *mOutput = nullptr;
83  QString mCommand;
84 
85  public slots:
86  void stdoutAvailable();
87  void stderrAvailable();
88  void processError( QProcess::ProcessError );
89  void processExit( int, QProcess::ExitStatus );
90  void dialogGone();
91 #endif // !(QT_CONFIG(process)
92 };
93 
94 #if QT_CONFIG(process)
95 
109 class CORE_EXPORT QgsBlockingProcess : public QObject
110 {
111  Q_OBJECT
112 
113  public:
114 
120  QgsBlockingProcess( const QString &program, const QStringList &arguments );
121 
122 #ifndef SIP_RUN
123 
127  void setStdOutHandler( const std::function< void( const QByteArray & ) > &handler ) { mStdoutHandler = handler; }
128 #else
129 
133  void setStdOutHandler( SIP_PYCALLABLE / AllowNone / );
134  % MethodCode
135  Py_BEGIN_ALLOW_THREADS
136 
137  sipCpp->setStdOutHandler( [a0]( const QByteArray &arg )
138  {
139  SIP_BLOCK_THREADS
140  Py_XDECREF( sipCallMethod( NULL, a0, "D", &arg, sipType_QByteArray, NULL ) );
141  SIP_UNBLOCK_THREADS
142  } );
143 
144  Py_END_ALLOW_THREADS
145  % End
146 #endif
147 
148 #ifndef SIP_RUN
149 
153  void setStdErrHandler( const std::function< void( const QByteArray & ) > &handler ) { mStderrHandler = handler; }
154 #else
155 
159  void setStdErrHandler( SIP_PYCALLABLE / AllowNone / );
160  % MethodCode
161  Py_BEGIN_ALLOW_THREADS
162 
163  sipCpp->setStdErrHandler( [a0]( const QByteArray &arg )
164  {
165  SIP_BLOCK_THREADS
166  Py_XDECREF( sipCallMethod( NULL, a0, "D", &arg, sipType_QByteArray, NULL ) );
167  SIP_UNBLOCK_THREADS
168  } );
169 
170  Py_END_ALLOW_THREADS
171  % End
172 #endif
173 
181  int run( QgsFeedback *feedback = nullptr );
182 
186  QProcess::ExitStatus exitStatus() const;
187 
193  QProcess::ProcessError processError() const;
194 
195  private:
196 
197  QString mProcess;
198  QStringList mArguments;
199  std::function< void( const QByteArray & ) > mStdoutHandler;
200  std::function< void( const QByteArray & ) > mStderrHandler;
201 
202  QProcess::ExitStatus mExitStatus = QProcess::NormalExit;
203  QProcess::ProcessError mProcessError = QProcess::UnknownError;
204 };
205 
206 #endif // QT_CONFIG(process)
207 
209 #ifndef SIP_RUN
210 
211 class ProcessThread : public QThread
212 {
213  Q_OBJECT
214 
215  public:
216  ProcessThread( const std::function<void()> &function, QObject *parent = nullptr )
217  : QThread( parent )
218  , mFunction( function )
219  {
220  }
221 
222  void run() override
223  {
224  mFunction();
225  }
226 
227  private:
228  std::function<void()> mFunction;
229 };
230 
231 #endif
233 
234 
235 #endif
Base class for feedback objects to be used for cancellation of something running in a worker thread.
Definition: qgsfeedback.h:45
Interface for showing messages from QGIS in GUI independent way.
A class that executes an external program/script.
Definition: qgsrunprocess.h:48
static QgsRunProcess * create(const QString &action, bool capture)
Definition: qgsrunprocess.h:59
#define SIP_FORCE
Definition: qgis_sip.h:131
#define SIP_FACTORY
Definition: qgis_sip.h:76
#define SIP_NODEFAULTCTORS
Definition: qgis_sip.h:101