jwaschedule.pas 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. {******************************************************************************}
  2. { }
  3. { Scheduler API interface Unit for Object Pascal }
  4. { }
  5. { Portions created by Microsoft are Copyright (C) 1995-2001 Microsoft }
  6. { Corporation. All Rights Reserved. }
  7. { }
  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). }
  11. { }
  12. { Portions created by Marcel van Brakel are Copyright (C) 1999-2001 }
  13. { Marcel van Brakel. All Rights Reserved. }
  14. { }
  15. { Obtained through: Joint Endeavour of Delphi Innovators (Project JEDI) }
  16. { }
  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 }
  19. { }
  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 }
  24. { }
  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. }
  28. { }
  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. }
  38. { }
  39. { For more information about the LGPL: http://www.gnu.org/copyleft/lesser.html }
  40. { }
  41. {******************************************************************************}
  42. // $Id: JwaSchedule.pas,v 1.8 2007/09/05 11:58:52 dezipaitor Exp $
  43. {$IFNDEF JWA_OMIT_SECTIONS}
  44. unit JwaSchedule;
  45. {$WEAKPACKAGEUNIT}
  46. {$ENDIF JWA_OMIT_SECTIONS}
  47. {$HPPEMIT ''}
  48. {$HPPEMIT '#include "schedule.h"'}
  49. {$HPPEMIT ''}
  50. {$IFNDEF JWA_OMIT_SECTIONS}
  51. {$I jediapilib.inc}
  52. interface
  53. uses
  54. JwaWinType;
  55. {$ENDIF JWA_OMIT_SECTIONS}
  56. {$IFNDEF JWA_IMPLEMENTATIONSECTION}
  57. //
  58. // The DS and FRS use the same structure to represent different schedules.
  59. // The DS uses a 15-minute polling schedule. FRS uses a 60-minute
  60. // start/stop schedule. Hence, the schedule for the system volume is
  61. // a special case because we only have the DS schedule to work from.
  62. // We will work around this problem by treating the 15
  63. // -minute polling schedule as a 60-minute start/stop schedule.
  64. // Replication is enabled for any hour that has any of the four
  65. // 15-minute bits set.
  66. //
  67. // When the ReplicationSchedule is not present the default is
  68. // "always replicate."
  69. //
  70. //
  71. // Only the interval schedule is currently implemented. Others are ignored.
  72. //
  73. const
  74. SCHEDULE_INTERVAL = 0; // schedule as understood by NT5
  75. {$EXTERNALSYM SCHEDULE_INTERVAL}
  76. SCHEDULE_BANDWIDTH = 1; // bandwidth as understood by NT5
  77. {$EXTERNALSYM SCHEDULE_BANDWIDTH}
  78. SCHEDULE_PRIORITY = 2; // priority as understood by NT5
  79. {$EXTERNALSYM SCHEDULE_PRIORITY}
  80. //
  81. // Schedule Header
  82. //
  83. // Each schedule blob begins with n array of schedule headers that
  84. // specify the number and type of schedules contained in the blob.
  85. //
  86. type
  87. PSCHEDULE_HEADER = ^SCHEDULE_HEADER;
  88. {$EXTERNALSYM PSCHEDULE_HEADER}
  89. _SCHEDULE_HEADER = record
  90. Type_: ULONG; // one of the SCHEDULE_ ordinals
  91. Offset: ULONG; // offset from start of schedule structure
  92. end;
  93. {$EXTERNALSYM _SCHEDULE_HEADER}
  94. SCHEDULE_HEADER = _SCHEDULE_HEADER;
  95. {$EXTERNALSYM SCHEDULE_HEADER}
  96. TScheduleHeader = SCHEDULE_HEADER;
  97. PScheduleHeader = PSCHEDULE_HEADER;
  98. //
  99. // Schedule
  100. //
  101. PSCHEDULE = ^_SCHEDULE;
  102. {$EXTERNALSYM PSCHEDULE}
  103. _SCHEDULE = record
  104. Size: ULONG; // inclusive size in bytes
  105. Bandwidth: ULONG;
  106. NumberOfSchedules: ULONG;
  107. Schedules: array [0..0] of SCHEDULE_HEADER;
  108. end;
  109. {$EXTERNALSYM _SCHEDULE}
  110. //SCHEDULE = _SCHEDULE;
  111. //{$EXTERNALSYM SCHEDULE}
  112. TSchedule = _SCHEDULE;
  113. // The above structure is followed by the Data buffer and the
  114. // SCHEDULE_HEADER contains offsets to refer to the appropriate
  115. // parts in the data buffer.
  116. const
  117. SCHEDULE_DATA_ENTRIES = 7 * 24; // 7 days X 24 hours
  118. {$EXTERNALSYM SCHEDULE_DATA_ENTRIES}
  119. {$ENDIF JWA_OMIT_SECTIONS}
  120. {$IFNDEF JWA_INTERFACESECTION}
  121. //your implementation here
  122. {$ENDIF JWA_INTERFACESECTION}
  123. {$IFNDEF JWA_OMIT_SECTIONS}
  124. Implementation // implementation is mandatory under FPC.
  125. end.
  126. {$ENDIF JWA_OMIT_SECTIONS}