Nuvoton
/
NuMaker-mbed-emWin-example
NuMaker emWin HMI
emWin/Include/GUI_Debug.h
- Committer:
- csyang2
- Date:
- 2019-02-27
- Revision:
- 1:c0f972361605
File content as of revision 1:c0f972361605:
/********************************************************************* * SEGGER Software GmbH * * Solutions for real time microcontroller applications * ********************************************************************** * * * (c) 1996 - 2018 SEGGER Microcontroller GmbH * * * * Internet: www.segger.com Support: support@segger.com * * * ********************************************************************** ** emWin V5.48 - Graphical user interface for embedded applications ** All Intellectual Property rights in the Software belongs to SEGGER. emWin is protected by international copyright laws. Knowledge of the source code may not be used to write a similar product. This file may only be used in accordance with the following terms: The software has been licensed by SEGGER Software GmbH to Nuvoton Technology Corporationat the address: No. 4, Creation Rd. III, Hsinchu Science Park, Taiwan for the purposes of creating libraries for its Arm Cortex-M and Arm9 32-bit microcontrollers, commercialized and distributed by Nuvoton Technology Corporation under the terms and conditions of an End User License Agreement supplied with the libraries. Full source code is available at: www.segger.com We appreciate your understanding and fairness. ---------------------------------------------------------------------- Licensing information Licensor: SEGGER Software GmbH Licensed to: Nuvoton Technology Corporation, No. 4, Creation Rd. III, Hsinchu Science Park, 30077 Hsinchu City, Taiwan Licensed SEGGER software: emWin License number: GUI-00735 License model: emWin License Agreement, signed February 27, 2018 Licensed platform: Cortex-M and ARM9 32-bit series microcontroller designed and manufactured by or for Nuvoton Technology Corporation ---------------------------------------------------------------------- Support and Update Agreement (SUA) SUA period: 2018-03-26 - 2019-03-27 Contact to extend SUA: sales@segger.com ---------------------------------------------------------------------- File : GUI_Debug.h Purpose : Debug macros ---------------------------------------------------------------------- Debug macros for logging In the GUI Simulation, all output is transferred into the log window. */ #ifndef GUI_DEBUG_H #define GUI_DEBUG_H #include <stddef.h> #include "GUI.h" #define GUI_DEBUG_LEVEL_NOCHECK 0 /* No run time checks are performed */ #define GUI_DEBUG_LEVEL_CHECK_PARA 1 /* Parameter checks are performed to avoid crashes */ #define GUI_DEBUG_LEVEL_CHECK_ALL 2 /* Parameter checks and consistency checks are performed */ #define GUI_DEBUG_LEVEL_LOG_ERRORS 3 /* Errors are recorded */ #define GUI_DEBUG_LEVEL_LOG_WARNINGS 4 /* Errors & Warnings are recorded */ #define GUI_DEBUG_LEVEL_LOG_ALL 5 /* Errors, Warnings and Messages are recorded. */ #ifndef GUI_DEBUG_LEVEL #ifdef WIN32 #define GUI_DEBUG_LEVEL GUI_DEBUG_LEVEL_LOG_WARNINGS /* Simulation should log all warnings */ #else #define GUI_DEBUG_LEVEL GUI_DEBUG_LEVEL_NOCHECK /* For most targets, min. size is important */ #endif #endif #define GUI_LOCK_H(hMem) GUI_ALLOC_LockH(hMem) #define GUI_UNLOCK_H(pMem) GUI_ALLOC_UnlockH((void **)&pMem) /******************************************************************* * * Commandline * ******************************************************************** */ #ifdef WIN32 #define GUI_DEBUG_GETCMDLINE() SIM_GetCmdLine() #else #define GUI_DEBUG_GETCMDLINE() 0 #endif /******************************************************************* * * Error macros * ******************************************************************** */ /* Make sure the macros are actually defined */ #if GUI_DEBUG_LEVEL >= GUI_DEBUG_LEVEL_LOG_ERRORS #define GUI_DEBUG_ERROROUT(s) GUI_ErrorOut(s) #define GUI_DEBUG_ERROROUT1(s,p0) GUI_ErrorOut1(s,p0) #define GUI_DEBUG_ERROROUT2(s,p0,p1) GUI_ErrorOut2(s,p0,p1) #define GUI_DEBUG_ERROROUT3(s,p0,p1,p2) GUI_ErrorOut3(s,p0,p1,p2) #define GUI_DEBUG_ERROROUT4(s,p0,p1,p2,p3) GUI_ErrorOut4(s,p0,p1,p2,p3) #define GUI_DEBUG_ERROROUT_IF(exp,s) { if (exp) GUI_DEBUG_ERROROUT(s); } #define GUI_DEBUG_ERROROUT1_IF(exp,s,p0) { if (exp) GUI_DEBUG_ERROROUT1(s,p0); } #define GUI_DEBUG_ERROROUT2_IF(exp,s,p0,p1) { if (exp) GUI_DEBUG_ERROROUT2(s,p0,p1); } #define GUI_DEBUG_ERROROUT3_IF(exp,s,p0,p1,p2) { if (exp) GUI_DEBUG_ERROROUT3(s,p0,p1,p2); } #define GUI_DEBUG_ERROROUT4_IF(exp,s,p0,p1,p2,p3) { if (exp) GUI_DEBUG_ERROROUT4(s,p0,p1,p2,p3); } #else #define GUI_DEBUG_ERROROUT(s) #define GUI_DEBUG_ERROROUT1(s,p0) #define GUI_DEBUG_ERROROUT2(s,p0,p1) #define GUI_DEBUG_ERROROUT3(s,p0,p1,p2) #define GUI_DEBUG_ERROROUT4(s,p0,p1,p2,p3) #define GUI_DEBUG_ERROROUT_IF(exp,s) #define GUI_DEBUG_ERROROUT1_IF(exp,s,p0) #define GUI_DEBUG_ERROROUT2_IF(exp,s,p0,p1) #define GUI_DEBUG_ERROROUT3_IF(exp,s,p0,p1,p2) #define GUI_DEBUG_ERROROUT4_IF(exp,s,p0,p1,p2,p3) #endif /******************************************************************* * * Warning macros * ******************************************************************** */ /* Make sure the macros are actually defined */ #if GUI_DEBUG_LEVEL >= GUI_DEBUG_LEVEL_LOG_WARNINGS #define GUI_DEBUG_WARN(s) GUI_Warn(s) #define GUI_DEBUG_WARN1(s,p0) GUI_Warn1(s,p0) #define GUI_DEBUG_WARN2(s,p0,p1) GUI_Warn2(s,p0,p1) #define GUI_DEBUG_WARN3(s,p0,p1,p2) GUI_Warn3(s,p0,p1,p2) #define GUI_DEBUG_WARN4(s,p0,p1,p2,p3) GUI_Warn4(s,p0,p1,p2,p3) #define GUI_DEBUG_WARN_IF(exp,s) { if (exp) GUI_DEBUG_WARN(s); } #define GUI_DEBUG_WARN1_IF(exp,s,p0) { if (exp) GUI_DEBUG_WARN1(s,p0); } #define GUI_DEBUG_WARN2_IF(exp,s,p0,p1) { if (exp) GUI_DEBUG_WARN2(s,p0,p1); } #define GUI_DEBUG_WARN3_IF(exp,s,p0,p1,p2) { if (exp) GUI_DEBUG_WARN3(s,p0,p1,p2); } #define GUI_DEBUG_WARN4_IF(exp,s,p0,p1,p2,p3) { if (exp) GUI_DEBUG_WARN4(s,p0,p1,p2,p3); } #else #define GUI_DEBUG_WARN(s) #define GUI_DEBUG_WARN1(s,p0) #define GUI_DEBUG_WARN2(s,p0,p1) #define GUI_DEBUG_WARN3(s,p0,p1,p2) #define GUI_DEBUG_WARN4(s,p0,p1,p2,p3) #define GUI_DEBUG_WARN_IF(exp,s) #define GUI_DEBUG_WARN1_IF(exp,s,p0) #define GUI_DEBUG_WARN2_IF(exp,s,p0,p1) #define GUI_DEBUG_WARN3_IF(exp,s,p0,p1,p2) #define GUI_DEBUG_WARN4_IF(exp,s,p0,p1,p2,p3) #endif /******************************************************************* * * Logging macros * ******************************************************************** */ /* Make sure the macros are actually defined */ #if GUI_DEBUG_LEVEL >= GUI_DEBUG_LEVEL_LOG_ALL #define GUI_DEBUG_LOG(s) GUI_Log(s) #define GUI_DEBUG_LOG1(s,p0) GUI_Log1(s,p0) #define GUI_DEBUG_LOG2(s,p0,p1) GUI_Log2(s,p0,p1) #define GUI_DEBUG_LOG3(s,p0,p1,p2) GUI_Log3(s,p0,p1,p2) #define GUI_DEBUG_LOG4(s,p0,p1,p2,p3) GUI_Log4(s,p0,p1,p2,p3) #define GUI_DEBUG_LOG_IF(exp,s) { if (exp) GUI_DEBUG_LOG(s); } #define GUI_DEBUG_LOG1_IF(exp,s,p0) { if (exp) GUI_DEBUG_LOG1(s,p0); } #define GUI_DEBUG_LOG2_IF(exp,s,p0,p1) { if (exp) GUI_DEBUG_LOG2(s,p0,p1); } #define GUI_DEBUG_LOG3_IF(exp,s,p0,p1,p2) { if (exp) GUI_DEBUG_LOG3(s,p0,p1,p2); } #define GUI_DEBUG_LOG4_IF(exp,s,p0,p1,p2,p3) { if (exp) GUI_DEBUG_LOG4(s,p0,p1,p2,p3); } #else #define GUI_DEBUG_LOG(s) #define GUI_DEBUG_LOG1(s,p0) #define GUI_DEBUG_LOG2(s,p0,p1) #define GUI_DEBUG_LOG3(s,p0,p1,p2) #define GUI_DEBUG_LOG4(s,p0,p1,p2,p3) #define GUI_DEBUG_LOG_IF(exp,s) #define GUI_DEBUG_LOG1_IF(exp,s,p0) #define GUI_DEBUG_LOG2_IF(exp,s,p0,p1) #define GUI_DEBUG_LOG3_IF(exp,s,p0,p1,p2) #define GUI_DEBUG_LOG4_IF(exp,s,p0,p1,p2,p3) #endif /******************************************************************* * * Asserts * ******************************************************************** */ #if GUI_DEBUG_LEVEL >= GUI_DEBUG_LEVEL_LOG_ERRORS #define GUI_DEBUG_ASSERT(exp) { if (!exp) GUI_DEBUG_ERROROUT(#exp); } #else #define GUI_DEBUG_ASSERT(exp) #endif #endif /* LCD_H */ /*************************** End of file ****************************/