Blame src/debug.cpp

Packit 1c1d7e
/******************************************************************************
Packit 1c1d7e
 *
Packit 1c1d7e
 * 
Packit 1c1d7e
 *
Packit 1c1d7e
 * Copyright (C) 1997-2015 by Dimitri van Heesch.
Packit 1c1d7e
 *
Packit 1c1d7e
 * Permission to use, copy, modify, and distribute this software and its
Packit 1c1d7e
 * documentation under the terms of the GNU General Public License is hereby 
Packit 1c1d7e
 * granted. No representations are made about the suitability of this software 
Packit 1c1d7e
 * for any purpose. It is provided "as is" without express or implied warranty.
Packit 1c1d7e
 * See the GNU General Public License for more details.
Packit 1c1d7e
 *
Packit 1c1d7e
 * Documents produced by Doxygen are derivative works derived from the
Packit 1c1d7e
 * input used in their production; they are not affected by this license.
Packit 1c1d7e
 *
Packit 1c1d7e
 */
Packit 1c1d7e
Packit 1c1d7e
#include <stdarg.h>
Packit 1c1d7e
#include <stdio.h>
Packit 1c1d7e
Packit 1c1d7e
#include <qdict.h>
Packit 1c1d7e
Packit 1c1d7e
#include "debug.h"
Packit 1c1d7e
#include "message.h"
Packit 1c1d7e
Packit 1c1d7e
//------------------------------------------------------------------------
Packit 1c1d7e
Packit 1c1d7e
/** Helper struct representing a mapping from debug label to a debug ID */
Packit 1c1d7e
struct LabelMap
Packit 1c1d7e
{
Packit 1c1d7e
  const char *name;
Packit 1c1d7e
  Debug::DebugMask event;
Packit 1c1d7e
};
Packit 1c1d7e
Packit 1c1d7e
static LabelMap s_labels[] =
Packit 1c1d7e
{
Packit 1c1d7e
  { "findmembers",  Debug::FindMembers  },
Packit 1c1d7e
  { "functions",    Debug::Functions    },
Packit 1c1d7e
  { "variables",    Debug::Variables    },
Packit 1c1d7e
  { "preprocessor", Debug::Preprocessor },
Packit 1c1d7e
  { "classes",      Debug::Classes      },
Packit 1c1d7e
  { "commentcnv",   Debug::CommentCnv   },
Packit 1c1d7e
  { "commentscan",  Debug::CommentScan  },
Packit 1c1d7e
  { "validate",     Debug::Validate     },
Packit 1c1d7e
  { "printtree",    Debug::PrintTree    },
Packit 1c1d7e
  { "time",         Debug::Time         },
Packit 1c1d7e
  { "extcmd",       Debug::ExtCmd       },
Packit 1c1d7e
  { "markdown",     Debug::Markdown     },
Packit 1c1d7e
  { "filteroutput", Debug::FilterOutput },
Packit 1c1d7e
  { "lex",          Debug::Lex },
Packit 1c1d7e
  { 0,             (Debug::DebugMask)0  }
Packit 1c1d7e
};
Packit 1c1d7e
Packit 1c1d7e
/** Class representing a mapping from debug labels to debug IDs. */
Packit 1c1d7e
class LabelMapper
Packit 1c1d7e
{
Packit 1c1d7e
  public:
Packit 1c1d7e
    LabelMapper() : m_map(17) 
Packit 1c1d7e
    {
Packit 1c1d7e
      m_map.setAutoDelete(TRUE);
Packit 1c1d7e
      LabelMap *p = s_labels;
Packit 1c1d7e
      while (p->name)
Packit 1c1d7e
      {
Packit 1c1d7e
        m_map.insert(p->name,new Debug::DebugMask(p->event));
Packit 1c1d7e
        p++;
Packit 1c1d7e
      }
Packit 1c1d7e
    }
Packit 1c1d7e
    Debug::DebugMask *find(const char *s) const 
Packit 1c1d7e
    {
Packit 1c1d7e
      if (s==0) return 0;
Packit 1c1d7e
      return m_map.find(s);
Packit 1c1d7e
    }
Packit 1c1d7e
  private:
Packit 1c1d7e
    QDict<Debug::DebugMask> m_map;
Packit 1c1d7e
};
Packit 1c1d7e
Packit 1c1d7e
static LabelMapper g_labelMapper;
Packit 1c1d7e
Packit 1c1d7e
//------------------------------------------------------------------------
Packit 1c1d7e
Packit 1c1d7e
Debug::DebugMask Debug::curMask = Debug::Quiet;
Packit 1c1d7e
int Debug::curPrio = 0;
Packit 1c1d7e
Packit 1c1d7e
void Debug::print(DebugMask mask,int prio,const char *fmt,...)
Packit 1c1d7e
{
Packit 1c1d7e
  if ((curMask&mask) && prio<=curPrio)
Packit 1c1d7e
  {
Packit 1c1d7e
    va_list args;
Packit 1c1d7e
    va_start(args,fmt);
Packit 1c1d7e
    vfprintf(stdout, fmt, args);
Packit 1c1d7e
    va_end(args);
Packit 1c1d7e
  }
Packit 1c1d7e
}
Packit 1c1d7e
Packit 1c1d7e
static int labelToEnumValue(const char *l)
Packit 1c1d7e
{
Packit 1c1d7e
  QCString label=l;
Packit 1c1d7e
  Debug::DebugMask *event = g_labelMapper.find(label.lower());
Packit 1c1d7e
  if (event) return *event; else return 0;
Packit 1c1d7e
}
Packit 1c1d7e
Packit 1c1d7e
int Debug::setFlag(const char *lab)
Packit 1c1d7e
{
Packit 1c1d7e
  int retVal = labelToEnumValue(lab);
Packit 1c1d7e
  curMask = (DebugMask)(curMask | labelToEnumValue(lab));   
Packit 1c1d7e
  return retVal;
Packit 1c1d7e
}
Packit 1c1d7e
Packit 1c1d7e
void Debug::clearFlag(const char *lab)
Packit 1c1d7e
{
Packit 1c1d7e
  curMask = (DebugMask)(curMask & ~labelToEnumValue(lab));
Packit 1c1d7e
}
Packit 1c1d7e
Packit 1c1d7e
void Debug::setPriority(int p)
Packit 1c1d7e
{
Packit 1c1d7e
  curPrio = p;
Packit 1c1d7e
}
Packit 1c1d7e
Packit 1c1d7e
bool Debug::isFlagSet(DebugMask mask)
Packit 1c1d7e
{
Packit 1c1d7e
  return (curMask & mask)!=0;
Packit 1c1d7e
}
Packit 1c1d7e
Packit 1c1d7e
void Debug::printFlags(void)
Packit 1c1d7e
{
Packit 1c1d7e
  int i;
Packit 1c1d7e
  for (i = 0; i < (int)(sizeof(s_labels)/sizeof(*s_labels)); i++)
Packit 1c1d7e
  {
Packit 1c1d7e
     if (s_labels[i].name)
Packit 1c1d7e
     {
Packit 1c1d7e
        msg("\t%s\n",s_labels[i].name);
Packit 1c1d7e
     }
Packit 1c1d7e
  }
Packit 1c1d7e
}