Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 7052361
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 28, 20262026-05-28T03:22:26+00:00 2026-05-28T03:22:26+00:00

I have spent hours trying to understand why my logger class does not work.

  • 0

I have spent hours trying to understand why my logger class does not work.
The idea is to hook existing qDebug, qWarning and qFatal to one of my slots and also extend the macro list with new ones (qInfo in this example)
I tried to follow the following guidelines:
Using a Singleton Class across a Qt Application and its Plugins

#pragma once

#include <QtGui>
#include <QMutex>

//! Creates a fake call, to have a cleaner design.
extern void qInfo(const char* fmt);

#define QtTraceMsg  QtMsgType(6)
#define QtInfoMsg   QtMsgType(7)

class MsgHandler: public QObject
{
    Q_OBJECT

signals:
    void newMsg(QtMsgType type, const QString &msg);

public:
    static MsgHandler *instance();
    static void Handler(QtMsgType type, const char *msg);

private:
    MsgHandler() { qRegisterMetaType<QtMsgType>("QtMsgType"); } // important
    static MsgHandler* _instance;
};

and cpp:

#include "MsgHandler.h"

MsgHandler* MsgHandler::_instance = NULL;

MsgHandler * MsgHandler::instance()
{
    static QMutex mutex;

    if (_instance == NULL)
    {
        mutex.lock();
        if (_instance == NULL)
            _instance = new MsgHandler;
        mutex.unlock();
    }

    return _instance;
}

void MsgHandler::Handler(QtMsgType type, const char *msg)
{
    QString s = msg;
    emit instance()->newMsg(type, s);
}

///////////////////////////////////////////////////////////////////////////////
void qInfo(const char *msg)
{
    MsgHandler::instance()->Handler(QtInfoMsg, msg);
}

then in the main I register my handler

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);

    // Handle error messages
    qInstallMsgHandler(MsgHandler::Handler);
}

Everything works perfectly in the main thread. But from a plugin that runs its own thread it fail:

void MyPlugin::run()
{
    qWarning("Test debug"); //works fine
    MsgHandler::instance()->Handler(QtInfoMsg, "info 2"); //creates a new instance!
    qInfo("test info"); //also creates a new instance!
}
  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-28T03:22:27+00:00Added an answer on May 28, 2026 at 3:22 am

    The solution is to pass a pointer to the MsgHandler to each plugin.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have spent many hours trying to work this damn thing out! so I
I have spent the last several hours trying to get this to work and
I have spent hours trying to work this out, and spent a long time
I have spent several hours trying to find a means of writing a cross
I have a problem with php header redirect. I already spent hours trying to
First, I have already spent the past few hours trying to find a solution
Ok so I've spent a couple hours trying to resolve this issue and have
I have spent hours trying to get my project working and I just can't
I have spent the last 3 hours trying to get this code working. I
I have spent hours trying to figure this problem and i just can't, so

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.