taskjuggler 0.0.8 → 0.0.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (613) hide show
  1. data/CHANGELOG +1144 -2047
  2. data/README +1 -1
  3. data/Rakefile +6 -6
  4. data/data/css/tjmanual.css +20 -0
  5. data/data/css/tjreport.css +7 -6
  6. data/doc/AppConfig.html +136 -130
  7. data/doc/Arguments.html +46 -40
  8. data/doc/CHANGELOG.html +1162 -2057
  9. data/doc/COPYING.html +8 -2
  10. data/doc/Object.html +205 -199
  11. data/doc/README.html +9 -3
  12. data/doc/RuntimeConfig.html +75 -69
  13. data/doc/String.html +69 -63
  14. data/doc/TaskJuggler.html +350 -291
  15. data/doc/TaskJuggler/Account.html +26 -20
  16. data/doc/TaskJuggler/AccountAttribute.html +24 -18
  17. data/doc/TaskJuggler/AccountScenario.html +24 -18
  18. data/doc/TaskJuggler/Allocation.html +74 -68
  19. data/doc/TaskJuggler/AllocationAttribute.html +54 -48
  20. data/doc/TaskJuggler/AttributeBase.html +172 -93
  21. data/doc/TaskJuggler/AttributeDefinition.html +22 -16
  22. data/doc/TaskJuggler/AttributeOverwrite.html +586 -0
  23. data/doc/TaskJuggler/BatchProcessor.html +263 -257
  24. data/doc/TaskJuggler/Booking.html +44 -38
  25. data/doc/TaskJuggler/BookingListAttribute.html +25 -21
  26. data/doc/TaskJuggler/BooleanAttribute.html +24 -18
  27. data/doc/TaskJuggler/CSVFile.html +193 -187
  28. data/doc/TaskJuggler/CellSettingPattern.html +13 -7
  29. data/doc/TaskJuggler/CellSettingPatternList.html +25 -19
  30. data/doc/TaskJuggler/Charge.html +49 -43
  31. data/doc/TaskJuggler/ChargeListAttribute.html +21 -15
  32. data/doc/TaskJuggler/ChargeSet.html +94 -88
  33. data/doc/TaskJuggler/ChargeSetListAttribute.html +29 -25
  34. data/doc/TaskJuggler/CollisionDetector.html +142 -136
  35. data/doc/TaskJuggler/ColumnListAttribute.html +21 -17
  36. data/doc/TaskJuggler/ColumnTable.html +50 -44
  37. data/doc/TaskJuggler/Daemon.html +71 -50
  38. data/doc/TaskJuggler/DataCache.html +110 -58
  39. data/doc/TaskJuggler/DataCacheEntry.html +22 -16
  40. data/doc/TaskJuggler/DateAttribute.html +24 -18
  41. data/doc/TaskJuggler/DefinitionListAttribute.html +12 -6
  42. data/doc/TaskJuggler/DependencyListAttribute.html +29 -25
  43. data/doc/TaskJuggler/DurationAttribute.html +25 -19
  44. data/doc/TaskJuggler/FileList.html +25 -19
  45. data/doc/TaskJuggler/FileRecord.html +17 -11
  46. data/doc/TaskJuggler/FixnumAttribute.html +16 -10
  47. data/doc/TaskJuggler/FlagListAttribute.html +25 -21
  48. data/doc/TaskJuggler/FloatAttribute.html +20 -14
  49. data/doc/TaskJuggler/FormatListAttribute.html +17 -11
  50. data/doc/TaskJuggler/GanttChart.html +242 -236
  51. data/doc/TaskJuggler/GanttContainer.html +71 -67
  52. data/doc/TaskJuggler/GanttHeader.html +113 -107
  53. data/doc/TaskJuggler/GanttHeaderScaleItem.html +26 -20
  54. data/doc/TaskJuggler/GanttLine.html +217 -210
  55. data/doc/TaskJuggler/GanttLoadStack.html +89 -83
  56. data/doc/TaskJuggler/GanttMilestone.html +11 -6
  57. data/doc/TaskJuggler/GanttRouter.html +194 -186
  58. data/doc/TaskJuggler/GanttTaskBar.html +41 -34
  59. data/doc/TaskJuggler/HTMLDocument.html +52 -46
  60. data/doc/TaskJuggler/HTMLGraphics.html +58 -52
  61. data/doc/TaskJuggler/Interval.html +90 -84
  62. data/doc/TaskJuggler/IntervalList.html +777 -0
  63. data/doc/TaskJuggler/IntervalListAttribute.html +29 -25
  64. data/doc/TaskJuggler/JobInfo.html +36 -30
  65. data/doc/TaskJuggler/Journal.html +188 -177
  66. data/doc/TaskJuggler/JournalEntry.html +36 -30
  67. data/doc/TaskJuggler/JournalEntryList.html +88 -82
  68. data/doc/TaskJuggler/KeywordArray.html +12 -6
  69. data/doc/TaskJuggler/KeywordDocumentation.html +512 -503
  70. data/doc/TaskJuggler/Limits.html +111 -105
  71. data/doc/TaskJuggler/Limits/Limit.html +71 -65
  72. data/doc/TaskJuggler/LimitsAttribute.html +21 -15
  73. data/doc/TaskJuggler/ListAttributeBase.html +16 -10
  74. data/doc/TaskJuggler/Log.html +111 -105
  75. data/doc/TaskJuggler/LogFile.html +54 -48
  76. data/doc/TaskJuggler/LogicalAttribute.html +35 -29
  77. data/doc/TaskJuggler/LogicalExpression.html +32 -26
  78. data/doc/TaskJuggler/LogicalExpressionAttribute.html +16 -10
  79. data/doc/TaskJuggler/LogicalExpressionListAttribute.html +671 -0
  80. data/doc/TaskJuggler/LogicalFlag.html +24 -18
  81. data/doc/TaskJuggler/LogicalFunction.html +164 -158
  82. data/doc/TaskJuggler/LogicalOperation.html +138 -132
  83. data/doc/TaskJuggler/Macro.html +14 -8
  84. data/doc/TaskJuggler/MacroTable.html +42 -36
  85. data/doc/TaskJuggler/ManagerResponsibilities.html +19 -13
  86. data/doc/TaskJuggler/ManagerStatusRecord.html +23 -17
  87. data/doc/TaskJuggler/Message.html +56 -50
  88. data/doc/TaskJuggler/MessageHandler.html +73 -67
  89. data/doc/TaskJuggler/Navigator.html +92 -86
  90. data/doc/TaskJuggler/NavigatorElement.html +88 -82
  91. data/doc/TaskJuggler/NikuProject.html +15 -9
  92. data/doc/TaskJuggler/NikuReport.html +405 -370
  93. data/doc/TaskJuggler/NikuResource.html +13 -7
  94. data/doc/TaskJuggler/NodeListAttribute.html +13 -9
  95. data/doc/TaskJuggler/PlaceHolderCell.html +22 -16
  96. data/doc/TaskJuggler/ProcessIntercom.html +116 -110
  97. data/doc/TaskJuggler/ProcessIntercomIface.html +39 -33
  98. data/doc/TaskJuggler/Project.html +1064 -895
  99. data/doc/TaskJuggler/ProjectBroker.html +439 -366
  100. data/doc/TaskJuggler/ProjectBrokerIface.html +63 -53
  101. data/doc/TaskJuggler/ProjectFileParser.html +329 -319
  102. data/doc/TaskJuggler/ProjectFileScanner.html +351 -345
  103. data/doc/TaskJuggler/ProjectRecord.html +66 -60
  104. data/doc/TaskJuggler/ProjectServer.html +287 -280
  105. data/doc/TaskJuggler/ProjectServerIface.html +43 -37
  106. data/doc/TaskJuggler/PropertyAttribute.html +16 -10
  107. data/doc/TaskJuggler/PropertyList.html +205 -199
  108. data/doc/TaskJuggler/PropertySet.html +264 -296
  109. data/doc/TaskJuggler/PropertyTreeNode.html +455 -505
  110. data/doc/TaskJuggler/Query.html +309 -524
  111. data/doc/TaskJuggler/RTFHandlers.html +17 -11
  112. data/doc/TaskJuggler/RTFNavigator.html +33 -27
  113. data/doc/TaskJuggler/RTFQuery.html +135 -129
  114. data/doc/TaskJuggler/RTFReport.html +63 -57
  115. data/doc/TaskJuggler/RTFReportLink.html +55 -49
  116. data/doc/TaskJuggler/RTFWithQuerySupport.html +17 -11
  117. data/doc/TaskJuggler/RealFormat.html +64 -58
  118. data/doc/TaskJuggler/RealFormatAttribute.html +12 -6
  119. data/doc/TaskJuggler/ReferenceAttribute.html +35 -29
  120. data/doc/TaskJuggler/Report.html +294 -249
  121. data/doc/TaskJuggler/ReportBase.html +229 -223
  122. data/doc/TaskJuggler/ReportContext.html +52 -46
  123. data/doc/TaskJuggler/ReportServer.html +143 -137
  124. data/doc/TaskJuggler/ReportServerIface.html +51 -43
  125. data/doc/TaskJuggler/ReportServerRecord.html +36 -30
  126. data/doc/TaskJuggler/ReportServlet.html +167 -140
  127. data/doc/TaskJuggler/ReportTable.html +137 -131
  128. data/doc/TaskJuggler/ReportTableCell.html +332 -292
  129. data/doc/TaskJuggler/ReportTableColumn.html +46 -40
  130. data/doc/TaskJuggler/ReportTableLegend.html +43 -38
  131. data/doc/TaskJuggler/ReportTableLine.html +66 -60
  132. data/doc/TaskJuggler/Resource.html +166 -160
  133. data/doc/TaskJuggler/ResourceListAttribute.html +54 -32
  134. data/doc/TaskJuggler/ResourceListRE.html +47 -41
  135. data/doc/TaskJuggler/ResourceScenario.html +671 -644
  136. data/doc/TaskJuggler/RichText.html +51 -45
  137. data/doc/TaskJuggler/RichTextAttribute.html +28 -22
  138. data/doc/TaskJuggler/RichTextDocument.html +96 -90
  139. data/doc/TaskJuggler/RichTextElement.html +503 -497
  140. data/doc/TaskJuggler/RichTextFunctionExample.html +41 -35
  141. data/doc/TaskJuggler/RichTextFunctionHandler.html +19 -13
  142. data/doc/TaskJuggler/RichTextImage.html +14 -8
  143. data/doc/TaskJuggler/RichTextIntermediate.html +86 -80
  144. data/doc/TaskJuggler/RichTextParser.html +59 -53
  145. data/doc/TaskJuggler/RichTextScanner.html +184 -178
  146. data/doc/TaskJuggler/RichTextSnip.html +69 -63
  147. data/doc/TaskJuggler/RichTextSyntaxRules.html +416 -410
  148. data/doc/TaskJuggler/Scenario.html +13 -7
  149. data/doc/TaskJuggler/ScenarioData.html +40 -34
  150. data/doc/TaskJuggler/ScenarioListAttribute.html +21 -15
  151. data/doc/TaskJuggler/Scoreboard.html +129 -107
  152. data/doc/TaskJuggler/SheetHandlerBase.html +245 -239
  153. data/doc/TaskJuggler/SheetReceiver.html +333 -327
  154. data/doc/TaskJuggler/SheetSender.html +227 -221
  155. data/doc/TaskJuggler/Shift.html +26 -20
  156. data/doc/TaskJuggler/ShiftAssignment.html +45 -39
  157. data/doc/TaskJuggler/ShiftAssignments.html +178 -172
  158. data/doc/TaskJuggler/ShiftAssignmentsAttribute.html +21 -15
  159. data/doc/TaskJuggler/ShiftScenario.html +29 -23
  160. data/doc/TaskJuggler/SimpleQueryExpander.html +36 -30
  161. data/doc/TaskJuggler/SortListAttribute.html +17 -13
  162. data/doc/TaskJuggler/SourceFileInfo.html +19 -13
  163. data/doc/TaskJuggler/StatusSheetReceiver.html +31 -25
  164. data/doc/TaskJuggler/StatusSheetReport.html +166 -159
  165. data/doc/TaskJuggler/StatusSheetSender.html +80 -74
  166. data/doc/TaskJuggler/StringAttribute.html +20 -14
  167. data/doc/TaskJuggler/SymbolAttribute.html +16 -10
  168. data/doc/TaskJuggler/SyntaxReference.html +231 -225
  169. data/doc/TaskJuggler/TOCEntry.html +46 -40
  170. data/doc/TaskJuggler/TSResourceRecord.html +15 -9
  171. data/doc/TaskJuggler/TSTaskRecord.html +16 -10
  172. data/doc/TaskJuggler/TableColumnDefinition.html +84 -39
  173. data/doc/TaskJuggler/TableOfContents.html +28 -22
  174. data/doc/TaskJuggler/TableReport.html +906 -866
  175. data/doc/TaskJuggler/Task.html +99 -93
  176. data/doc/TaskJuggler/TaskDependency.html +24 -18
  177. data/doc/TaskJuggler/TaskListAttribute.html +29 -25
  178. data/doc/TaskJuggler/TaskListRE.html +46 -39
  179. data/doc/TaskJuggler/TaskScenario.html +2218 -1965
  180. data/doc/TaskJuggler/TextFormatter.html +154 -148
  181. data/doc/TaskJuggler/TextParser.html +362 -348
  182. data/doc/TaskJuggler/TextParser/Pattern.html +313 -307
  183. data/doc/TaskJuggler/TextParser/Rule.html +147 -141
  184. data/doc/TaskJuggler/TextParser/StackElement.html +58 -52
  185. data/doc/TaskJuggler/TextParser/State.html +88 -82
  186. data/doc/TaskJuggler/TextParser/StateTransition.html +42 -36
  187. data/doc/TaskJuggler/TextParser/TextParserResultArray.html +20 -14
  188. data/doc/TaskJuggler/TextParser/TokenDoc.html +19 -13
  189. data/doc/TaskJuggler/TextReport.html +80 -74
  190. data/doc/TaskJuggler/TextScanner.html +284 -272
  191. data/doc/TaskJuggler/TextScanner/BufferStreamHandle.html +14 -8
  192. data/doc/TaskJuggler/TextScanner/FileStreamHandle.html +21 -15
  193. data/doc/TaskJuggler/TextScanner/MacroStackEntry.html +15 -9
  194. data/doc/TaskJuggler/TextScanner/StreamHandle.html +102 -96
  195. data/doc/TaskJuggler/TimeSheet.html +123 -117
  196. data/doc/TaskJuggler/TimeSheetReceiver.html +28 -22
  197. data/doc/TaskJuggler/TimeSheetRecord.html +212 -206
  198. data/doc/TaskJuggler/TimeSheetReport.html +206 -199
  199. data/doc/TaskJuggler/TimeSheetSender.html +27 -21
  200. data/doc/TaskJuggler/TimeSheetSummary.html +140 -134
  201. data/doc/TaskJuggler/TimeSheets.html +20 -14
  202. data/doc/TaskJuggler/Tj3AppBase.html +100 -94
  203. data/doc/TaskJuggler/Tj3Client.html +407 -483
  204. data/doc/TaskJuggler/Tj3Daemon.html +116 -107
  205. data/doc/TaskJuggler/Tj3SheetAppBase.html +45 -39
  206. data/doc/TaskJuggler/Tj3SsReceiver.html +31 -25
  207. data/doc/TaskJuggler/Tj3SsSender.html +64 -58
  208. data/doc/TaskJuggler/Tj3TsReceiver.html +31 -25
  209. data/doc/TaskJuggler/Tj3TsSender.html +51 -45
  210. data/doc/TaskJuggler/Tj3TsSummary.html +59 -53
  211. data/doc/TaskJuggler/TjException.html +13 -7
  212. data/doc/TaskJuggler/TjTime.html +444 -438
  213. data/doc/TaskJuggler/TjpExample.html +84 -78
  214. data/doc/TaskJuggler/TjpExportRE.html +356 -349
  215. data/doc/TaskJuggler/TjpSyntaxRules.html +4279 -4151
  216. data/doc/TaskJuggler/URLParameter.html +16 -10
  217. data/doc/TaskJuggler/UserManual.html +185 -179
  218. data/doc/TaskJuggler/VimSyntax.html +144 -138
  219. data/doc/TaskJuggler/WebServer.html +46 -39
  220. data/doc/TaskJuggler/WelcomePage.html +769 -0
  221. data/doc/TaskJuggler/WorkingHours.html +185 -179
  222. data/doc/TaskJuggler/WorkingHoursAttribute.html +42 -36
  223. data/doc/TaskJuggler/XMLBlob.html +21 -15
  224. data/doc/TaskJuggler/XMLComment.html +17 -11
  225. data/doc/TaskJuggler/XMLDocument.html +33 -27
  226. data/doc/TaskJuggler/XMLElement.html +97 -91
  227. data/doc/TaskJuggler/XMLNamedText.html +13 -7
  228. data/doc/TaskJuggler/XMLText.html +32 -26
  229. data/doc/index.html +601 -563
  230. data/doc/lib/AccountScenario_rb.html +5 -3
  231. data/doc/lib/Account_rb.html +5 -3
  232. data/doc/lib/Allocation_rb.html +5 -3
  233. data/doc/lib/AppConfig_rb.html +5 -3
  234. data/doc/lib/AttributeBase_rb.html +5 -3
  235. data/doc/lib/AttributeDefinition_rb.html +5 -3
  236. data/doc/lib/Attributes_rb.html +5 -3
  237. data/doc/lib/BatchProcessor_rb.html +5 -3
  238. data/doc/lib/Booking_rb.html +5 -3
  239. data/doc/lib/ChargeSet_rb.html +5 -3
  240. data/doc/lib/Charge_rb.html +5 -3
  241. data/doc/lib/DataCache_rb.html +5 -3
  242. data/doc/lib/FileList_rb.html +5 -3
  243. data/doc/lib/HTMLDocument_rb.html +5 -3
  244. data/doc/lib/IntervalList_rb.html +69 -0
  245. data/doc/lib/Interval_rb.html +5 -3
  246. data/doc/lib/Journal_rb.html +5 -3
  247. data/doc/lib/KeywordArray_rb.html +5 -3
  248. data/doc/lib/KeywordDocumentation_rb.html +5 -3
  249. data/doc/lib/Limits_rb.html +5 -3
  250. data/doc/lib/LogFile_rb.html +5 -3
  251. data/doc/lib/Log_rb.html +5 -3
  252. data/doc/lib/LogicalExpression_rb.html +5 -3
  253. data/doc/lib/LogicalFunction_rb.html +5 -3
  254. data/doc/lib/LogicalOperation_rb.html +5 -3
  255. data/doc/lib/MacroTable_rb.html +5 -3
  256. data/doc/lib/MessageHandler_rb.html +5 -3
  257. data/doc/lib/ProjectFileParser_rb.html +5 -3
  258. data/doc/lib/ProjectFileScanner_rb.html +5 -3
  259. data/doc/lib/Project_rb.html +5 -3
  260. data/doc/lib/PropertyList_rb.html +5 -3
  261. data/doc/lib/PropertySet_rb.html +5 -3
  262. data/doc/lib/PropertyTreeNode_rb.html +5 -3
  263. data/doc/lib/Query_rb.html +5 -3
  264. data/doc/lib/RTFHandlers_rb.html +5 -3
  265. data/doc/lib/RTFNavigator_rb.html +5 -3
  266. data/doc/lib/RTFQuery_rb.html +5 -3
  267. data/doc/lib/RTFReportLink_rb.html +5 -3
  268. data/doc/lib/RTFReport_rb.html +5 -3
  269. data/doc/lib/RTFWithQuerySupport_rb.html +5 -3
  270. data/doc/lib/RealFormat_rb.html +5 -3
  271. data/doc/lib/ResourceScenario_rb.html +5 -3
  272. data/doc/lib/Resource_rb.html +5 -3
  273. data/doc/lib/RichTextDocument_rb.html +5 -3
  274. data/doc/lib/RichTextElement_rb.html +5 -3
  275. data/doc/lib/RichTextFunctionExample_rb.html +5 -3
  276. data/doc/lib/RichTextFunctionHandler_rb.html +5 -3
  277. data/doc/lib/RichTextParser_rb.html +5 -3
  278. data/doc/lib/RichTextScanner_rb.html +5 -3
  279. data/doc/lib/RichTextSnip_rb.html +5 -3
  280. data/doc/lib/RichTextSyntaxRules_rb.html +5 -3
  281. data/doc/lib/RichText_rb.html +5 -3
  282. data/doc/lib/RuntimeConfig_rb.html +5 -3
  283. data/doc/lib/ScenarioData_rb.html +5 -3
  284. data/doc/lib/Scenario_rb.html +5 -3
  285. data/doc/lib/Scoreboard_rb.html +7 -3
  286. data/doc/lib/SheetHandlerBase_rb.html +5 -3
  287. data/doc/lib/SheetReceiver_rb.html +5 -3
  288. data/doc/lib/SheetSender_rb.html +5 -3
  289. data/doc/lib/ShiftAssignments_rb.html +5 -3
  290. data/doc/lib/ShiftScenario_rb.html +5 -3
  291. data/doc/lib/Shift_rb.html +5 -3
  292. data/doc/lib/SimpleQueryExpander_rb.html +5 -3
  293. data/doc/lib/SourceFileInfo_rb.html +5 -3
  294. data/doc/lib/StatusSheetReceiver_rb.html +5 -3
  295. data/doc/lib/StatusSheetSender_rb.html +5 -3
  296. data/doc/lib/SyntaxReference_rb.html +5 -3
  297. data/doc/lib/TOCEntry_rb.html +5 -3
  298. data/doc/lib/TableColumnDefinition_rb.html +5 -3
  299. data/doc/lib/TableOfContents_rb.html +5 -3
  300. data/doc/lib/TaskDependency_rb.html +5 -3
  301. data/doc/lib/TaskJuggler_rb.html +5 -3
  302. data/doc/lib/TaskScenario_rb.html +5 -3
  303. data/doc/lib/Task_rb.html +5 -3
  304. data/doc/lib/TextFormatter_rb.html +6 -4
  305. data/doc/lib/TextParser/Pattern_rb.html +5 -3
  306. data/doc/lib/TextParser/Rule_rb.html +5 -3
  307. data/doc/lib/TextParser/StackElement_rb.html +5 -3
  308. data/doc/lib/TextParser/State_rb.html +6 -4
  309. data/doc/lib/TextParser/TokenDoc_rb.html +5 -3
  310. data/doc/lib/TextParser_rb.html +5 -3
  311. data/doc/lib/TextScanner_rb.html +5 -3
  312. data/doc/lib/TimeSheetReceiver_rb.html +5 -3
  313. data/doc/lib/TimeSheetSender_rb.html +5 -3
  314. data/doc/lib/TimeSheetSummary_rb.html +6 -4
  315. data/doc/lib/TimeSheets_rb.html +5 -3
  316. data/doc/lib/Tj3AppBase_rb.html +5 -3
  317. data/doc/lib/Tj3Config_rb.html +5 -3
  318. data/doc/lib/Tj3SheetAppBase_rb.html +5 -3
  319. data/doc/lib/TjException_rb.html +5 -3
  320. data/doc/lib/TjTime_rb.html +5 -3
  321. data/doc/lib/TjpExample_rb.html +5 -3
  322. data/doc/lib/TjpSyntaxRules_rb.html +5 -3
  323. data/doc/lib/URLParameter_rb.html +5 -3
  324. data/doc/lib/UTF8String_rb.html +5 -3
  325. data/doc/lib/UserManual_rb.html +5 -3
  326. data/doc/lib/VimSyntax_rb.html +6 -4
  327. data/doc/lib/WorkingHours_rb.html +5 -3
  328. data/doc/lib/XMLDocument_rb.html +5 -3
  329. data/doc/lib/XMLElement_rb.html +5 -3
  330. data/doc/lib/daemon/Daemon_rb.html +5 -3
  331. data/doc/lib/daemon/ProcessIntercom_rb.html +7 -3
  332. data/doc/lib/daemon/ProjectBroker_rb.html +5 -3
  333. data/doc/lib/daemon/ProjectServer_rb.html +5 -3
  334. data/doc/lib/daemon/ReportServer_rb.html +5 -3
  335. data/doc/lib/daemon/ReportServlet_rb.html +69 -0
  336. data/doc/lib/daemon/WebServer_rb.html +9 -3
  337. data/doc/lib/daemon/WelcomePage_rb.html +71 -0
  338. data/doc/lib/deep_copy_rb.html +5 -3
  339. data/doc/lib/reports/CSVFile_rb.html +5 -3
  340. data/doc/lib/reports/CollisionDetector_rb.html +5 -3
  341. data/doc/lib/reports/ColumnTable_rb.html +5 -3
  342. data/doc/lib/reports/GanttChart_rb.html +5 -3
  343. data/doc/lib/reports/GanttContainer_rb.html +5 -3
  344. data/doc/lib/reports/GanttHeaderScaleItem_rb.html +5 -3
  345. data/doc/lib/reports/GanttHeader_rb.html +5 -3
  346. data/doc/lib/reports/GanttLine_rb.html +5 -3
  347. data/doc/lib/reports/GanttLoadStack_rb.html +5 -3
  348. data/doc/lib/reports/GanttMilestone_rb.html +5 -3
  349. data/doc/lib/reports/GanttRouter_rb.html +5 -3
  350. data/doc/lib/reports/GanttTaskBar_rb.html +5 -3
  351. data/doc/lib/reports/HTMLGraphics_rb.html +5 -3
  352. data/doc/lib/reports/Navigator_rb.html +5 -3
  353. data/doc/lib/reports/NikuReport_rb.html +5 -3
  354. data/doc/lib/reports/ReportBase_rb.html +5 -3
  355. data/doc/lib/reports/ReportContext_rb.html +5 -3
  356. data/doc/lib/reports/ReportTableCell_rb.html +5 -3
  357. data/doc/lib/reports/ReportTableColumn_rb.html +5 -3
  358. data/doc/lib/reports/ReportTableLegend_rb.html +5 -3
  359. data/doc/lib/reports/ReportTableLine_rb.html +5 -3
  360. data/doc/lib/reports/ReportTable_rb.html +5 -3
  361. data/doc/lib/reports/Report_rb.html +5 -3
  362. data/doc/lib/reports/ResourceListRE_rb.html +5 -3
  363. data/doc/lib/reports/StatusSheetReport_rb.html +5 -3
  364. data/doc/lib/reports/TableReport_rb.html +5 -3
  365. data/doc/lib/reports/TaskListRE_rb.html +5 -3
  366. data/doc/lib/reports/TextReport_rb.html +5 -3
  367. data/doc/lib/reports/TimeSheetReport_rb.html +5 -3
  368. data/doc/lib/reports/TjpExportRE_rb.html +5 -3
  369. data/doc/lib/{taskjuggler3_rb.html → tj3_rb.html} +7 -5
  370. data/doc/lib/tj3client_rb.html +5 -3
  371. data/doc/lib/tj3d_rb.html +6 -4
  372. data/doc/lib/tj3man_rb.html +5 -3
  373. data/doc/lib/tj3ss_receiver_rb.html +5 -3
  374. data/doc/lib/tj3ss_sender_rb.html +5 -3
  375. data/doc/lib/tj3ts_receiver_rb.html +5 -3
  376. data/doc/lib/tj3ts_sender_rb.html +5 -3
  377. data/doc/lib/tj3ts_summary_rb.html +5 -3
  378. data/examples/tutorial.tjp +13 -5
  379. data/gem_spec.rb +3 -0
  380. data/lib/Account.rb +2 -1
  381. data/lib/AccountScenario.rb +2 -1
  382. data/lib/Allocation.rb +2 -1
  383. data/lib/AppConfig.rb +2 -1
  384. data/lib/AttributeBase.rb +19 -5
  385. data/lib/AttributeDefinition.rb +2 -1
  386. data/lib/Attributes.rb +49 -38
  387. data/lib/BatchProcessor.rb +2 -1
  388. data/lib/Booking.rb +2 -1
  389. data/lib/Charge.rb +2 -1
  390. data/lib/ChargeSet.rb +2 -1
  391. data/lib/DataCache.rb +15 -1
  392. data/lib/FileList.rb +2 -1
  393. data/lib/HTMLDocument.rb +2 -1
  394. data/lib/Interval.rb +2 -1
  395. data/lib/IntervalList.rb +100 -0
  396. data/lib/Journal.rb +8 -2
  397. data/lib/KeywordArray.rb +2 -1
  398. data/lib/KeywordDocumentation.rb +10 -6
  399. data/lib/Limits.rb +2 -1
  400. data/lib/Log.rb +3 -2
  401. data/lib/LogFile.rb +2 -1
  402. data/lib/LogicalExpression.rb +2 -1
  403. data/lib/LogicalFunction.rb +2 -1
  404. data/lib/LogicalOperation.rb +2 -1
  405. data/lib/MacroTable.rb +2 -1
  406. data/lib/MessageHandler.rb +2 -1
  407. data/lib/Project.rb +92 -25
  408. data/lib/ProjectFileParser.rb +7 -2
  409. data/lib/ProjectFileScanner.rb +2 -1
  410. data/lib/PropertyList.rb +2 -1
  411. data/lib/PropertySet.rb +2 -6
  412. data/lib/PropertyTreeNode.rb +22 -44
  413. data/lib/Query.rb +32 -13
  414. data/lib/RTFHandlers.rb +2 -1
  415. data/lib/RTFNavigator.rb +2 -1
  416. data/lib/RTFQuery.rb +3 -2
  417. data/lib/RTFReport.rb +2 -1
  418. data/lib/RTFReportLink.rb +2 -1
  419. data/lib/RTFWithQuerySupport.rb +2 -1
  420. data/lib/RealFormat.rb +2 -1
  421. data/lib/Resource.rb +2 -1
  422. data/lib/ResourceScenario.rb +35 -14
  423. data/lib/RichText.rb +2 -1
  424. data/lib/RichTextDocument.rb +2 -1
  425. data/lib/RichTextElement.rb +2 -1
  426. data/lib/RichTextFunctionExample.rb +2 -1
  427. data/lib/RichTextFunctionHandler.rb +2 -1
  428. data/lib/RichTextParser.rb +2 -1
  429. data/lib/RichTextScanner.rb +2 -1
  430. data/lib/RichTextSnip.rb +2 -1
  431. data/lib/RichTextSyntaxRules.rb +2 -1
  432. data/lib/RuntimeConfig.rb +2 -1
  433. data/lib/Scenario.rb +2 -1
  434. data/lib/ScenarioData.rb +2 -1
  435. data/lib/Scoreboard.rb +27 -8
  436. data/lib/SheetHandlerBase.rb +2 -1
  437. data/lib/SheetReceiver.rb +2 -1
  438. data/lib/SheetSender.rb +2 -1
  439. data/lib/Shift.rb +2 -1
  440. data/lib/ShiftAssignments.rb +2 -1
  441. data/lib/ShiftScenario.rb +2 -1
  442. data/lib/SimpleQueryExpander.rb +2 -1
  443. data/lib/SourceFileInfo.rb +2 -1
  444. data/lib/StatusSheetReceiver.rb +2 -1
  445. data/lib/StatusSheetSender.rb +2 -1
  446. data/lib/SyntaxReference.rb +2 -1
  447. data/lib/TOCEntry.rb +2 -1
  448. data/lib/TableColumnDefinition.rb +9 -2
  449. data/lib/TableOfContents.rb +2 -1
  450. data/lib/Task.rb +2 -1
  451. data/lib/TaskDependency.rb +2 -1
  452. data/lib/TaskJuggler.rb +8 -6
  453. data/lib/TaskScenario.rb +337 -153
  454. data/lib/TextFormatter.rb +3 -2
  455. data/lib/TextParser.rb +7 -2
  456. data/lib/TextParser/Pattern.rb +2 -1
  457. data/lib/TextParser/Rule.rb +2 -1
  458. data/lib/TextParser/StackElement.rb +2 -1
  459. data/lib/TextParser/State.rb +3 -2
  460. data/lib/TextParser/TokenDoc.rb +2 -1
  461. data/lib/TextScanner.rb +12 -5
  462. data/lib/TimeSheetReceiver.rb +2 -1
  463. data/lib/TimeSheetSender.rb +2 -1
  464. data/lib/TimeSheetSummary.rb +3 -2
  465. data/lib/TimeSheets.rb +2 -1
  466. data/lib/Tj3AppBase.rb +6 -5
  467. data/lib/Tj3Config.rb +5 -4
  468. data/lib/Tj3SheetAppBase.rb +2 -1
  469. data/lib/TjException.rb +2 -1
  470. data/lib/TjTime.rb +2 -1
  471. data/lib/TjpExample.rb +2 -1
  472. data/lib/TjpSyntaxRules.rb +264 -65
  473. data/lib/URLParameter.rb +2 -1
  474. data/lib/UTF8String.rb +2 -1
  475. data/lib/UserManual.rb +2 -1
  476. data/lib/VimSyntax.rb +3 -2
  477. data/lib/WorkingHours.rb +2 -1
  478. data/lib/XMLDocument.rb +2 -1
  479. data/lib/XMLElement.rb +2 -1
  480. data/lib/daemon/Daemon.rb +3 -1
  481. data/lib/daemon/ProcessIntercom.rb +3 -1
  482. data/lib/daemon/ProjectBroker.rb +84 -32
  483. data/lib/daemon/ProjectServer.rb +5 -3
  484. data/lib/daemon/ReportServer.rb +8 -5
  485. data/lib/daemon/ReportServlet.rb +166 -0
  486. data/lib/daemon/WebServer.rb +6 -150
  487. data/lib/daemon/WelcomePage.rb +80 -0
  488. data/lib/deep_copy.rb +2 -1
  489. data/lib/reports/CSVFile.rb +2 -1
  490. data/lib/reports/CollisionDetector.rb +2 -1
  491. data/lib/reports/ColumnTable.rb +2 -1
  492. data/lib/reports/GanttChart.rb +2 -1
  493. data/lib/reports/GanttContainer.rb +3 -4
  494. data/lib/reports/GanttHeader.rb +2 -1
  495. data/lib/reports/GanttHeaderScaleItem.rb +2 -1
  496. data/lib/reports/GanttLine.rb +12 -10
  497. data/lib/reports/GanttLoadStack.rb +2 -1
  498. data/lib/reports/GanttMilestone.rb +3 -3
  499. data/lib/reports/GanttRouter.rb +4 -1
  500. data/lib/reports/GanttTaskBar.rb +9 -7
  501. data/lib/reports/HTMLGraphics.rb +2 -1
  502. data/lib/reports/Navigator.rb +2 -1
  503. data/lib/reports/NikuReport.rb +79 -49
  504. data/lib/reports/Report.rb +42 -10
  505. data/lib/reports/ReportBase.rb +2 -1
  506. data/lib/reports/ReportContext.rb +2 -1
  507. data/lib/reports/ReportTable.rb +2 -1
  508. data/lib/reports/ReportTableCell.rb +63 -28
  509. data/lib/reports/ReportTableColumn.rb +2 -1
  510. data/lib/reports/ReportTableLegend.rb +5 -5
  511. data/lib/reports/ReportTableLine.rb +2 -1
  512. data/lib/reports/ResourceListRE.rb +2 -1
  513. data/lib/reports/StatusSheetReport.rb +4 -2
  514. data/lib/reports/TableReport.rb +42 -38
  515. data/lib/reports/TaskListRE.rb +4 -2
  516. data/lib/reports/TextReport.rb +2 -1
  517. data/lib/reports/TimeSheetReport.rb +4 -2
  518. data/lib/reports/TjpExportRE.rb +4 -2
  519. data/lib/{taskjuggler3.rb → tj3.rb} +6 -5
  520. data/lib/tj3client.rb +19 -36
  521. data/lib/tj3d.rb +6 -2
  522. data/lib/tj3man.rb +4 -3
  523. data/lib/tj3ss_receiver.rb +2 -1
  524. data/lib/tj3ss_sender.rb +2 -1
  525. data/lib/tj3ts_receiver.rb +2 -1
  526. data/lib/tj3ts_sender.rb +2 -1
  527. data/lib/tj3ts_summary.rb +2 -1
  528. data/manual/Day_To_Day_Juggling +36 -0
  529. data/manual/How_To_Contribute +9 -4
  530. data/manual/Installation +10 -3
  531. data/manual/TaskJuggler_Internals +0 -2
  532. data/manual/Tutorial +25 -3
  533. data/prj_cfg.rb +4 -2
  534. data/spec/IntervalList_spec.rb +138 -0
  535. data/spec/ProjectBroker_spec.rb +133 -0
  536. data/tasks/changelog.rake +41 -24
  537. data/tasks/csts.rake +1 -0
  538. data/tasks/gem.rake +1 -0
  539. data/tasks/rcov.rake +1 -1
  540. data/tasks/spec.rake +7 -0
  541. data/tasks/test.rake +1 -0
  542. data/test/MessageChecker.rb +2 -1
  543. data/test/TestSuite/CSV-Reports/niku.tjp +70 -0
  544. data/test/TestSuite/CSV-Reports/{celltext-Reference.csv → refs/celltext.csv} +0 -0
  545. data/test/TestSuite/CSV-Reports/refs/niku.csv +5 -0
  546. data/test/TestSuite/CSV-Reports/{resourcereport-Reference.csv → refs/resourcereport.csv} +0 -0
  547. data/test/TestSuite/CSV-Reports/{resourcereport_with_tasks-Reference.csv → refs/resourcereport_with_tasks.csv} +0 -0
  548. data/test/TestSuite/CSV-Reports/{sortByTree-Reference.csv → refs/sortByTree.csv} +0 -0
  549. data/test/TestSuite/CSV-Reports/{sortBy_duration.down-Reference.csv → refs/sortBy_duration.down.csv} +0 -0
  550. data/test/TestSuite/CSV-Reports/{sortBy_effort.up-Reference.csv → refs/sortBy_effort.up.csv} +0 -0
  551. data/test/TestSuite/CSV-Reports/{sortBy_plan.start.down-Reference.csv → refs/sortBy_plan.start.down.csv} +0 -0
  552. data/test/TestSuite/CSV-Reports/{taskreport-Reference.csv → refs/taskreport.csv} +0 -0
  553. data/test/TestSuite/CSV-Reports/{taskreport_with_resources-Reference.csv → refs/taskreport_with_resources.csv} +0 -0
  554. data/test/TestSuite/CSV-Reports/{weekly-Reference.csv → refs/weekly.csv} +0 -0
  555. data/test/TestSuite/HTML-Reports/Alerts.tjp +12 -0
  556. data/test/TestSuite/Scheduler/Correct/Allocate.tjp +2 -2
  557. data/test/TestSuite/Scheduler/Correct/Container-2.tjp +1 -2
  558. data/test/TestSuite/Scheduler/Correct/InheritedAttributes.tjp +77 -0
  559. data/test/TestSuite/Scheduler/Correct/WeakDeps.tjp +40 -0
  560. data/test/TestSuite/Scheduler/Errors/loop_detected_12.tjp +2 -2
  561. data/test/TestSuite/Scheduler/Errors/loop_detected_13.tjp +3 -4
  562. data/test/TestSuite/Scheduler/Errors/loop_detected_3.tjp +2 -2
  563. data/test/TestSuite/Scheduler/Errors/loop_detected_6.tjp +8 -7
  564. data/test/TestSuite/Scheduler/Errors/onend_wrong_direction.tjp +19 -0
  565. data/test/TestSuite/Scheduler/Errors/onstart_wrong_direction.tjp +18 -0
  566. data/test/TestSuite/Scheduler/Errors/task_depend_multi.tjp +1 -2
  567. data/test/TestSuite/StatusSheets/StatusSheetTemplates/2002-03-02/boss_2002-03-02.tji +46 -0
  568. data/test/TestSuite/StatusSheets/StatusSheetTemplates/2002-03-02/dev2_2002-03-02.tji +22 -0
  569. data/test/TestSuite/StatusSheets/StatusSheetTemplates/2002-03-02/resources.yml +11 -0
  570. data/test/TestSuite/StatusSheets/StatusSheetTemplates/acceptable_intervals +1 -0
  571. data/test/TestSuite/StatusSheets/sender.log +256 -0
  572. data/test/TestSuite/StatusSheets/statussheets.log +9 -0
  573. data/test/TestSuite/StatusSheets/tj3d.log +395 -0
  574. data/test/TestSuite/Syntax/Correct/Limits-1.tjp +2 -0
  575. data/test/TestSuite/Syntax/Correct/Niku.tjp +6 -1
  576. data/test/TestSuite/Syntax/Correct/Scenario.tjp +4 -1
  577. data/test/TestSuite/Syntax/Correct/Supplement.tjp +12 -5
  578. data/test/TestSuite/Syntax/Correct/TaskPrefix.tji +3 -0
  579. data/test/TestSuite/Syntax/Correct/TaskPrefix.tjp +24 -0
  580. data/test/TestSuite/Syntax/Correct/css/tjreport.css +7 -2
  581. data/test/TestSuite/Syntax/Correct/tutorial.tjp +15 -5
  582. data/test/all.rb +2 -4
  583. data/test/test_BatchProcessor.rb +2 -1
  584. data/test/test_CSV-Reports.rb +34 -23
  585. data/test/test_CSVFile.rb +2 -1
  586. data/test/test_CollisionDetector.rb +3 -2
  587. data/test/test_Journal.rb +2 -1
  588. data/test/test_Limits.rb +2 -1
  589. data/test/test_LogicalExpression.rb +2 -1
  590. data/test/test_MacroTable.rb +2 -1
  591. data/test/test_Project.rb +3 -2
  592. data/test/test_ProjectFileScanner.rb +2 -1
  593. data/test/test_PropertySet.rb +2 -1
  594. data/test/test_Query.rb +2 -1
  595. data/test/test_RealFormat.rb +2 -1
  596. data/test/test_ReportGenerator.rb +2 -1
  597. data/test/test_RichText.rb +2 -1
  598. data/test/test_Scheduler.rb +2 -1
  599. data/test/test_ShiftAssignments.rb +2 -1
  600. data/test/test_SimpleQueryExpander.rb +2 -1
  601. data/test/test_Syntax.rb +2 -1
  602. data/test/test_TextFormatter.rb +3 -2
  603. data/test/test_TjTime.rb +2 -1
  604. data/test/test_TjpExample.rb +2 -1
  605. data/test/test_URLParameter.rb +2 -1
  606. data/test/test_UTF8String.rb +2 -1
  607. data/test/test_WorkingHours.rb +2 -1
  608. data/test/test_deep_copy.rb +2 -1
  609. metadata +74 -20
  610. data/doc/StringIO.html +0 -595
  611. data/test/TestSuite/Scheduler/Errors/loop_detected_7.tjp +0 -46
  612. data/test/TestSuite/Scheduler/Errors/loop_detected_8.tjp +0 -51
  613. data/test/TestSuite/Scheduler/Errors/multiple_durations.tjp +0 -11
