debug.cpp 2.91 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-2013 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"
Dimitri van Heesch's avatar
Dimitri van Heesch committed
24

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

Dimitri van Heesch's avatar
Dimitri van Heesch committed
27
/** Helper struct representing a mapping from debug label to a debug ID */
Dimitri van Heesch's avatar
Dimitri van Heesch committed
28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46
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       },
47
  { "markdown",     Debug::Markdown     },
48
  { "filteroutput", Debug::FilterOutput },
Dimitri van Heesch's avatar
Dimitri van Heesch committed
49 50 51
  { 0,             (Debug::DebugMask)0  }
};

Dimitri van Heesch's avatar
Dimitri van Heesch committed
52
/** Class representing a mapping from debug labels to debug IDs. */
Dimitri van Heesch's avatar
Dimitri van Heesch committed
53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
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
79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94
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)
{
95
  QCString label=l;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
96 97
  Debug::DebugMask *event = g_labelMapper.find(label.lower());
  if (event) return *event; else return 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113
}

void Debug::setFlag(const char *lab)
{
  curMask = (DebugMask)(curMask | labelToEnumValue(lab));   
}

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

void Debug::setPriority(int p)
{
  curPrio = p;
}
114 115 116 117 118

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