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.
  • 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 Online
      jsulmJ Online
      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 Online
          jsulmJ Online
          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 Offline
            J.HilkJ Offline
            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 Offline
                J.HilkJ Offline
                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 Online
                    jsulmJ Online
                    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 Online
                            jsulmJ Online
                            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
                                      • SPlattenS SPlatten

                                        @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.

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

                                        @SPlatten
                                        You have been changing: with the code you now display in this latest post, can you show how you start the sub-process, please paste the line.

                                        SPlattenS 1 Reply Last reply
                                        0
                                        • JonBJ JonB

                                          @SPlatten
                                          You have been changing: with the code you now display in this latest post, can you show how you start the sub-process, please paste the line.

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

                                          @JonB , the actual 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;
                                          }
                                          

                                          The call itself:

                                          std::string strPort = std::to_string(clsMainWnd::intGetServerPort());
                                          const char* cpszPort = strPort.data();
                                          QString strFullPath(strModulesPath + strModule.toString());
                                          QStringList slstArgs;
                                          qint64 int64PID;
                                          slstArgs << cpszPort;                                           //RX port
                                          slstArgs << QString::number(clsSocketThread::uint16NextPort()); //TX port
                                          
                                          if ( clsMainWnd::blnLaunch(strFullPath, slstArgs, int64PID) == true ) {
                                          

                                          This is all working and the process is started I can see that because when the application starts it creates a log file:

                                          -rw-r--r--  1 simonplatten  staff   201 21 Oct 17:33 mdFileIO20201021.001
                                          

                                          And this is its content:

                                          D00000000000000000001:mdFileIO Version: 1.00
                                          D00000000000000000002:Setting up socket on ip: 127.0.0.1, port: 8124
                                          D00000000000000000003:Setting up socket on ip: 127.0.0.1, port: 8123, for heartbeat
                                          

                                          Then it dies...

                                          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