debug.cpp 3.21 KB
Newer Older
Dimitri van Heesch's avatar
Dimitri van Heesch committed
1 2
/******************************************************************************
 *
3
 * 
Dimitri van Heesch's avatar
Dimitri van Heesch committed
4
 *
Dimitri van Heesch's avatar
Dimitri van Heesch committed
5
 * Copyright (C) 1997-2014 by Dimitri van Heesch.
Dimitri van Heesch's avatar
Dimitri van Heesch committed
6 7 8 9 10 11 12
 *
 * Permission to use, copy, modify, and distribute this software and its
 * documentation under the terms of the GNU General Public License is hereby 
 * granted. No representations are made about the suitability of this software 
 * for any purpose. It is provided "as is" without express or implied warranty.
 * See the GNU General Public License for more details.
 *
Dimitri van Heesch's avatar
Dimitri van Heesch committed
13 14
 * Documents produced by Doxygen are derivative works derived from the
 * input used in their production; they are not affected by this license.
Dimitri van Heesch's avatar
Dimitri van Heesch committed
15 16 17 18 19
 *
 */

#include <stdarg.h>
#include <stdio.h>
20

Dimitri van Heesch's avatar
Dimitri van Heesch committed
21 22
#include <qdict.h>

23
#include "debug.h"
24
#include "message.h"
Dimitri van Heesch's avatar
Dimitri van Heesch committed
25

Dimitri van Heesch's avatar
Dimitri van Heesch committed
26 27
//------------------------------------------------------------------------

Dimitri van Heesch's avatar
Dimitri van Heesch committed
28
/** Helper struct representing a mapping from debug label to a debug ID */
Dimitri van Heesch's avatar
Dimitri van Heesch committed
29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
struct LabelMap
{
  const char *name;
  Debug::DebugMask event;
};

static LabelMap s_labels[] =
{
  { "findmembers",  Debug::FindMembers  },
  { "functions",    Debug::Functions    },
  { "variables",    Debug::Variables    },
  { "preprocessor", Debug::Preprocessor },
  { "classes",      Debug::Classes      },
  { "commentcnv",   Debug::CommentCnv   },
  { "commentscan",  Debug::CommentScan  },
  { "validate",     Debug::Validate     },
  { "printtree",    Debug::PrintTree    },
  { "time",         Debug::Time         },
  { "extcmd",       Debug::ExtCmd       },
48
  { "markdown",     Debug::Markdown     },
49
  { "filteroutput", Debug::FilterOutput },
50
  { "lex",          Debug::Lex },
Dimitri van Heesch's avatar
Dimitri van Heesch committed
51 52 53
  { 0,             (Debug::DebugMask)0  }
};

Dimitri van Heesch's avatar
Dimitri van Heesch committed
54
/** Class representing a mapping from debug labels to debug IDs. */
Dimitri van Heesch's avatar
Dimitri van Heesch committed
55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
class LabelMapper
{
  public:
    LabelMapper() : m_map(17) 
    {
      m_map.setAutoDelete(TRUE);
      LabelMap *p = s_labels;
      while (p->name)
      {
        m_map.insert(p->name,new Debug::DebugMask(p->event));
        p++;
      }
    }
    Debug::DebugMask *find(const char *s) const 
    {
      if (s==0) return 0;
      return m_map.find(s);
    }
  private:
    QDict<Debug::DebugMask> m_map;
};

static LabelMapper g_labelMapper;

//------------------------------------------------------------------------

Dimitri van Heesch's avatar
Dimitri van Heesch committed
81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96
Debug::DebugMask Debug::curMask = Debug::Quiet;
int Debug::curPrio = 0;

void Debug::print(DebugMask mask,int prio,const char *fmt,...)
{
  if ((curMask&mask) && prio<=curPrio)
  {
    va_list args;
    va_start(args,fmt);
    vfprintf(stdout, fmt, args);
    va_end(args);
  }
}

static int labelToEnumValue(const char *l)
{
97
  QCString label=l;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
98 99
  Debug::DebugMask *event = g_labelMapper.find(label.lower());
  if (event) return *event; else return 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
100 101
}

102
int Debug::setFlag(const char *lab)
Dimitri van Heesch's avatar
Dimitri van Heesch committed
103
{
104
  int retVal = labelToEnumValue(lab);
Dimitri van Heesch's avatar
Dimitri van Heesch committed
105
  curMask = (DebugMask)(curMask | labelToEnumValue(lab));   
106
  return retVal;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
107 108 109 110 111 112 113 114 115 116 117
}

void Debug::clearFlag(const char *lab)
{
  curMask = (DebugMask)(curMask & ~labelToEnumValue(lab));
}

void Debug::setPriority(int p)
{
  curPrio = p;
}
118 119 120 121 122

bool Debug::isFlagSet(DebugMask mask)
{
  return (curMask & mask)!=0;
}
Dimitri van Heesch's avatar
Dimitri van Heesch committed
123

124 125 126
void Debug::printFlags(void)
{
  int i;
127
  for (i = 0; i < (int)(sizeof(s_labels)/sizeof(*s_labels)); i++)
128 129 130 131 132 133 134
  {
     if (s_labels[i].name)
     {
        msg("\t%s\n",s_labels[i].name);
     }
  }
}