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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
|
/***************************************************************************
saparser.h - description
-------------------
begin : Wed Feb 11 2004
copyright : (C) 2004 Andras Mantia <[email protected]>
***************************************************************************/
/***************************************************************************
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
#ifndef SAPARSER_H
#define SAPARSER_H
//qt includes
#include <qobject.h>
#include <qregexp.h>
#include <qvaluestack.h>
//own includes
#include "tag.h" //for AreaStruct
//forward definitions
struct DTDStruct;
class Document;
class QString;
class QStringList;
class QTimer;
class KDirWatch;
class SAGroupParser;
/**
This class is used to parse a special area (script) in the document.
*/
class SAParser: public QObject
{
Q_OBJECT
public:
SAParser();
virtual ~SAParser();
void setParsingEnabled(bool enabled);
bool parsingEnabled() {return m_parsingEnabled;}
Document *write() {return m_write;}
void init(Node *node, Document *write);
/*
Parses the document for special areas (eg. scripts).
specialArea: the area (start/end position) in the document that may contain the special
area. It may end before the end position.
areaStartString: the special area starting string
forcedAreaEndString: force this as the special area ending string.
parentNode: the Node under where the special area goes
fullParse: the script node will be fully parsed for groups, structures or so. If false, only the script beginning and end will be determined.
synchronous: if true, the function does not return until the parsing is finished, otherwise
return immediately.
return value: in synchronous case returns the last inserted node, otherwise return 0L.
*/
Node* parseArea(const AreaStruct &specialArea,
const QString &areaStartString,
const QString &forcedAreaEndString,
Node *parentNode,
bool fullParse, bool synchronous);
/** Returns the line where the last parsing run ended. */
int lastParsedLine() {return m_lastParsedLine;}
/** Returns the column where the last parsing run ended. */
int lastParsedColumn() {return m_lastParsedCol;}
void parseInDetail(bool synchronous);
void setSpecialInsideXml(bool insideXml) {m_specialInsideXml = insideXml;}
public slots:
void slotGroupParsingDone(SAGroupParser *groupParser);
private slots:
/** Parses one line and calls itself with a singleshot timer to parse the next line. */
bool slotParseOneLine();
void slotParseNodeInDetail();
signals:
void rebuildStructureTree(bool);
void cleanGroups();
private:
//private methods
Node* parsingDone();
//private structures
struct ContextStruct{
int type;
AreaStruct area;
QString startString;
Node *parentNode;
Node *lastNode;
};
enum ContextType {
Unknown = 0,
Text,
Comment,
QuotedString,
Group
};
//private member variables
bool m_useNext;
bool m_parsingEnabled;
bool m_synchronous;
Document* m_write;
Node* m_baseNode;
Node* m_lastParsedNode;
Node* m_currentNode; ///< the currently parsed script node for details. Changes only after the whole area between m_currentNode and m_currentNode->next is parsed.
int m_lastParsedLine, m_lastParsedCol;
const DTDStruct *m_dtd;
QRegExp m_quotesRx;
bool m_specialInsideXml; //< true if the special area is defined inside a tag, like the PHP in <a href="<? echo $a ?>">
bool s_contextFound;
ContextStruct s_currentContext;
Node *s_parentNode;
bool s_searchContent;
QString s_searchedString;
QString s_textLine;
int s_line, s_col;
int s_endLine, s_endCol;
bool s_fullParse;
QString s_areaEndString;
bool s_searchForAreaEnd;
bool s_searchForForcedAreaEnd;
QRegExp s_forcedAreaRx;
const DTDStruct *s_dtd;
bool s_searchForSpecialAreas;
ContextStruct s_context;
QValueStack<ContextStruct> s_contextStack;
ContextStruct s_previousContext;
Node *s_currentNode; ///< the current detailed node while parsing for details
Node *s_returnNode;
bool s_useReturnVars;
Node *s_next;
QValueList<SAGroupParser*> m_groupParsers;
QTimer *m_parseOneLineTimer;
QTimer *m_parseInDetailTimer;
};
#endif
|