Menu

[r3207]: / trunk / Src / USaveSnippetMgr.pas  Maximize  Restore  History

Download this file

184 lines (155 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
169
170
171
172
173
174
175
176
177
178
179
180
181
182
{
* 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) 2005-2012, Peter Johnson (www.delphidabbler.com).
*
* $Rev$
* $Date$
*
* Defines a class that manages generation, previewing and saving of a code
* snippet.
}
unit USaveSnippetMgr;
interface
uses
// Project
USourceFileInfo, USaveSourceMgr, USourceGen, UView;
type
/// <summary>
/// Manages generation, previewing and saving of a suitable code snippet or
/// category to disk.
/// </summary>
/// <remarks>
/// Generated file can be a Pascal include file, a plain text file, an HTML
/// file or a RTF file. The last two file types can optionally be syntax
/// highlighted.
/// </remarks>
TSaveSnippetMgr = class(TSaveSourceMgr)
strict private
/// <summary>View containing item for which source code to be output.
/// </summary>
fView: IView;
strict protected
/// <summary>Object constructor. Sets up object to save source code
/// encapsulated by a view.</summary>
constructor InternalCreate(View: IView);
/// <summary>Gets description of given source code file type.</summary>
function GetFileTypeDesc(const FileType: TSourceFileType): string; override;
/// <summary>Gets default file name to display in dialog box.</summary>
function GetDefaultFileName: string; override;
/// <summary>Gets dialog box title.</summary>
function GetDlgTitle: string; override;
/// <summary>Get dialog box's help keyword.</summary>
function GetDlgHelpKeyword: string; override;
/// <summary>Gets title to be used for source document.</summary>
function GetDocTitle: string; override;
/// <summary>Generates raw, un-highlighted, source code.</summary>
/// <param name="CommentStyle">TCommentStyle [in] Style of commenting to be
/// used in source code.</param>
/// <param name="TruncateComments">Boolean [in] Indicates whether multi
/// paragraph comments are to be truncated to first paragraph.</param>
/// <returns>String containing generated source code.</returns>
function GenerateSource(const CommentStyle: TCommentStyle;
const TruncateComments: Boolean): string;
override;
/// <summary>Checks if a file name is valid for the kind of file being
/// saved.</summary>
/// <param name="FileName">string [in] Name of file to check.</param>
/// <param name="NameOK">Boolean [out] Set True if file name OK, False if
/// not.</param>
/// <param name="ErrorMessage">string [out] Error message describing
/// problem with invalid file name. Undefined if NameOK is True.</param>
procedure CheckFileName(const FileName: string; out NameOK: Boolean;
out ErrorMessage: string); override;
public
/// <summary>Creates and outputs a compilable include file generated from a
/// view item with name and format speficied by user.</summary>
/// <param name="View">IView [in] View from which source code is generated.
/// CanHandleView must return True for this view.</param>
class procedure Execute(View: IView);
/// <summary>Checks whether a snippet include file can be created from a
/// given view.</summary>
class function CanHandleView(View: IView): Boolean;
end;
implementation
uses
// Delphi
SysUtils,
// Project
USnippetSourceGen;
resourcestring
// Dialog box title
sSaveDlgTitle = 'Save %0:s Snippet';
// Output document title for snippets and categories
sDocTitle = '"%0:s" %1:s';
sCategory = 'category';
sSnippet = 'routine';
// File filter strings
sHtmExtDesc = 'HTML file';
sRtfExtDesc = 'Rich text file';
sIncExtDesc = 'Pascal include file';
sTxtExtDesc = 'Plain text file';
{ TSaveSnippetMgr }
class function TSaveSnippetMgr.CanHandleView(View: IView): Boolean;
begin
Result := TSnippetSourceGen.CanGenerate(View);
end;
procedure TSaveSnippetMgr.CheckFileName(const FileName: string;
out NameOK: Boolean; out ErrorMessage: string);
begin
NameOK := True;
end;
class procedure TSaveSnippetMgr.Execute(View: IView);
begin
with InternalCreate(View) do
try
DoExecute;
finally
Free;
end;
end;
function TSaveSnippetMgr.GenerateSource(const CommentStyle: TCommentStyle;
const TruncateComments: Boolean): string;
begin
Result := TSnippetSourceGen.Generate(fView, CommentStyle, TruncateComments);
end;
function TSaveSnippetMgr.GetDefaultFileName: string;
begin
Result := fView.Description;
end;
function TSaveSnippetMgr.GetDlgHelpKeyword: string;
begin
Result := 'SaveSnippetDlg';
end;
function TSaveSnippetMgr.GetDlgTitle: string;
begin
Result := Format(sSaveDlgTitle, [fView.Description]);
end;
function TSaveSnippetMgr.GetDocTitle: string;
begin
if Supports(fView, ICategoryView) then
Result := Format(sDocTitle, [fView.Description, sCategory])
else if Supports(fView, ISnippetView) then
Result := Format(sDocTitle, [fView.Description, sSnippet])
else
Result := '';
end;
function TSaveSnippetMgr.GetFileTypeDesc(
const FileType: TSourceFileType): string;
const
Descriptions: array[TSourceFileType] of string = (
sTxtExtDesc, sIncExtDesc, sHtmExtDesc, sRtfExtDesc
);
begin
Result := Descriptions[FileType];
end;
constructor TSaveSnippetMgr.InternalCreate(View: IView);
begin
// Record reference to view object: we do this here because overridden methods
// calls made in inherited constructor.
fView := View;
inherited InternalCreate;
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.