summaryrefslogtreecommitdiffstats
path: root/addon/xmlparse/mainhandler.cpp
blob: c32426fffa825556d3ab922707b201a9fcd9cde7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
/******************************************************************************
 *
 * $Id$
 *
 *
 * Copyright (C) 1997-2001 by Dimitri van Heesch.
 *
 * 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.
 *
 */

#include <qxml.h>
#include "mainhandler.h"

MainHandler::MainHandler() : m_compoundDict(10007), m_compoundNameDict(10007)
{
  m_compounds.setAutoDelete(TRUE);
  addStartHandler("doxygen"); 
  addStartHandler("compounddef",this,&MainHandler::startCompound);
  addEndHandler("doxygen");
  addEndHandler("compounddef");
}

MainHandler::~MainHandler()
{
  printf("MainHandler::~MainHandler()\n");
}

void MainHandler::startCompound(const QXmlAttributes& attrib)
{
  CompoundHandler *compHandler = new CompoundHandler(this);
  compHandler->startCompound(attrib);
  m_compounds.append(compHandler);
}

void MainHandler::insertMemberById(const QString &id,IMember *h)
{
  m_memberDict.insert(id,h);
}

void MainHandler::insertMemberByName(const QString &name,IMember *h)
{
  QList<IMember> *ml = m_memberNameDict[name];
  if (ml)
  {
    ml->append(h);
  }
  else
  {
    ml = new QList<IMember>;
    ml->append(h);
    m_memberNameDict.insert(name,ml);
  }
}

void MainHandler::initialize()
{
  QListIterator<ICompound> mci(m_compounds);
  CompoundHandler *compHandler;
  for (;(compHandler=(CompoundHandler *)mci.current());++mci)
  {
    compHandler->initialize(this);
    m_compoundNameDict.insert(compHandler->name(),compHandler);
    m_compoundDict.insert(compHandler->id(),compHandler);
  }

  // for each member
  QDictIterator< QList<IMember> > mndi(m_memberNameDict);
  QList<IMember> *ml;
  for (;(ml=mndi.current());++mndi)
  {
    QListIterator<IMember> mli(*ml);
    IMember *mem;
    for (;(mem=mli.current());++mli)
    {
      ((MemberHandler*)mem)->initialize(this);
    }
  }

}

class ErrorHandler : public QXmlErrorHandler
{
    public:
      virtual ~ErrorHandler() {}
      bool warning( const QXmlParseException & )
      {
        return FALSE;
      }
      bool error( const QXmlParseException & )
      {
        return FALSE;
      }
      bool fatalError( const QXmlParseException &exception )
      {
        fprintf(stderr,"Fatal error at line %d column %d: %s\n",
            exception.lineNumber(),exception.columnNumber(),
            exception.message().data());
        return FALSE;
      }
      QString errorString() { return ""; }

    private:
      QString errorMsg;
};

IDoxygen *createObjectModelFromXML(const char * xmlFileName)
{
  QFile xmlFile(xmlFileName);
  MainHandler * handler = new MainHandler;
  ErrorHandler errorHandler;
  QXmlInputSource source( xmlFile );
  QXmlSimpleReader reader;
  reader.setContentHandler( handler );
  reader.setErrorHandler( &errorHandler );
  reader.parse( source );
  handler->initialize();
  return handler;
}