X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Fdebug.h;h=af7b04067e08b20c66e9dd7f6fa18cfe8e4dc012;hb=b9963e1a57135c3e2ab128a9ec4300f0e4886992;hp=3e828d858960edc290201d527bbccc108066bc6b;hpb=e8db0ccc46566f36a1711e35c3758a2e785021f1;p=lyx.git diff --git a/src/debug.h b/src/debug.h index 3e828d8589..af7b04067e 100644 --- a/src/debug.h +++ b/src/debug.h @@ -1,16 +1,26 @@ // -*- C++ -*- +/** + * \file debug.h + * This file is part of LyX, the document processor. + * Licence details can be found in the file COPYING. + * + * \author Lars Gullik Bjønnes + * \author Jean-Marc Lasgouttes + * + * Full author contact details are available in file CREDITS. + */ #ifndef LYXDEBUG_H #define LYXDEBUG_H -#include "LString.h" -#include "support/lstrings.h" +#include "support/debugstream.h" /** Ideally this should have been a namespace, but since we try to be - compilable on older C++ compilators too, we use a struct instead. - This is all the different debug levels that we have. -*/ -struct Debug { + * compilable on older C++ compilators too, we use a struct instead. + * This is all the different debug levels that we have. + */ +class lyx_debug_trait { +public: /// enum type { /// @@ -22,7 +32,7 @@ struct Debug { /// KEY = (1 << 2), // 4 /// - TOOLBAR = (1 << 3), // 8 + GUI = (1 << 3), // 8 /// PARSER = (1 << 4), // 16 /// @@ -44,45 +54,64 @@ struct Debug { /// ROFF = (1 << 13), // 8192 /// - ACTION = (1 << 14) // 16384 + ACTION = (1 << 14), // 16384 + /// + LYXLEX = (1 << 15), + /// + DEPEND = (1 << 16), + /// + INSETS = (1 << 17), + /// + FILES = (1 << 18), + /// + WORKAREA = (1 << 19), + /// + INSETTEXT = (1 << 20), + /// + GRAPHICS = (1 << 21), + /// change tracking + CHANGES = (1 << 22), + /// + EXTERNAL = (1 << 23), + /// + DEBUG = (1 << 31), + /// + ANY = 0xffffffff }; - /// - static const type ANY = type(INFO | INIT | KEY | TOOLBAR | - PARSER | LYXRC | KBMAP | LATEX | - MATHED | FONT | TCLASS | LYXVC | - LYXSERVER | ROFF | ACTION); - /// - friend inline void operator|=(Debug::type & d1, Debug::type d2); - + + static bool match(type a, type b) { + return (a & b); + } + /** A function to convert symbolic string names on debug levels to their numerical value. */ - static Debug::type value(string const & val); + static type value(std::string const & val); - /** Display the tags and descriptions of the current debug level - of ds + /** Display the tags and descriptions of the current debug level + of ds */ - static void showLevel(ostream & o, type level); + static void showLevel(std::ostream & o, type level); /** show all the possible tags that can be used for debugging */ - static void showTags(ostream & o); + static void showTags(std::ostream & o); }; -/// -inline void operator|= (Debug::type & d1, Debug::type d2) + +inline +void operator|=(lyx_debug_trait::type & d1, lyx_debug_trait::type d2) { - d1 = static_cast(d1 | d2); + d1 = static_cast(d1 | d2); } -#include "support/DebugStream.h" - +// std::ostream & operator<<(std::ostream & o, Debug::type t); -/// -ostream & operator<<(ostream & o, Debug::type t); +typedef basic_debugstream LyXErr; +typedef LyXErr::debug Debug; -extern DebugStream lyxerr; +extern LyXErr lyxerr; #endif