blob: 528549ee465daa56da039eb4dd996968f092a6cc (
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
|
/* This is RTF to HTML converter, implemented as a text filter, generally.
Copyright (C) 2003 Valentin Lavrinenko, [email protected]
available at http://rtf2html.sf.net
Original available under the terms of the GNU LGPL2, and according
to those terms, relicensed under the GNU GPL2 for inclusion in Tellico */
/***************************************************************************
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of version 2 of the GNU General Public License as *
* published by the Free Software Foundation; *
* *
***************************************************************************/
#ifndef __RTF_TOOLS_H__
#define __RTF_TOOLS_H__
#include "common.h"
#include "rtf_keyword.h"
namespace rtf {
template <class InputIter>
void skip_group(InputIter &iter);
/****************************************
function assumes that file pointer points AFTER the opening brace
and that the group is really closed. cs is caller's curchar.
Returns the character that comes after the enclosing brace.
*****************************************/
template <class InputIter>
void skip_group(InputIter &iter)
{
int cnt=1;
while (cnt)
{
switch (*iter++)
{
case '{':
cnt++;
break;
case '}':
cnt--;
break;
case '\\':
{
rtf_keyword kw(iter);
if (!kw.is_control_char() && kw.keyword()==rtf_keyword::rkw_bin
&& kw.parameter()>0)
{
std::advance(iter, kw.parameter());
}
break;
}
}
}
}
}
#endif
|