@@ -153,6 +153,8 @@
153
153
 
154
154
  <li><a href="../TaskJuggler/AttributeDefinition.html">TaskJuggler::AttributeDefinition</a></li>
155
155
 
156
+ <li><a href="../TaskJuggler/AttributeOverwrite.html">TaskJuggler::AttributeOverwrite</a></li>
157
+
156
158
  <li><a href="../TaskJuggler/BatchProcessor.html">TaskJuggler::BatchProcessor</a></li>
157
159
 
158
160
  <li><a href="../TaskJuggler/Booking.html">TaskJuggler::Booking</a></li>
@@ -231,6 +233,8 @@
231
233
 
232
234
  <li><a href="../TaskJuggler/Interval.html">TaskJuggler::Interval</a></li>
233
235
 
236
+ <li><a href="../TaskJuggler/IntervalList.html">TaskJuggler::IntervalList</a></li>
237
+
234
238
  <li><a href="../TaskJuggler/IntervalListAttribute.html">TaskJuggler::IntervalListAttribute</a></li>
235
239
 
236
240
  <li><a href="../TaskJuggler/JobInfo.html">TaskJuggler::JobInfo</a></li>
@@ -263,6 +267,8 @@
263
267
 
264
268
  <li><a href="../TaskJuggler/LogicalExpressionAttribute.html">TaskJuggler::LogicalExpressionAttribute</a></li>
