Menu

[r4173]: / branches / parsnip / Src / SWAG.USnippetCache.pas  Maximize  Restore  History

Download this file

127 lines (105 with data), 3.4 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
{
* 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) 2013, Peter Johnson (www.delphidabbler.com).
*
* $Rev$
* $Date$
*
* Provides a class that implements a cache of SWAG snippets.
}
unit SWAG.USnippetCache;
interface
uses
// Delphi
Generics.Collections,
// Project
SWAG.UCommon;
type
/// <summary>Class that implements a cache of SWAG snippets.</summary>
/// <remarks>When the cache is full a snippet must be removed from the cache
/// for each one added. The cache is implemented so that the snippets
/// referenced the most are the least likely to be removed from the cache.
/// </remarks>
TSWAGSnippetCache = class(TObject)
strict private
const
/// <summary>Minimum permitted size of cache.</summary>
MinCacheSize = 10;
/// <summary>Maximum permitted size of cache.</summary>
MaxCacheSize = 200;
var
/// <summary>Stores the cached snippets.</summary>
fCache: TList<TSWAGSnippet>;
/// <summary>Records size of cache.</summary>
fCacheSize: Integer;
/// <summary>Returns index of SWAG snippet with given ID in cache, or -1 if
/// snippet not in cache.</summary>
function IndexOfID(const SnippetID: Cardinal): Integer;
public
/// <summary>Creates a new cache instance with given size.</summary>
/// <remarks>CacheSize may be adjusted to fall within valid range of cache
/// sizes.</remarks>
constructor Create(CacheSize: Integer);
/// <summary>Destroys current object instance.</summary>
destructor Destroy; override;
/// <summary>Retrieves the SWAG snippet with the given ID from the cache.
/// If the snippet is present it is stored in Snippet and True is returned.
/// If the snippet is not present False is returned and Snippet is
/// undefined.</summary>
function Retrieve(const SnippetID: Cardinal; out Snippet: TSWAGSnippet):
Boolean;
/// <summary>Adds the given SWAG snippet to the cache.</summary>
/// <remarks>If the cache is full a snippet will be removed from the cache
/// to make way for the newly added snippet.</remarks>
procedure Add(const Snippet: TSWAGSnippet);
end;
implementation
uses
// Project
UStructs;
{ TSWAGSnippetCache }
procedure TSWAGSnippetCache.Add(const Snippet: TSWAGSnippet);
begin
if fCache.Count = fCacheSize then
fCache.Delete(0);
fCache.Add(Snippet);
end;
constructor TSWAGSnippetCache.Create(CacheSize: Integer);
var
CacheSizeRange: TRange;
begin
inherited Create;
CacheSizeRange := TRange.Create(MinCacheSize, MaxCacheSize);
fCacheSize := CacheSizeRange.Constrain(CacheSize);
fCache := TList<TSWAGSnippet>.Create;
end;
destructor TSWAGSnippetCache.Destroy;
begin
fCache.Free;
inherited;
end;
function TSWAGSnippetCache.IndexOfID(const SnippetID: Cardinal): Integer;
var
Idx: Integer;
begin
for Idx := 0 to Pred(fCache.Count) do
if fCache[Idx].ID = SnippetID then
Exit(Idx);
Result := -1;
end;
function TSWAGSnippetCache.Retrieve(const SnippetID: Cardinal;
out Snippet: TSWAGSnippet): Boolean;
var
Idx: Integer;
begin
Idx := IndexOfID(SnippetID);
if Idx = -1 then
Exit(False);
fCache.Move(Idx, Pred(fCache.Count));
Snippet := fCache.Last;
Result := True;
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.