LoggerDefines.h 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. /*=============================================================================
  2. Copyright (C) 2012 Allied Vision Technologies. All Rights Reserved.
  3. Redistribution of this file, in original or modified form, without
  4. prior written consent of Allied Vision Technologies is prohibited.
  5. -------------------------------------------------------------------------------
  6. File: LoggerDefines.h
  7. Description: Definition of macros for logging.
  8. -------------------------------------------------------------------------------
  9. THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED
  10. WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF TITLE,
  11. NON-INFRINGEMENT, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  12. DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
  13. INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
  14. (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  15. LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
  16. AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
  17. TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  18. OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  19. =============================================================================*/
  20. #ifndef AVT_VMBAPI_LOGGERDEFINES_H
  21. #define AVT_VMBAPI_LOGGERDEFINES_H
  22. #include <VimbaCPP/Include/UserLoggerDefines.h>
  23. #ifndef USER_LOGGER
  24. #include <VimbaCPP/Include/FileLogger.h>
  25. namespace AVT {
  26. namespace VmbAPI {
  27. #define LOGGER_DECL FileLogger
  28. #define LOGGER_DEF FileLogger( "VimbaCPP.log", true )
  29. #define LOGGER_LOG( logger, loggingInfo ) if ( NULL != (logger) ) (logger)->Log( loggingInfo );
  30. // These are all uses of LOGGER_DECL logger declarations
  31. typedef LOGGER_DECL* Logger;
  32. }}
  33. #else
  34. #include <VimbaCPP/Include/UserLoggerDefines.h>
  35. #endif
  36. #include <VimbaCPP/Include/VimbaSystem.h>
  37. #define LOG_FREE_TEXT( txt ) std::string strExc( txt );\
  38. strExc.append( " in function: " );\
  39. strExc.append( __FUNCTION__ );\
  40. LOGGER_LOG( VimbaSystem::GetInstance().GetLogger(), strExc );
  41. #endif