265
269
 
270
+ <li><a href="../TaskJuggler/LogicalExpressionListAttribute.html">TaskJuggler::LogicalExpressionListAttribute</a></li>
271
+
266
272
  <li><a href="../TaskJuggler/LogicalFlag.html">TaskJuggler::LogicalFlag</a></li>
267
273
 
268
274
  <li><a href="../TaskJuggler/LogicalFunction.html">TaskJuggler::LogicalFunction</a></li>
@@ -543,6 +549,8 @@
543
549
 
544
550
  <li><a href="../TaskJuggler/WebServer.html">TaskJuggler::WebServer</a></li>
545
551
 
552
+ <li><a href="../TaskJuggler/WelcomePage.html">TaskJuggler::WelcomePage</a></li>
553
+
546
554
  <li><a href="../TaskJuggler/WorkingHours.html">TaskJuggler::WorkingHours</a></li>
547
555
 
548
556
  <li><a href="../TaskJuggler/WorkingHoursAttribute.html">TaskJuggler::WorkingHoursAttribute</a></li>
@@ -569,8 +577,6 @@
569
577
 
570
578
  <li><a href="../String.html">String</a></li>
571
579
 
572
- <li><a href="../StringIO.html">StringIO</a></li>
573
-
574
580
  </ul>
575
581
  <div id="no-class-search-results" style="display: none;">No matching classes.</div>
576
582
  </div>
@@ -613,6 +619,23 @@ href="../TaskJuggler.html">TaskJuggler</a> daemon.
613
619
  <h3 class="section-header">Attributes</h3>
614
620
 
615
621
 
622
+ <div id="auth-ey-attribute-method" class="method-detail">
623
+ <a name="authKey"></a>
624
+
625
+ <a name="authKey="></a>
626
+
627
+ <div class="method-heading attribute-method-heading">
628
+ <span class="method-name">authKey</span><span
629
+ class="attribute-access-type">[RW]</span>
630
+ </div>
631
+
632
+ <div class="method-description">
633
+
634
+
635
+
636
+ </div>
637
+ </div>
638
+
616
639
  <div id="port-attribute-method" class="method-detail">
617
640
  <a name="port"></a>
618
641
 
@@ -698,12 +721,14 @@ href="../TaskJuggler.html">TaskJuggler</a> daemon.
698
721
  </div>
699
722
  </div>
700
723
 
701
- <div id="auth-ey-attribute-method" class="method-detail">
702
- <a name="authKey"></a>
724
+ <div id="log-td--attribute-method" class="method-detail">
725
+ <a name="logStdIO"></a>
726
+
727
+ <a name="logStdIO="></a>
703
728
 
704
729
  <div class="method-heading attribute-method-heading">
705
- <span class="method-name">authKey</span><span
706
- class="attribute-access-type">[R]</span>
730
+ <span class="method-name">logStdIO</span><span
731
+ class="attribute-access-type">[RW]</span>
707
732
  </div>
708
733
 
709
734
  <div class="method-description">
