Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. General and Desktop
  4. Process and child process
Forum Updated to NodeBB v4.3 + New Features

Process and child process

Scheduled Pinned Locked Moved Solved General and Desktop
35 Posts 4 Posters 6.2k Views 2 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • SPlattenS SPlatten

    @jsulm To be honest, probably because the example I came across for QProcess was using it. What I want is to launch the child process and allow the launching process to carry on without being held up.

    jsulmJ Offline
    jsulmJ Offline
    jsulm
    Lifetime Qt Champion
    wrote on last edited by
    #10

    @SPlatten Usually you would only use startDetached if the second process needs to continue if the parent process terminates. If this is not a requirement for your app then simply use start(...).

    https://forum.qt.io/topic/113070/qt-code-of-conduct

    1 Reply Last reply
    2
    • SPlattenS SPlatten

      @jsulm To be honest, probably because the example I came across for QProcess was using it. What I want is to launch the child process and allow the launching process to carry on without being held up.

      JonBJ Offline
      JonBJ Offline
      JonB
      wrote on last edited by
      #11

      @SPlatten said in Process and child process:

      What I want is to launch the child process and allow the launching process to carry on without being held up.

      That happens without startDetached(), QProcess runs asynchronously. You only need startDetached basically if you want to sub-process not to e.g. get terminated when your process exits.

      SPlattenS 1 Reply Last reply
      1
      • JonBJ JonB

        @SPlatten said in Process and child process:

        What I want is to launch the child process and allow the launching process to carry on without being held up.

        That happens without startDetached(), QProcess runs asynchronously. You only need startDetached basically if you want to sub-process not to e.g. get terminated when your process exits.

        SPlattenS Offline
        SPlattenS Offline
        SPlatten
        wrote on last edited by SPlatten
        #12

        @JonB , @jsulm , also startDetached() obtains the PID where as start does not.

        Why does startDetached take a qint64 for the PID as the last parameter but the QProcess function pid returns not a qint64 but a Q_PID?

        Why are these different types?

        Kind Regards,
        Sy

        jsulmJ JonBJ 2 Replies Last reply
        0
        • SPlattenS SPlatten

          @JonB , @jsulm , also startDetached() obtains the PID where as start does not.

          Why does startDetached take a qint64 for the PID as the last parameter but the QProcess function pid returns not a qint64 but a Q_PID?

          Why are these different types?

          jsulmJ Offline
          jsulmJ Offline
          jsulm
          Lifetime Qt Champion
          wrote on last edited by
          #13

          @SPlatten Do you really need the PID? In the code you posted you only check and print it out.

          https://forum.qt.io/topic/113070/qt-code-of-conduct

          1 Reply Last reply
          0
          • SPlattenS Offline
            SPlattenS Offline
            SPlatten
            wrote on last edited by
            #14

            @jsulm , I get the PID so I can verify its actually running since neither start or startDetached return anything.

            Kind Regards,
            Sy

            jsulmJ J.HilkJ JonBJ 3 Replies Last reply
            0
            • SPlattenS SPlatten

              @jsulm , I get the PID so I can verify its actually running since neither start or startDetached return anything.

              jsulmJ Offline
              jsulmJ Offline
              jsulm
              Lifetime Qt Champion
              wrote on last edited by jsulm
              #15

              @SPlatten See https://doc.qt.io/qt-5/qprocess.html#state
              And check https://doc.qt.io/qt-5/qprocess.html#start

              https://forum.qt.io/topic/113070/qt-code-of-conduct

              1 Reply Last reply
              3
              • SPlattenS SPlatten

                @jsulm , I get the PID so I can verify its actually running since neither start or startDetached return anything.

                J.HilkJ Online
                J.HilkJ Online
                J.Hilk
                Moderators
                wrote on last edited by
                #16

                @SPlatten said in Process and child process:

                @jsulm , I get the PID so I can verify its actually running since neither start or startDetached return anything.

                well, Process has the started and stateChanged signal for that.
                https://doc.qt.io/qt-5/qprocess.html#started

                you should actually listen to the stateChanged signal, to see if it changes from Running to NotRunning


                Be aware of the Qt Code of Conduct, when posting : https://forum.qt.io/topic/113070/qt-code-of-conduct


                Q: What's that?
                A: It's blue light.
                Q: What does it do?
                A: It turns blue.

                1 Reply Last reply
                3
                • SPlattenS SPlatten

                  @jsulm , I get the PID so I can verify its actually running since neither start or startDetached return anything.

                  JonBJ Offline
                  JonBJ Offline
                  JonB
                  wrote on last edited by JonB
                  #17

                  @SPlatten
                  You have other things you can look at instead, like QProcess::stateChanged signal for clues.

                  While you get it working, you may find start() is easier to work with than startDetached().

                  EDIT Sigh, looks like 3 of us are all trying to answer :)

                  If it's not secret, you might like to share with us the full command you are running, including the arguments, in case we can spot anything for you....

                  SPlattenS 2 Replies Last reply
                  3
                  • J.HilkJ Online
                    J.HilkJ Online
                    J.Hilk
                    Moderators
                    wrote on last edited by J.Hilk
                    #18

                    3 People 3 times the same thought

                    Up Top🙌


                    Be aware of the Qt Code of Conduct, when posting : https://forum.qt.io/topic/113070/qt-code-of-conduct


                    Q: What's that?
                    A: It's blue light.
                    Q: What does it do?
                    A: It turns blue.

                    1 Reply Last reply
                    1
                    • JonBJ JonB

                      @SPlatten
                      You have other things you can look at instead, like QProcess::stateChanged signal for clues.

                      While you get it working, you may find start() is easier to work with than startDetached().

                      EDIT Sigh, looks like 3 of us are all trying to answer :)

                      If it's not secret, you might like to share with us the full command you are running, including the arguments, in case we can spot anything for you....

                      SPlattenS Offline
                      SPlattenS Offline
                      SPlatten
                      wrote on last edited by
                      #19

                      @JonB I just tried start and it didn't work, I got errors in the Application Output:

                      QObject: Cannot create children for a parent that is in a different thread.
                      (Parent is QProcess(0x101e0b420), parent's thread is QThread(0x101e0b880), current thread is clsThread(0x122c1bcc0)
                      

                      Kind Regards,
                      Sy

                      jsulmJ JonBJ 2 Replies Last reply
                      0
                      • SPlattenS SPlatten

                        @JonB I just tried start and it didn't work, I got errors in the Application Output:

                        QObject: Cannot create children for a parent that is in a different thread.
                        (Parent is QProcess(0x101e0b420), parent's thread is QThread(0x101e0b880), current thread is clsThread(0x122c1bcc0)
                        
                        jsulmJ Offline
                        jsulmJ Offline
                        jsulm
                        Lifetime Qt Champion
                        wrote on last edited by
                        #20

                        @SPlatten Do you use threads?

                        https://forum.qt.io/topic/113070/qt-code-of-conduct

                        1 Reply Last reply
                        1
                        • SPlattenS SPlatten

                          @JonB , @jsulm , also startDetached() obtains the PID where as start does not.

                          Why does startDetached take a qint64 for the PID as the last parameter but the QProcess function pid returns not a qint64 but a Q_PID?

                          Why are these different types?

                          JonBJ Offline
                          JonBJ Offline
                          JonB
                          wrote on last edited by
                          #21

                          @SPlatten said in Process and child process:

                          Why does startDetached take a qint64 for the PID as the last parameter but the QProcess function pid returns not a qint64 but a Q_PID?
                          Why are these different types?

                          Don't use Q_PID for this (Windows). Use qint64 QProcess::processId() const.

                          1 Reply Last reply
                          0
                          • SPlattenS SPlatten

                            @JonB I just tried start and it didn't work, I got errors in the Application Output:

                            QObject: Cannot create children for a parent that is in a different thread.
                            (Parent is QProcess(0x101e0b420), parent's thread is QThread(0x101e0b880), current thread is clsThread(0x122c1bcc0)
                            
                            JonBJ Offline
                            JonBJ Offline
                            JonB
                            wrote on last edited by
                            #22

                            @SPlatten said in Process and child process:

                            QObject: Cannot create children for a parent that is in a different thread.

                            That would explain a lot...! :)

                            SPlattenS 1 Reply Last reply
                            0
                            • JonBJ JonB

                              @SPlatten said in Process and child process:

                              QObject: Cannot create children for a parent that is in a different thread.

                              That would explain a lot...! :)

                              SPlattenS Offline
                              SPlattenS Offline
                              SPlatten
                              wrote on last edited by
                              #23

                              @JonB, I think I said from the start these are two different processes, not threads in the same process.

                              Kind Regards,
                              Sy

                              jsulmJ 1 Reply Last reply
                              0
                              • SPlattenS SPlatten

                                @JonB, I think I said from the start these are two different processes, not threads in the same process.

                                jsulmJ Offline
                                jsulmJ Offline
                                jsulm
                                Lifetime Qt Champion
                                wrote on last edited by
                                #24

                                @SPlatten said in Process and child process:

                                I think I said from the start these are two different processes

                                This is clear.
                                I asked because the warning you posted comes when using threads.

                                https://forum.qt.io/topic/113070/qt-code-of-conduct

                                1 Reply Last reply
                                0
                                • JonBJ JonB

                                  @SPlatten
                                  You have other things you can look at instead, like QProcess::stateChanged signal for clues.

                                  While you get it working, you may find start() is easier to work with than startDetached().

                                  EDIT Sigh, looks like 3 of us are all trying to answer :)

                                  If it's not secret, you might like to share with us the full command you are running, including the arguments, in case we can spot anything for you....

                                  SPlattenS Offline
                                  SPlattenS Offline
                                  SPlatten
                                  wrote on last edited by
                                  #25

                                  @JonB I tried start and it didn't work at all, so I'm back to startDetached which does launch the application and I can see it creates a log file then disappears.

                                  Kind Regards,
                                  Sy

                                  SPlattenS 1 Reply Last reply
                                  0
                                  • SPlattenS SPlatten

                                    @JonB I tried start and it didn't work at all, so I'm back to startDetached which does launch the application and I can see it creates a log file then disappears.

                                    SPlattenS Offline
                                    SPlattenS Offline
                                    SPlatten
                                    wrote on last edited by
                                    #26

                                    @J-Hilk , @JonB , @jsulm, I've modified the function:

                                    bool clsMainWnd::blnLaunch(QString strApp, QStringList& slstArgs, qint64& int64PID) {
                                        Q_ASSERT_X(clsMainWnd::mspobjProcess!=nullptr, "blnLaunch", "mspobjProcess is null!");
                                        QString strFullPath(clsDebugService::strGetUserFolder(strApp));
                                        int64PID = 0;    
                                        qdbg() << "Checking for PID for: " << strFullPath;
                                        if ( blnGetPID(strFullPath, int64PID) == true ) {
                                        //Process already running, no action required
                                        } else {
                                            int intLastSep = strFullPath.lastIndexOf(QDir::separator());
                                    
                                            if ( intLastSep > 0 ) {
                                                QString strName = strFullPath.mid(intLastSep + 1)
                                                       ,strPath = strFullPath.mid(0, intLastSep + 1);
                                                qdbg() << "Launching: " << strFullPath;
                                                clsMainWnd::mspobjProcess->setArguments(slstArgs);
                                                clsMainWnd::mspobjProcess->setWorkingDirectory(strPath);
                                                clsMainWnd::mspobjProcess->setProgram(strName);
                                                clsMainWnd::mspobjProcess->startDetached(&int64PID);
                                            }
                                        }    
                                        if ( int64PID > 0 ) {
                                            qdbg() << "Process: " << strFullPath << ", is running PID: " << QString::number(int64PID);
                                            return true;
                                        }
                                        return false;
                                    }
                                    

                                    I can see that a valid PID is returned and that the log files are created, but when I check for the process:

                                    ps -A
                                    

                                    The PID isn't present.

                                    Kind Regards,
                                    Sy

                                    JonBJ 1 Reply Last reply
                                    0
                                    • SPlattenS SPlatten

                                      @J-Hilk , @JonB , @jsulm, I've modified the function:

                                      bool clsMainWnd::blnLaunch(QString strApp, QStringList& slstArgs, qint64& int64PID) {
                                          Q_ASSERT_X(clsMainWnd::mspobjProcess!=nullptr, "blnLaunch", "mspobjProcess is null!");
                                          QString strFullPath(clsDebugService::strGetUserFolder(strApp));
                                          int64PID = 0;    
                                          qdbg() << "Checking for PID for: " << strFullPath;
                                          if ( blnGetPID(strFullPath, int64PID) == true ) {
                                          //Process already running, no action required
                                          } else {
                                              int intLastSep = strFullPath.lastIndexOf(QDir::separator());
                                      
                                              if ( intLastSep > 0 ) {
                                                  QString strName = strFullPath.mid(intLastSep + 1)
                                                         ,strPath = strFullPath.mid(0, intLastSep + 1);
                                                  qdbg() << "Launching: " << strFullPath;
                                                  clsMainWnd::mspobjProcess->setArguments(slstArgs);
                                                  clsMainWnd::mspobjProcess->setWorkingDirectory(strPath);
                                                  clsMainWnd::mspobjProcess->setProgram(strName);
                                                  clsMainWnd::mspobjProcess->startDetached(&int64PID);
                                              }
                                          }    
                                          if ( int64PID > 0 ) {
                                              qdbg() << "Process: " << strFullPath << ", is running PID: " << QString::number(int64PID);
                                              return true;
                                          }
                                          return false;
                                      }
                                      

                                      I can see that a valid PID is returned and that the log files are created, but when I check for the process:

                                      ps -A
                                      

                                      The PID isn't present.

                                      JonBJ Offline
                                      JonBJ Offline
                                      JonB
                                      wrote on last edited by JonB
                                      #27

                                      @SPlatten
                                      As we said before, if you want help on this you really need to put in more debugging information calls. Like slots for errorOccurred, finished, started, stateChanged, and reading of anything appearing on stdout/stderr, e.g. via readyReadStandardError/Output. And there is the exitCode(). Sorry, but that's how it is. I also offered to look for clues if you wanted to tell us the program you are executing and what arguments you pass , but you didn't reply yea or nay.

                                      And btw you have something fishy going on if you can run this command via startDetached() but not via start().

                                      And one other thing: the fact that you can't find the pid in itself proves nothing. It might be running fine. Processes can spawn sub-processes and exit.

                                      SPlattenS 1 Reply Last reply
                                      1
                                      • JonBJ JonB

                                        @SPlatten
                                        As we said before, if you want help on this you really need to put in more debugging information calls. Like slots for errorOccurred, finished, started, stateChanged, and reading of anything appearing on stdout/stderr, e.g. via readyReadStandardError/Output. And there is the exitCode(). Sorry, but that's how it is. I also offered to look for clues if you wanted to tell us the program you are executing and what arguments you pass , but you didn't reply yea or nay.

                                        And btw you have something fishy going on if you can run this command via startDetached() but not via start().

                                        And one other thing: the fact that you can't find the pid in itself proves nothing. It might be running fine. Processes can spawn sub-processes and exit.

                                        SPlattenS Offline
                                        SPlattenS Offline
                                        SPlatten
                                        wrote on last edited by
                                        #28

                                        @JonB, I'll give it a go now.

                                        Kind Regards,
                                        Sy

                                        1 Reply Last reply
                                        0
                                        • SPlattenS Offline
                                          SPlattenS Offline
                                          SPlatten
                                          wrote on last edited by SPlatten
                                          #29

                                          @JonB , I've connected up slots to the following signals:

                                          connect(clsMainWnd::mspobjProcess, &QProcess::errorOccurred, this, &clsMainWnd::qprocErrorOccurred);
                                          connect(clsMainWnd::mspobjProcess, &QProcess::started, this, &clsMainWnd::qprocStarted);
                                          connect(clsMainWnd::mspobjProcess, &QProcess::stateChanged, this, &clsMainWnd::qprocStateChanged);
                                          

                                          The implementation:

                                          void clsMainWnd::qprocErrorOccurred(QProcess::ProcessError error) {
                                             qdbg() << "QProcess errorOccurred:" << error;
                                          }
                                          void clsMainWnd::qprocStarted() {
                                              qdbg() << "QProcess started";
                                          }
                                          void clsMainWnd::qprocStateChanged(QProcess::ProcessState newState) {
                                              qdbg() << "QProcess stateChanged, newState:" << newState;
                                          }
                                          

                                          I also put breakpoints in each slot, none of these got triggered. I'm not surprised though because I'm not suggesting the problem is with QProcess. I'm just trying to find out why the process when started this way is terminating where as if I launch it in Qt Creator it continues to run.

                                          I would have though the "started" and "stateChanged" signals would get raised, but I don't get anything.

                                          Kind Regards,
                                          Sy

                                          JonBJ 1 Reply Last reply
                                          0

                                          • Login

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Categories
                                          • Recent
                                          • Tags
                                          • Popular
                                          • Users
                                          • Groups
                                          • Search
                                          • Get Qt Extensions
                                          • Unsolved