Unsolved how to pipe qprocess' stdout to father process as stdin
-
@JNBarchan said in how to pipe qprocess' stdout to father process as stdin:
@jsulm
I still don't understand the question/objective, you seem to more then I do. Does "father process" mean "self process"? The way you phrase it, do you/OP mean "pipe a process's own stdout to its own stdin"?? Can you explain "clearly", then I might understand?I'm so sorry for my poor description, I'm not a native English speaker so I make some mistakes in jargon. And I think that "father process" means "self process".
-
@Isolde
It's not your fault, you do your best, especially if English not your first language!For processes, we talk about parent process and child process. We just don't say father!
My last post above offers you the (only( two ways I know to achieve what you are asking for. If you can afford to you the first "send-to-file" approach that at least will work and is too much code....!
-
@JNBarchan said in how to pipe qprocess' stdout to father process as stdin:
@Isolde
It's not your fault, you do your best, especially if English not your first language!For processes, we talk about parent process and child process. We just don't say father!
My last post above offers you the (only( two ways I know to achieve what you are asking for. If you can afford to you the first "send-to-file" approach that at least will work and is too much code....!
I think it's a little bit different from what I want. I want to pipe a child QProcess' stdout to parent process' stdin. This question could be that how can I pass a QProcess instance for my own process to the
setStandardOutputProcess
method? -
I think it's a little bit different from what I want. I want to pipe a child QProcess' stdout to parent process' stdin
Darn, I wish I had understood that was what you wanted at the outset!
This question could be that how can I pass a QProcess instance for my own process to the setStandardOutputProcess method?
Like @jsulm wrote in an earlier post above, Qt does not offer that (AFAIK).
You normally accomplish this via
QProcess::readAllStandardOutput()
from the parent --- or you can receive signalQProcess::readyReadStandardOutput()
--- but I don't know how easy/possible to connect that to parent's stdin, one usually just uses the resulting data without that. That's what I'm doing at the moment in my own code. -
@JNBarchan said in how to pipe qprocess' stdout to father process as stdin:
-- but I don't know how easy/possible to connect that to parent's stdin, one usually just uses the resulting data without that. That's what I'm doing at the moment in my own code.
I know this way, but my situation looks complex, because the library(libmpv) that I used only provides very high level api that only support passing option key-value pairs, so I can only passing a filename string or "-" means stdin. And unfortunately, the data source I need is provide by another program(streamlink), it support stdout. Up to now, I'm using
streamlink -O | my-qt-program
to make it work. But I don't deem it a best way. So I want to start streamlink inside my program and pipe its stdout into my-qt-program's stdin. Is it possible? -
@Isolde If you want to start external program and read its output you can do it very easily using http://doc.qt.io/qt-5/qprocess.html#readyReadStandardOutput and http://doc.qt.io/qt-5/qprocess.html#readAllStandardOutput
You do not need setStandardOutputProcess for that at all. -
@jsulm My situation is a little complex, I explained in the last reply.
-
@Isolde "So I want to start streamlink inside my program and pipe its stdout into my-qt-program's stdin" - why do you want to pipe it into your stdin instead of simply reading its output like I suggested?
-
@jsulm Because libmpv only support passing filename string or "-" that means read from stdin...
-
@Isolde said in how to pipe qprocess' stdout to father process as stdin:
So I want to start streamlink inside my program and pipe its stdout into my-qt-program's stdin. Is it possible?
That's why I wrote earlier "but I don't know how easy/possible to connect that to parent's stdin". Neither I nor seemingly @jsulm know how to change a running Qt program's stdin.
You may safely assume that the
QProcess
approach is not going to work in the running parent program. One can guess that this refers to only a "sub-process", not the current process. I know what sort of code they will have written for the redirection, and they will be offering it only as they start a sub-process. What you need is a "redirect current stdin" call, and I don't see Qt offering that.If you are Linux only, I can tell you how to do it in C, which will presumably be reflected in C++, or you could look that up. I think it will "work" in that Qt's stdin will reflect the change, but you would not be doing the redirection or the sub-process spawning as Qt calls. Which may not be attractive.
Alternatively you can write simple shell scripts as a "wrapper" when launching your Qt application. You could even write another small Qt application to invoke your current Qt application in the right way if you prefer!
-
Hi,
As already suggested, you can use QProcess and its channels communication API to process the output of mpv within your application. From the looks of it, there's no need for piping anything.
-
@SGaist But what I want is to input data into libmpv...
-
@JNBarchan Thank you for your patient help, I'll write a shell script to wrap them.
-
@Isolde
I do think if you can manage with that it will be a lot simpler than trying to do it from Qt.Now that I have understood your objective, I will say that there is nothing wrong about it as a desired facility in Qt. However, so far as I can see (and I have Googled a lot) Qt does not offer any means of redirecting a parent process's (not
QProcess
) own stdin/stdout/stderr from/to a piped child process, and that is actually a lacking feature in its otherwise comprehensive library. -
@JNBarchan I found a workaround.
Now I usingQProcess
'sstartDetached()
likeQProcess* restart; restart = new QProcess; restart->startDetached("bash -c \"streamlink -O | my-qt-program \""); exit(0);
It works well!
-
@Isolde
Yes, you mean, you have written that as a second Qt application which does this to invoke your original Qt application, instead of a script file. Which is what we were suggesting :) [EDIT: Or, do you mean you actually do this from within your original "my-qt-program"?] -
@JNBarchan said in how to pipe qprocess' stdout to father process as stdin:
Or, do you mean you actually do this from within your original "my-qt-program
That would be an endless loop :-)
-
@JNBarchan said in how to pipe qprocess' stdout to father process as stdin:
is
Not quite. I just add a simple if statement that determine whether to execute this restart code like
if(QCoreApplication::arguments().at(1) != "bypass-parser") { QProcess* restart; restart = new QProcess; restart->startDetached("bash -c \"streamlink " + parser.value(urlOption) + " " + parser.value(streamOption) + " -O | " + QCoreApplication::applicationFilePath() + " bypass-parser " + parser.value(urlOption) + "\""); exit(0); }
-
@jsulm I'm sorry. They are not the whole codes, I post them completely in the last reply.
-
@Isolde You should not exit a Qt app like this, use http://doc.qt.io/qt-5/qcoreapplication.html#exit instead. Also there is no need to allocate QProcess on the heap. And in this particular case there is even no need for a QProcess instance at all as startDetached is static:
if(QCoreApplication::arguments().at(1) != "bypass-parser") { QProcess::startDetached("bash -c \"streamlink " + parser.value(urlOption) + " " + parser.value(streamOption) + " -O | " + QCoreApplication::applicationFilePath() + " bypass-parser " + parser.value(urlOption) + "\""); QCoreApplication::exit(0); }