@@ -765,18 +790,22 @@ href="../TaskJuggler.html">TaskJuggler</a> daemon.
765
790
  62: <span class="ruby-comment cmt"># requests that the housekeeping thread will then perform.</span>
766
791
  63: <span class="ruby-ivar">@projectsToLoad</span> = <span class="ruby-constant">Queue</span>.<span class="ruby-identifier">new</span>
767
792
  64:
768
- 65: <span class="ruby-comment cmt"># Referece to WEBrick object.</span>
769
- 66: <span class="ruby-ivar">@webServer</span> = <span class="ruby-keyword kw">nil</span>
770
- 67:
771
- 68: <span class="ruby-comment cmt"># Port used by the web server</span>
772
- 69: <span class="ruby-ivar">@webServerPort</span> = <span class="ruby-value">8080</span>
773
- 70:
774
- 71: <span class="ruby-comment cmt"># True if web server should be activated</span>
775
- 72: <span class="ruby-ivar">@enableWebServer</span> = <span class="ruby-keyword kw">false</span>
776
- 73:
777
- 74: <span class="ruby-comment cmt"># This flag will be set to true to terminate the daemon.</span>
778
- 75: <span class="ruby-ivar">@terminate</span> = <span class="ruby-keyword kw">false</span>
779
- 76: <span class="ruby-keyword kw">end</span></pre>
793
+ 65: <span class="ruby-comment cmt"># Set this flag to true to have standard IO logged into files. There</span>
794
+ 66: <span class="ruby-comment cmt"># will be seperate set of files for each process.</span>
795
+ 67: <span class="ruby-ivar">@logStdIO</span> = <span class="ruby-operator">!</span><span class="ruby-ivar">@daemonize</span>
796
+ 68:
797
+ 69: <span class="ruby-comment cmt"># Reference to WEBrick object.</span>
798
+ 70: <span class="ruby-ivar">@webServer</span> = <span class="ruby-keyword kw">nil</span>
799
+ 71:
800
+ 72: <span class="ruby-comment cmt"># Port used by the web server</span>
801
+ 73: <span class="ruby-ivar">@webServerPort</span> = <span class="ruby-value">8080</span>
802
+ 74:
803
+ 75: <span class="ruby-comment cmt"># True if web server should be activated</span>
804
+ 76: <span class="ruby-ivar">@enableWebServer</span> = <span class="ruby-keyword kw">false</span>
805
+ 77:
806
+ 78: <span class="ruby-comment cmt"># This flag will be set to true to terminate the daemon.</span>
807
+ 79: <span class="ruby-ivar">@terminate</span> = <span class="ruby-keyword kw">false</span>
808
+ 80: <span class="ruby-keyword kw">end</span></pre>
780
809
  </div>
781
810
 
782
811
  </div>
@@ -799,7 +828,7 @@ href="../TaskJuggler.html">TaskJuggler</a> daemon.
799
828
  <div class="method-heading">
800
829
 
801
830
  <span class="method-name">addProject</span><span
802
- class="method-args">()</span>
831
+ class="method-args">(cwd, args, stdOut, stdErr, stdIn, silent)</span>
803
832
  <span class="method-click-advice">click to toggle source</span>
804
833
 
805
834
  </div>
@@ -816,37 +845,71 @@ the project has been loaded or the load has failed.
816
845
  <div class="method-source-code"
817
846
  id="add-roject-source">
818
847
  <pre>
819
- <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 208</span>
820
- 208: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">addProject</span>
821
- 209: <span class="ruby-comment cmt"># We need some tag to identify the ProjectRecord that this project was</span>
822
- 210: <span class="ruby-comment cmt"># associated to. Just use a large enough random number.</span>
823
- 211: <span class="ruby-identifier">tag</span> = <span class="ruby-identifier">rand</span>(<span class="ruby-value">9999999999999</span>)
824
- 212:
825
- 213: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-node">&quot;Pushing #{tag} to load Queue&quot;</span>)
826
- 214: <span class="ruby-ivar">@projectsToLoad</span>.<span class="ruby-identifier">push</span>(<span class="ruby-identifier">tag</span>)
827
- 215:
828
- 216: <span class="ruby-comment cmt"># Now we have to wait until the loaded project shows up in the @projects</span>
829
- 217: <span class="ruby-comment cmt"># list. We use our tag to identify the right entry.</span>
830
- 218: <span class="ruby-identifier">pr</span> = <span class="ruby-keyword kw">nil</span>
831
- 219: <span class="ruby-keyword kw">while</span> <span class="ruby-identifier">pr</span>.<span class="ruby-identifier">nil?</span>
832
- 220: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
833
- 221: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span>
834
- 222: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">tag</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">tag</span>
835
- 223: <span class="ruby-identifier">pr</span> = <span class="ruby-identifier">p</span>
836
- 224: <span class="ruby-keyword kw">break</span>
837
- 225: <span class="ruby-keyword kw">end</span>
838
- 226: <span class="ruby-keyword kw">end</span>
839
- 227: <span class="ruby-keyword kw">end</span>
840
- 228: <span class="ruby-comment cmt"># The wait in this loop should be pretty short and we don't want to</span>
841
- 229: <span class="ruby-comment cmt"># miss IO from the ProjectServer process.</span>
842
- 230: <span class="ruby-identifier">sleep</span> <span class="ruby-value">0.1</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">pr</span>
843
- 231: <span class="ruby-keyword kw">end</span>
844
- 232:
845
- 233: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-node">&quot;Found tag #{tag} in list of loaded projects with URI &quot;</span> <span class="ruby-operator">+</span>
846
- 234: <span class="ruby-node">&quot;#{pr.uri}&quot;</span>)
847
- 235: <span class="ruby-comment cmt"># Return the URI and the authentication key of the new ProjectServer.</span>
848
- 236: [ <span class="ruby-identifier">pr</span>.<span class="ruby-identifier">uri</span>, <span class="ruby-identifier">pr</span>.<span class="ruby-identifier">authKey</span> ]
849
- 237: <span class="ruby-keyword kw">end</span></pre>
848
+ <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 214</span>
849
+ 214: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">addProject</span>(<span class="ruby-identifier">cwd</span>, <span class="ruby-identifier">args</span>, <span class="ruby-identifier">stdOut</span>, <span class="ruby-identifier">stdErr</span>, <span class="ruby-identifier">stdIn</span>, <span class="ruby-identifier">silent</span>)
850
+ 215: <span class="ruby-comment cmt"># We need some tag to identify the ProjectRecord that this project was</span>
851
+ 216: <span class="ruby-comment cmt"># associated to. Just use a large enough random number.</span>
852
+ 217: <span class="ruby-identifier">tag</span> = <span class="ruby-identifier">rand</span>(<span class="ruby-value">9999999999999</span>)
853
+ 218:
854
+ 219: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-node">&quot;Pushing #{tag} to load Queue&quot;</span>)
855
+ 220: <span class="ruby-ivar">@projectsToLoad</span>.<span class="ruby-identifier">push</span>(<span class="ruby-identifier">tag</span>)
856
+ 221:
857
+ 222: <span class="ruby-comment cmt"># Now we have to wait until the project shows up in the @projects</span>
858
+ 223: <span class="ruby-comment cmt"># list. We use our tag to identify the right entry.</span>
859
+ 224: <span class="ruby-identifier">pr</span> = <span class="ruby-keyword kw">nil</span>
860
+ 225: <span class="ruby-keyword kw">while</span> <span class="ruby-identifier">pr</span>.<span class="ruby-identifier">nil?</span>
861
+ 226: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
862
+ 227: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span>
863
+ 228: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">tag</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">tag</span>
864
+ 229: <span class="ruby-identifier">pr</span> = <span class="ruby-identifier">p</span>
865
+ 230: <span class="ruby-keyword kw">break</span>
866
+ 231: <span class="ruby-keyword kw">end</span>
867
+ 232: <span class="ruby-keyword kw">end</span>
868
+ 233: <span class="ruby-keyword kw">end</span>
869
+ 234: <span class="ruby-comment cmt"># The wait in this loop should be pretty short and we don't want to</span>
870
+ 235: <span class="ruby-comment cmt"># miss IO from the ProjectServer process.</span>
871
+ 236: <span class="ruby-identifier">sleep</span> <span class="ruby-value">0.1</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">pr</span>
872
+ 237: <span class="ruby-keyword kw">end</span>
873
+ 238:
874
+ 239: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-node">&quot;Found tag #{tag} in list of loaded projects with URI &quot;</span> <span class="ruby-operator">+</span>
875
+ 240: <span class="ruby-node">&quot;#{pr.uri}&quot;</span>)
876
+ 241: <span class="ruby-comment cmt"># Return the URI and the authentication key of the new ProjectServer.</span>
877
+ 242: [ <span class="ruby-identifier">pr</span>.<span class="ruby-identifier">uri</span>, <span class="ruby-identifier">pr</span>.<span class="ruby-identifier">authKey</span> ]
878
+ 243:
879
+ 244: <span class="ruby-comment cmt"># Open a DRb connection to the ProjectServer process</span>
880
+ 245: <span class="ruby-keyword kw">begin</span>
881
+ 246: <span class="ruby-identifier">projectServer</span> = <span class="ruby-constant">DRbObject</span>.<span class="ruby-identifier">new</span>(<span class="ruby-keyword kw">nil</span>, <span class="ruby-identifier">pr</span>.<span class="ruby-identifier">uri</span>)
882
+ 247: <span class="ruby-keyword kw">rescue</span>
883
+ 248: <span class="ruby-identifier">stdErr</span>.<span class="ruby-identifier">puts</span> <span class="ruby-node">&quot;Can't get ProjectServer object: #{$!}&quot;</span>
884
+ 249: <span class="ruby-keyword kw">return</span> <span class="ruby-keyword kw">false</span>
885
+ 250: <span class="ruby-keyword kw">end</span>
886
+ 251: <span class="ruby-keyword kw">begin</span>
887
+ 252: <span class="ruby-comment cmt"># Hook up IO from requestor to the ProjectServer process.</span>
888
+ 253: <span class="ruby-identifier">projectServer</span>.<span class="ruby-identifier">connect</span>(<span class="ruby-identifier">pr</span>.<span class="ruby-identifier">authKey</span>, <span class="ruby-identifier">stdOut</span>, <span class="ruby-identifier">stdErr</span>, <span class="ruby-identifier">stdIn</span>, <span class="ruby-identifier">silent</span>)
889
+ 254: <span class="ruby-keyword kw">rescue</span>
890
+ 255: <span class="ruby-identifier">stdErr</span>.<span class="ruby-identifier">puts</span> <span class="ruby-node">&quot;Can't connect IO: #{$!}&quot;</span>
891
+ 256: <span class="ruby-keyword kw">return</span> <span class="ruby-keyword kw">false</span>
892
+ 257: <span class="ruby-keyword kw">end</span>
893
+ 258:
894
+ 259: <span class="ruby-comment cmt"># Ask the ProjectServer to load the files in _args_ into the</span>
895
+ 260: <span class="ruby-comment cmt"># ProjectServer.</span>
896
+ 261: <span class="ruby-keyword kw">begin</span>
897
+ 262: <span class="ruby-identifier">res</span> = <span class="ruby-identifier">projectServer</span>.<span class="ruby-identifier">loadProject</span>(<span class="ruby-identifier">pr</span>.<span class="ruby-identifier">authKey</span>, [ <span class="ruby-identifier">cwd</span>, *<span class="ruby-identifier">args</span> ])
898
+ 263: <span class="ruby-keyword kw">rescue</span>
899
+ 264: <span class="ruby-identifier">stdErr</span>.<span class="ruby-identifier">puts</span> <span class="ruby-node">&quot;Loading of project failed: #{$!}&quot;</span>
900
+ 265: <span class="ruby-keyword kw">return</span> <span class="ruby-keyword kw">false</span>
901
+ 266: <span class="ruby-keyword kw">end</span>
902
+ 267:
903
+ 268: <span class="ruby-comment cmt"># Disconnect the IO from the ProjectServer and close the DRb connection.</span>
904
+ 269: <span class="ruby-keyword kw">begin</span>
905
+ 270: <span class="ruby-identifier">projectServer</span>.<span class="ruby-identifier">disconnect</span>(<span class="ruby-identifier">pr</span>.<span class="ruby-identifier">authKey</span>)
906
+ 271: <span class="ruby-keyword kw">rescue</span>
907
+ 272: <span class="ruby-identifier">stdErr</span>.<span class="ruby-identifier">puts</span> <span class="ruby-node">&quot;Can't disconnect IO: #{$!}&quot;</span>
908
+ 273: <span class="ruby-keyword kw">return</span> <span class="ruby-keyword kw">false</span>
909
+ 274: <span class="ruby-keyword kw">end</span>
910
+ 275:
911
+ 276: <span class="ruby-identifier">res</span>
912
+ 277: <span class="ruby-keyword kw">end</span></pre>
850
913
  </div>
851
914
 
852
915
  </div>
@@ -880,17 +943,17 @@ client and the server get this secret key from the same configuration file.
880
943
  <div class="method-source-code"
881
944
  id="check-ey-source">
882
945
  <pre>
883
- <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 156</span>
884
- 156: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">checkKey</span>(<span class="ruby-identifier">authKey</span>, <span class="ruby-identifier">command</span>)
885
- 157: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">authKey</span> <span class="ruby-operator">==</span> <span class="ruby-ivar">@authKey</span>
886
- 158: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-node">&quot;Accepted authentication key for command '#{command}'&quot;</span>)
887
- 159: <span class="ruby-keyword kw">else</span>
888
- 160: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">warning</span>(<span class="ruby-node">&quot;Rejected wrong authentication key '#{authKey}' &quot;</span> <span class="ruby-operator">+</span>
889
- 161: <span class="ruby-node">&quot;for command '#{command}'&quot;</span>)
890
- 162: <span class="ruby-keyword kw">return</span> <span class="ruby-keyword kw">false</span>
891
- 163: <span class="ruby-keyword kw">end</span>
892
- 164: <span class="ruby-keyword kw">true</span>
893
- 165: <span class="ruby-keyword kw">end</span></pre>
946
+ <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 162</span>
947
+ 162: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">checkKey</span>(<span class="ruby-identifier">authKey</span>, <span class="ruby-identifier">command</span>)
948
+ 163: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">authKey</span> <span class="ruby-operator">==</span> <span class="ruby-ivar">@authKey</span>
949
+ 164: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-node">&quot;Accepted authentication key for command '#{command}'&quot;</span>)
950
+ 165: <span class="ruby-keyword kw">else</span>
951
+ 166: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">warning</span>(<span class="ruby-node">&quot;Rejected wrong authentication key '#{authKey}' &quot;</span> <span class="ruby-operator">+</span>
952
+ 167: <span class="ruby-node">&quot;for command '#{command}'&quot;</span>)
953
+ 168: <span class="ruby-keyword kw">return</span> <span class="ruby-keyword kw">false</span>
954
+ 169: <span class="ruby-keyword kw">end</span>
955
+ 170: <span class="ruby-keyword kw">true</span>
956
+ 171: <span class="ruby-keyword kw">end</span></pre>
894
957
  </div>
895
958
 
896
959
  </div>
@@ -924,22 +987,22 @@ for the project with project ID <em>projectId</em>.
924
987
  <div class="method-source-code"
925
988
  id="get-roject-source">
926
989
  <pre>
