Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Special Interest Groups
  3. C++ Gurus
  4. matherror issue
Forum Updated to NodeBB v4.3 + New Features

matherror issue

Scheduled Pinned Locked Moved Unsolved C++ Gurus
17 Posts 4 Posters 1.6k Views
  • 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.
  • jsulmJ jsulm

    @qAlexKo said in matherror issue:

    //QtCreator says:

    Do you mean QtCreator code model in the editor or compiler?
    So, does your application compile?
    Also, what compiler do you use?

    Q Offline
    Q Offline
    qAlexKo
    wrote on last edited by qAlexKo
    #3

    @jsulm said in matherror issue:

    Do you mean QtCreator code model in the editor or compiler?
    So, does your application compile?
    Also, what compiler do you use?

    I've got this error in the QtCreator editor. I can't compile my app
    My compiler is minGW 7.3.0 64-bit

    Compiler says "Multiple definition of _matherr"

    1 Reply Last reply
    0
    • jsulmJ Offline
      jsulmJ Offline
      jsulm
      Lifetime Qt Champion
      wrote on last edited by
      #4

      On Linux I don't have problems compiling your code.
      Don't have Windows at hand to test.

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

      Q 2 Replies Last reply
      0
      • jsulmJ jsulm

        On Linux I don't have problems compiling your code.
        Don't have Windows at hand to test.

        Q Offline
        Q Offline
        qAlexKo
        wrote on last edited by qAlexKo
        #5

        @jsulm said in matherror issue:

        On Linux I don't have problems compiling your code.
        Don't have Windows at hand to test.

        Yes, I also have no problem in Linux Qtcreator. I need to transfer one my app to Windows.

        1 Reply Last reply
        0
        • jsulmJ Offline
          jsulmJ Offline
          jsulm
          Lifetime Qt Champion
          wrote on last edited by
          #6

          Maybe https://stackoverflow.com/questions/65490663/function-defined-with-declspecdllexport-in-h-file-but-not-in-c-file-discar gives a clue?

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

          1 Reply Last reply
          0
          • Christian EhrlicherC Online
            Christian EhrlicherC Online
            Christian Ehrlicher
            Lifetime Qt Champion
            wrote on last edited by
            #7

            I would guess you have to find another way to catch those errors as the MinGW runtime catches this by itself and writes to stderr: https://github.com/mingw-w64/mingw-w64/blob/master/mingw-w64-crt/crt/merr.c

            You can use the MSVC compiler instead for instance.

            Qt Online Installer direct download: https://download.qt.io/official_releases/online_installers/
            Visit the Qt Academy at https://academy.qt.io/catalog

            Q 1 Reply Last reply
            0
            • Christian EhrlicherC Christian Ehrlicher

              I would guess you have to find another way to catch those errors as the MinGW runtime catches this by itself and writes to stderr: https://github.com/mingw-w64/mingw-w64/blob/master/mingw-w64-crt/crt/merr.c

              You can use the MSVC compiler instead for instance.

              Q Offline
              Q Offline
              qAlexKo
              wrote on last edited by qAlexKo
              #8

              @Christian-Ehrlicher said in matherror issue:

              I would guess you have to find another way to catch those errors as the MinGW runtime catches this by itself and writes to stderr: https://github.com/mingw-w64/mingw-w64/blob/master/mingw-w64-crt/crt/merr.c

              You can use the MSVC compiler instead for instance.

              Thanx, indeed I need just an indicator for math errors happened in the calculation block. The example you've just given also containes _matherr in question.
              I've found out another way to indicate math errors in a calculaton block:

              int err_indicator = 0;   //global indicator
              void MainWindow::on_bt_test1_clicked()
              {
                  errno = 0;
                   double res = 0;
                   res = sqrt(-10.0);   //tst err calc1
                   res = 10.0 / 0.0;    //tst err calc2
                   res = 10.0 / 1.0;    //tst OK calc3
                   res = sqrt(10.0);    //tst OK calc4
              
                   if(!errno)
                      { err_indicator=0;  ui->statusbar->showMessage("OK, no errs"); }
                   else
                      { err_indicator=1; ui->statusbar->showMessage("Some err(s)' happened"); }
              }
              

              So I think I'll do like this, to save my time thinking of why _matherr is not perfect for windows Qtcreator.

              JonBJ Christian EhrlicherC 2 Replies Last reply
              0
              • Q qAlexKo

                @Christian-Ehrlicher said in matherror issue:

                I would guess you have to find another way to catch those errors as the MinGW runtime catches this by itself and writes to stderr: https://github.com/mingw-w64/mingw-w64/blob/master/mingw-w64-crt/crt/merr.c

                You can use the MSVC compiler instead for instance.

                Thanx, indeed I need just an indicator for math errors happened in the calculation block. The example you've just given also containes _matherr in question.
                I've found out another way to indicate math errors in a calculaton block:

                int err_indicator = 0;   //global indicator
                void MainWindow::on_bt_test1_clicked()
                {
                    errno = 0;
                     double res = 0;
                     res = sqrt(-10.0);   //tst err calc1
                     res = 10.0 / 0.0;    //tst err calc2
                     res = 10.0 / 1.0;    //tst OK calc3
                     res = sqrt(10.0);    //tst OK calc4
                
                     if(!errno)
                        { err_indicator=0;  ui->statusbar->showMessage("OK, no errs"); }
                     else
                        { err_indicator=1; ui->statusbar->showMessage("Some err(s)' happened"); }
                }
                

                So I think I'll do like this, to save my time thinking of why _matherr is not perfect for windows Qtcreator.

                JonBJ Online
                JonBJ Online
                JonB
                wrote on last edited by JonB
                #9

                @qAlexKo
                I am jumping in here. I do not use Windows or MinGW. I cannot test anything, but I had a look at https://github.com/Alexpux/mingw-w64/blob/master/mingw-w64-crt/crt/merr.c which I take to be the source for MinGW's _matherr stuff.

                There it defines int __CRTDECL _matherr (struct _exception *pexcept) which is the handling function which hard-codes calling fprintf(stderr that you do not want.

                I don't think you are supposed to redefine function named _matherr(). Rather I see

                typedef int (__cdecl *fUserMathErr)(struct _exception *);
                static fUserMathErr stUserMathErr;
                
                void __mingw_setusermatherr (int (__cdecl *f)(struct _exception *))
                {
                  stUserMathErr = f;
                  __setusermatherr (f);
                }
                

                I assume MinGW start up code calls __mingw_setusermatherr(_matherr);? So, can you not replace their _matherr() as handler by writing your own under a different name and calling __mingw_setusermatherr(your_matherr)? For your function copy their _matherr(struct _exception *pexcept) for the switch statement and just replace the final fprintf with whatever you want instead?

                This is all of course if you want that old behaviour, rather than being happy with errno.

                Q 1 Reply Last reply
                0
                • JonBJ JonB

                  @qAlexKo
                  I am jumping in here. I do not use Windows or MinGW. I cannot test anything, but I had a look at https://github.com/Alexpux/mingw-w64/blob/master/mingw-w64-crt/crt/merr.c which I take to be the source for MinGW's _matherr stuff.

                  There it defines int __CRTDECL _matherr (struct _exception *pexcept) which is the handling function which hard-codes calling fprintf(stderr that you do not want.

                  I don't think you are supposed to redefine function named _matherr(). Rather I see

                  typedef int (__cdecl *fUserMathErr)(struct _exception *);
                  static fUserMathErr stUserMathErr;
                  
                  void __mingw_setusermatherr (int (__cdecl *f)(struct _exception *))
                  {
                    stUserMathErr = f;
                    __setusermatherr (f);
                  }
                  

                  I assume MinGW start up code calls __mingw_setusermatherr(_matherr);? So, can you not replace their _matherr() as handler by writing your own under a different name and calling __mingw_setusermatherr(your_matherr)? For your function copy their _matherr(struct _exception *pexcept) for the switch statement and just replace the final fprintf with whatever you want instead?

                  This is all of course if you want that old behaviour, rather than being happy with errno.

                  Q Offline
                  Q Offline
                  qAlexKo
                  wrote on last edited by qAlexKo
                  #10

                  @JonB said in matherror issue:

                  This is all of course if you want that old behaviour, rather than being happy with errno.

                  Yes, your way is working OK:

                  #include "mainwindow.h"
                  #include "ui_mainwindow.h"
                  #include <math.h>
                  #include <string>
                  using namespace std;
                  
                  typedef int (__cdecl *fUserMathErr)(struct _exception *);
                  static fUserMathErr stUserMathErr;
                  
                  //--------------------------------
                  string math_err_res;
                  
                  int __CRTDECL _matherr_my (struct _exception *pexcept)
                  {
                    const char * type;
                  
                    switch(pexcept->type)
                      {
                        case _DOMAIN:
                      type = "Argument domain error (DOMAIN)";
                      break;
                  
                        case _SING:
                      type = "Argument singularity (SIGN)";
                      break;
                  
                        case _OVERFLOW:
                      type = "Overflow range error (OVERFLOW)";
                      break;
                  
                        case _PLOSS:
                      type = "Partial loss of significance (PLOSS)";
                      break;
                  
                        case _TLOSS:
                      type = "Total loss of significance (TLOSS)";
                      break;
                  
                        case _UNDERFLOW:
                      type = "The result is too small to be represented (UNDERFLOW)";
                      break;
                  
                        default:
                      type = "Unknown error";
                      break;
                      }
                  
                    char buf[200];
                    sprintf (buf, "_matherr(): %s in %s(%g, %g)  (retval=%g)\n",
                        type, pexcept->name, pexcept->arg1, pexcept->arg2, pexcept->retval);
                    math_err_res = type;
                    return 0;
                  }
                  
                  
                  MainWindow::MainWindow(QWidget *parent)
                      : QMainWindow(parent)
                      , ui(new Ui::MainWindow)
                  {
                      ui->setupUi(this);
                      __mingw_setusermatherr(_matherr_my);
                  }
                  
                  MainWindow::~MainWindow()
                  {
                      delete ui;
                  }
                  
                  void MainWindow::on_bt_test1_2_clicked()
                  {
                      double res = 0;
                      res = sqrt(-10.0);   //tst err calc1
                      res = 10.0 / 0.0;    //tst err calc2
                      res = 10.0 / 1.0;    //tst OK calc3
                      res = sqrt(10.0);    //tst OK calc4
                  
                      if(math_err_res.size() == 0)
                         ui->statusbar->showMessage("OK, no errs");
                      else
                         { err_indicator=1; ui->statusbar->showMessage("Some err(s)' happened (" + QString(math_err_res.c_str()) + ")"); }
                  
                      math_err_res = "";
                  }
                  
                  

                  However I doubt - the source text will not be for all compilers? - I have a different compiler for my app Linux version.

                  JonBJ 1 Reply Last reply
                  0
                  • Q qAlexKo

                    @Christian-Ehrlicher said in matherror issue:

                    I would guess you have to find another way to catch those errors as the MinGW runtime catches this by itself and writes to stderr: https://github.com/mingw-w64/mingw-w64/blob/master/mingw-w64-crt/crt/merr.c

                    You can use the MSVC compiler instead for instance.

                    Thanx, indeed I need just an indicator for math errors happened in the calculation block. The example you've just given also containes _matherr in question.
                    I've found out another way to indicate math errors in a calculaton block:

                    int err_indicator = 0;   //global indicator
                    void MainWindow::on_bt_test1_clicked()
                    {
                        errno = 0;
                         double res = 0;
                         res = sqrt(-10.0);   //tst err calc1
                         res = 10.0 / 0.0;    //tst err calc2
                         res = 10.0 / 1.0;    //tst OK calc3
                         res = sqrt(10.0);    //tst OK calc4
                    
                         if(!errno)
                            { err_indicator=0;  ui->statusbar->showMessage("OK, no errs"); }
                         else
                            { err_indicator=1; ui->statusbar->showMessage("Some err(s)' happened"); }
                    }
                    

                    So I think I'll do like this, to save my time thinking of why _matherr is not perfect for windows Qtcreator.

                    Christian EhrlicherC Online
                    Christian EhrlicherC Online
                    Christian Ehrlicher
                    Lifetime Qt Champion
                    wrote on last edited by
                    #11

                    @qAlexKo said in matherror issue:

                    for windows Qtcreator

                    I don't understand what this has to do with windows nor QtCreator... It's an issue of the compiler you use...

                    Qt Online Installer direct download: https://download.qt.io/official_releases/online_installers/
                    Visit the Qt Academy at https://academy.qt.io/catalog

                    1 Reply Last reply
                    1
                    • Q qAlexKo

                      @JonB said in matherror issue:

                      This is all of course if you want that old behaviour, rather than being happy with errno.

                      Yes, your way is working OK:

                      #include "mainwindow.h"
                      #include "ui_mainwindow.h"
                      #include <math.h>
                      #include <string>
                      using namespace std;
                      
                      typedef int (__cdecl *fUserMathErr)(struct _exception *);
                      static fUserMathErr stUserMathErr;
                      
                      //--------------------------------
                      string math_err_res;
                      
                      int __CRTDECL _matherr_my (struct _exception *pexcept)
                      {
                        const char * type;
                      
                        switch(pexcept->type)
                          {
                            case _DOMAIN:
                          type = "Argument domain error (DOMAIN)";
                          break;
                      
                            case _SING:
                          type = "Argument singularity (SIGN)";
                          break;
                      
                            case _OVERFLOW:
                          type = "Overflow range error (OVERFLOW)";
                          break;
                      
                            case _PLOSS:
                          type = "Partial loss of significance (PLOSS)";
                          break;
                      
                            case _TLOSS:
                          type = "Total loss of significance (TLOSS)";
                          break;
                      
                            case _UNDERFLOW:
                          type = "The result is too small to be represented (UNDERFLOW)";
                          break;
                      
                            default:
                          type = "Unknown error";
                          break;
                          }
                      
                        char buf[200];
                        sprintf (buf, "_matherr(): %s in %s(%g, %g)  (retval=%g)\n",
                            type, pexcept->name, pexcept->arg1, pexcept->arg2, pexcept->retval);
                        math_err_res = type;
                        return 0;
                      }
                      
                      
                      MainWindow::MainWindow(QWidget *parent)
                          : QMainWindow(parent)
                          , ui(new Ui::MainWindow)
                      {
                          ui->setupUi(this);
                          __mingw_setusermatherr(_matherr_my);
                      }
                      
                      MainWindow::~MainWindow()
                      {
                          delete ui;
                      }
                      
                      void MainWindow::on_bt_test1_2_clicked()
                      {
                          double res = 0;
                          res = sqrt(-10.0);   //tst err calc1
                          res = 10.0 / 0.0;    //tst err calc2
                          res = 10.0 / 1.0;    //tst OK calc3
                          res = sqrt(10.0);    //tst OK calc4
                      
                          if(math_err_res.size() == 0)
                             ui->statusbar->showMessage("OK, no errs");
                          else
                             { err_indicator=1; ui->statusbar->showMessage("Some err(s)' happened (" + QString(math_err_res.c_str()) + ")"); }
                      
                          math_err_res = "";
                      }
                      
                      

                      However I doubt - the source text will not be for all compilers? - I have a different compiler for my app Linux version.

                      JonBJ Online
                      JonBJ Online
                      JonB
                      wrote on last edited by
                      #12

                      @qAlexKo said in matherror issue:

                      However I doubt - the source text will not be for all compilers? - I have a different compiler for my app Linux version.

                      The code in itself is pretty standard.

                      • If you are on Linux you will want to get rid of __CRTDECL I think.
                      • But I think then you will not be using MinGW, and if this code is only supposed to work under that you will put your __mingw_setusermatherr(_matherr_my); statement (plus the whole of the int _matherr_my (struct _exception *pexcept) function) inside some #if/#ifdef which tests for a defined symbol indicating it is being compiled under MinGW.
                      1 Reply Last reply
                      1
                      • Q qAlexKo has marked this topic as solved on
                      • Q qAlexKo has marked this topic as unsolved on
                      • jsulmJ jsulm

                        On Linux I don't have problems compiling your code.
                        Don't have Windows at hand to test.

                        Q Offline
                        Q Offline
                        qAlexKo
                        wrote on last edited by qAlexKo
                        #13

                        @jsulm said in matherror issue:

                        On Linux I don't have problems compiling your code.
                        Don't have Windows at hand to test.

                        Sorry I am again! :) I am in Linux Qtcreatornow.
                        I said that there is no problem with _matherror in Linux Clang compiler but unexpectedly I've got one! ;) Look:
                        if you compile with the commented lines the compilation will be OK.
                        But If you remove the comments to use pexcept pointer -- QtCreator says about an error in line where "pexcept->type"
                        "mainwindow.cpp:14:17: error: member access into incomplete type 'struct _exception'
                        mainwindow.cpp:11:22: note: forward declaration of '_exception'"
                        #include <exception> has not helped
                        what else should I include?

                        #include "mainwindow.h"
                        #include "ui_mainwindow.h"
                        
                        #include <exception>
                        #include <math.h>
                        #include <string>
                        using namespace std;
                        
                        //--------------------------------
                        string math_err_res;
                        int _matherr (struct _exception *pexcept)
                        {
                          const char * type=NULL;
                        //  switch(pexcept->type)
                        //    {
                        //      case _DOMAIN:
                        //    type = "Argument domain error (DOMAIN)";
                        //    break;
                        //    }
                        
                        //  char buf[200];
                        //  sprintf (buf, "_matherr(): %s in %s(%g, %g)  (retval=%g)\n",
                        //      type, pexcept->name, pexcept->arg1, pexcept->arg2, pexcept->retval);
                          math_err_res = type;
                          return 0;
                        }
                        
                        
                        MainWindow::MainWindow(QWidget *parent)
                            : QMainWindow(parent)
                            , ui(new Ui::MainWindow)
                        {
                            ui->setupUi(this);
                        }
                        
                        MainWindow::~MainWindow()
                        {
                            delete ui;
                        }
                        
                        void MainWindow::on_bt_test1_2_clicked()
                        {
                            double res = 0;
                            res = sqrt(-10.0);   //tst err calc1
                            res = 10.0 / 0.0;    //tst err calc2
                            res = 10.0 / 1.0;    //tst OK calc3
                            res = sqrt(10.0);    //tst OK calc4
                        
                            if(math_err_res.size() == 0)
                               ui->statusbar->showMessage("OK, no errs");
                            else
                               { ui->statusbar->showMessage("Some err(s)' happened (" + QString(math_err_res.c_str()) + ")"); }
                        
                            math_err_res = "";
                        }
                        
                        

                        I have switched the Qtcreator compiler to gcc and the problem remained.

                        jsulmJ 1 Reply Last reply
                        0
                        • Q qAlexKo

                          @jsulm said in matherror issue:

                          On Linux I don't have problems compiling your code.
                          Don't have Windows at hand to test.

                          Sorry I am again! :) I am in Linux Qtcreatornow.
                          I said that there is no problem with _matherror in Linux Clang compiler but unexpectedly I've got one! ;) Look:
                          if you compile with the commented lines the compilation will be OK.
                          But If you remove the comments to use pexcept pointer -- QtCreator says about an error in line where "pexcept->type"
                          "mainwindow.cpp:14:17: error: member access into incomplete type 'struct _exception'
                          mainwindow.cpp:11:22: note: forward declaration of '_exception'"
                          #include <exception> has not helped
                          what else should I include?

                          #include "mainwindow.h"
                          #include "ui_mainwindow.h"
                          
                          #include <exception>
                          #include <math.h>
                          #include <string>
                          using namespace std;
                          
                          //--------------------------------
                          string math_err_res;
                          int _matherr (struct _exception *pexcept)
                          {
                            const char * type=NULL;
                          //  switch(pexcept->type)
                          //    {
                          //      case _DOMAIN:
                          //    type = "Argument domain error (DOMAIN)";
                          //    break;
                          //    }
                          
                          //  char buf[200];
                          //  sprintf (buf, "_matherr(): %s in %s(%g, %g)  (retval=%g)\n",
                          //      type, pexcept->name, pexcept->arg1, pexcept->arg2, pexcept->retval);
                            math_err_res = type;
                            return 0;
                          }
                          
                          
                          MainWindow::MainWindow(QWidget *parent)
                              : QMainWindow(parent)
                              , ui(new Ui::MainWindow)
                          {
                              ui->setupUi(this);
                          }
                          
                          MainWindow::~MainWindow()
                          {
                              delete ui;
                          }
                          
                          void MainWindow::on_bt_test1_2_clicked()
                          {
                              double res = 0;
                              res = sqrt(-10.0);   //tst err calc1
                              res = 10.0 / 0.0;    //tst err calc2
                              res = 10.0 / 1.0;    //tst OK calc3
                              res = sqrt(10.0);    //tst OK calc4
                          
                              if(math_err_res.size() == 0)
                                 ui->statusbar->showMessage("OK, no errs");
                              else
                                 { ui->statusbar->showMessage("Some err(s)' happened (" + QString(math_err_res.c_str()) + ")"); }
                          
                              math_err_res = "";
                          }
                          
                          

                          I have switched the Qtcreator compiler to gcc and the problem remained.

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

                          @qAlexKo said in matherror issue:

                          int _matherr (struct _exception *pexcept)

                          Shouldn't it be exception instead of _exception?

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

                          Q 1 Reply Last reply
                          0
                          • jsulmJ jsulm

                            @qAlexKo said in matherror issue:

                            int _matherr (struct _exception *pexcept)

                            Shouldn't it be exception instead of _exception?

                            Q Offline
                            Q Offline
                            qAlexKo
                            wrote on last edited by
                            #15

                            @jsulm said in matherror issue:

                            Shouldn't it be exception instead of _exception?

                            If I change to exception I am get this message
                            mainwindow.cpp:14:19: error: no member named 'type' in 'std::exception'

                            JonBJ 1 Reply Last reply
                            0
                            • Q qAlexKo

                              @jsulm said in matherror issue:

                              Shouldn't it be exception instead of _exception?

                              If I change to exception I am get this message
                              mainwindow.cpp:14:19: error: no member named 'type' in 'std::exception'

                              JonBJ Online
                              JonBJ Online
                              JonB
                              wrote on last edited by JonB
                              #16

                              @qAlexKo
                              If the int _matherr (struct _exception *pexcept) appears in merr.c you need to trace from there to find out where it (_exception) is defined. Maybe it's a MinGW-only definition/file, I don't know.

                              Q 1 Reply Last reply
                              0
                              • JonBJ JonB

                                @qAlexKo
                                If the int _matherr (struct _exception *pexcept) appears in merr.c you need to trace from there to find out where it (_exception) is defined. Maybe it's a MinGW-only definition/file, I don't know.

                                Q Offline
                                Q Offline
                                qAlexKo
                                wrote on last edited by qAlexKo
                                #17

                                @JonB said in matherror issue:

                                If the int _matherr (struct _exception *pexcept) appears in merr.c you need to trace from there to find out where it (_exception) is defined. Maybe it's a MinGW-only definition/file, I don't know.

                                If I compile in Clang

                                int err_ind = 0;
                                int _matherr (struct _exception *pexcept)
                                {
                                 err_ind = 1;
                                }
                                

                                Compilation OK, but math exception doesn't work

                                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