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. Example of calling a function to parent?
Forum Updated to NodeBB v4.3 + New Features

Example of calling a function to parent?

Scheduled Pinned Locked Moved Unsolved General and Desktop
38 Posts 5 Posters 4.8k 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.
  • P Offline
    P Offline
    Panoss
    wrote on last edited by Panoss
    #20

    Why is this wrong?
    Every time I want to open the form I create an instance of it 's class.
    When I close the form the instance is destroyed, right?

    What 's the correct way?

    M jsulmJ JonBJ 3 Replies Last reply
    0
    • P Panoss

      Why is this wrong?
      Every time I want to open the form I create an instance of it 's class.
      When I close the form the instance is destroyed, right?

      What 's the correct way?

      M Offline
      M Offline
      mpergand
      wrote on last edited by mpergand
      #21

      @Panoss
      Add sender() and look if it's different objects
      qDebug() << "ArticlesWindow::positionChanged"<<sender();

      P 1 Reply Last reply
      0
      • P Panoss

        Why is this wrong?
        Every time I want to open the form I create an instance of it 's class.
        When I close the form the instance is destroyed, right?

        What 's the correct way?

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

        @Panoss said in Example of calling a function to parent?:

        Every time I want to open the form I create an instance of it 's class.

        Do you also delete the instance when you do not need it anymore?

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

        M P 2 Replies Last reply
        1
        • jsulmJ jsulm

          @Panoss said in Example of calling a function to parent?:

          Every time I want to open the form I create an instance of it 's class.

          Do you also delete the instance when you do not need it anymore?

          M Offline
          M Offline
          mpergand
          wrote on last edited by mpergand
          #23

          @jsulm said in Example of calling a function to parent?:

          @Panoss said in Example of calling a function to parent?:

          Every time I want to open the form I create an instance of it 's class.

          Do you also delete the instance when you do not need it anymore?

          That's what @Panoss should find out for himself by looking at the sender() on multiple messages.

          1 Reply Last reply
          0
          • M mpergand

            @Panoss
            Add sender() and look if it's different objects
            qDebug() << "ArticlesWindow::positionChanged"<<sender();

            P Offline
            P Offline
            Panoss
            wrote on last edited by
            #24

            @mpergand said in Example of calling a function to parent?:

            @Panoss
            Add sender() and look if it's different objects
            qDebug() << "ArticlesWindow::positionChanged"<<sender();

            This is the output:

            updateParent called!!
            ArticlesWindow::positionChanged positionsForm(0x5de4a24160, name = "positionsForm")
            updateParent called!!
            ArticlesWindow::positionChanged positionsForm(0x5de4a24160, name = "positionsForm")
            
            1 Reply Last reply
            0
            • P Panoss

              Why is this wrong?
              Every time I want to open the form I create an instance of it 's class.
              When I close the form the instance is destroyed, right?

              What 's the correct way?

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

              @Panoss said in Example of calling a function to parent?:

              When I close the form the instance is destroyed, right?

              No, that depends on what you mean/do by "close". And we don't see that in your shown code?

              It works but the message is printed twice, like if function ArticlesWindow::positionChanged is called twice??

              Does the "twice" happen from the very first time you create the form or after a second open? Are the number calls equal to the number of times you create the form? If it stays at "twice" always, that alters what i would look for in the code.

              P 1 Reply Last reply
              1
              • jsulmJ jsulm

                @Panoss said in Example of calling a function to parent?:

                Every time I want to open the form I create an instance of it 's class.

                Do you also delete the instance when you do not need it anymore?

                P Offline
                P Offline
                Panoss
                wrote on last edited by
                #26

                @jsulm said in Example of calling a function to parent?:

                @Panoss said in Example of calling a function to parent?:

                Every time I want to open the form I create an instance of it 's class.

                Do you also delete the instance when you do not need it anymore?

                When I close the form instance (clicking on the close button or with form->close) doesn't it get deleted?

                e.g. with this code:

                void addArticle::on_cancelButton_clicked()
                {
                    this->close();
                }
                
                JonBJ 1 Reply Last reply
                0
                • P Panoss

                  @jsulm said in Example of calling a function to parent?:

                  @Panoss said in Example of calling a function to parent?:

                  Every time I want to open the form I create an instance of it 's class.

                  Do you also delete the instance when you do not need it anymore?

                  When I close the form instance (clicking on the close button or with form->close) doesn't it get deleted?

                  e.g. with this code:

                  void addArticle::on_cancelButton_clicked()
                  {
                      this->close();
                  }
                  
                  JonBJ Offline
                  JonBJ Offline
                  JonB
                  wrote on last edited by JonB
                  #27

                  @Panoss
                  Only if you have the "delete on close" attribute set on the window, I can't recall right now its name. [UPDATE: Qt::WA_DeleteOnClose].

                  But I would know (I think) if you answered:

                  Does the "twice" happen from the very first time you create the form or after a second open? Are the number calls equal to the number of times you create the form? If it stays at "twice" always, that alters what i would look for in the code.

                  which is why I asked that.....

                  1 Reply Last reply
                  2
                  • JonBJ JonB

                    @Panoss said in Example of calling a function to parent?:

                    When I close the form the instance is destroyed, right?

                    No, that depends on what you mean/do by "close". And we don't see that in your shown code?

                    It works but the message is printed twice, like if function ArticlesWindow::positionChanged is called twice??

                    Does the "twice" happen from the very first time you create the form or after a second open? Are the number calls equal to the number of times you create the form? If it stays at "twice" always, that alters what i would look for in the code.

                    P Offline
                    P Offline
                    Panoss
                    wrote on last edited by Panoss
                    #28

                    @JonB said in Example of calling a function to parent?:

                    @Panoss said in Example of calling a function to parent?:

                    When I close the form the instance is destroyed, right?

                    No, that depends on what you mean/do by "close". And we don't see that in your shown code?

                    It works but the message is printed twice, like if function ArticlesWindow::positionChanged is called twice??

                    Does the "twice" happen from the very first time you create the form or after a second open?

                    From the very first.

                    @JonB said in Example of calling a function to parent?:
                    Are the number calls equal to the number of times you create the form? If it stays at "twice" always, that alters what i would look for in the code.

                    You mean number of calls to the function?
                    I only call it once. Now, why it acts like if I call it twice, I have no idea!!

                    JonBJ 1 Reply Last reply
                    0
                    • P Panoss

                      @JonB said in Example of calling a function to parent?:

                      @Panoss said in Example of calling a function to parent?:

                      When I close the form the instance is destroyed, right?

                      No, that depends on what you mean/do by "close". And we don't see that in your shown code?

                      It works but the message is printed twice, like if function ArticlesWindow::positionChanged is called twice??

                      Does the "twice" happen from the very first time you create the form or after a second open?

                      From the very first.

                      @JonB said in Example of calling a function to parent?:
                      Are the number calls equal to the number of times you create the form? If it stays at "twice" always, that alters what i would look for in the code.

                      You mean number of calls to the function?
                      I only call it once. Now, why it acts like if I call it twice, I have no idea!!

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

                      @Panoss
                      Your ArticlesWindow::openPositionsForm() goes class positionsForm *form = new class positionsForm(model, this);. I want to know how many times you call openPositionsForm(), I believe you create each time you do something like click on something. I want to know whether the number of times you call openPositionsForm() (number of times you click to open it??) is or is not equal to the number of times you report

                      updateParent called!!
                      ArticlesWindow::positionChanged positionsForm(0x5de4a24160, name = "positionsForm")
                      

                      gets output. If you open & close the "positions form" 10 times do you get 10 "updateParent called!!" output?

                      Meanwhile, where you have emit valueChanged(value); let's have a

                      qDebug() << "emit valueChanged(value);"  << value;
                      
                      P 2 Replies Last reply
                      0
                      • JonBJ JonB

                        @Panoss
                        Your ArticlesWindow::openPositionsForm() goes class positionsForm *form = new class positionsForm(model, this);. I want to know how many times you call openPositionsForm(), I believe you create each time you do something like click on something. I want to know whether the number of times you call openPositionsForm() (number of times you click to open it??) is or is not equal to the number of times you report

                        updateParent called!!
                        ArticlesWindow::positionChanged positionsForm(0x5de4a24160, name = "positionsForm")
                        

                        gets output. If you open & close the "positions form" 10 times do you get 10 "updateParent called!!" output?

                        Meanwhile, where you have emit valueChanged(value); let's have a

                        qDebug() << "emit valueChanged(value);"  << value;
                        
                        P Offline
                        P Offline
                        Panoss
                        wrote on last edited by Panoss
                        #30

                        @JonB

                        1st opening of the positionsForm. Edited data and updated:
                        updateParent called!!
                        ArticlesWindow::positionChanged positionsForm(0xc2423e7660, name = "positionsForm")
                        updateParent called!!
                        ArticlesWindow::positionChanged positionsForm(0xc2423e7660, name = "positionsForm")
                        
                        2nd  opening of the positionsForm. Edited data and updated:
                        updateParent called!!
                        ArticlesWindow::positionChanged positionsForm(0xc2423e3980, name = "positionsForm")
                        updateParent called!!
                        ArticlesWindow::positionChanged positionsForm(0xc2423e3980, name = "positionsForm")
                        
                        3rd  opening of the positionsForm. Edited data and updated:
                        updateParent called!!
                        ArticlesWindow::positionChanged positionsForm(0xc2423e86a0, name = "positionsForm")
                        updateParent called!!
                        ArticlesWindow::positionChanged positionsForm(0xc2423e86a0, name = "positionsForm")
                        

                        So no matter how many times I open (and close) the positionsForm (which, as you correctly supposed, is created each time I click on a button), the function (positionChanged) gets called twice.
                        I 'll have to look more thoroughly in the code, something stupid I must have done somewhere.

                        1 Reply Last reply
                        1
                        • JonBJ JonB

                          @Panoss
                          Your ArticlesWindow::openPositionsForm() goes class positionsForm *form = new class positionsForm(model, this);. I want to know how many times you call openPositionsForm(), I believe you create each time you do something like click on something. I want to know whether the number of times you call openPositionsForm() (number of times you click to open it??) is or is not equal to the number of times you report

                          updateParent called!!
                          ArticlesWindow::positionChanged positionsForm(0x5de4a24160, name = "positionsForm")
                          

                          gets output. If you open & close the "positions form" 10 times do you get 10 "updateParent called!!" output?

                          Meanwhile, where you have emit valueChanged(value); let's have a

                          qDebug() << "emit valueChanged(value);"  << value;
                          
                          P Offline
                          P Offline
                          Panoss
                          wrote on last edited by
                          #31

                          @JonB said in Example of calling a function to parent?:

                          @Panoss
                          Meanwhile, where you have emit valueChanged(value); let's have a

                          qDebug() << "emit valueChanged(value);"  << value;
                          
                          updateParent called!!
                          ArticlesWindow::positionChanged positionsForm(0xba0e7004e0, name = "positionsForm")
                          emit valueChanged(value); 1
                          updateParent called!!
                          ArticlesWindow::positionChanged positionsForm(0xba0e7004e0, name = "positionsForm")
                          emit valueChanged(value); 1
                          

                          The signal is emited twice???

                          JonBJ M 2 Replies Last reply
                          0
                          • P Panoss

                            @JonB said in Example of calling a function to parent?:

                            @Panoss
                            Meanwhile, where you have emit valueChanged(value); let's have a

                            qDebug() << "emit valueChanged(value);"  << value;
                            
                            updateParent called!!
                            ArticlesWindow::positionChanged positionsForm(0xba0e7004e0, name = "positionsForm")
                            emit valueChanged(value); 1
                            updateParent called!!
                            ArticlesWindow::positionChanged positionsForm(0xba0e7004e0, name = "positionsForm")
                            emit valueChanged(value); 1
                            

                            The signal is emited twice???

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

                            @Panoss
                            OK to the it-only-ever-gets-called-twice. (You may still have a leak on non-destruction, we'll leave that for now.)

                            So... just how many times does your code call positionsForm::setValue(int value)?? Could that be twice, somewhere?

                            1 Reply Last reply
                            0
                            • P Panoss

                              @JonB said in Example of calling a function to parent?:

                              @Panoss
                              Meanwhile, where you have emit valueChanged(value); let's have a

                              qDebug() << "emit valueChanged(value);"  << value;
                              
                              updateParent called!!
                              ArticlesWindow::positionChanged positionsForm(0xba0e7004e0, name = "positionsForm")
                              emit valueChanged(value); 1
                              updateParent called!!
                              ArticlesWindow::positionChanged positionsForm(0xba0e7004e0, name = "positionsForm")
                              emit valueChanged(value); 1
                              

                              The signal is emited twice???

                              M Offline
                              M Offline
                              mpergand
                              wrote on last edited by
                              #33

                              @Panoss said in Example of calling a function to parent?:

                              @JonB said in Example of calling a function to parent?:

                              @Panoss
                              Meanwhile, where you have emit valueChanged(value); let's have a

                              qDebug() << "emit valueChanged(value);"  << value;
                              
                              updateParent called!!
                              ArticlesWindow::positionChanged positionsForm(0xba0e7004e0, name = "positionsForm")
                              emit valueChanged(value); 1
                              updateParent called!!
                              ArticlesWindow::positionChanged positionsForm(0xba0e7004e0, name = "positionsForm")
                              emit valueChanged(value); 1
                              

                              The signal is emited twice???

                              Put a break point and look at the stack trace upon each call.

                              As @JonB said, nothing is delete until you set it with:
                              setAttribute(Qt::WA_DeleteOnClose);

                              1 Reply Last reply
                              2
                              • P Offline
                                P Offline
                                Panoss
                                wrote on last edited by Panoss
                                #34

                                Whereever in my code I open a form, this:

                                form.setAttribute(Qt::WA_DeleteOnClose);
                                

                                is always included.

                                I dubugged it but didn't find anything.
                                Anyway, as it's not causing any issues I 'll leave as is.
                                Better update twice than none! ):

                                jsulmJ 1 Reply Last reply
                                0
                                • P Panoss

                                  Whereever in my code I open a form, this:

                                  form.setAttribute(Qt::WA_DeleteOnClose);
                                  

                                  is always included.

                                  I dubugged it but didn't find anything.
                                  Anyway, as it's not causing any issues I 'll leave as is.
                                  Better update twice than none! ):

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

                                  @Panoss You could add

                                  qDebug() << sender();
                                  

                                  to your slot - it will print the pointer to the emitter/sender of the signal. Then you will see whether the sender is always the same or different.

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

                                  1 Reply Last reply
                                  1
                                  • P Offline
                                    P Offline
                                    Panoss
                                    wrote on last edited by Panoss
                                    #36

                                    @jsulm I did it, the sender is always the same.

                                    1 Reply Last reply
                                    0
                                    • P Offline
                                      P Offline
                                      Panoss
                                      wrote on last edited by Panoss
                                      #37

                                      I have modified the Signal - Slot mechanism so that makes more sense:
                                      Receiver:

                                      articleswindow.cpp
                                      void ArticlesWindow::positionChanged(){
                                          qDebug() << "ArticlesWindow::positionChanged";
                                      }
                                      void ArticlesWindow::openPositionsForm(){    
                                          class positionsForm *form = new class positionsForm(model, this);
                                          connect(form, &positionsForm::valueChanged, this , &ArticlesWindow::positionChanged);
                                      
                                      

                                      Sender:

                                      positionsform.h
                                        public slots:
                                          void emitSignal();
                                        signals:
                                          void valueChanged(int newValue);
                                      
                                      positionsform.cpp
                                      positionsForm::positionsForm(QSqlRelationalTableModel *parentmodel, QWidget *parent) : QDialog(parent), ui(new Ui::positionsForm){
                                          connect(ui->positionsTable->model(),
                                                  SIGNAL(dataChanged(QModelIndex,QModelIndex)), this,
                                                  SLOT(emitSignal()));
                                      }
                                      void positionsForm::emitSignal(){    
                                          emit valueChanged(1);
                                      }
                                      
                                      1 Reply Last reply
                                      0
                                      • M Offline
                                        M Offline
                                        mpergand
                                        wrote on last edited by mpergand
                                        #38

                                        This code looks strange ...

                                        class positionsForm *form = new class positionsForm(model, this);

                                        The class name doesn't start with a capital letter and looking like a function, confusing.
                                        Why are you using class , obviously positionsForm is a class.

                                        and finally:

                                        connect(ui->positionsTable->model(),
                                                    SIGNAL(dataChanged(QModelIndex,QModelIndex)), this,
                                                    SLOT(emitSignal()));
                                        

                                        since model is defined in ArticlesWindow why not make the connection straight away in that class ?

                                        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