Implement GetNanoseconds() with std::chrono.
[platform/core/uifw/dali-core.git] / dali / integration-api / debug.cpp
index dc6a90c..ebbc339 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2014 Samsung Electronics Co., Ltd.
+ * Copyright (c) 2020 Samsung Electronics Co., Ltd.
  *
  * Licensed under the Apache License, Version 2.0 (the "License");
  * you may not use this file except in compliance with the License.
 #include <dali/integration-api/debug.h>
 
 // EXTERNAL INCLUDES
-#include <cstdio>
+#include <chrono>
 #include <cstdarg>
-#include <cstring>
-#include <cstdlib>
-#include <sstream>
-#include <iomanip>
-#include <ctime>
-
-// INTERNAL INCLUDES
-#include <dali/public-api/common/constants.h>
-#include <dali/public-api/math/matrix3.h>
-#include <dali/public-api/math/matrix.h>
-#include <dali/public-api/math/vector3.h>
-#include <dali/public-api/math/vector4.h>
-#include <dali/public-api/math/quaternion.h>
-#include <dali/internal/event/common/thread-local-storage.h>
 
 namespace Dali
 {
+#ifdef DEBUG_ENABLED
 
-namespace // unnamed namespace
-{
-
-const uint64_t NANOSECONDS_PER_SECOND = 1e+9;
-
-/**
- * Generic function to print out any 2-Dimensional array
- * @param[in] data pointer to the source data stored as float[rows][cols]
- * @param[in] rows number of rows in 2D array
- * @param[in] cols number of columns in 2D array
- * @param[in] precision - the precision to write the float data.
- * @param[in] indent - the indent level to use.
- * @return string - the text representation of the 2D array
- */
-std::string Array2DToString(const float *data, unsigned int rows, unsigned int cols, size_t precision, size_t indent)
-{
-  std::ostringstream oss;
-
-  std::ios_base::fmtflags mask = oss.flags();
-  mask &= ~std::ios_base::scientific;
-  mask |=  std::ios_base::fixed;
-
-  for(unsigned int rowIdx = 0; rowIdx < rows; rowIdx++)
-  {
-    oss  << std::setw(indent) << std::setfill(' ') << ' ' << "[ ";
-    oss  << std::setfill(' ') << std::setprecision(precision) << std::right << std::setiosflags(mask);
-
-    for(unsigned int colIdx = 0; colIdx < cols; colIdx++)
-    {
-      oss << std::setw(precision + 6) << (*data++) << ' ';
-    }
-
-    oss << ']' << std::endl;
-  }
-
-  return oss.str();
-}
+// Fake globals for gdb typedefs
+Dali::DebugPropertyValueArray gValueArray;
+Dali::DebugPropertyValueMap   gValueMap;
 
-}
+#endif
 
 namespace Integration
 {
-
 namespace Log
 {
-
-__thread LogFunction gthreadLocalLogFunction = NULL;
+thread_local LogFunction gthreadLocalLogFunction = nullptr;
 
 /* Forward declarations */
-std::string FormatToString(const char *format, ...);
-std::string ArgListToString(const char *format, va_list args);
+std::string FormatToString(const charformat, ...);
+std::string ArgListToString(const charformat, va_list args);
 
 void LogMessage(DebugPriority priority, const char* format, ...)
 {
-  if ( !gthreadLocalLogFunction )
+  if(!gthreadLocalLogFunction)
   {
     return;
   }
@@ -103,7 +54,7 @@ void LogMessage(DebugPriority priority, const char* format, ...)
   std::string message = ArgListToString(format, arg);
   va_end(arg);
 
-  gthreadLocalLogFunction(priority,message);
+  gthreadLocalLogFunction(priority, message);
 }
 
 void InstallLogFunction(const LogFunction& logFunction)
@@ -116,7 +67,7 @@ void InstallLogFunction(const LogFunction& logFunction)
 
 void UninstallLogFunction()
 {
-  gthreadLocalLogFunction = NULL;
+  gthreadLocalLogFunction = nullptr;
 }
 
 #ifdef DEBUG_ENABLED
@@ -125,11 +76,11 @@ void UninstallLogFunction()
 Filter* Filter::gRender     = Filter::New(Debug::Concise, false, "LOG_RENDER");
 Filter* Filter::gResource   = Filter::New(Debug::Concise, false, "LOG_RESOURCE");
 Filter* Filter::gGLResource = Filter::New(Debug::Concise, false, "LOG_GL_RESOURCE");
-Filter* Filter::gObject     = NULL;
+Filter* Filter::gObject     = nullptr;
 Filter* Filter::gImage      = Filter::New(Debug::Concise, false, "LOG_IMAGE");
 Filter* Filter::gModel      = Filter::New(Debug::Concise, false, "LOG_MODEL");
-Filter* Filter::gNode       = NULL;
-Filter* Filter::gElement    = NULL;
+Filter* Filter::gNode       = nullptr;
+Filter* Filter::gElement    = nullptr;
 Filter* Filter::gActor      = Filter::New(Debug::Concise, false, "LOG_ACTOR");
 Filter* Filter::gShader     = Filter::New(Debug::Concise, false, "LOG_SHADER");
 
@@ -139,27 +90,27 @@ Filter::FilterList* Filter::GetActiveFilters()
   return activeFilters;
 }
 
-Filter* Filter::New( LogLevel level, bool trace, const char * environmentVariableName )
+Filter* Filter::New(LogLevel level, bool trace, const char* environmentVariableName)
 {
-  char * environmentVariableValue = getenv( environmentVariableName );
-  if ( environmentVariableValue )
+  char* environmentVariableValue = getenv(environmentVariableName);
+  if(environmentVariableValue)
   {
     unsigned int envLevel(0);
-    char envTraceString(0);
-    sscanf( environmentVariableValue, "%u,%c", &envLevel, &envTraceString );
+    char         envTraceString(0);
+    sscanf(environmentVariableValue, "%u,%c", &envLevel, &envTraceString);
 
-    if ( envLevel > Verbose )
+    if(envLevel > Verbose)
     {
       envLevel = Verbose;
     }
-    level = LogLevel( envLevel );
+    level = LogLevel(envLevel);
 
     // Just use 'f' and 't' as it's faster than doing full string comparisons
-    if ( envTraceString == 't' )
+    if(envTraceString == 't')
     {
       trace = true;
     }
-    else if ( envTraceString == 'f' )
+    else if(envTraceString == 'f')
     {
       trace = false;
     }
@@ -193,6 +144,13 @@ void Filter::DisableGlobalTrace()
   }
 }
 
+void Filter::SetGlobalLogLevel(LogLevel level)
+{
+  for(FilterIter iter = GetActiveFilters()->begin(); iter != GetActiveFilters()->end(); iter++)
+  {
+    (*iter)->SetLogLevel(level);
+  }
+}
 
 void Filter::Log(LogLevel level, const char* format, ...)
 {
@@ -201,28 +159,28 @@ void Filter::Log(LogLevel level, const char* format, ...)
     va_list arg;
     va_start(arg, format);
 
-    if( mTraceEnabled )
+    if(mTraceEnabled)
     {
-      char *buffer = NULL;
-      int numChars = asprintf( &buffer, "    %-*c %s", mNesting, ':', format );
-      if( numChars >= 0 ) // No error
+      char* buffer   = nullptr;
+      int   numChars = asprintf(&buffer, "    %-*c %s", mNesting, ':', format);
+      if(numChars >= 0) // No error
       {
-        std::string message = ArgListToString( buffer, arg );
-        LogMessage( DebugInfo, message.c_str() );
-        free( buffer );
+        std::string message = ArgListToString(buffer, arg);
+        LogMessage(DebugInfo, message.c_str());
+        free(buffer);
       }
     }
     else
     {
-      std::string message = ArgListToString( format, arg );
-      LogMessage( DebugInfo, message.c_str() );
+      std::string message = ArgListToString(format, arg);
+      LogMessage(DebugInfo, message.c_str());
     }
     va_end(arg);
   }
 }
 
-
-TraceObj::TraceObj(Filter* filter, const char*format, ...) : mFilter(filter)
+TraceObj::TraceObj(Filter* filter, const char* format, ...)
+: mFilter(filter)
 {
   if(mFilter && mFilter->IsTraceEnabled())
   {
@@ -240,7 +198,7 @@ TraceObj::~TraceObj()
 {
   if(mFilter && mFilter->IsTraceEnabled())
   {
-    if (mFilter->mNesting)
+    if(mFilter->mNesting)
     {
       --mFilter->mNesting;
     }
@@ -250,14 +208,13 @@ TraceObj::~TraceObj()
 
 #endif // DEBUG_ENABLED
 
-
-std::string ArgListToString(const char *format, va_list args)
+std::string ArgListToString(const char* format, va_list args)
 {
   std::string str; // empty string
-  if(format != NULL)
+  if(format != nullptr)
   {
-    char* buffer = NULL;
-    int err = vasprintf(&buffer, format, args);
+    char* buffer = nullptr;
+    int   err    = vasprintf(&buffer, format, args);
     if(err >= 0) // No error
     {
       str = buffer;
@@ -267,7 +224,7 @@ std::string ArgListToString(const char *format, va_list args)
   return str;
 }
 
-std::string FormatToString(const char *format, ...)
+std::string FormatToString(const charformat, ...)
 {
   va_list arg;
   va_start(arg, format);
@@ -276,66 +233,19 @@ std::string FormatToString(const char *format, ...)
   return s;
 }
 
-std::string ColorToString(const Vector4& color)
-{
-  std::ostringstream oss;
-  oss << "<R:" << color.r << " G:" << color.g << " B:" << color.b << " A:" << color.a << ">";
-  return oss.str();
-}
-
-std::string Vector4ToString(const Vector4& v, size_t precision, size_t indent)
-{
-  std::ostringstream oss;
-  oss << std::setw(indent+3) << std::setfill(' ') << std::setprecision(precision) << std::right;
-  oss << "<X:" << std::setw(precision+4) << v.x
-      << " Y:" << std::setw(precision+4) << v.y
-      << " Z:" << std::setw(precision+4) << v.z
-      << " W:" << std::setw(precision+4) << v.w << ">";
-  return oss.str();
-}
-
-std::string Vector3ToString(const Vector3& v, size_t precision, size_t indent)
-{
-  std::ostringstream oss;
-  oss << std::setw(indent+3) << std::setfill(' ') << std::setprecision(precision) << std::right << std::setiosflags(std::ios_base::fixed);
-  oss << "<X:" << std::setw(precision+4) << v.x
-      << " Y:" << std::setw(precision+4) << v.y
-      << " Z:" << std::setw(precision+4) << v.z << ">";
-  return oss.str();
-}
+#ifdef DEBUG_ENABLED
 
-std::string QuaternionToString(const Quaternion& q, size_t precision, size_t indent)
+void GetNanoseconds(uint64_t& timeInNanoseconds)
 {
-  std::ostringstream oss;
+  // Get the time of a monotonic clock since its epoch.
+  auto epoch = std::chrono::steady_clock::now().time_since_epoch();
 
-  Vector3 axis;
-  Radian angle;
-  q.ToAxisAngle(axis, angle);
+  auto duration = std::chrono::duration_cast<std::chrono::nanoseconds>(epoch);
 
-  oss << std::setw(indent+3) << std::setfill(' ') << std::setprecision(precision) << std::right;
-  oss << "<A:" << std::setw(precision+4) << Degree( angle ).degree << ", " << Vector3ToString(axis, precision, 0) << ">";
-
-  return oss.str();
-}
-
-std::string Matrix3ToString(const Matrix3& m, size_t precision, size_t indent)
-{
-  return Array2DToString(m.AsFloat(), 3, 3, precision, indent);
+  timeInNanoseconds = static_cast<uint64_t>(duration.count());
 }
 
-std::string MatrixToString(const Matrix& m, size_t precision, size_t indent)
-{
-  return Array2DToString(m.AsFloat(), 4, 4, precision, indent);
-}
-
-void GetNanoseconds( uint64_t& timeInNanoseconds )
-{
-  timespec timeSpec;
-  clock_gettime( CLOCK_MONOTONIC, &timeSpec );
-
-  // Convert all values to uint64_t to match our return type
-  timeInNanoseconds = ( static_cast< uint64_t >( timeSpec.tv_sec ) * NANOSECONDS_PER_SECOND ) + static_cast< uint64_t >( timeSpec.tv_nsec );
-}
+#endif // DEBUG_ENABLED
 
 } // namespace Log