Menu

[r3166]: / trunk / Src / USnippetCreditsParser.pas  Maximize  Restore  History

Download this file

170 lines (147 with data), 5.6 kB

  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
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
{
* This Source Code Form is subject to the terms of the Mozilla Public License,
* v. 2.0. If a copy of the MPL was not distributed with this file, You can
* obtain one at http://mozilla.org/MPL/2.0/
*
* Copyright (C) 2008-2013, Peter Johnson (www.delphidabbler.com).
*
* $Rev$
* $Date$
*
* Provides an implementation of IActiveTextParser that can parse the markup
* used in Credits elements of data files and convert the markup into an active
* text object.
}
unit USnippetCreditsParser;
interface
uses
// Project
ActiveText.UMain;
type
/// <summary>Class that parses markup used in Credits element read from
/// snippets data files. Markup is translated into active text.</summary>
/// <remarks>The Credits element may occur in main database files and v1 of
/// the user database and export files.</remarks>
TSnippetCreditsParser = class(TInterfacedObject, IActiveTextParser)
strict private
var
/// <summary>URL to be used in any link contained in markup.</summary>
fURL: string;
public
/// <summary>Object constructor. Sets up object.</summary>
/// <param name="URL">string [in] URL to be used in any hyperlinks defined
/// by Credit markup.</param>
constructor Create(const URL: string);
/// <summary>Parses markup and updates active text object.</summary>
/// <param name="Markup">string [in] Markup containing definition of active
/// text. Must be valid Credits element markup.</param>
/// <param name="ActiveText">IActiveText [in] Active text object updated by
/// parser.</param>
/// <remarks>Implements IActiveTextParser.Parse.</remarks>
procedure Parse(const Markup: string; const ActiveText: IActiveText);
end;
implementation
{
About the "Credits" Markup
--------------------------
The markup is simple. It is just plain text with at most one group of text
delimited by '[' and ']' characters. The text enclosed in brackets represents
a hyperlink. The destination URL of the hyperlink is given by the URL
parameter passed to the constructor.
Examples:
"Some markup without a link."
"Some markup with a [link]."
}
uses
// Project
UStrUtils;
{ TSnippetCreditsParser }
constructor TSnippetCreditsParser.Create(const URL: string);
begin
inherited Create;
fURL := URL;
end;
procedure TSnippetCreditsParser.Parse(const Markup: string;
const ActiveText: IActiveText);
const
cOpenBracket = '['; // open bracket character that starts a link
cCloseBracket = ']'; // close bracket character that ends a link
resourcestring
// Error messages
sUnexpectedCloser = 'Unexpected closing bracket found';
sUnterminatedLink = 'Unterminated link';
sEmptyLink = 'Empty link definition';
sWrongBracketOrder = 'Close bracket preceeds link open bracket';
sMultipleOpeners = 'More than one open bracket is present';
sMultipleClosers = 'More than one close bracket is present';
sNoURL = 'No URL specified';
var
OpenBracketPos: Integer; // position of opening bracket in markup
CloseBracketPos: Integer; // position of closing bracket in markup
Prefix, Postfix: string; // text before and after link (can be empty)
LinkText: string; // link text
begin
// Find open and closing brackets that delimit link text
OpenBracketPos := StrPos(cOpenBracket, Markup);
CloseBracketPos := StrPos(cCloseBracket, Markup);
if OpenBracketPos = 0 then
begin
// No links: plain text only
// check for errors
if CloseBracketPos > 0 then
raise EActiveTextParserError.Create(sUnexpectedCloser);
// record text element
ActiveText.AddElem(TActiveTextFactory.CreateTextElem(Markup));
end
else
begin
// We have a potential link
// check for errors
if CloseBracketPos = 0 then
raise EActiveTextParserError.Create(sUnterminatedLink);
if CloseBracketPos = OpenBracketPos + 1 then
raise EActiveTextParserError.Create(sEmptyLink);
if CloseBracketPos < OpenBracketPos then
raise EActiveTextParserError.Create(sWrongBracketOrder);
if StrCountDelims(cOpenBracket, Markup) > 1 then
raise EActiveTextParserError.Create(sMultipleOpeners);
if StrCountDelims(cCloseBracket, Markup) > 1 then
raise EActiveTextParserError.Create(sMultipleClosers);
// must have a URL
if fURL = '' then
raise EActiveTextParserError.Create(sNoURL);
// get the various components
LinkText := StrSlice(
Markup, OpenBracketPos + 1, CloseBracketPos - OpenBracketPos - 1
);
Assert(LinkText <> '',
ClassName + '.Parse: Link text is '' but has passed check');
Prefix := StrSliceLeft(Markup, OpenBracketPos - 1);
Postfix := StrSliceRight(Markup, Length(Markup) - CloseBracketPos);
// record the elements
if Prefix <> '' then
ActiveText.AddElem(TActiveTextFactory.CreateTextElem(Prefix));
ActiveText.AddElem(
TActiveTextFactory.CreateActionElem(
ekLink,
TActiveTextFactory.CreateAttrs(
TActiveTextAttr.Create(TActiveTextAttrNames.Link_URL, fURL)
),
fsOpen
)
);
ActiveText.AddElem(TActiveTextFactory.CreateTextElem(LinkText));
ActiveText.AddElem(
TActiveTextFactory.CreateActionElem(
ekLink,
TActiveTextFactory.CreateAttrs(
TActiveTextAttr.Create(TActiveTextAttrNames.Link_URL, fURL)
),
fsClose
)
);
if Postfix <> '' then
ActiveText.AddElem(TActiveTextFactory.CreateTextElem(Postfix));
end;
end;
end.
Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.