1
{******************************************************************************}
3
{ Scheduler API interface Unit for Object Pascal }
5
{ Portions created by Microsoft are Copyright (C) 1995-2001 Microsoft }
6
{ Corporation. All Rights Reserved. }
8
{ The original file is: schedule.h, released June 2000. The original Pascal }
9
{ code is: Schedule.pas, released December 2000. The initial developer of the }
10
{ Pascal code is Marcel van Brakel (brakelm att chello dott nl). }
12
{ Portions created by Marcel van Brakel are Copyright (C) 1999-2001 }
13
{ Marcel van Brakel. All Rights Reserved. }
15
{ Obtained through: Joint Endeavour of Delphi Innovators (Project JEDI) }
17
{ You may retrieve the latest version of this file at the Project JEDI }
18
{ APILIB home page, located at http://jedi-apilib.sourceforge.net }
20
{ The contents of this file are used with permission, subject to the Mozilla }
21
{ Public License Version 1.1 (the "License"); you may not use this file except }
22
{ in compliance with the License. You may obtain a copy of the License at }
23
{ http://www.mozilla.org/MPL/MPL-1.1.html }
25
{ Software distributed under the License is distributed on an "AS IS" basis, }
26
{ WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for }
27
{ the specific language governing rights and limitations under the License. }
29
{ Alternatively, the contents of this file may be used under the terms of the }
30
{ GNU Lesser General Public License (the "LGPL License"), in which case the }
31
{ provisions of the LGPL License are applicable instead of those above. }
32
{ If you wish to allow use of your version of this file only under the terms }
33
{ of the LGPL License and not to allow others to use your version of this file }
34
{ under the MPL, indicate your decision by deleting the provisions above and }
35
{ replace them with the notice and other provisions required by the LGPL }
36
{ License. If you do not delete the provisions above, a recipient may use }
37
{ your version of this file under either the MPL or the LGPL License. }
39
{ For more information about the LGPL: http://www.gnu.org/copyleft/lesser.html }
41
{******************************************************************************}
43
// $Id: jwaschedule.pas,v 1.1 2005/04/04 07:56:10 marco Exp $
50
{$HPPEMIT '#include "schedule.h"'}
61
// The DS and FRS use the same structure to represent different schedules.
62
// The DS uses a 15-minute polling schedule. FRS uses a 60-minute
63
// start/stop schedule. Hence, the schedule for the system volume is
64
// a special case because we only have the DS schedule to work from.
65
// We will work around this problem by treating the 15
66
// -minute polling schedule as a 60-minute start/stop schedule.
67
// Replication is enabled for any hour that has any of the four
68
// 15-minute bits set.
70
// When the ReplicationSchedule is not present the default is
71
// "always replicate."
75
// Only the interval schedule is currently implemented. Others are ignored.
79
SCHEDULE_INTERVAL = 0; // schedule as understood by NT5
80
{$EXTERNALSYM SCHEDULE_INTERVAL}
81
SCHEDULE_BANDWIDTH = 1; // bandwidth as understood by NT5
82
{$EXTERNALSYM SCHEDULE_BANDWIDTH}
83
SCHEDULE_PRIORITY = 2; // priority as understood by NT5
84
{$EXTERNALSYM SCHEDULE_PRIORITY}
89
// Each schedule blob begins with n array of schedule headers that
90
// specify the number and type of schedules contained in the blob.
94
PSCHEDULE_HEADER = ^SCHEDULE_HEADER;
95
{$EXTERNALSYM PSCHEDULE_HEADER}
96
_SCHEDULE_HEADER = record
97
Type_: ULONG; // one of the SCHEDULE_ ordinals
98
Offset: ULONG; // offset from start of schedule structure
100
{$EXTERNALSYM _SCHEDULE_HEADER}
101
SCHEDULE_HEADER = _SCHEDULE_HEADER;
102
{$EXTERNALSYM SCHEDULE_HEADER}
103
TScheduleHeader = SCHEDULE_HEADER;
104
PScheduleHeader = PSCHEDULE_HEADER;
110
PSCHEDULE = ^_SCHEDULE;
111
{$EXTERNALSYM PSCHEDULE}
113
Size: ULONG; // inclusive size in bytes
115
NumberOfSchedules: ULONG;
116
Schedules: array [0..0] of SCHEDULE_HEADER;
118
{$EXTERNALSYM _SCHEDULE}
119
//SCHEDULE = _SCHEDULE;
120
//{$EXTERNALSYM SCHEDULE}
121
TSchedule = _SCHEDULE;
123
// The above structure is followed by the Data buffer and the
124
// SCHEDULE_HEADER contains offsets to refer to the appropriate
125
// parts in the data buffer.
128
SCHEDULE_DATA_ENTRIES = 7 * 24; // 7 days X 24 hours
129
{$EXTERNALSYM SCHEDULE_DATA_ENTRIES}