927
- <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 262</span>
928
- 262: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">getProject</span>(<span class="ruby-identifier">projectId</span>)
929
- 263: <span class="ruby-comment cmt"># Find the project with the ID args[0].</span>
930
- 264: <span class="ruby-identifier">project</span> = <span class="ruby-keyword kw">nil</span>
931
- 265: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
932
- 266: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span>
933
- 267: <span class="ruby-identifier">project</span> = <span class="ruby-identifier">p</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">id</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">projectId</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">state</span> <span class="ruby-operator">==</span> <span class="ruby-value">:ready</span>
934
- 268: <span class="ruby-keyword kw">end</span>
935
- 269: <span class="ruby-keyword kw">end</span>
936
- 270:
937
- 271: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">project</span>.<span class="ruby-identifier">nil?</span>
938
- 272: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-node">&quot;No project with ID #{projectId} found&quot;</span>)
939
- 273: <span class="ruby-keyword kw">return</span> [ <span class="ruby-keyword kw">nil</span>, <span class="ruby-keyword kw">nil</span> ]
940
- 274: <span class="ruby-keyword kw">end</span>
941
- 275: [ <span class="ruby-identifier">project</span>.<span class="ruby-identifier">uri</span>, <span class="ruby-identifier">project</span>.<span class="ruby-identifier">authKey</span> ]
942
- 276: <span class="ruby-keyword kw">end</span></pre>
990
+ <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 308</span>
991
+ 308: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">getProject</span>(<span class="ruby-identifier">projectId</span>)
992
+ 309: <span class="ruby-comment cmt"># Find the project with the ID args[0].</span>
993
+ 310: <span class="ruby-identifier">project</span> = <span class="ruby-keyword kw">nil</span>
994
+ 311: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
995
+ 312: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span>
996
+ 313: <span class="ruby-identifier">project</span> = <span class="ruby-identifier">p</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">id</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">projectId</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">state</span> <span class="ruby-operator">==</span> <span class="ruby-value">:ready</span>
997
+ 314: <span class="ruby-keyword kw">end</span>
998
+ 315: <span class="ruby-keyword kw">end</span>
999
+ 316:
1000
+ 317: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">project</span>.<span class="ruby-identifier">nil?</span>
1001
+ 318: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-node">&quot;No project with ID #{projectId} found&quot;</span>)
1002
+ 319: <span class="ruby-keyword kw">return</span> [ <span class="ruby-keyword kw">nil</span>, <span class="ruby-keyword kw">nil</span> ]
1003
+ 320: <span class="ruby-keyword kw">end</span>
1004
+ 321: [ <span class="ruby-identifier">project</span>.<span class="ruby-identifier">uri</span>, <span class="ruby-identifier">project</span>.<span class="ruby-identifier">authKey</span> ]
1005
+ 322: <span class="ruby-keyword kw">end</span></pre>
943
1006
  </div>
944
1007
 
945
1008
  </div>
@@ -972,16 +1035,16 @@ Return a list of IDs of projects that are in state :ready.
972
1035
  <div class="method-source-code"
973
1036
  id="get-roject-ist-source">
974
1037
  <pre>
975
- <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 292</span>
976
- 292: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">getProjectList</span>
977
- 293: <span class="ruby-identifier">list</span> = []
978
- 294: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
979
- 295: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">project</span><span class="ruby-operator">|</span>
980
- 296: <span class="ruby-identifier">list</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">project</span>.<span class="ruby-identifier">id</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">project</span>.<span class="ruby-identifier">state</span> <span class="ruby-operator">==</span> <span class="ruby-value">:ready</span>
981
- 297: <span class="ruby-keyword kw">end</span>
982
- 298: <span class="ruby-keyword kw">end</span>
983
- 299: <span class="ruby-identifier">list</span>
984
- 300: <span class="ruby-keyword kw">end</span></pre>
1038
+ <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 338</span>
1039
+ 338: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">getProjectList</span>
1040
+ 339: <span class="ruby-identifier">list</span> = []
1041
+ 340: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1042
+ 341: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">project</span><span class="ruby-operator">|</span>
1043
+ 342: <span class="ruby-identifier">list</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">project</span>.<span class="ruby-identifier">id</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">project</span>.<span class="ruby-identifier">state</span> <span class="ruby-operator">==</span> <span class="ruby-value">:ready</span>
1044
+ 343: <span class="ruby-keyword kw">end</span>
1045
+ 344: <span class="ruby-keyword kw">end</span>
1046
+ 345: <span class="ruby-identifier">list</span>
1047
+ 346: <span class="ruby-keyword kw">end</span></pre>
985
1048
  </div>
986
1049
 
987
1050
  </div>
@@ -1012,27 +1075,33 @@ Return a list of IDs of projects that are in state :ready.
1012
1075
  <div class="method-source-code"
1013
1076
  id="remove-roject-source">
1014
1077
  <pre>
1015
- <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 239</span>
1016
- 239: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">removeProject</span>(<span class="ruby-identifier">indexOrId</span>)
1017
- 240: <span class="ruby-comment cmt"># Find all projects with the IDs in indexOrId and mark them as :obsolete.</span>
1018
- 241: <span class="ruby-keyword kw">if</span> <span class="ruby-regexp re">/^[0-9]$/</span>.<span class="ruby-identifier">match</span>(<span class="ruby-identifier">indexOrId</span>)
1019
- 242: <span class="ruby-identifier">index</span> = <span class="ruby-identifier">indexOrId</span>.<span class="ruby-identifier">to_i</span> <span class="ruby-operator">-</span> <span class="ruby-value">1</span>
1020
- 243: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">index</span> <span class="ruby-operator">&gt;=</span> <span class="ruby-value">0</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-identifier">index</span> <span class="ruby-operator">&lt;</span> <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">length</span>
1021
- 244: <span class="ruby-ivar">@projects</span>[<span class="ruby-identifier">index</span>].<span class="ruby-identifier">state</span> = <span class="ruby-value">:obsolete</span>
1022
- 245: <span class="ruby-keyword kw">return</span> <span class="ruby-keyword kw">true</span>
1023
- 246: <span class="ruby-keyword kw">end</span>
1024
- 247: <span class="ruby-keyword kw">else</span>
1025
- 248: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1026
- 249: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span>
1027
- 250: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">indexOrId</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">id</span>
1028
- 251: <span class="ruby-identifier">p</span>.<span class="ruby-identifier">state</span> = <span class="ruby-value">:obsolete</span>
1029
- 252: <span class="ruby-keyword kw">return</span> <span class="ruby-keyword kw">true</span>
1030
- 253: <span class="ruby-keyword kw">end</span>
1031
- 254: <span class="ruby-keyword kw">end</span>
1032
- 255: <span class="ruby-keyword kw">end</span>
1033
- 256: <span class="ruby-keyword kw">end</span>
1034
- 257: <span class="ruby-keyword kw">false</span>
1035
- 258: <span class="ruby-keyword kw">end</span></pre>
1078
+ <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 279</span>
1079
+ 279: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">removeProject</span>(<span class="ruby-identifier">indexOrId</span>)
1080
+ 280: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1081
+ 281: <span class="ruby-comment cmt"># Find all projects with the IDs in indexOrId and mark them as :obsolete.</span>
1082
+ 282: <span class="ruby-keyword kw">if</span> <span class="ruby-regexp re">/^[0-9]$/</span>.<span class="ruby-identifier">match</span>(<span class="ruby-identifier">indexOrId</span>)
1083
+ 283: <span class="ruby-identifier">index</span> = <span class="ruby-identifier">indexOrId</span>.<span class="ruby-identifier">to_i</span> <span class="ruby-operator">-</span> <span class="ruby-value">1</span>
1084
+ 284: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">index</span> <span class="ruby-operator">&gt;=</span> <span class="ruby-value">0</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-identifier">index</span> <span class="ruby-operator">&lt;</span> <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">length</span>
1085
+ 285: <span class="ruby-comment cmt"># If we have marked the project as obsolete, we return false to</span>
1086
+ 286: <span class="ruby-comment cmt"># indicate the double remove.</span>
1087
+ 287: <span class="ruby-keyword kw">return</span> <span class="ruby-keyword kw">false</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">state</span> <span class="ruby-operator">==</span> <span class="ruby-value">:obsolete</span>
1088
+ 288: <span class="ruby-ivar">@projects</span>[<span class="ruby-identifier">index</span>].<span class="ruby-identifier">state</span> = <span class="ruby-value">:obsolete</span>
1089
+ 289: <span class="ruby-keyword kw">return</span> <span class="ruby-keyword kw">true</span>
1090
+ 290: <span class="ruby-keyword kw">end</span>
1091
+ 291: <span class="ruby-keyword kw">else</span>
1092
+ 292: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span>
1093
+ 293: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">indexOrId</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">id</span>
1094
+ 294: <span class="ruby-comment cmt"># If we have marked the project as obsolete, we return false to</span>
1095
+ 295: <span class="ruby-comment cmt"># indicate the double remove.</span>
1096
+ 296: <span class="ruby-keyword kw">return</span> <span class="ruby-keyword kw">false</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">state</span> <span class="ruby-operator">==</span> <span class="ruby-value">:obsolete</span>
1097
+ 297: <span class="ruby-identifier">p</span>.<span class="ruby-identifier">state</span> = <span class="ruby-value">:obsolete</span>
1098
+ 298: <span class="ruby-keyword kw">return</span> <span class="ruby-keyword kw">true</span>
1099
+ 299: <span class="ruby-keyword kw">end</span>
1100
+ 300: <span class="ruby-keyword kw">end</span>
1101
+ 301: <span class="ruby-keyword kw">end</span>
1102
+ 302: <span class="ruby-keyword kw">end</span>
1103
+ 303: <span class="ruby-keyword kw">false</span>
1104
+ 304: <span class="ruby-keyword kw">end</span></pre>
1036
1105
  </div>
1037
1106
 
1038
1107
  </div>
@@ -1063,10 +1132,10 @@ Return a list of IDs of projects that are in state :ready.
1063
1132
  <div class="method-source-code"
1064
1133
  id="report-source">
1065
1134
  <pre>
1066
- <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 302</span>
1067
- 302: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">report</span>(<span class="ruby-identifier">projectId</span>, <span class="ruby-identifier">reportId</span>)
1068
- 303: <span class="ruby-identifier">uri</span>, <span class="ruby-identifier">key</span> = <span class="ruby-identifier">getProject</span>(<span class="ruby-identifier">projectId</span>)
1069
- 304: <span class="ruby-keyword kw">end</span></pre>
1135
+ <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 348</span>
1136
+ 348: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">report</span>(<span class="ruby-identifier">projectId</span>, <span class="ruby-identifier">reportId</span>)
1137
+ 349: <span class="ruby-identifier">uri</span>, <span class="ruby-identifier">key</span> = <span class="ruby-identifier">getProject</span>(<span class="ruby-identifier">projectId</span>)
1138
+ 350: <span class="ruby-keyword kw">end</span></pre>
1070
1139
  </div>
1071
1140
 
1072
1141
  </div>
@@ -1097,74 +1166,76 @@ Return a list of IDs of projects that are in state :ready.
1097
1166
  <div class="method-source-code"
1098
1167
  id="start-source">
1099
1168
  <pre>
1100
- <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 78</span>
1101
- 78: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">start</span>
1102
- 79: <span class="ruby-comment cmt"># To ensure a certain level of security, the user must provide an</span>
1103
- 80: <span class="ruby-comment cmt"># authentication key to authenticate the client to this server.</span>
1104
- 81: <span class="ruby-keyword kw">unless</span> <span class="ruby-ivar">@authKey</span>
1105
- 82: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">fatal</span>(<span class="ruby-value str">You must set an authentication key in the configuration file. Create a filenamed .taskjugglerrc or taskjuggler.rc that contains at least the followinglines. Replace 'your_secret_key' with some random character sequence._global: authKey: your_secret_key</span>
1106
- 83: )
1107
- 84: <span class="ruby-keyword kw">end</span>
1108
- 85:
1109
- 86: <span class="ruby-comment cmt"># In daemon mode, we fork twice and only the 2nd child continues here.</span>
1110
- 87: <span class="ruby-keyword kw">super</span>()
1111
- 88: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-value str">&quot;Starting project broker&quot;</span>)
1169
+ <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 82</span>
1170
+ 82: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">start</span>
1171
+ 83: <span class="ruby-comment cmt"># To ensure a certain level of security, the user must provide an</span>
1172
+ 84: <span class="ruby-comment cmt"># authentication key to authenticate the client to this server.</span>
1173
+ 85: <span class="ruby-keyword kw">unless</span> <span class="ruby-ivar">@authKey</span>
1174
+ 86: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">fatal</span>(<span class="ruby-value str">You must set an authentication key in the configuration file. Create a filenamed .taskjugglerrc or taskjuggler.rc that contains at least the followinglines. Replace 'your_secret_key' with some random character sequence._global: authKey: your_secret_key</span>
1175
+ 87: )
1176
+ 88: <span class="ruby-keyword kw">end</span>
1112
1177
  89:
