1 | /* smplayer, GUI front-end for mplayer.
|
---|
2 | Copyright (C) 2006-2017 Ricardo Villalba <rvm@users.sourceforge.net>
|
---|
3 |
|
---|
4 | This program is free software; you can redistribute it and/or modify
|
---|
5 | it under the terms of the GNU General Public License as published by
|
---|
6 | the Free Software Foundation; either version 2 of the License, or
|
---|
7 | (at your option) any later version.
|
---|
8 |
|
---|
9 | This program is distributed in the hope that it will be useful,
|
---|
10 | but WITHOUT ANY WARRANTY; without even the implied warranty of
|
---|
11 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
---|
12 | GNU General Public License for more details.
|
---|
13 |
|
---|
14 | You should have received a copy of the GNU General Public License
|
---|
15 | along with this program; if not, write to the Free Software
|
---|
16 | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
---|
17 | */
|
---|
18 |
|
---|
19 | #ifndef MY_PROCESS_H
|
---|
20 | #define MY_PROCESS_H
|
---|
21 |
|
---|
22 | #include <QProcess>
|
---|
23 | #include <QTemporaryFile>
|
---|
24 | #include <QTimer>
|
---|
25 |
|
---|
26 | //! MyProcess is a specialized QProcess designed to properly work with mplayer.
|
---|
27 |
|
---|
28 | /*!
|
---|
29 | It can split the mplayer status line into lines.
|
---|
30 | It also provides some Qt 3 like functions like addArgument().
|
---|
31 |
|
---|
32 | There are two working modes, controlled by the USE_TEMP_FILE define.
|
---|
33 | If USE_TEMP_FILE is 1 it will send the output of mplayer to a temporary
|
---|
34 | file, and then it will be read from it. Otherwise it will read from
|
---|
35 | standard ouput as usual.
|
---|
36 | */
|
---|
37 |
|
---|
38 | class MyProcess : public QProcess
|
---|
39 | {
|
---|
40 | Q_OBJECT
|
---|
41 |
|
---|
42 | public:
|
---|
43 | MyProcess ( QObject * parent = 0 );
|
---|
44 |
|
---|
45 | virtual void setExecutable(const QString & p) { program = p; };
|
---|
46 | QString executable() { return program; };
|
---|
47 |
|
---|
48 | virtual void addArgument(const QString & a); //!< Add an argument
|
---|
49 |
|
---|
50 | void clearArguments(); //!< Clear the list of arguments
|
---|
51 | QStringList arguments(); //!< Return the list of arguments
|
---|
52 |
|
---|
53 | void start(); //!< Start the process
|
---|
54 | bool isRunning(); //!< Return true if the process is running
|
---|
55 |
|
---|
56 | static QStringList splitArguments(const QString & args);
|
---|
57 |
|
---|
58 | signals:
|
---|
59 | //! Emitted when there's a line available
|
---|
60 | void lineAvailable(QByteArray ba);
|
---|
61 |
|
---|
62 | protected slots:
|
---|
63 | void readStdOut(); //!< Called for reading from standard output
|
---|
64 | void readTmpFile(); //!< Called for reading from the temp file
|
---|
65 | void procFinished(); //!< Called when the process has finished
|
---|
66 |
|
---|
67 | protected:
|
---|
68 | //! Return true if it's possible to read an entire line.
|
---|
69 | /*! @param from specifies the position to begin. */
|
---|
70 | int canReadLine(const QByteArray & ba, int from = 0);
|
---|
71 | //! Called from readStdOut() and readTmpFile() to do all the work
|
---|
72 | void genericRead(QByteArray buffer);
|
---|
73 |
|
---|
74 | protected:
|
---|
75 | QString program;
|
---|
76 | QStringList arg;
|
---|
77 |
|
---|
78 | QByteArray remaining_output;
|
---|
79 |
|
---|
80 | QTemporaryFile temp_file;
|
---|
81 | QTimer timer;
|
---|
82 | };
|
---|
83 |
|
---|
84 | #endif
|
---|