{
* UFileHiliter.pas
*
* Implements class that generates hilighted and formatted source code for a
* specified file type.
*
* $Rev$
* $Date$
*
* ***** BEGIN LICENSE BLOCK *****
*
* Version: MPL 1.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for
* the specific language governing rights and limitations under the License.
*
* The Original Code is UFileHiliter.pas
*
* The Initial Developer of the Original Code is Peter Johnson
* (http://www.delphidabbler.com/).
*
* Portions created by the Initial Developer are Copyright (C) 2006-2009 Peter
* Johnson. All Rights Reserved.
*
* Contributor(s)
* NONE
*
* ***** END LICENSE BLOCK *****
}
unit UFileHiliter;
interface
uses
// Project
IntfHiliter, USourceFileInfo;
type
{
TFileHiliter:
Class that generates hilighted and formatted source code for a specified
file type.
}
TFileHiliter = class(TObject)
private
fWantHiliting: Boolean;
{Flag indicating whether output is to be highlighted. Ignored if target
file type does not support highlighting}
fFileType: TSourceFileType;
{Type of source file to be targetted}
function HiliterKind: TSyntaxHiliterKind;
{Determines kind of highlighter required for source file type.
@return Required highlighter kind.
}
function GetHiliteAttrs: IHiliteAttrs;
{Determines any attributes to be used by highlighter.
@return Required highlighter attributes or nil if no highlighter being
used.
}
public
constructor Create(const WantHiliting: Boolean;
const FileType: TSourceFileType);
{Class contructor. Creates file highlighter object of requested kind.
@param WantHighlighting [in] Whether user wants actual highlighting
performed. When false source code output is correct kind for file
type, but contains no special formatting.
@param FileType [in] Specifies kind of file that highlighting is to
target. This determines format of output.
}
function Hilite(const SourceCode, DocTitle: string): string;
{Highlights source code. Output is correctly formatted for file type.
@param SourceCode [in] Source code to be highlighted.
@param DocTitle [in] Title of document to be outputted. Ignored if
file type does not support document title meta data.
@return Highlighted source.
}
class function IsHilitingSupported(
const FileType: TSourceFileType): Boolean;
{Tests if a source file type supports highlighting.
@param FileType [in] Source code file type.
@return True if file type supports highlighting, false if not.
}
end;
implementation
uses
// Project
UHiliteAttrs, USyntaxHiliters;
{ TFileHiliter }
constructor TFileHiliter.Create(const WantHiliting: Boolean;
const FileType: TSourceFileType);
{Class contructor. Creates file highlighter object of requested kind.
@param WantHighlighting [in] Whether user wants actual highlighting
performed. When false source code output is correct kind for file type,
but contains no special formatting.
@param FileType [in] Specifies kind of file that highlighting is to target.
This determines format of output.
}
begin
inherited Create;
fFileType := FileType;
fWantHiliting := WantHiliting;
end;
function TFileHiliter.GetHiliteAttrs: IHiliteAttrs;
{Determines any attributes to be used by highlighter.
@return Required highlighter attributes or nil if no highlighter being used.
}
begin
// We use default attributes only if highlighting requested and highlighter
// kind supports attributes
if fWantHiliting and (HiliterKind in [hkXHTML, hkRTF]) then
Result := THiliteAttrsFactory.CreateUserAttrs
else
Result := nil;
end;
function TFileHiliter.Hilite(const SourceCode, DocTitle: string): string;
{Highlights source code. Output is correctly formatted for file type.
@param SourceCode [in] Source code to be highlighted.
@param DocTitle [in] Title of document to be outputted. Ignored if file type
does not support document title meta data.
@return Highlighted source.
}
var
Hiliter: ISyntaxHiliter; // syntax highlighter object
begin
Hiliter := TSyntaxHiliterFactory.CreateHiliter(HiliterKind);
Result := Hiliter.Hilite(SourceCode, GetHiliteAttrs, DocTitle);
end;
function TFileHiliter.HiliterKind: TSyntaxHiliterKind;
{Determines kind of highlighter required for source file type.
@return Required highlighter kind.
}
begin
// We have nul hiliter unless file type is RTF or HTML
case fFileType of
sfHTML: Result := hkXHTML;
sfRTF: Result := hkRTF;
else Result := hkNul;
end;
end;
class function TFileHiliter.IsHilitingSupported(
const FileType: TSourceFileType): Boolean;
{Tests if a source file type supports highlighting.
@param FileType [in] Source code file type.
@return True if file type supports highlighting, false if not.
}
begin
Result := FileType in [sfHTML, sfRTF];
end;
end.