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
183
184
185
186
187
188
189
190
191
| ///////////////////////////////////////////////////////////////////////////
// //
// Copyright (c) 2015 by Charta Software B.V. //
// All rights reserved //
// //
// Version: 1.7.0.83525 //
// Web site: https://pascal.chartasoftware.com/ //
// //
// This code and information are provided "as is" without warranty of //
// any kind. Dissemination of this information or reproduction of //
// this material is strictly forbidden unless prior written permission //
// is obtained from Charta Software B.V.. //
// //
///////////////////////////////////////////////////////////////////////////
unit Task.Group;
interface
uses
Collection.List,
DateTime.Calendar.Gregorian.Instant,
Object_.ReferenceCounted,
Task,
Task.Node,
Task.Scheduled,
Text;
type
TTaskRegistration = class(TObject)
private
FTask: TTask;
FDependencies: TList<TTask>;
procedure SetTask(const Value: TTask);
public
constructor Create(Task: TTask); virtual;
destructor Destroy(); override;
property Task: TTask read FTask write SetTask;
property Dependencies: TList<TTask> read FDependencies;
end;
TTaskGroup = class(TTaskNode)
private
FTasks: TList<TTaskRegistration>;
FStopAfter: TGregorianInstant;
procedure SetStopAfter(const Value: TGregorianInstant);
public
Name: TText;
constructor Create(); override;
destructor Destroy(); override;
function Register(Task: TTask): TTaskRegistration;
function ToText(): TText; override;
property Tasks: TList<TTaskRegistration> read FTasks;
published
property StopAfter: TGregorianInstant read FStopAfter write SetStopAfter;
end;
TScheduledTaskGroup = class(TReferenceCountedObject)
private
FTaskGroup: TTaskGroup;
FTasks: TList<TScheduledTask>;
protected
procedure SetTaskGroup(Value: TTaskGroup);
public
constructor Create(); override;
destructor Destroy(); override;
property TaskGroup: TTaskGroup read FTaskGroup write SetTaskGroup;
property Tasks: TList<TScheduledTask> read FTasks;
end;
implementation
uses
Object_.List,
Object_.Reference.Counter;
{ TTaskGroup }
constructor TTaskGroup.Create();
begin
inherited Create();
FTasks := TObjectList<TTaskRegistration>.Create();
end;
destructor TTaskGroup.Destroy();
begin
Tasks.Free();
StopAfter.ReleaseReference();
inherited Destroy();
end;
function TTaskGroup.Register(Task: TTask): TTaskRegistration;
begin
Result := TTaskRegistration.Create(Task);
Tasks.Add(Result);
end;
procedure TTaskGroup.SetStopAfter(const Value: TGregorianInstant);
begin
if Value <> StopAfter then
begin
Value.AddReference();
StopAfter.ReleaseReference();
FStopAfter := Value;
end;
end;
function TTaskGroup.ToText(): TText;
begin
if Name.Count > 0 then
Result := Name
else
Result := inherited ToText();
end;
{ TTaskRegistration }
constructor TTaskRegistration.Create(Task: TTask);
begin
inherited Create();
FDependencies := TObjectList<TTask>.Create();
FDependencies.ElementManager := TReferenceCounter<TTask>.Create();
Self.Task := Task;
end;
destructor TTaskRegistration.Destroy();
begin
Task.ReleaseReference();
Dependencies.Free();
inherited Destroy();
end;
procedure TTaskRegistration.SetTask(const Value: TTask);
begin
if Value <> Task then
begin
Value.AddReference();
Task.ReleaseReference();
FTask := Value;
end;
end;
{ TScheduledTaskGroup }
constructor TScheduledTaskGroup.Create();
begin
inherited Create();
FTasks := TObjectList<TScheduledTask>.Create();
FTasks.ElementManager := TReferenceCounter<TScheduledTask>.Create();
end;
destructor TScheduledTaskGroup.Destroy();
begin
TaskGroup.ReleaseReference();
Tasks.Free();
inherited Destroy();
end;
procedure TScheduledTaskGroup.SetTaskGroup(Value: TTaskGroup);
begin
if Value <> TaskGroup then
begin
Value.AddReference();
TaskGroup.ReleaseReference();
FTaskGroup := Value;
end;
end;
end.
|