1113
- 90: <span class="ruby-keyword kw">begin</span>
1114
- 91: <span class="ruby-comment cmt"># The web server must be started before we turn SAFE mode on.</span>
1115
- 92: <span class="ruby-ivar">@webServer</span> = <span class="ruby-constant">WebServer</span>.<span class="ruby-identifier">new</span>(<span class="ruby-keyword kw">self</span>, <span class="ruby-ivar">@webServerPort</span>) <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@enableWebServer</span>
1116
- 93: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">info</span>(<span class="ruby-value str">&quot;TaskJuggler web server is listening on port &quot;</span> <span class="ruby-operator">+</span>
1117
- 94: <span class="ruby-node">&quot;#{@webServerPort}&quot;</span>)
1118
- 95: <span class="ruby-keyword kw">rescue</span>
1119
- 96: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">fatal</span>(<span class="ruby-node">&quot;Cannot start web server: #{$!}&quot;</span>)
1120
- 97: <span class="ruby-keyword kw">end</span>
1121
- 98:
1122
- 99: <span class="ruby-comment cmt"># Setup a DRb server to handle the incomming requests from the clients.</span>
1123
- 100: <span class="ruby-identifier">brokerIface</span> = <span class="ruby-constant">ProjectBrokerIface</span>.<span class="ruby-identifier">new</span>(<span class="ruby-keyword kw">self</span>)
1124
- 101: <span class="ruby-keyword kw">begin</span>
1125
- 102: <span class="ruby-identifier">$SAFE</span> = <span class="ruby-value">1</span>
1126
- 103: <span class="ruby-constant">DRb</span>.<span class="ruby-identifier">install_acl</span>(<span class="ruby-constant">ACL</span>.<span class="ruby-identifier">new</span>(<span class="ruby-node">] deny all
1127
- 104: allow 127.0.0.1 ]</span>))
1128
- 105: <span class="ruby-ivar">@uri</span> = <span class="ruby-constant">DRb</span>.<span class="ruby-identifier">start_service</span>(<span class="ruby-node">&quot;druby://127.0.0.1:#{@port}&quot;</span>, <span class="ruby-identifier">brokerIface</span>).<span class="ruby-identifier">uri</span>
1129
- 106: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">info</span>(<span class="ruby-node">&quot;TaskJuggler daemon is listening on #{@uri}&quot;</span>)
1130
- 107: <span class="ruby-keyword kw">rescue</span>
1131
- 108: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">fatal</span>(<span class="ruby-node">&quot;Cannot listen on port #{@port}: #{$!}&quot;</span>)
1132
- 109: <span class="ruby-keyword kw">end</span>
1133
- 110:
1134
- 111: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@port</span> <span class="ruby-operator">==</span> <span class="ruby-value">0</span>
1135
- 112: <span class="ruby-comment cmt"># If the port is set to 0 (any port) we save the ProjectBroker URI in</span>
1136
- 113: <span class="ruby-comment cmt"># the file .tj3d.uri. tj3client will look for it.</span>
1137
- 114: <span class="ruby-keyword kw">begin</span>
1138
- 115: <span class="ruby-constant">File</span>.<span class="ruby-identifier">open</span>(<span class="ruby-ivar">@uriFile</span>, <span class="ruby-value str">'w'</span>) { <span class="ruby-operator">|</span><span class="ruby-identifier">f</span><span class="ruby-operator">|</span> <span class="ruby-identifier">f</span>.<span class="ruby-identifier">write</span> <span class="ruby-ivar">@uri</span> }
1139
- 116: <span class="ruby-keyword kw">rescue</span>
1140
- 117: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">fatal</span>(<span class="ruby-node">&quot;Cannot write URI file #{@uriFile}: #{$!}&quot;</span>)
1141
- 118: <span class="ruby-keyword kw">end</span>
1142
- 119: <span class="ruby-keyword kw">end</span>
1143
- 120:
1144
- 121: <span class="ruby-comment cmt"># If project files were specified on the command line, we add them here.</span>
1145
- 122: <span class="ruby-identifier">i</span> = <span class="ruby-value">0</span>
1146
- 123: <span class="ruby-ivar">@projectFiles</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">project</span><span class="ruby-operator">|</span>
1147
- 124: <span class="ruby-ivar">@projectsToLoad</span>.<span class="ruby-identifier">push</span>(<span class="ruby-identifier">project</span>)
1178
+ 90: <span class="ruby-comment cmt"># In daemon mode, we fork twice and only the 2nd child continues here.</span>
1179
+ 91: <span class="ruby-keyword kw">super</span>()
1180
+ 92: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-value str">&quot;Starting project broker&quot;</span>)
1181
+ 93:
1182
+ 94: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@enableWebServer</span>
1183
+ 95: <span class="ruby-keyword kw">begin</span>
1184
+ 96: <span class="ruby-comment cmt"># The web server must be started before we turn SAFE mode on.</span>
1185
+ 97: <span class="ruby-ivar">@webServer</span> = <span class="ruby-constant">WebServer</span>.<span class="ruby-identifier">new</span>(<span class="ruby-keyword kw">self</span>, <span class="ruby-ivar">@webServerPort</span>)
1186
+ 98: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">info</span>(<span class="ruby-value str">&quot;TaskJuggler web server is listening on port &quot;</span> <span class="ruby-operator">+</span>
1187
+ 99: <span class="ruby-node">&quot;#{@webServerPort}&quot;</span>)
1188
+ 100: <span class="ruby-keyword kw">rescue</span>
1189
+ 101: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">fatal</span>(<span class="ruby-node">&quot;Cannot start web server: #{$!}&quot;</span>)
1190
+ 102: <span class="ruby-keyword kw">end</span>
1191
+ 103: <span class="ruby-keyword kw">end</span>
1192
+ 104:
1193
+ 105: <span class="ruby-comment cmt"># Setup a DRb server to handle the incomming requests from the clients.</span>
1194
+ 106: <span class="ruby-identifier">brokerIface</span> = <span class="ruby-constant">ProjectBrokerIface</span>.<span class="ruby-identifier">new</span>(<span class="ruby-keyword kw">self</span>)
1195
+ 107: <span class="ruby-keyword kw">begin</span>
1196
+ 108: <span class="ruby-identifier">$SAFE</span> = <span class="ruby-value">1</span>
1197
+ 109: <span class="ruby-constant">DRb</span>.<span class="ruby-identifier">install_acl</span>(<span class="ruby-constant">ACL</span>.<span class="ruby-identifier">new</span>(<span class="ruby-node">] deny all
1198
+ 110: allow 127.0.0.1 ]</span>))
1199
+ 111: <span class="ruby-ivar">@uri</span> = <span class="ruby-constant">DRb</span>.<span class="ruby-identifier">start_service</span>(<span class="ruby-node">&quot;druby://127.0.0.1:#{@port}&quot;</span>, <span class="ruby-identifier">brokerIface</span>).<span class="ruby-identifier">uri</span>
1200
+ 112: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">info</span>(<span class="ruby-node">&quot;TaskJuggler daemon is listening on #{@uri}&quot;</span>)
1201
+ 113: <span class="ruby-keyword kw">rescue</span>
1202
+ 114: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">fatal</span>(<span class="ruby-node">&quot;Cannot listen on port #{@port}: #{$!}&quot;</span>)
1203
+ 115: <span class="ruby-keyword kw">end</span>
1204
+ 116:
1205
+ 117: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@port</span> <span class="ruby-operator">==</span> <span class="ruby-value">0</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-ivar">@uriFile</span>
1206
+ 118: <span class="ruby-comment cmt"># If the port is set to 0 (any port) we save the ProjectBroker URI in</span>
1207
+ 119: <span class="ruby-comment cmt"># the file .tj3d.uri. tj3client will look for it.</span>
1208
+ 120: <span class="ruby-keyword kw">begin</span>
1209
+ 121: <span class="ruby-constant">File</span>.<span class="ruby-identifier">open</span>(<span class="ruby-ivar">@uriFile</span>, <span class="ruby-value str">'w'</span>) { <span class="ruby-operator">|</span><span class="ruby-identifier">f</span><span class="ruby-operator">|</span> <span class="ruby-identifier">f</span>.<span class="ruby-identifier">write</span> <span class="ruby-ivar">@uri</span> }
1210
+ 122: <span class="ruby-keyword kw">rescue</span>
1211
+ 123: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">fatal</span>(<span class="ruby-node">&quot;Cannot write URI file #{@uriFile}: #{$!}&quot;</span>)
1212
+ 124: <span class="ruby-keyword kw">end</span>
1148
1213
  125: <span class="ruby-keyword kw">end</span>
1149
1214
  126:
1150
- 127: <span class="ruby-comment cmt"># Start a Thread that waits for the @terminate flag to be set and does</span>
1151
- 128: <span class="ruby-comment cmt"># some other work asynchronously.</span>
1152
- 129: <span class="ruby-identifier">startHousekeeping</span>
1153
- 130:
1154
- 131: <span class="ruby-comment cmt"># Cleanup the DRb threads</span>
1155
- 132: <span class="ruby-constant">DRb</span>.<span class="ruby-identifier">thread</span>.<span class="ruby-identifier">join</span>
1156
- 133:
1157
- 134: <span class="ruby-comment cmt"># If we have created a URI file, we need to delete it again.</span>
1158
- 135: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@port</span> <span class="ruby-operator">==</span> <span class="ruby-value">0</span>
1159
- 136: <span class="ruby-keyword kw">begin</span>
1160
- 137: <span class="ruby-constant">File</span>.<span class="ruby-identifier">delete</span>(<span class="ruby-ivar">@uriFile</span>)
1161
- 138: <span class="ruby-keyword kw">rescue</span>
1162
- 139: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">fatal</span>(<span class="ruby-node">&quot;Cannot delete URI file .tj3d.uri: #{$!}&quot;</span>)
1163
- 140: <span class="ruby-keyword kw">end</span>
1164
- 141: <span class="ruby-keyword kw">end</span>
1165
- 142:
1166
- 143: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">info</span>(<span class="ruby-value str">'TaskJuggler daemon terminated'</span>)
1167
- 144: <span class="ruby-keyword kw">end</span></pre>
1215
+ 127: <span class="ruby-comment cmt"># If project files were specified on the command line, we add them here.</span>
1216
+ 128: <span class="ruby-identifier">i</span> = <span class="ruby-value">0</span>
1217
+ 129: <span class="ruby-ivar">@projectFiles</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">project</span><span class="ruby-operator">|</span>
1218
+ 130: <span class="ruby-ivar">@projectsToLoad</span>.<span class="ruby-identifier">push</span>(<span class="ruby-identifier">project</span>)
1219
+ 131: <span class="ruby-keyword kw">end</span>
1220
+ 132:
1221
+ 133: <span class="ruby-comment cmt"># Start a Thread that waits for the @terminate flag to be set and does</span>
1222
+ 134: <span class="ruby-comment cmt"># some other work asynchronously.</span>
1223
+ 135: <span class="ruby-identifier">startHousekeeping</span>
1224
+ 136:
1225
+ 137: <span class="ruby-comment cmt"># Cleanup the DRb threads</span>
1226
+ 138: <span class="ruby-constant">DRb</span>.<span class="ruby-identifier">thread</span>.<span class="ruby-identifier">join</span>
1227
+ 139:
1228
+ 140: <span class="ruby-comment cmt"># If we have created a URI file, we need to delete it again.</span>
1229
+ 141: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@port</span> <span class="ruby-operator">==</span> <span class="ruby-value">0</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-ivar">@uriFile</span>
1230
+ 142: <span class="ruby-keyword kw">begin</span>
1231
+ 143: <span class="ruby-constant">File</span>.<span class="ruby-identifier">delete</span>(<span class="ruby-ivar">@uriFile</span>)
1232
+ 144: <span class="ruby-keyword kw">rescue</span>
1233
+ 145: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">fatal</span>(<span class="ruby-node">&quot;Cannot delete URI file .tj3d.uri: #{$!}&quot;</span>)
1234
+ 146: <span class="ruby-keyword kw">end</span>
1235
+ 147: <span class="ruby-keyword kw">end</span>
1236
+ 148:
1237
+ 149: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">info</span>(<span class="ruby-value str">'TaskJuggler daemon terminated'</span>)
1238
+ 150: <span class="ruby-keyword kw">end</span></pre>
1168
1239
  </div>
1169
1240
 
1170
1241
  </div>
@@ -1197,24 +1268,24 @@ Generate a table with information about the loaded projects.
1197
1268
  <div class="method-source-code"
1198
1269
  id="status-source">
1199
1270
  <pre>
1200
- <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 188</span>
1201
- 188: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">status</span>
1202
- 189: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">empty?</span>
1203
- 190: <span class="ruby-value str">&quot;No projects registered\n&quot;</span>
1204
- 191: <span class="ruby-keyword kw">else</span>
1205
- 192: <span class="ruby-identifier">format</span> = <span class="ruby-value str">&quot; %3s | %-25s | %-14s | %s | %-20s\n&quot;</span>
1206
- 193: <span class="ruby-identifier">out</span> = <span class="ruby-identifier">sprintf</span>(<span class="ruby-identifier">format</span>, <span class="ruby-value str">'No.'</span>, <span class="ruby-value str">'Project ID'</span>, <span class="ruby-value str">'Status'</span>, <span class="ruby-value str">'M'</span>,
1207
- 194: <span class="ruby-value str">'Loaded since'</span>)
1208
- 195: <span class="ruby-identifier">out</span> <span class="ruby-operator">+=</span> <span class="ruby-node">&quot; #{'-' * 4}+#{'-' * 27}+#{'-' * 16}+#{'-' * 3}+#{'-' * 20}\n&quot;</span>
1209
- 196: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1210
- 197: <span class="ruby-identifier">i</span> = <span class="ruby-value">0</span>
1211
- 198: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">project</span><span class="ruby-operator">|</span>
1212
- 199: <span class="ruby-identifier">out</span> <span class="ruby-operator">+=</span> <span class="ruby-identifier">project</span>.<span class="ruby-identifier">to_s</span>(<span class="ruby-identifier">format</span>, <span class="ruby-identifier">i</span> <span class="ruby-operator">+=</span> <span class="ruby-value">1</span>)
1213
- 200: <span class="ruby-keyword kw">end</span>
1214
- 201: <span class="ruby-keyword kw">end</span>
1215
- 202: <span class="ruby-identifier">out</span>
1216
- 203: <span class="ruby-keyword kw">end</span>
1217
- 204: <span class="ruby-keyword kw">end</span></pre>
1271
+ <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 194</span>
1272
+ 194: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">status</span>
1273
+ 195: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">empty?</span>
1274
+ 196: <span class="ruby-value str">&quot;No projects registered\n&quot;</span>
1275
+ 197: <span class="ruby-keyword kw">else</span>
1276
+ 198: <span class="ruby-identifier">format</span> = <span class="ruby-value str">&quot; %3s | %-25s | %-14s | %s | %-20s\n&quot;</span>
1277
+ 199: <span class="ruby-identifier">out</span> = <span class="ruby-identifier">sprintf</span>(<span class="ruby-identifier">format</span>, <span class="ruby-value str">'No.'</span>, <span class="ruby-value str">'Project ID'</span>, <span class="ruby-value str">'Status'</span>, <span class="ruby-value str">'M'</span>,
1278
+ 200: <span class="ruby-value str">'Loaded since'</span>)
1279
+ 201: <span class="ruby-identifier">out</span> <span class="ruby-operator">+=</span> <span class="ruby-node">&quot; #{'-' * 4}+#{'-' * 27}+#{'-' * 16}+#{'-' * 3}+#{'-' * 20}\n&quot;</span>
1280
+ 202: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1281
+ 203: <span class="ruby-identifier">i</span> = <span class="ruby-value">0</span>
1282
+ 204: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">project</span><span class="ruby-operator">|</span>
1283
+ 205: <span class="ruby-identifier">out</span> <span class="ruby-operator">+=</span> <span class="ruby-identifier">project</span>.<span class="ruby-identifier">to_s</span>(<span class="ruby-identifier">format</span>, <span class="ruby-identifier">i</span> <span class="ruby-operator">+=</span> <span class="ruby-value">1</span>)
1284
+ 206: <span class="ruby-keyword kw">end</span>
1285
+ 207: <span class="ruby-keyword kw">end</span>
1286
+ 208: <span class="ruby-identifier">out</span>
1287
+ 209: <span class="ruby-keyword kw">end</span>
1288
+ 210: <span class="ruby-keyword kw">end</span></pre>
1218
1289
  </div>
1219
1290
 
1220
1291
  </div>
@@ -1247,25 +1318,25 @@ This command will initiate the termination of the daemon.
1247
1318
  <div class="method-source-code"
1248
1319
  id="stop-source">
1249
1320
  <pre>
1250
- <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 168</span>
1251
- 168: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">stop</span>
1252
- 169: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-value str">'Terminating on client request'</span>)
1253
- 170:
1254
- 171: <span class="ruby-comment cmt"># Shut down the web server if we've started one.</span>
1255
- 172: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@webServer</span>
1256
- 173: <span class="ruby-ivar">@webServer</span>.<span class="ruby-identifier">stop</span>
1257
- 174: <span class="ruby-keyword kw">end</span>
1258
- 175:
1259
- 176: <span class="ruby-comment cmt"># Send termination signal to all ProjectServer instances</span>
1260
- 177: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1261
- 178: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> { <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">terminateServer</span> }
1262
- 179: <span class="ruby-keyword kw">end</span>
1263
- 180:
1264
- 181: <span class="ruby-comment cmt"># Setting the @terminate flag to true will case the terminator Thread to</span>
1265
- 182: <span class="ruby-comment cmt"># call DRb.stop_service</span>
1266
- 183: <span class="ruby-ivar">@terminate</span> = <span class="ruby-keyword kw">true</span>
1267
- 184: <span class="ruby-keyword kw">super</span>
1268
- 185: <span class="ruby-keyword kw">end</span></pre>
1321
+ <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 174</span>
1322
+ 174: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">stop</span>
1323
+ 175: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-value str">'Terminating on client request'</span>)
1324
+ 176:
1325
+ 177: <span class="ruby-comment cmt"># Shut down the web server if we've started one.</span>
1326
+ 178: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@webServer</span>
1327
+ 179: <span class="ruby-ivar">@webServer</span>.<span class="ruby-identifier">stop</span>
1328
+ 180: <span class="ruby-keyword kw">end</span>
1329
+ 181:
1330
+ 182: <span class="ruby-comment cmt"># Send termination signal to all ProjectServer instances</span>
1331
+ 183: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1332
+ 184: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> { <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">terminateServer</span> }
1333
+ 185: <span class="ruby-keyword kw">end</span>
1334
+ 186:
1335
+ 187: <span class="ruby-comment cmt"># Setting the @terminate flag to true will case the terminator Thread to</span>
1336
+ 188: <span class="ruby-comment cmt"># call DRb.stop_service</span>
1337
+ 189: <span class="ruby-ivar">@terminate</span> = <span class="ruby-keyword kw">true</span>
1338
+ 190: <span class="ruby-keyword kw">super</span>
1339
+ 191: <span class="ruby-keyword kw">end</span></pre>
1269
1340
  </div>
1270
1341
 
1271
1342
  </div>
@@ -1299,17 +1370,17 @@ reloaded.
1299
1370
  <div class="method-source-code"
1300
1371
  id="update-source">
1301
1372
  <pre>
1302
- <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 280</span>
1303
- 280: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">update</span>
1304
- 281: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1305
- 282: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">project</span><span class="ruby-operator">|</span>
1306
- 283: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">project</span>.<span class="ruby-identifier">modified</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-operator">!</span><span class="ruby-identifier">project</span>.<span class="ruby-identifier">reloading</span>
1307
- 284: <span class="ruby-identifier">project</span>.<span class="ruby-identifier">reloading</span> = <span class="ruby-keyword kw">true</span>
1308
- 285: <span class="ruby-ivar">@projectsToLoad</span>.<span class="ruby-identifier">push</span>(<span class="ruby-identifier">project</span>.<span class="ruby-identifier">files</span>)
1309
- 286: <span class="ruby-keyword kw">end</span>
1310
- 287: <span class="ruby-keyword kw">end</span>
1311
- 288: <span class="ruby-keyword kw">end</span>
1312
- 289: <span class="ruby-keyword kw">end</span></pre>
1373
+ <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 326</span>
1374
+ 326: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">update</span>
1375
+ 327: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1376
+ 328: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">project</span><span class="ruby-operator">|</span>
1377
+ 329: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">project</span>.<span class="ruby-identifier">modified</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-operator">!</span><span class="ruby-identifier">project</span>.<span class="ruby-identifier">reloading</span>
1378
+ 330: <span class="ruby-identifier">project</span>.<span class="ruby-identifier">reloading</span> = <span class="ruby-keyword kw">true</span>
1379
+ 331: <span class="ruby-ivar">@projectsToLoad</span>.<span class="ruby-identifier">push</span>(<span class="ruby-identifier">project</span>.<span class="ruby-identifier">files</span>)
1380
+ 332: <span class="ruby-keyword kw">end</span>
1381
+ 333: <span class="ruby-keyword kw">end</span>
1382
+ 334: <span class="ruby-keyword kw">end</span>
1383
+ 335: <span class="ruby-keyword kw">end</span></pre>
1313
1384
  </div>
1314
1385
 
1315
1386
  </div>
@@ -1326,7 +1397,7 @@ reloaded.
1326
1397
  <div class="method-heading">
1327
1398
 
1328
1399
  <span class="method-name">updateState</span><span
1329
- class="method-args">(authKey, filesOrId, state, modified)</span>
1400
+ class="method-args">(projectKey, filesOrId, state, modified)</span>
1330
1401
  <span class="method-click-advice">click to toggle source</span>
1331
1402
 
1332
1403
  </div>
@@ -1337,7 +1408,9 @@ reloaded.
1337
1408
  This is a callback from the <a href="ProjectServer.html">ProjectServer</a>
1338
1409
  process. It&#8217;s used to update the current state of the <a
1339
1410
  href="ProjectServer.html">ProjectServer</a> in the <a
1340
- href="ProjectRecord.html">ProjectRecord</a> list.
1411
+ href="ProjectRecord.html">ProjectRecord</a> list. <em>projectKey</em> is
1412
+ the authentication key for that project. It is used to idenfity the entry
1413
+ in the <a href="ProjectRecord.html">ProjectRecord</a> list to be updated.
1341
1414
  </p>
1342
1415
 
1343
1416
 
@@ -1345,59 +1418,59 @@ href="ProjectRecord.html">ProjectRecord</a> list.
1345
1418
  <div class="method-source-code"
1346
1419
  id="update-tate-source">
1347
1420
  <pre>
1348
- <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 308</span>
1349
- 308: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">updateState</span>(<span class="ruby-identifier">authKey</span>, <span class="ruby-identifier">filesOrId</span>, <span class="ruby-identifier">state</span>, <span class="ruby-identifier">modified</span>)
1350
- 309: <span class="ruby-identifier">result</span> = <span class="ruby-keyword kw">false</span>
1351
- 310: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">filesOrId</span>.<span class="ruby-identifier">is_a?</span>(<span class="ruby-constant">Array</span>)
1352
- 311: <span class="ruby-identifier">files</span> = <span class="ruby-identifier">filesOrId</span>
1353
- 312: <span class="ruby-comment cmt"># Use the name of the master files for now.</span>
1354
- 313: <span class="ruby-identifier">id</span> = <span class="ruby-identifier">files</span>[<span class="ruby-value">1</span>]
1355
- 314: <span class="ruby-keyword kw">elsif</span> <span class="ruby-identifier">filesOrId</span>.<span class="ruby-identifier">is_a?</span>(<span class="ruby-constant">String</span>)
1356
- 315: <span class="ruby-identifier">id</span> = <span class="ruby-identifier">filesOrId</span>
1357
- 316: <span class="ruby-identifier">files</span> = <span class="ruby-keyword kw">nil</span>
1358
- 317: <span class="ruby-keyword kw">else</span>
1359
- 318: <span class="ruby-identifier">id</span> = <span class="ruby-identifier">files</span> = <span class="ruby-keyword kw">nil</span>
1360
- 319: <span class="ruby-keyword kw">end</span>
1361
- 320:
1362
- 321: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1363
- 322: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">project</span><span class="ruby-operator">|</span>
1364
- 323: <span class="ruby-comment cmt"># Don't accept updates for already obsolete entries.</span>
1365
- 324: <span class="ruby-keyword kw">next</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">project</span>.<span class="ruby-identifier">state</span> <span class="ruby-operator">==</span> <span class="ruby-value">:obsolete</span>
1366
- 325:
1367
- 326: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-node">&quot;Updating state for #{id} to #{state}&quot;</span>)
1368
- 327: <span class="ruby-comment cmt"># Only update the record that has the matching authKey</span>
1369
- 328: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">project</span>.<span class="ruby-identifier">authKey</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">authKey</span>
1370
- 329: <span class="ruby-identifier">project</span>.<span class="ruby-identifier">id</span> = <span class="ruby-identifier">id</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">id</span>
1371
- 330: <span class="ruby-comment cmt"># An Array of [ workingDir, tjpFile, ... other tji files ]</span>
1372
- 331: <span class="ruby-identifier">project</span>.<span class="ruby-identifier">files</span> = <span class="ruby-identifier">files</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">files</span>
1373
- 332:
1374
- 333: <span class="ruby-comment cmt"># If the state is being changed from something to :ready, this is</span>
1375
- 334: <span class="ruby-comment cmt"># now the current project for the project ID.</span>
1376
- 335: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">state</span> <span class="ruby-operator">==</span> <span class="ruby-value">:ready</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-identifier">project</span>.<span class="ruby-identifier">state</span> <span class="ruby-operator">!=</span> <span class="ruby-value">:ready</span>
1377
- 336: <span class="ruby-comment cmt"># Mark other project records with same project ID as obsolete</span>
1378
- 337: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span>
1379
- 338: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">p</span> <span class="ruby-operator">!=</span> <span class="ruby-identifier">project</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">id</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">id</span>
1380
- 339: <span class="ruby-identifier">p</span>.<span class="ruby-identifier">state</span> = <span class="ruby-value">:obsolete</span>
1381
- 340: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-node">&quot;Marking entry with ID #{id} as obsolete&quot;</span>)
1382
- 341: <span class="ruby-keyword kw">end</span>
1383
- 342: <span class="ruby-keyword kw">end</span>
1384
- 343: <span class="ruby-identifier">project</span>.<span class="ruby-identifier">readySince</span> = <span class="ruby-constant">TjTime</span>.<span class="ruby-identifier">now</span>
1385
- 344: <span class="ruby-keyword kw">end</span>
1386
- 345:
1387
- 346: <span class="ruby-comment cmt"># Failed ProjectServers are terminated automatically. We can't</span>
1388
- 347: <span class="ruby-comment cmt"># reach them any more.</span>
1389
- 348: <span class="ruby-identifier">project</span>.<span class="ruby-identifier">uri</span> = <span class="ruby-keyword kw">nil</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">state</span> <span class="ruby-operator">==</span> <span class="ruby-value">:failed</span>
1390
- 349:
1391
- 350: <span class="ruby-identifier">project</span>.<span class="ruby-identifier">state</span> = <span class="ruby-identifier">state</span>
1392
- 351: <span class="ruby-identifier">project</span>.<span class="ruby-identifier">modified</span> = <span class="ruby-identifier">modified</span>
1393
- 352: <span class="ruby-identifier">result</span> = <span class="ruby-keyword kw">true</span>
1394
- 353: <span class="ruby-keyword kw">break</span>
1395
- 354: <span class="ruby-keyword kw">end</span>
1396
- 355: <span class="ruby-keyword kw">end</span>
1397
- 356: <span class="ruby-keyword kw">end</span>
1398
- 357:
1399
- 358: <span class="ruby-identifier">result</span>
1400
- 359: <span class="ruby-keyword kw">end</span></pre>
1421
+ <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 356</span>
1422
+ 356: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">updateState</span>(<span class="ruby-identifier">projectKey</span>, <span class="ruby-identifier">filesOrId</span>, <span class="ruby-identifier">state</span>, <span class="ruby-identifier">modified</span>)
1423
+ 357: <span class="ruby-identifier">result</span> = <span class="ruby-keyword kw">false</span>
1424
+ 358: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">filesOrId</span>.<span class="ruby-identifier">is_a?</span>(<span class="ruby-constant">Array</span>)
1425
+ 359: <span class="ruby-identifier">files</span> = <span class="ruby-identifier">filesOrId</span>
1426
+ 360: <span class="ruby-comment cmt"># Use the name of the master files for now.</span>
1427
+ 361: <span class="ruby-identifier">id</span> = <span class="ruby-identifier">files</span>[<span class="ruby-value">1</span>]
1428
+ 362: <span class="ruby-keyword kw">elsif</span> <span class="ruby-identifier">filesOrId</span>.<span class="ruby-identifier">is_a?</span>(<span class="ruby-constant">String</span>)
1429
+ 363: <span class="ruby-identifier">id</span> = <span class="ruby-identifier">filesOrId</span>
1430
+ 364: <span class="ruby-identifier">files</span> = <span class="ruby-keyword kw">nil</span>
1431
+ 365: <span class="ruby-keyword kw">else</span>
1432
+ 366: <span class="ruby-identifier">id</span> = <span class="ruby-identifier">files</span> = <span class="ruby-keyword kw">nil</span>
1433
+ 367: <span class="ruby-keyword kw">end</span>
1434
+ 368:
1435
+ 369: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1436
+ 370: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">project</span><span class="ruby-operator">|</span>
1437
+ 371: <span class="ruby-comment cmt"># Don't accept updates for already obsolete entries.</span>
1438
+ 372: <span class="ruby-keyword kw">next</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">project</span>.<span class="ruby-identifier">state</span> <span class="ruby-operator">==</span> <span class="ruby-value">:obsolete</span>
1439
+ 373:
1440
+ 374: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-node">&quot;Updating state for #{id} to #{state}&quot;</span>)
1441
+ 375: <span class="ruby-comment cmt"># Only update the record that has the matching key</span>
1442
+ 376: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">project</span>.<span class="ruby-identifier">authKey</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">projectKey</span>
1443
+ 377: <span class="ruby-identifier">project</span>.<span class="ruby-identifier">id</span> = <span class="ruby-identifier">id</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">id</span>
1444
+ 378: <span class="ruby-comment cmt"># An Array of [ workingDir, tjpFile, ... other tji files ]</span>
1445
+ 379: <span class="ruby-identifier">project</span>.<span class="ruby-identifier">files</span> = <span class="ruby-identifier">files</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">files</span>
1446
+ 380:
1447
+ 381: <span class="ruby-comment cmt"># If the state is being changed from something to :ready, this is</span>
1448
+ 382: <span class="ruby-comment cmt"># now the current project for the project ID.</span>
1449
+ 383: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">state</span> <span class="ruby-operator">==</span> <span class="ruby-value">:ready</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-identifier">project</span>.<span class="ruby-identifier">state</span> <span class="ruby-operator">!=</span> <span class="ruby-value">:ready</span>
1450
+ 384: <span class="ruby-comment cmt"># Mark other project records with same project ID as obsolete</span>
1451
+ 385: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span>
1452
+ 386: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">p</span> <span class="ruby-operator">!=</span> <span class="ruby-identifier">project</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">id</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">id</span>
1453
+ 387: <span class="ruby-identifier">p</span>.<span class="ruby-identifier">state</span> = <span class="ruby-value">:obsolete</span>
1454
+ 388: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-node">&quot;Marking entry with ID #{id} as obsolete&quot;</span>)
1455
+ 389: <span class="ruby-keyword kw">end</span>
1456
+ 390: <span class="ruby-keyword kw">end</span>
1457
+ 391: <span class="ruby-identifier">project</span>.<span class="ruby-identifier">readySince</span> = <span class="ruby-constant">TjTime</span>.<span class="ruby-identifier">now</span>
1458
+ 392: <span class="ruby-keyword kw">end</span>
1459
+ 393:
1460
+ 394: <span class="ruby-comment cmt"># Failed ProjectServers are terminated automatically. We can't</span>
1461
+ 395: <span class="ruby-comment cmt"># reach them any more.</span>
1462
+ 396: <span class="ruby-identifier">project</span>.<span class="ruby-identifier">uri</span> = <span class="ruby-keyword kw">nil</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">state</span> <span class="ruby-operator">==</span> <span class="ruby-value">:failed</span>
1463
+ 397:
1464
+ 398: <span class="ruby-identifier">project</span>.<span class="ruby-identifier">state</span> = <span class="ruby-identifier">state</span>
1465
+ 399: <span class="ruby-identifier">project</span>.<span class="ruby-identifier">modified</span> = <span class="ruby-identifier">modified</span>
1466
+ 400: <span class="ruby-identifier">result</span> = <span class="ruby-keyword kw">true</span>
1467
+ 401: <span class="ruby-keyword kw">break</span>
1468
+ 402: <span class="ruby-keyword kw">end</span>
1469
+ 403: <span class="ruby-keyword kw">end</span>
1470
+ 404: <span class="ruby-keyword kw">end</span>
1471
+ 405:
1472
+ 406: <span class="ruby-identifier">result</span>
1473
+ 407: <span class="ruby-keyword kw">end</span></pre>
1401
1474
  </div>
1402
1475
 
1403
1476
  </div>
@@ -1434,30 +1507,30 @@ href="ProjectRecord.html">ProjectRecord</a> list.
1434
1507
  <div class="method-source-code"
1435
1508
  id="load-roject-source">
1436
1509
  <pre>
1437
- <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 425</span>
1438
- 425: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">loadProject</span>(<span class="ruby-identifier">tagOrProject</span>)
1439
- 426: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">tagOrProject</span>.<span class="ruby-identifier">is_a?</span>(<span class="ruby-constant">Array</span>)
1440
- 427: <span class="ruby-identifier">tag</span> = <span class="ruby-identifier">rand</span>(<span class="ruby-value">9999999999999</span>)
1441
- 428: <span class="ruby-identifier">project</span> = <span class="ruby-identifier">tagOrProject</span>
1442
- 429: <span class="ruby-comment cmt"># The 2nd element of the Array is the *.tjp file name.</span>
1443
- 430: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-node">&quot;Loading project #{tagOrProject[1]} with tag #{tag}&quot;</span>)
1444
- 431: <span class="ruby-keyword kw">else</span>
1445
- 432: <span class="ruby-identifier">tag</span> = <span class="ruby-identifier">tagOrProject</span>
1446
- 433: <span class="ruby-identifier">project</span> = <span class="ruby-keyword kw">nil</span>
1447
- 434: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-node">&quot;Loading project for tag #{tag}&quot;</span>)
1448
- 435: <span class="ruby-keyword kw">end</span>
1449
- 436: <span class="ruby-identifier">pr</span> = <span class="ruby-constant">ProjectRecord</span>.<span class="ruby-identifier">new</span>(<span class="ruby-identifier">tag</span>)
1450
- 437: <span class="ruby-identifier">ps</span> = <span class="ruby-constant">ProjectServer</span>.<span class="ruby-identifier">new</span>(<span class="ruby-identifier">project</span>, <span class="ruby-operator">!</span><span class="ruby-ivar">@daemonize</span>)
1451
- 438: <span class="ruby-comment cmt"># The ProjectServer can be reached via this DRb URI</span>
1452
- 439: <span class="ruby-identifier">pr</span>.<span class="ruby-identifier">uri</span> = <span class="ruby-identifier">ps</span>.<span class="ruby-identifier">uri</span>
1453
- 440: <span class="ruby-comment cmt"># Method calls must be authenticated with this key</span>
1454
- 441: <span class="ruby-identifier">pr</span>.<span class="ruby-identifier">authKey</span> = <span class="ruby-identifier">ps</span>.<span class="ruby-identifier">authKey</span>
1455
- 442:
1456
- 443: <span class="ruby-comment cmt"># Add the ProjectRecord to the @projects list</span>
1457
- 444: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1458
- 445: <span class="ruby-ivar">@projects</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">pr</span>
1459
- 446: <span class="ruby-keyword kw">end</span>
1460
- 447: <span class="ruby-keyword kw">end</span></pre>
1510
+ <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 473</span>
1511
+ 473: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">loadProject</span>(<span class="ruby-identifier">tagOrProject</span>)
1512
+ 474: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">tagOrProject</span>.<span class="ruby-identifier">is_a?</span>(<span class="ruby-constant">Array</span>)
1513
+ 475: <span class="ruby-identifier">tag</span> = <span class="ruby-identifier">rand</span>(<span class="ruby-value">9999999999999</span>)
1514
+ 476: <span class="ruby-identifier">project</span> = <span class="ruby-identifier">tagOrProject</span>
1515
+ 477: <span class="ruby-comment cmt"># The 2nd element of the Array is the *.tjp file name.</span>
1516
+ 478: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-node">&quot;Loading project #{tagOrProject[1]} with tag #{tag}&quot;</span>)
1517
+ 479: <span class="ruby-keyword kw">else</span>
1518
+ 480: <span class="ruby-identifier">tag</span> = <span class="ruby-identifier">tagOrProject</span>
1519
+ 481: <span class="ruby-identifier">project</span> = <span class="ruby-keyword kw">nil</span>
1520
+ 482: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-node">&quot;Loading project for tag #{tag}&quot;</span>)
1521
+ 483: <span class="ruby-keyword kw">end</span>
1522
+ 484: <span class="ruby-identifier">pr</span> = <span class="ruby-constant">ProjectRecord</span>.<span class="ruby-identifier">new</span>(<span class="ruby-identifier">tag</span>)
1523
+ 485: <span class="ruby-identifier">ps</span> = <span class="ruby-constant">ProjectServer</span>.<span class="ruby-identifier">new</span>(<span class="ruby-ivar">@authKey</span>, <span class="ruby-identifier">project</span>, <span class="ruby-ivar">@logStdIO</span>)
1524
+ 486: <span class="ruby-comment cmt"># The ProjectServer can be reached via this DRb URI</span>
1525
+ 487: <span class="ruby-identifier">pr</span>.<span class="ruby-identifier">uri</span> = <span class="ruby-identifier">ps</span>.<span class="ruby-identifier">uri</span>
1526
+ 488: <span class="ruby-comment cmt"># Method calls must be authenticated with this key</span>
1527
+ 489: <span class="ruby-identifier">pr</span>.<span class="ruby-identifier">authKey</span> = <span class="ruby-identifier">ps</span>.<span class="ruby-identifier">authKey</span>
1528
+ 490:
1529
+ 491: <span class="ruby-comment cmt"># Add the ProjectRecord to the @projects list</span>
1530
+ 492: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1531
+ 493: <span class="ruby-ivar">@projects</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">pr</span>
1532
+ 494: <span class="ruby-keyword kw">end</span>
1533
+ 495: <span class="ruby-keyword kw">end</span></pre>
1461
1534
  </div>
1462
1535
 
1463
1536
  </div>
@@ -1488,68 +1561,68 @@ href="ProjectRecord.html">ProjectRecord</a> list.
1488
1561
  <div class="method-source-code"
1489
1562
  id="start-ousekeeping-source">
1490
1563
  <pre>
1491
- <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 363</span>
1492
- 363: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">startHousekeeping</span>
1493
- 364: <span class="ruby-constant">Thread</span>.<span class="ruby-identifier">new</span> <span class="ruby-keyword kw">do</span>
1494
- 365: <span class="ruby-keyword kw">begin</span>
1495
- 366: <span class="ruby-identifier">cntr</span> = <span class="ruby-value">0</span>
1496
- 367: <span class="ruby-identifier">loop</span> <span class="ruby-keyword kw">do</span>
1497
- 368: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@terminate</span>
1498
- 369: <span class="ruby-comment cmt"># Give the caller a chance to properly terminate the connection.</span>
1499
- 370: <span class="ruby-identifier">sleep</span> <span class="ruby-value">0.5</span>
1500
- 371: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-value str">'Shutting down DRb server'</span>)
1501
- 372: <span class="ruby-constant">DRb</span>.<span class="ruby-identifier">stop_service</span>
1502
- 373: <span class="ruby-keyword kw">break</span>
1503
- 374: <span class="ruby-keyword kw">elsif</span> <span class="ruby-operator">!</span><span class="ruby-ivar">@projectsToLoad</span>.<span class="ruby-identifier">empty?</span>
1504
- 375: <span class="ruby-identifier">loadProject</span>(<span class="ruby-ivar">@projectsToLoad</span>.<span class="ruby-identifier">pop</span>)
1505
- 376: <span class="ruby-keyword kw">else</span>
1506
- 377: <span class="ruby-comment cmt"># Send termination command to all obsolute ProjectServer</span>
1507
- 378: <span class="ruby-comment cmt"># objects. To minimize the locking of @projects we collect the</span>
1508
- 379: <span class="ruby-comment cmt"># obsolete items first.</span>
1509
- 380: <span class="ruby-identifier">termList</span> = []
1510
- 381: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1511
- 382: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span>
1512
- 383: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">state</span> <span class="ruby-operator">==</span> <span class="ruby-value">:obsolete</span>
1513
- 384: <span class="ruby-identifier">termList</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">p</span>
1514
- 385: <span class="ruby-keyword kw">elsif</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">state</span> <span class="ruby-operator">==</span> <span class="ruby-value">:failed</span>
1515
- 386: <span class="ruby-comment cmt"># Start removal of entries that didn't parse.</span>
1516
- 387: <span class="ruby-identifier">p</span>.<span class="ruby-identifier">state</span> = <span class="ruby-value">:obsolete</span>
1517
- 388: <span class="ruby-keyword kw">end</span>
1518
- 389: <span class="ruby-keyword kw">end</span>
1519
- 390: <span class="ruby-keyword kw">end</span>
1520
- 391: <span class="ruby-comment cmt"># And then send them a termination command.</span>
1521
- 392: <span class="ruby-identifier">termList</span>.<span class="ruby-identifier">each</span> { <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">terminateServer</span> }
1522
- 393:
1523
- 394: <span class="ruby-comment cmt"># Check every 10 seconds that the ProjectServer processes are</span>
1524
- 395: <span class="ruby-comment cmt"># still alive. If not, remove them from the list.</span>
1525
- 396: <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">cntr</span> <span class="ruby-operator">+=</span> <span class="ruby-value">1</span>) <span class="ruby-operator">&gt;</span> <span class="ruby-value">10</span>
1526
- 397: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1527
- 398: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span>
1528
- 399: <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">ping</span>
1529
- 400: <span class="ruby-identifier">termList</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">p</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">termList</span>.<span class="ruby-identifier">include?</span>(<span class="ruby-identifier">p</span>)
1530
- 401: <span class="ruby-keyword kw">end</span>
1531
- 402: <span class="ruby-keyword kw">end</span>
1532
- 403: <span class="ruby-keyword kw">end</span>
1533
- 404: <span class="ruby-identifier">cntr</span> = <span class="ruby-value">0</span>
1534
- 405: <span class="ruby-keyword kw">end</span>
1535
- 406:
1536
- 407: <span class="ruby-comment cmt"># The housekeeping thread rarely needs to so something. Make</span>
1537
- 408: <span class="ruby-comment cmt"># sure it's sleeping most of the time.</span>
1538
- 409: <span class="ruby-identifier">sleep</span> <span class="ruby-value">1</span>
1539
- 410:
1540
- 411: <span class="ruby-comment cmt"># Remove the obsolete records from the @projects list.</span>
1541
- 412: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1542
- 413: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">delete_if</span> { <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span> <span class="ruby-identifier">termList</span>.<span class="ruby-identifier">include?</span>(<span class="ruby-identifier">p</span>) }
1543
- 414: <span class="ruby-keyword kw">end</span>
1544
- 415: <span class="ruby-keyword kw">end</span>
1545
- 416: <span class="ruby-keyword kw">end</span>
1546
- 417: <span class="ruby-keyword kw">rescue</span>
1547
- 418: <span class="ruby-identifier">$stderr</span>.<span class="ruby-identifier">print</span> <span class="ruby-identifier">$!</span>.<span class="ruby-identifier">to_s</span>
1548
- 419: <span class="ruby-identifier">$stderr</span>.<span class="ruby-identifier">print</span> <span class="ruby-identifier">$!</span>.<span class="ruby-identifier">backtrace</span>.<span class="ruby-identifier">join</span>(<span class="ruby-value str">&quot;\n&quot;</span>)
1549
- 420: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">fatal</span>(<span class="ruby-node">&quot;ProjectBroker housekeeping error: #{$!}&quot;</span>)
1550
- 421: <span class="ruby-keyword kw">end</span>
1551
- 422: <span class="ruby-keyword kw">end</span>
1552
- 423: <span class="ruby-keyword kw">end</span></pre>
1564
+ <span class="ruby-comment cmt"># File lib/daemon/ProjectBroker.rb, line 411</span>
1565
+ 411: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">startHousekeeping</span>
1566
+ 412: <span class="ruby-constant">Thread</span>.<span class="ruby-identifier">new</span> <span class="ruby-keyword kw">do</span>
1567
+ 413: <span class="ruby-keyword kw">begin</span>
1568
+ 414: <span class="ruby-identifier">cntr</span> = <span class="ruby-value">0</span>
1569
+ 415: <span class="ruby-identifier">loop</span> <span class="ruby-keyword kw">do</span>
1570
+ 416: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@terminate</span>
1571
+ 417: <span class="ruby-comment cmt"># Give the caller a chance to properly terminate the connection.</span>
1572
+ 418: <span class="ruby-identifier">sleep</span> <span class="ruby-value">0.5</span>
1573
+ 419: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">debug</span>(<span class="ruby-value str">'Shutting down DRb server'</span>)
1574
+ 420: <span class="ruby-constant">DRb</span>.<span class="ruby-identifier">stop_service</span>
1575
+ 421: <span class="ruby-keyword kw">break</span>
1576
+ 422: <span class="ruby-keyword kw">elsif</span> <span class="ruby-operator">!</span><span class="ruby-ivar">@projectsToLoad</span>.<span class="ruby-identifier">empty?</span>
1577
+ 423: <span class="ruby-identifier">loadProject</span>(<span class="ruby-ivar">@projectsToLoad</span>.<span class="ruby-identifier">pop</span>)
1578
+ 424: <span class="ruby-keyword kw">else</span>
1579
+ 425: <span class="ruby-comment cmt"># Send termination command to all obsolute ProjectServer</span>
1580
+ 426: <span class="ruby-comment cmt"># objects. To minimize the locking of @projects we collect the</span>
1581
+ 427: <span class="ruby-comment cmt"># obsolete items first.</span>
1582
+ 428: <span class="ruby-identifier">termList</span> = []
1583
+ 429: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1584
+ 430: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span>
1585
+ 431: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">state</span> <span class="ruby-operator">==</span> <span class="ruby-value">:obsolete</span>
1586
+ 432: <span class="ruby-identifier">termList</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">p</span>
1587
+ 433: <span class="ruby-keyword kw">elsif</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">state</span> <span class="ruby-operator">==</span> <span class="ruby-value">:failed</span>
1588
+ 434: <span class="ruby-comment cmt"># Start removal of entries that didn't parse.</span>
1589
+ 435: <span class="ruby-identifier">p</span>.<span class="ruby-identifier">state</span> = <span class="ruby-value">:obsolete</span>
1590
+ 436: <span class="ruby-keyword kw">end</span>
1591
+ 437: <span class="ruby-keyword kw">end</span>
1592
+ 438: <span class="ruby-keyword kw">end</span>
1593
+ 439: <span class="ruby-comment cmt"># And then send them a termination command.</span>
1594
+ 440: <span class="ruby-identifier">termList</span>.<span class="ruby-identifier">each</span> { <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">terminateServer</span> }
1595
+ 441:
1596
+ 442: <span class="ruby-comment cmt"># Check every 10 seconds that the ProjectServer processes are</span>
1597
+ 443: <span class="ruby-comment cmt"># still alive. If not, remove them from the list.</span>
1598
+ 444: <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">cntr</span> <span class="ruby-operator">+=</span> <span class="ruby-value">1</span>) <span class="ruby-operator">&gt;</span> <span class="ruby-value">10</span>
1599
+ 445: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1600
+ 446: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span>
1601
+ 447: <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">ping</span>
1602
+ 448: <span class="ruby-identifier">termList</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">p</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">termList</span>.<span class="ruby-identifier">include?</span>(<span class="ruby-identifier">p</span>)
1603
+ 449: <span class="ruby-keyword kw">end</span>
1604
+ 450: <span class="ruby-keyword kw">end</span>
1605
+ 451: <span class="ruby-keyword kw">end</span>
1606
+ 452: <span class="ruby-identifier">cntr</span> = <span class="ruby-value">0</span>
1607
+ 453: <span class="ruby-keyword kw">end</span>
1608
+ 454:
1609
+ 455: <span class="ruby-comment cmt"># The housekeeping thread rarely needs to so something. Make</span>
1610
+ 456: <span class="ruby-comment cmt"># sure it's sleeping most of the time.</span>
1611
+ 457: <span class="ruby-identifier">sleep</span> <span class="ruby-value">1</span>
1612
+ 458:
1613
+ 459: <span class="ruby-comment cmt"># Remove the obsolete records from the @projects list.</span>
1614
+ 460: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1615
+ 461: <span class="ruby-ivar">@projects</span>.<span class="ruby-identifier">delete_if</span> { <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span> <span class="ruby-identifier">termList</span>.<span class="ruby-identifier">include?</span>(<span class="ruby-identifier">p</span>) }
1616
+ 462: <span class="ruby-keyword kw">end</span>
1617
+ 463: <span class="ruby-keyword kw">end</span>
1618
+ 464: <span class="ruby-keyword kw">end</span>
1619
+ 465: <span class="ruby-keyword kw">rescue</span>
1620
+ 466: <span class="ruby-identifier">$stderr</span>.<span class="ruby-identifier">print</span> <span class="ruby-identifier">$!</span>.<span class="ruby-identifier">to_s</span>
1621
+ 467: <span class="ruby-identifier">$stderr</span>.<span class="ruby-identifier">print</span> <span class="ruby-identifier">$!</span>.<span class="ruby-identifier">backtrace</span>.<span class="ruby-identifier">join</span>(<span class="ruby-value str">&quot;\n&quot;</span>)
1622
+ 468: <span class="ruby-ivar">@log</span>.<span class="ruby-identifier">fatal</span>(<span class="ruby-node">&quot;ProjectBroker housekeeping error: #{$!}&quot;</span>)
1623
+ 469: <span class="ruby-keyword kw">end</span>
1624
+ 470: <span class="ruby-keyword kw">end</span>
1625
+ 471: <span class="ruby-keyword kw">end</span></pre>
1553
1626
  </div>
1554
1627
 
1555
1628
  </div>