Qt: QGLShaderProgram apaga los mensajes de registro

¿Hay alguna forma de desactivar los mensajes de registro al llamar a QGLShaderProgram::link()? http://qt-project.org/doc/qt-4.8/qglshaderprogram.html#link

Los mensajes se ven como:

QGLShader::link: "Vertex shader(s) linked, fragment shader(s) linked.
"

El código Qt se ve así: src/opengl/qglshaderprogram.cpp:893

    glLinkProgram(program);
    value = 0;
    glGetProgramiv(program, GL_LINK_STATUS, &value);
    d->linked = (value != 0);
    value = 0;
    glGetProgramiv(program, GL_INFO_LOG_LENGTH, &value);
    d->log = QString();
    if (value > 1) {
        char *logbuf = new char [value];
        GLint len;
        glGetProgramInfoLog(program, value, &len, logbuf);
        d->log = QString::fromLatin1(logbuf);
        QString name = objectName();
        if (name.isEmpty())
            qWarning() << "QGLShader::link:" << d->log;
        else
            qWarning() << "QGLShader::link[" << name << "]:" << d->log;
        delete [] logbuf;
    }
    return d->linked;
}

preguntado el 12 de junio de 12 a las 15:06

1 Respuestas

Así que parece que la única solución posible es redirigir qWarning() como se hace en: ¿Cómo redirigir la salida qDebug, qWarning, qCritical, etc.?

 qInstallMsgHandler([](QtMsgType , const char* ) { });  // empty message handler
 bool result = program.link();
 qInstallMsgHandler(0);  // restore default message handling

contestado el 23 de mayo de 17 a las 13:05

No es la respuesta que estás buscando? Examinar otras preguntas etiquetadas or haz tu propia pregunta.