c++ - 调试函数包装器

标签 c++ templates c++11 variadic

我使用模板函数来包装 OpenGL API 调用(用于捕获错误代码):

template<typename Function, typename ... Args>
auto __glFunction(const char *file, int line, Function f, Args ...args) -> decltype(f(args...)) {
    auto result = f(args...);
    auto error = glGetError();
    if (error != GL_NO_ERROR) {
        switch(error) {
            case GL_INVALID_ENUM:
                std::cout << "GL_INVALID_ENUM";
                break;
            case GL_INVALID_VALUE:
                std::cout << "GL_INVALID_VALUE";
                break;
            case GL_INVALID_OPERATION:
                std::cout << "GL_INVALID_OPERATION";
                break;
            case GL_INVALID_FRAMEBUFFER_OPERATION:
                std::cout << "GL_INVALID_FRAMEBUFFER_OPERATION";
                break;
            case GL_OUT_OF_MEMORY:
                std::cout << "GL_OUT_OF_MEMORY";
                break;
            case GL_STACK_UNDERFLOW:
                std::cout << "GL_STACK_UNDERFLOW";
                break;
            case GL_STACK_OVERFLOW:
                std::cout << "GL_STACK_OVERFLOW";
                break;
            default:
                std::cout << "GL_ERROR #" << error;
                break;
        }
        std::cout << " at " << file << ":" << line << std::endl;
    }

    return result;
};

#define glFunction(function, ...) __glFunction(__FILE__, __LINE__, function, ##__VA_ARGS__)

它适用于具有非 void 返回类型的函数。我应该如何指定模板以使用返回 void 的函数以及非 void 函数。

最佳答案

解决方案

可能对某人有帮助。 下一个代码适用于(void/non-void)返回函数:

void __glPrintError(const char *file, const int line) {
    auto error = glGetError();
    if (error != GL_NO_ERROR) {
        switch(error) {
            case GL_INVALID_ENUM:
                std::cout << "GL_INVALID_ENUM";
                break;
            case GL_INVALID_VALUE:
                std::cout << "GL_INVALID_VALUE";
                break;
            case GL_INVALID_OPERATION:
                std::cout << "GL_INVALID_OPERATION";
                break;
            case GL_INVALID_FRAMEBUFFER_OPERATION:
                std::cout << "GL_INVALID_FRAMEBUFFER_OPERATION";
                break;
            case GL_OUT_OF_MEMORY:
                std::cout << "GL_OUT_OF_MEMORY";
                break;
            case GL_STACK_UNDERFLOW:
                std::cout << "GL_STACK_UNDERFLOW";
                break;
            case GL_STACK_OVERFLOW:
                std::cout << "GL_STACK_OVERFLOW";
                break;
            default:
                std::cout << "GL_ERROR #" << error;
                break;
        }
        std::cout << " at " << file << ":" << line << std::endl;
    }
}

template<typename Function, typename ... Args>
auto __glFunction(const char *file, const int line, Function f, Args ...args) ->
    typename std::enable_if<!std::is_same<decltype(f(args...)), void>::value, decltype(f(args...))>::type {

    auto result = f(args...);
    __glPrintError(file, line);
    return result;
};

template<typename Function, typename ... Args>
auto __glFunction(const char *file, const int line, Function f, Args ...args) ->
    typename std::enable_if<std::is_same<decltype(f(args...)), void>::value, decltype(f(args...))>::type {

    f(args...);
    __glPrintError(file, line);
};

#define glFunction(function, ...) __glFunction(__FILE__, __LINE__, function, ##__VA_ARGS__)

关于c++ - 调试函数包装器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37089624/

相关文章:

c++ - 如何从http响应中删除垃圾数据

c++ - 在C++中的多个类中使用模板类

c++ - alignas 说明符是否与 'new' 一起使用?

C++:将模板函数作为参数传递给其他模板函数时的模板参数推导

c++ - 为 vector 实例化一个模板

c++ - std::function 成员可以访问其他成员吗?

c++ - 使用 lambda 创建 unordered_set

c++ - 如何在 C++ 中获取列表?

c++ - typeid(复杂<double>(0.0,1.0)) != typeid(1.0i)

c++ - gdb 在检查断点处的条件时失败