/* Test macros Implemntation * * Copyright (c) 2019-2024 The OSCAR Team * Copyright (c) 2011-2018 Mark Watkins * * This file is subject to the terms and conditions of the GNU General Public * License. See the file COPYING in the main directory of the source code * for more details. */ /* These functions will display formatted debug information. The macro TEST_MACROS_ENABLED will enable these macros to display information When The macro TEST_MACROS_ENABLED is undefined then these marcos will expand to white space. When these macos are used then debugging is disabled When only these macos are used then debugging is disabled. SO for production code rename TEST_MACROS_ENABLED to TEST_MACROS_ENABLEDoff ########################################### The the following to source cpp files to turn on the debug macros for use. #define TEST_MACROS_ENABLED #include To turn off the the test macros. #define TEST_MACROS_ENABLEDoff #include ########################################### */ #ifndef TEST_MACROS_ENABLED_ONCE #define TEST_MACROS_ENABLED_ONCE #ifdef TEST_MACROS_ENABLED #include #include #define DEBUGI qInfo().noquote() << "INFO;" #define DEBUGD qInfo().noquote() << "DEBUG;" #define DEBUGQ qDebug().noquote() #define DEBUGW qWarning().noquote() #define DEBUGC qCritical().noquote() #define DEBUGF DEBUGI <10) return nullptr; if (mode==debugDisplay) { DEBUGF O(indent) O(widget) ; } else if (mode==returnQTextEdit){ if(QTextEdit* te = dynamic_cast(widget)) { return widget ; }; } const QList list = widget->children(); for (int i = 0; i < list.size(); ++i) { QWidget *next_widget = dynamic_cast(list.at(i)); if (!next_widget) continue; QWidget* found=findQTextEditdisplaywidgets(next_widget,mode,objectName,recurseCount); if (found) return found; } if (mode==debugDisplay && recurseCount==1) DEBUGF O("==================================================="); return nullptr; } } #endif // TEST_ROUTIMES_ENABLED #endif // TEST_MACROS_ENABLED_ONCE