File: metaformatcontrol.cpp

package info (click to toggle)
aethera 0.9.3-7
  • links: PTS
  • area: main
  • in suites: woody
  • size: 8,588 kB
  • ctags: 7,282
  • sloc: cpp: 64,544; sh: 9,913; perl: 1,756; makefile: 1,680; python: 258
file content (87 lines) | stat: -rw-r--r-- 2,309 bytes parent folder | download
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
#include <metaformatcontrol.h>
#include <kconfig.h>
#include <qstringlist.h>
#include <qstring.h>
#include <stdio.h>

extern KConfig *GlobalConfig;

MetaFormatControl *MetaFormatControl::thisInstance;

MetaFormatControl::MetaFormatControl()
{
	refresh();
}

MetaFormatControl::~MetaFormatControl()
{
	// save to config file
}

void MetaFormatControl::refresh()
{
	QStrList activeRules;
	if(!GlobalConfig->hasGroup("HTML Parser"))
	{
		printf("Non-existent group.\n");
		return;
	}
	GlobalConfig->setGroup("HTML Parser");
	// reply data
	GlobalConfig->readListEntry("Reply pattern", replyData);
	enableReplyTags=enableBlockReplyTags=replyData.count()!=0;
	// "Xxxxx wrote:"
	GlobalConfig->readListEntry("Wrote pattern", wroteData);
	enableWroteSequence=wroteData.count()!=0;
#ifdef DEBUG_MFC
	printf("WROTE: %d, REPLY: %d\n", enableWroteSequence, enableReplyTags);
#endif
	GlobalConfig->readListEntry("Active rules", activeRules);
	enableAnySequence=activeRules.count()!=0;
	for(QStrListIterator it(activeRules); it.current(); ++it)
	{
		QString group=QString("HTML Rule ")+(*it);
		if(GlobalConfig->hasGroup(group))
		{
			GlobalConfig->setGroup(group);
			QString beginPattern=GlobalConfig->readEntry("Begin pattern");
			QString bodyPattern=GlobalConfig->readEntry("Body pattern");
			QString endPattern=GlobalConfig->readEntry("End pattern");
			if(beginPattern.isEmpty() && endPattern.isEmpty() && !bodyPattern.isEmpty())
				anyData.append(MetaFormatControl::SeqTag(bodyPattern, (*it)));
			if(!beginPattern.isEmpty() && !endPattern.isEmpty() && !bodyPattern.isEmpty())
				anyData.append(MetaFormatControl::SeqTag(beginPattern, bodyPattern, endPattern, (*it)));
		}
	}
		
}

MetaFormatControl *MetaFormatControl::ref()
{
	if(!MetaFormatControl::thisInstance)
	{
		MetaFormatControl::thisInstance=new MetaFormatControl();
	}
	
	return MetaFormatControl::thisInstance;
}

MetaFormatControl::SeqTag::SeqTag()
{
}

MetaFormatControl::SeqTag::SeqTag(const QString &_beginPattern, const QString &_textPattern, const QString &_endPattern, const QString &_tag)
{
	beginPattern=_beginPattern;
	textPattern=_textPattern;
	endPattern=_endPattern;
	tag=_tag;
	strip=true;
}

MetaFormatControl::SeqTag::SeqTag(const QString &_textPattern, const QString &_tag)
{
	textPattern=_textPattern;
	tag=_tag;
	strip=false;
}