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
@@ -141,6 +141,8 @@
141
141
 
142
142
  <li><a href="../TaskJuggler/AttributeDefinition.html">TaskJuggler::AttributeDefinition</a></li>
143
143
 
144
+ <li><a href="../TaskJuggler/AttributeOverwrite.html">TaskJuggler::AttributeOverwrite</a></li>
145
+
144
146
  <li><a href="../TaskJuggler/BatchProcessor.html">TaskJuggler::BatchProcessor</a></li>
145
147
 
146
148
  <li><a href="../TaskJuggler/Booking.html">TaskJuggler::Booking</a></li>
@@ -219,6 +221,8 @@
219
221
 
220
222
  <li><a href="../TaskJuggler/Interval.html">TaskJuggler::Interval</a></li>
221
223
 
224
+ <li><a href="../TaskJuggler/IntervalList.html">TaskJuggler::IntervalList</a></li>
225
+
222
226
  <li><a href="../TaskJuggler/IntervalListAttribute.html">TaskJuggler::IntervalListAttribute</a></li>
223
227
 
224
228
  <li><a href="../TaskJuggler/JobInfo.html">TaskJuggler::JobInfo</a></li>
@@ -251,6 +255,8 @@
251
255
 
252
256
  <li><a href="../TaskJuggler/LogicalExpressionAttribute.html">TaskJuggler::LogicalExpressionAttribute</a></li>
253
257
 
258
+ <li><a href="../TaskJuggler/LogicalExpressionListAttribute.html">TaskJuggler::LogicalExpressionListAttribute</a></li>
259
+
254
260
  <li><a href="../TaskJuggler/LogicalFlag.html">TaskJuggler::LogicalFlag</a></li>
255
261
 
256
262
  <li><a href="../TaskJuggler/LogicalFunction.html">TaskJuggler::LogicalFunction</a></li>
@@ -531,6 +537,8 @@
531
537
 
532
538
  <li><a href="../TaskJuggler/WebServer.html">TaskJuggler::WebServer</a></li>
533
539
 
540
+ <li><a href="../TaskJuggler/WelcomePage.html">TaskJuggler::WelcomePage</a></li>
541
+
534
542
  <li><a href="../TaskJuggler/WorkingHours.html">TaskJuggler::WorkingHours</a></li>
535
543
 
536
544
  <li><a href="../TaskJuggler/WorkingHoursAttribute.html">TaskJuggler::WorkingHoursAttribute</a></li>
@@ -557,8 +565,6 @@
557
565
 
558
566
  <li><a href="../String.html">String</a></li>
559
567
 
560
- <li><a href="../StringIO.html">StringIO</a></li>
561
-
562
568
  </ul>
563
569
  <div id="no-class-search-results" style="display: none;">No matching classes.</div>
564
570
  </div>
@@ -621,42 +627,42 @@ Create a <a href="BatchProcessor.html">BatchProcessor</a> object.
621
627
  <div class="method-source-code"
622
628
  id="new-source">
623
629
  <pre>
624
- <span class="ruby-comment cmt"># File lib/BatchProcessor.rb, line 68</span>
625
- 68: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">initialize</span>(<span class="ruby-identifier">maxCpuCores</span>)
626
- 69: <span class="ruby-ivar">@maxCpuCores</span> = <span class="ruby-identifier">maxCpuCores</span>
627
- 70: <span class="ruby-comment cmt"># Jobs submitted by calling queue() are put in the @toRunQueue. The</span>
628
- 71: <span class="ruby-comment cmt"># pusher Thread will pick them up and fork them off into another</span>
629
- 72: <span class="ruby-comment cmt"># process.</span>
630
- 73: <span class="ruby-ivar">@toRunQueue</span> = <span class="ruby-constant">Queue</span>.<span class="ruby-identifier">new</span>
631
- 74: <span class="ruby-comment cmt"># A hash that maps the JobInfo objects of running jobs by their PID.</span>
632
- 75: <span class="ruby-ivar">@runningJobs</span> = { }
633
- 76: <span class="ruby-comment cmt"># A list of jobs that wait to complete their writing.</span>
634
- 77: <span class="ruby-ivar">@spoolingJobs</span> = [ ]
635
- 78: <span class="ruby-comment cmt"># The wait() method will then clean the @toDropQueue, executes the post</span>
636
- 79: <span class="ruby-comment cmt"># processing block and removes all JobInfo related objects.</span>
637
- 80: <span class="ruby-ivar">@toDropQueue</span> = <span class="ruby-constant">Queue</span>.<span class="ruby-identifier">new</span>
638
- 81:
639
- 82: <span class="ruby-comment cmt"># A semaphore to guard accesses to @runningJobs, @spoolingJobs and</span>
640
- 83: <span class="ruby-comment cmt"># following shared data structures.</span>
641
- 84: <span class="ruby-ivar">@lock</span> = <span class="ruby-constant">Monitor</span>.<span class="ruby-identifier">new</span>
642
- 85: <span class="ruby-comment cmt"># We count the submitted and completed jobs. The @jobsIn counter also</span>
643
- 86: <span class="ruby-comment cmt"># doubles as a unique job ID.</span>
644
- 87: <span class="ruby-ivar">@jobsIn</span> = <span class="ruby-ivar">@jobsOut</span> = <span class="ruby-value">0</span>
645
- 88: <span class="ruby-comment cmt"># An Array that holds all the IO objects to receive data from.</span>
646
- 89: <span class="ruby-ivar">@pipes</span> = []
647
- 90: <span class="ruby-comment cmt"># A hash that maps IO objects to JobInfo objects</span>
648
- 91: <span class="ruby-ivar">@pipeToJob</span> = {}
649
- 92:
650
- 93: <span class="ruby-comment cmt"># This global flag is set to true to signal the threads to terminate.</span>
651
- 94: <span class="ruby-ivar">@terminate</span> = <span class="ruby-keyword kw">false</span>
652
- 95: <span class="ruby-comment cmt"># Sleep time of the threads when no data is pending. This value must be</span>
653
- 96: <span class="ruby-comment cmt"># large enough to allow for a context switch between the sending</span>
654
- 97: <span class="ruby-comment cmt"># (forked-off) process and this process. If it's too large, throughput</span>
655
- 98: <span class="ruby-comment cmt"># will suffer.</span>
656
- 99: <span class="ruby-ivar">@timeout</span> = <span class="ruby-value">0.02</span>
657
- 100:
658
- 101: <span class="ruby-constant">Thread</span>.<span class="ruby-identifier">abort_on_exception</span> = <span class="ruby-keyword kw">true</span>
659
- 102: <span class="ruby-keyword kw">end</span></pre>
630
+ <span class="ruby-comment cmt"># File lib/BatchProcessor.rb, line 69</span>
631
+ 69: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">initialize</span>(<span class="ruby-identifier">maxCpuCores</span>)
632
+ 70: <span class="ruby-ivar">@maxCpuCores</span> = <span class="ruby-identifier">maxCpuCores</span>
633
+ 71: <span class="ruby-comment cmt"># Jobs submitted by calling queue() are put in the @toRunQueue. The</span>
634
+ 72: <span class="ruby-comment cmt"># pusher Thread will pick them up and fork them off into another</span>
635
+ 73: <span class="ruby-comment cmt"># process.</span>
636
+ 74: <span class="ruby-ivar">@toRunQueue</span> = <span class="ruby-constant">Queue</span>.<span class="ruby-identifier">new</span>
637
+ 75: <span class="ruby-comment cmt"># A hash that maps the JobInfo objects of running jobs by their PID.</span>
638
+ 76: <span class="ruby-ivar">@runningJobs</span> = { }
639
+ 77: <span class="ruby-comment cmt"># A list of jobs that wait to complete their writing.</span>
640
+ 78: <span class="ruby-ivar">@spoolingJobs</span> = [ ]
641
+ 79: <span class="ruby-comment cmt"># The wait() method will then clean the @toDropQueue, executes the post</span>
642
+ 80: <span class="ruby-comment cmt"># processing block and removes all JobInfo related objects.</span>
643
+ 81: <span class="ruby-ivar">@toDropQueue</span> = <span class="ruby-constant">Queue</span>.<span class="ruby-identifier">new</span>
644
+ 82:
645
+ 83: <span class="ruby-comment cmt"># A semaphore to guard accesses to @runningJobs, @spoolingJobs and</span>
646
+ 84: <span class="ruby-comment cmt"># following shared data structures.</span>
647
+ 85: <span class="ruby-ivar">@lock</span> = <span class="ruby-constant">Monitor</span>.<span class="ruby-identifier">new</span>
648
+ 86: <span class="ruby-comment cmt"># We count the submitted and completed jobs. The @jobsIn counter also</span>
649
+ 87: <span class="ruby-comment cmt"># doubles as a unique job ID.</span>
650
+ 88: <span class="ruby-ivar">@jobsIn</span> = <span class="ruby-ivar">@jobsOut</span> = <span class="ruby-value">0</span>
651
+ 89: <span class="ruby-comment cmt"># An Array that holds all the IO objects to receive data from.</span>
652
+ 90: <span class="ruby-ivar">@pipes</span> = []
653
+ 91: <span class="ruby-comment cmt"># A hash that maps IO objects to JobInfo objects</span>
654
+ 92: <span class="ruby-ivar">@pipeToJob</span> = {}
655
+ 93:
656
+ 94: <span class="ruby-comment cmt"># This global flag is set to true to signal the threads to terminate.</span>
657
+ 95: <span class="ruby-ivar">@terminate</span> = <span class="ruby-keyword kw">false</span>
658
+ 96: <span class="ruby-comment cmt"># Sleep time of the threads when no data is pending. This value must be</span>
659
+ 97: <span class="ruby-comment cmt"># large enough to allow for a context switch between the sending</span>
660
+ 98: <span class="ruby-comment cmt"># (forked-off) process and this process. If it's too large, throughput</span>
661
+ 99: <span class="ruby-comment cmt"># will suffer.</span>
662
+ 100: <span class="ruby-ivar">@timeout</span> = <span class="ruby-value">0.02</span>
663
+ 101:
664
+ 102: <span class="ruby-constant">Thread</span>.<span class="ruby-identifier">abort_on_exception</span> = <span class="ruby-keyword kw">true</span>
665
+ 103: <span class="ruby-keyword kw">end</span></pre>
660
666
  </div>
661
667
 
662
668
  </div>
@@ -697,31 +703,31 @@ block to be executed in a separate process.
697
703
  <div class="method-source-code"
698
704
  id="queue-source">
699
705
  <pre>
700
- <span class="ruby-comment cmt"># File lib/BatchProcessor.rb, line 107</span>
701
- 107: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">queue</span>(<span class="ruby-identifier">tag</span> = <span class="ruby-keyword kw">nil</span>, &amp;<span class="ruby-identifier">block</span>)
702
- 108: <span class="ruby-identifier">raise</span> <span class="ruby-value str">'You cannot call queue() while wait() is running!'</span> <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@jobsOut</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>
703
- 109:
704
- 110: <span class="ruby-comment cmt"># If this is the first queued job for this run, we have to start the</span>
705
- 111: <span class="ruby-comment cmt"># helper threads.</span>
706
- 112: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@jobsIn</span> <span class="ruby-operator">==</span> <span class="ruby-value">0</span>
707
- 113: <span class="ruby-comment cmt"># The JobInfo objects in the @toRunQueue are processed by the pusher</span>
708
- 114: <span class="ruby-comment cmt"># thread. It forkes off processes to execute the code block associated</span>
709
- 115: <span class="ruby-comment cmt"># with the JobInfo.</span>
710
- 116: <span class="ruby-ivar">@pusher</span> = <span class="ruby-constant">Thread</span>.<span class="ruby-identifier">new</span> { <span class="ruby-identifier">pusher</span> }
711
- 117: <span class="ruby-comment cmt"># The popper thread waits for terminated childs and picks up the</span>
712
- 118: <span class="ruby-comment cmt"># results.</span>
713
- 119: <span class="ruby-ivar">@popper</span> = <span class="ruby-constant">Thread</span>.<span class="ruby-identifier">new</span> { <span class="ruby-identifier">popper</span> }
714
- 120: <span class="ruby-comment cmt"># The grabber thread collects $stdout and $stderr data from each child</span>
715
- 121: <span class="ruby-comment cmt"># process and stores them in the corresponding JobInfo.</span>
716
- 122: <span class="ruby-ivar">@grabber</span> = <span class="ruby-constant">Thread</span>.<span class="ruby-identifier">new</span> { <span class="ruby-identifier">grabber</span> }
717
- 123: <span class="ruby-keyword kw">end</span>
718
- 124:
719
- 125: <span class="ruby-comment cmt"># Create a new JobInfo object for the job and push it to the @toRunQueue.</span>
720
- 126: <span class="ruby-identifier">job</span> = <span class="ruby-constant">JobInfo</span>.<span class="ruby-identifier">new</span>(<span class="ruby-ivar">@jobsIn</span>, <span class="ruby-identifier">block</span>, <span class="ruby-identifier">tag</span>)
721
- 127: <span class="ruby-comment cmt"># Increase job counter</span>
722
- 128: <span class="ruby-ivar">@lock</span>.<span class="ruby-identifier">synchronize</span> { <span class="ruby-ivar">@jobsIn</span> <span class="ruby-operator">+=</span> <span class="ruby-value">1</span> }
723
- 129: <span class="ruby-ivar">@toRunQueue</span>.<span class="ruby-identifier">push</span>(<span class="ruby-identifier">job</span>)
724
- 130: <span class="ruby-keyword kw">end</span></pre>
706
+ <span class="ruby-comment cmt"># File lib/BatchProcessor.rb, line 108</span>
707
+ 108: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">queue</span>(<span class="ruby-identifier">tag</span> = <span class="ruby-keyword kw">nil</span>, &amp;<span class="ruby-identifier">block</span>)
708
+ 109: <span class="ruby-identifier">raise</span> <span class="ruby-value str">'You cannot call queue() while wait() is running!'</span> <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@jobsOut</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>
709
+ 110:
710
+ 111: <span class="ruby-comment cmt"># If this is the first queued job for this run, we have to start the</span>
711
+ 112: <span class="ruby-comment cmt"># helper threads.</span>
712
+ 113: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@jobsIn</span> <span class="ruby-operator">==</span> <span class="ruby-value">0</span>
713
+ 114: <span class="ruby-comment cmt"># The JobInfo objects in the @toRunQueue are processed by the pusher</span>
714
+ 115: <span class="ruby-comment cmt"># thread. It forkes off processes to execute the code block associated</span>
715
+ 116: <span class="ruby-comment cmt"># with the JobInfo.</span>
716
+ 117: <span class="ruby-ivar">@pusher</span> = <span class="ruby-constant">Thread</span>.<span class="ruby-identifier">new</span> { <span class="ruby-identifier">pusher</span> }
717
+ 118: <span class="ruby-comment cmt"># The popper thread waits for terminated childs and picks up the</span>
718
+ 119: <span class="ruby-comment cmt"># results.</span>
719
+ 120: <span class="ruby-ivar">@popper</span> = <span class="ruby-constant">Thread</span>.<span class="ruby-identifier">new</span> { <span class="ruby-identifier">popper</span> }
720
+ 121: <span class="ruby-comment cmt"># The grabber thread collects $stdout and $stderr data from each child</span>
721
+ 122: <span class="ruby-comment cmt"># process and stores them in the corresponding JobInfo.</span>
722
+ 123: <span class="ruby-ivar">@grabber</span> = <span class="ruby-constant">Thread</span>.<span class="ruby-identifier">new</span> { <span class="ruby-identifier">grabber</span> }
723
+ 124: <span class="ruby-keyword kw">end</span>
724
+ 125:
725
+ 126: <span class="ruby-comment cmt"># Create a new JobInfo object for the job and push it to the @toRunQueue.</span>
726
+ 127: <span class="ruby-identifier">job</span> = <span class="ruby-constant">JobInfo</span>.<span class="ruby-identifier">new</span>(<span class="ruby-ivar">@jobsIn</span>, <span class="ruby-identifier">block</span>, <span class="ruby-identifier">tag</span>)
727
+ 128: <span class="ruby-comment cmt"># Increase job counter</span>
728
+ 129: <span class="ruby-ivar">@lock</span>.<span class="ruby-identifier">synchronize</span> { <span class="ruby-ivar">@jobsIn</span> <span class="ruby-operator">+=</span> <span class="ruby-value">1</span> }
729
+ 130: <span class="ruby-ivar">@toRunQueue</span>.<span class="ruby-identifier">push</span>(<span class="ruby-identifier">job</span>)
730
+ 131: <span class="ruby-keyword kw">end</span></pre>
725
731
  </div>
726
732
 
727
733
  </div>
@@ -756,45 +762,45 @@ results.
756
762
  <div class="method-source-code"
757
763
  id="wait-source">
758
764
  <pre>
759
- <span class="ruby-comment cmt"># File lib/BatchProcessor.rb, line 134</span>
760
- 134: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">wait</span>
761
- 135: <span class="ruby-comment cmt"># Don't wait if there are no jobs.</span>
762
- 136: <span class="ruby-keyword kw">return</span> <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@jobsIn</span> <span class="ruby-operator">==</span> <span class="ruby-value">0</span>
763
- 137:
764
- 138: <span class="ruby-comment cmt"># When we have received as many jobs in the @toDropQueue than we have</span>
765
- 139: <span class="ruby-comment cmt"># started then we're done.</span>
766
- 140: <span class="ruby-keyword kw">while</span> <span class="ruby-operator">!</span><span class="ruby-ivar">@lock</span>.<span class="ruby-identifier">synchronize</span> { <span class="ruby-ivar">@jobsIn</span> <span class="ruby-operator">==</span> <span class="ruby-ivar">@jobsOut</span> }
767
- 141: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@toDropQueue</span>.<span class="ruby-identifier">empty?</span>
768
- 142: <span class="ruby-identifier">sleep</span>(<span class="ruby-ivar">@timeout</span>)
769
- 143: <span class="ruby-keyword kw">else</span>
770
- 144: <span class="ruby-comment cmt"># We have completed jobs.</span>
771
- 145: <span class="ruby-keyword kw">while</span> <span class="ruby-operator">!</span><span class="ruby-ivar">@toDropQueue</span>.<span class="ruby-identifier">empty?</span>
772
- 146: <span class="ruby-comment cmt"># Pop a job from the @toDropQueue and call the block with it.</span>
773
- 147: <span class="ruby-identifier">job</span> = <span class="ruby-ivar">@toDropQueue</span>.<span class="ruby-identifier">pop</span>
774
- 148: <span class="ruby-comment cmt"># Remove the job related entries from the housekeeping tables.</span>
775
- 149: <span class="ruby-ivar">@lock</span>.<span class="ruby-identifier">synchronize</span> { <span class="ruby-ivar">@jobsOut</span> <span class="ruby-operator">+=</span> <span class="ruby-value">1</span> }
776
- 150:
777
- 151: <span class="ruby-comment cmt"># Call the post-processing block that was passed to wait() with</span>
778
- 152: <span class="ruby-comment cmt"># the JobInfo object as argument.</span>
779
- 153: <span class="ruby-keyword kw">yield</span>(<span class="ruby-identifier">job</span>)
780
- 154: <span class="ruby-keyword kw">end</span>
781
- 155: <span class="ruby-keyword kw">end</span>
782
- 156: <span class="ruby-keyword kw">end</span>
783
- 157:
784
- 158: <span class="ruby-comment cmt"># Signal threads to stop</span>
785
- 159: <span class="ruby-ivar">@terminate</span> = <span class="ruby-keyword kw">true</span>
786
- 160: <span class="ruby-comment cmt"># Wait for treads to finish</span>
787
- 161: <span class="ruby-ivar">@pusher</span>.<span class="ruby-identifier">join</span>
788
- 162: <span class="ruby-ivar">@popper</span>.<span class="ruby-identifier">join</span>
789
- 163: <span class="ruby-ivar">@grabber</span>.<span class="ruby-identifier">join</span>
790
- 164:
791
- 165: <span class="ruby-comment cmt"># Reset some variables so we can reuse the object for further job runs.</span>
792
- 166: <span class="ruby-ivar">@jobsIn</span> = <span class="ruby-ivar">@jobsOut</span> = <span class="ruby-value">0</span>
793
- 167: <span class="ruby-ivar">@terminate</span> = <span class="ruby-keyword kw">false</span>
794
- 168:
795
- 169: <span class="ruby-comment cmt"># Make sure all data structures are empty and clean.</span>
796
- 170: <span class="ruby-identifier">check</span>
797
- 171: <span class="ruby-keyword kw">end</span></pre>
765
+ <span class="ruby-comment cmt"># File lib/BatchProcessor.rb, line 135</span>
766
+ 135: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">wait</span>
767
+ 136: <span class="ruby-comment cmt"># Don't wait if there are no jobs.</span>
768
+ 137: <span class="ruby-keyword kw">return</span> <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@jobsIn</span> <span class="ruby-operator">==</span> <span class="ruby-value">0</span>
769
+ 138:
770
+ 139: <span class="ruby-comment cmt"># When we have received as many jobs in the @toDropQueue than we have</span>
771
+ 140: <span class="ruby-comment cmt"># started then we're done.</span>
772
+ 141: <span class="ruby-keyword kw">while</span> <span class="ruby-operator">!</span><span class="ruby-ivar">@lock</span>.<span class="ruby-identifier">synchronize</span> { <span class="ruby-ivar">@jobsIn</span> <span class="ruby-operator">==</span> <span class="ruby-ivar">@jobsOut</span> }
773
+ 142: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@toDropQueue</span>.<span class="ruby-identifier">empty?</span>
774
+ 143: <span class="ruby-identifier">sleep</span>(<span class="ruby-ivar">@timeout</span>)
775
+ 144: <span class="ruby-keyword kw">else</span>
776
+ 145: <span class="ruby-comment cmt"># We have completed jobs.</span>
777
+ 146: <span class="ruby-keyword kw">while</span> <span class="ruby-operator">!</span><span class="ruby-ivar">@toDropQueue</span>.<span class="ruby-identifier">empty?</span>
778
+ 147: <span class="ruby-comment cmt"># Pop a job from the @toDropQueue and call the block with it.</span>
779
+ 148: <span class="ruby-identifier">job</span> = <span class="ruby-ivar">@toDropQueue</span>.<span class="ruby-identifier">pop</span>
780
+ 149: <span class="ruby-comment cmt"># Remove the job related entries from the housekeeping tables.</span>
781
+ 150: <span class="ruby-ivar">@lock</span>.<span class="ruby-identifier">synchronize</span> { <span class="ruby-ivar">@jobsOut</span> <span class="ruby-operator">+=</span> <span class="ruby-value">1</span> }
782
+ 151:
783
+ 152: <span class="ruby-comment cmt"># Call the post-processing block that was passed to wait() with</span>
784
+ 153: <span class="ruby-comment cmt"># the JobInfo object as argument.</span>
785
+ 154: <span class="ruby-keyword kw">yield</span>(<span class="ruby-identifier">job</span>)
786
+ 155: <span class="ruby-keyword kw">end</span>
787
+ 156: <span class="ruby-keyword kw">end</span>
788
+ 157: <span class="ruby-keyword kw">end</span>
789
+ 158:
790
+ 159: <span class="ruby-comment cmt"># Signal threads to stop</span>
791
+ 160: <span class="ruby-ivar">@terminate</span> = <span class="ruby-keyword kw">true</span>
792
+ 161: <span class="ruby-comment cmt"># Wait for treads to finish</span>
793
+ 162: <span class="ruby-ivar">@pusher</span>.<span class="ruby-identifier">join</span>
794
+ 163: <span class="ruby-ivar">@popper</span>.<span class="ruby-identifier">join</span>
795
+ 164: <span class="ruby-ivar">@grabber</span>.<span class="ruby-identifier">join</span>
796
+ 165:
797
+ 166: <span class="ruby-comment cmt"># Reset some variables so we can reuse the object for further job runs.</span>
798
+ 167: <span class="ruby-ivar">@jobsIn</span> = <span class="ruby-ivar">@jobsOut</span> = <span class="ruby-value">0</span>
799
+ 168: <span class="ruby-ivar">@terminate</span> = <span class="ruby-keyword kw">false</span>
800
+ 169:
801
+ 170: <span class="ruby-comment cmt"># Make sure all data structures are empty and clean.</span>
802
+ 171: <span class="ruby-identifier">check</span>
803
+ 172: <span class="ruby-keyword kw">end</span></pre>
798
804
  </div>
799
805
 
800
806
  </div>
@@ -831,16 +837,16 @@ results.
831
837
  <div class="method-source-code"
832
838
  id="check-source">
833
839
  <pre>
834
- <span class="ruby-comment cmt"># File lib/BatchProcessor.rb, line 328</span>
835
- 328: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">check</span>
836
- 329: <span class="ruby-identifier">raise</span> <span class="ruby-value str">&quot;toRunQueue not empty!&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-ivar">@toRunQueue</span>.<span class="ruby-identifier">empty?</span>
837
- 330: <span class="ruby-identifier">raise</span> <span class="ruby-value str">&quot;runningJobs list not empty!&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-ivar">@runningJobs</span>.<span class="ruby-identifier">empty?</span>
838
- 331: <span class="ruby-identifier">raise</span> <span class="ruby-value str">&quot;spoolingJobs list not empty!&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-ivar">@spoolingJobs</span>.<span class="ruby-identifier">empty?</span>
839
- 332: <span class="ruby-identifier">raise</span> <span class="ruby-value str">&quot;toDropQueue not empty!&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-ivar">@toDropQueue</span>.<span class="ruby-identifier">empty?</span>
840
- 333:
841
- 334: <span class="ruby-identifier">raise</span> <span class="ruby-value str">&quot;pipe list not empty!&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-ivar">@pipes</span>.<span class="ruby-identifier">empty?</span>
842
- 335: <span class="ruby-identifier">raise</span> <span class="ruby-value str">&quot;pipe map not empty!&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-ivar">@pipeToJob</span>.<span class="ruby-identifier">empty?</span>
843
- 336: <span class="ruby-keyword kw">end</span></pre>
840
+ <span class="ruby-comment cmt"># File lib/BatchProcessor.rb, line 329</span>
841
+ 329: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">check</span>
842
+ 330: <span class="ruby-identifier">raise</span> <span class="ruby-value str">&quot;toRunQueue not empty!&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-ivar">@toRunQueue</span>.<span class="ruby-identifier">empty?</span>
843
+ 331: <span class="ruby-identifier">raise</span> <span class="ruby-value str">&quot;runningJobs list not empty!&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-ivar">@runningJobs</span>.<span class="ruby-identifier">empty?</span>
844
+ 332: <span class="ruby-identifier">raise</span> <span class="ruby-value str">&quot;spoolingJobs list not empty!&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-ivar">@spoolingJobs</span>.<span class="ruby-identifier">empty?</span>
845
+ 333: <span class="ruby-identifier">raise</span> <span class="ruby-value str">&quot;toDropQueue not empty!&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-ivar">@toDropQueue</span>.<span class="ruby-identifier">empty?</span>
846
+ 334:
847
+ 335: <span class="ruby-identifier">raise</span> <span class="ruby-value str">&quot;pipe list not empty!&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-ivar">@pipes</span>.<span class="ruby-identifier">empty?</span>
848
+ 336: <span class="ruby-identifier">raise</span> <span class="ruby-value str">&quot;pipe map not empty!&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-ivar">@pipeToJob</span>.<span class="ruby-identifier">empty?</span>
849
+ 337: <span class="ruby-keyword kw">end</span></pre>
844
850
  </div>
845
851
 
846
852
  </div>
@@ -871,19 +877,19 @@ results.
871
877
  <div class="method-source-code"
872
878
  id="clean-ipes-source">
873
879
  <pre>
874
- <span class="ruby-comment cmt"># File lib/BatchProcessor.rb, line 315</span>
875
- 315: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">cleanPipes</span>(<span class="ruby-identifier">job</span>)
876
- 316: <span class="ruby-ivar">@pipes</span>.<span class="ruby-identifier">delete</span>(<span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutP</span>)
877
- 317: <span class="ruby-ivar">@pipeToJob</span>.<span class="ruby-identifier">delete</span>(<span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutP</span>)
878
- 318: <span class="ruby-ivar">@pipes</span>.<span class="ruby-identifier">delete</span>(<span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrP</span>)
879
- 319: <span class="ruby-ivar">@pipeToJob</span>.<span class="ruby-identifier">delete</span>(<span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrP</span>)
880
- 320: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutC</span>.<span class="ruby-identifier">close</span>
881
- 321: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutP</span>.<span class="ruby-identifier">close</span>
882
- 322: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrC</span>.<span class="ruby-identifier">close</span>
883
- 323: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrP</span>.<span class="ruby-identifier">close</span>
884
- 324: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutC</span> = <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrC</span> = <span class="ruby-keyword kw">nil</span>
885
- 325: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutP</span> = <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrP</span> = <span class="ruby-keyword kw">nil</span>
886
- 326: <span class="ruby-keyword kw">end</span></pre>
880
+ <span class="ruby-comment cmt"># File lib/BatchProcessor.rb, line 316</span>
881
+ 316: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">cleanPipes</span>(<span class="ruby-identifier">job</span>)
882
+ 317: <span class="ruby-ivar">@pipes</span>.<span class="ruby-identifier">delete</span>(<span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutP</span>)
883
+ 318: <span class="ruby-ivar">@pipeToJob</span>.<span class="ruby-identifier">delete</span>(<span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutP</span>)
884
+ 319: <span class="ruby-ivar">@pipes</span>.<span class="ruby-identifier">delete</span>(<span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrP</span>)
885
+ 320: <span class="ruby-ivar">@pipeToJob</span>.<span class="ruby-identifier">delete</span>(<span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrP</span>)
886
+ 321: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutC</span>.<span class="ruby-identifier">close</span>
887
+ 322: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutP</span>.<span class="ruby-identifier">close</span>
888
+ 323: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrC</span>.<span class="ruby-identifier">close</span>
889
+ 324: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrP</span>.<span class="ruby-identifier">close</span>
890
+ 325: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutC</span> = <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrC</span> = <span class="ruby-keyword kw">nil</span>
891
+ 326: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutP</span> = <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrP</span> = <span class="ruby-keyword kw">nil</span>
892
+ 327: <span class="ruby-keyword kw">end</span></pre>
887
893
  </div>
888
894
 
889
895
  </div>
@@ -919,59 +925,59 @@ process.
919
925
  <div class="method-source-code"
920
926
  id="grabber-source">
921
927
  <pre>
922
- <span class="ruby-comment cmt"># File lib/BatchProcessor.rb, line 262</span>
923
- 262: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">grabber</span>
924
- 263: <span class="ruby-keyword kw">until</span> <span class="ruby-ivar">@terminate</span>
925
- 264: <span class="ruby-comment cmt"># Wait for output in any of the pipes or a timeout. To make sure that</span>
926
- 265: <span class="ruby-comment cmt"># we get all output, we remain in the loop until the select() call</span>
927
- 266: <span class="ruby-comment cmt"># times out.</span>
928
- 267: <span class="ruby-identifier">res</span> = <span class="ruby-keyword kw">nil</span>
929
- 268: <span class="ruby-keyword kw">begin</span>
930
- 269: <span class="ruby-ivar">@lock</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
931
- 270: <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">res</span> = <span class="ruby-identifier">select</span>(<span class="ruby-ivar">@pipes</span>, <span class="ruby-keyword kw">nil</span>, <span class="ruby-ivar">@pipes</span>, <span class="ruby-ivar">@timeout</span>))
932
- 271: <span class="ruby-comment cmt"># We have output data from at least one child. Check which pipe</span>
933
- 272: <span class="ruby-comment cmt"># actually triggered the select.</span>
934
- 273: <span class="ruby-identifier">res</span>[<span class="ruby-value">0</span>].<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">pipe</span><span class="ruby-operator">|</span>
935
- 274: <span class="ruby-comment cmt"># Find the corresponding JobInfo object.</span>
936
- 275: <span class="ruby-identifier">job</span> = <span class="ruby-ivar">@pipeToJob</span>[<span class="ruby-identifier">pipe</span>]
937
- 276: <span class="ruby-comment cmt"># Store the output.</span>
938
- 277: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">pipe</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutP</span>
939
- 278: <span class="ruby-comment cmt"># Look for the EOT character to signal the end of the text.</span>
940
- 279: <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">c</span> = <span class="ruby-identifier">pipe</span>.<span class="ruby-identifier">getc</span>) <span class="ruby-operator">==</span> <span class="ruby-value">\0004\</span>
941
- 280: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutEOT</span> = <span class="ruby-keyword kw">true</span>
942
- 281: <span class="ruby-keyword kw">else</span>
943
- 282: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdout</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">c</span>
944
- 283: <span class="ruby-keyword kw">end</span>
945
- 284: <span class="ruby-keyword kw">else</span>
946
- 285: <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">c</span> = <span class="ruby-identifier">pipe</span>.<span class="ruby-identifier">getc</span>) <span class="ruby-operator">==</span> <span class="ruby-value">\0004\</span>
947
- 286: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrEOT</span> = <span class="ruby-keyword kw">true</span>
948
- 287: <span class="ruby-keyword kw">else</span>
949
- 288: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderr</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">c</span>
950
- 289: <span class="ruby-keyword kw">end</span>
951
- 290: <span class="ruby-keyword kw">end</span>
952
- 291: <span class="ruby-keyword kw">end</span>
953
- 292: <span class="ruby-keyword kw">end</span>
954
- 293: <span class="ruby-keyword kw">end</span>
955
- 294: <span class="ruby-identifier">sleep</span>(<span class="ruby-ivar">@timeout</span>) <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">res</span>
956
- 295: <span class="ruby-keyword kw">end</span> <span class="ruby-keyword kw">while</span> <span class="ruby-identifier">res</span>
957
- 296:
958
- 297: <span class="ruby-comment cmt"># Search the @spoolingJobs list for jobs that have completed IO and</span>
959
- 298: <span class="ruby-comment cmt"># push them to the @toDropQueue.</span>
960
- 299: <span class="ruby-ivar">@lock</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
961
- 300: <span class="ruby-ivar">@spoolingJobs</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">job</span><span class="ruby-operator">|</span>
962
- 301: <span class="ruby-comment cmt"># Both stdout and stderr need to have reached the end of text.</span>
963
- 302: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutEOT</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrEOT</span>
964
- 303: <span class="ruby-ivar">@spoolingJobs</span>.<span class="ruby-identifier">delete</span>(<span class="ruby-identifier">job</span>)
965
- 304: <span class="ruby-identifier">cleanPipes</span>(<span class="ruby-identifier">job</span>)
966
- 305: <span class="ruby-ivar">@toDropQueue</span>.<span class="ruby-identifier">push</span>(<span class="ruby-identifier">job</span>)
967
- 306: <span class="ruby-comment cmt"># Since we deleted a list item during an iterator run, we</span>
968
- 307: <span class="ruby-comment cmt"># terminate the iterator.</span>
969
- 308: <span class="ruby-keyword kw">break</span>
970
- 309: <span class="ruby-keyword kw">end</span>
971
- 310: <span class="ruby-keyword kw">end</span>
972
- 311: <span class="ruby-keyword kw">end</span>
973
- 312: <span class="ruby-keyword kw">end</span>
974
- 313: <span class="ruby-keyword kw">end</span></pre>
928
+ <span class="ruby-comment cmt"># File lib/BatchProcessor.rb, line 263</span>
929
+ 263: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">grabber</span>
930
+ 264: <span class="ruby-keyword kw">until</span> <span class="ruby-ivar">@terminate</span>
931
+ 265: <span class="ruby-comment cmt"># Wait for output in any of the pipes or a timeout. To make sure that</span>
932
+ 266: <span class="ruby-comment cmt"># we get all output, we remain in the loop until the select() call</span>
933
+ 267: <span class="ruby-comment cmt"># times out.</span>
934
+ 268: <span class="ruby-identifier">res</span> = <span class="ruby-keyword kw">nil</span>
935
+ 269: <span class="ruby-keyword kw">begin</span>
936
+ 270: <span class="ruby-ivar">@lock</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
937
+ 271: <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">res</span> = <span class="ruby-identifier">select</span>(<span class="ruby-ivar">@pipes</span>, <span class="ruby-keyword kw">nil</span>, <span class="ruby-ivar">@pipes</span>, <span class="ruby-ivar">@timeout</span>))
938
+ 272: <span class="ruby-comment cmt"># We have output data from at least one child. Check which pipe</span>
939
+ 273: <span class="ruby-comment cmt"># actually triggered the select.</span>
940
+ 274: <span class="ruby-identifier">res</span>[<span class="ruby-value">0</span>].<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">pipe</span><span class="ruby-operator">|</span>
941
+ 275: <span class="ruby-comment cmt"># Find the corresponding JobInfo object.</span>
942
+ 276: <span class="ruby-identifier">job</span> = <span class="ruby-ivar">@pipeToJob</span>[<span class="ruby-identifier">pipe</span>]
943
+ 277: <span class="ruby-comment cmt"># Store the output.</span>
944
+ 278: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">pipe</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutP</span>
945
+ 279: <span class="ruby-comment cmt"># Look for the EOT character to signal the end of the text.</span>
946
+ 280: <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">c</span> = <span class="ruby-identifier">pipe</span>.<span class="ruby-identifier">getc</span>) <span class="ruby-operator">==</span> <span class="ruby-value">\0004\</span>
947
+ 281: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutEOT</span> = <span class="ruby-keyword kw">true</span>
948
+ 282: <span class="ruby-keyword kw">else</span>
949
+ 283: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdout</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">c</span>
950
+ 284: <span class="ruby-keyword kw">end</span>
951
+ 285: <span class="ruby-keyword kw">else</span>
952
+ 286: <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">c</span> = <span class="ruby-identifier">pipe</span>.<span class="ruby-identifier">getc</span>) <span class="ruby-operator">==</span> <span class="ruby-value">\0004\</span>
953
+ 287: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrEOT</span> = <span class="ruby-keyword kw">true</span>
954
+ 288: <span class="ruby-keyword kw">else</span>
955
+ 289: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderr</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">c</span>
956
+ 290: <span class="ruby-keyword kw">end</span>
957
+ 291: <span class="ruby-keyword kw">end</span>
958
+ 292: <span class="ruby-keyword kw">end</span>
959
+ 293: <span class="ruby-keyword kw">end</span>
960
+ 294: <span class="ruby-keyword kw">end</span>
961
+ 295: <span class="ruby-identifier">sleep</span>(<span class="ruby-ivar">@timeout</span>) <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">res</span>
962
+ 296: <span class="ruby-keyword kw">end</span> <span class="ruby-keyword kw">while</span> <span class="ruby-identifier">res</span>
963
+ 297:
964
+ 298: <span class="ruby-comment cmt"># Search the @spoolingJobs list for jobs that have completed IO and</span>
965
+ 299: <span class="ruby-comment cmt"># push them to the @toDropQueue.</span>
966
+ 300: <span class="ruby-ivar">@lock</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
967
+ 301: <span class="ruby-ivar">@spoolingJobs</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">job</span><span class="ruby-operator">|</span>
968
+ 302: <span class="ruby-comment cmt"># Both stdout and stderr need to have reached the end of text.</span>
969
+ 303: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutEOT</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrEOT</span>
970
+ 304: <span class="ruby-ivar">@spoolingJobs</span>.<span class="ruby-identifier">delete</span>(<span class="ruby-identifier">job</span>)
971
+ 305: <span class="ruby-identifier">cleanPipes</span>(<span class="ruby-identifier">job</span>)
972
+ 306: <span class="ruby-ivar">@toDropQueue</span>.<span class="ruby-identifier">push</span>(<span class="ruby-identifier">job</span>)
973
+ 307: <span class="ruby-comment cmt"># Since we deleted a list item during an iterator run, we</span>
974
+ 308: <span class="ruby-comment cmt"># terminate the iterator.</span>
975
+ 309: <span class="ruby-keyword kw">break</span>
976
+ 310: <span class="ruby-keyword kw">end</span>
977
+ 311: <span class="ruby-keyword kw">end</span>
978
+ 312: <span class="ruby-keyword kw">end</span>
979
+ 313: <span class="ruby-keyword kw">end</span>
980
+ 314: <span class="ruby-keyword kw">end</span></pre>
975
981
  </div>
976
982
 
977
983
  </div>
@@ -1006,39 +1012,39 @@ waits for the process completion and stores the result in the corresponding
1006
1012
  <div class="method-source-code"
1007
1013
  id="popper-source">
1008
1014
  <pre>
1009
- <span class="ruby-comment cmt"># File lib/BatchProcessor.rb, line 226</span>
1010
- 226: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">popper</span>
1011
- 227: <span class="ruby-keyword kw">until</span> <span class="ruby-ivar">@terminate</span>
1012
- 228: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@runningJobs</span>.<span class="ruby-identifier">empty?</span>
1013
- 229: <span class="ruby-comment cmt"># No pending jobs, wait a bit.</span>
1014
- 230: <span class="ruby-identifier">sleep</span>(<span class="ruby-ivar">@timeout</span>)
1015
- 231: <span class="ruby-keyword kw">else</span>
1016
- 232: <span class="ruby-comment cmt"># Wait for the next job to complete.</span>
1017
- 233: <span class="ruby-identifier">pid</span>, <span class="ruby-identifier">retVal</span> = <span class="ruby-constant">Process</span>.<span class="ruby-identifier">wait2</span>
1018
- 234: <span class="ruby-identifier">job</span> = <span class="ruby-keyword kw">nil</span>
1019
- 235: <span class="ruby-ivar">@lock</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1020
- 236: <span class="ruby-comment cmt"># Get the JobInfo object that corresponds to the process ID. The</span>
1021
- 237: <span class="ruby-comment cmt"># blocks passed to queue() or wait() may fork child processes as</span>
1022
- 238: <span class="ruby-comment cmt"># well. If we get their PID, we can just ignore them.</span>
1023
- 239: <span class="ruby-keyword kw">next</span> <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">job</span> = <span class="ruby-ivar">@runningJobs</span>[<span class="ruby-identifier">pid</span>]).<span class="ruby-identifier">nil?</span>
1024
- 240: <span class="ruby-comment cmt"># Remove the job from the @runningJobs Hash.</span>
1025
- 241: <span class="ruby-ivar">@runningJobs</span>.<span class="ruby-identifier">delete</span>(<span class="ruby-identifier">pid</span>)
1026
- 242: <span class="ruby-comment cmt"># Save the return value.</span>
1027
- 243: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">retVal</span> = <span class="ruby-identifier">retVal</span>.<span class="ruby-identifier">dup</span>
1028
- 244: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">retVal</span>.<span class="ruby-identifier">signaled?</span>
1029
- 245: <span class="ruby-identifier">cleanPipes</span>(<span class="ruby-identifier">job</span>)
1030
- 246: <span class="ruby-comment cmt"># Aborted jobs will probably not send an EOT. So we fastrack</span>
1031
- 247: <span class="ruby-comment cmt"># them to the toDropQueue.</span>
1032
- 248: <span class="ruby-ivar">@toDropQueue</span>.<span class="ruby-identifier">push</span>(<span class="ruby-identifier">job</span>)
1033
- 249: <span class="ruby-keyword kw">else</span>
1034
- 250: <span class="ruby-comment cmt"># Push the job into the @spoolingJobs list to wait for it to</span>
1035
- 251: <span class="ruby-comment cmt"># finish writing IO.</span>
1036
- 252: <span class="ruby-ivar">@spoolingJobs</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">job</span>
1037
- 253: <span class="ruby-keyword kw">end</span>
1038
- 254: <span class="ruby-keyword kw">end</span>
1039
- 255: <span class="ruby-keyword kw">end</span>
1040
- 256: <span class="ruby-keyword kw">end</span>
1041
- 257: <span class="ruby-keyword kw">end</span></pre>
1015
+ <span class="ruby-comment cmt"># File lib/BatchProcessor.rb, line 227</span>
1016
+ 227: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">popper</span>
1017
+ 228: <span class="ruby-keyword kw">until</span> <span class="ruby-ivar">@terminate</span>
1018
+ 229: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@runningJobs</span>.<span class="ruby-identifier">empty?</span>
1019
+ 230: <span class="ruby-comment cmt"># No pending jobs, wait a bit.</span>
1020
+ 231: <span class="ruby-identifier">sleep</span>(<span class="ruby-ivar">@timeout</span>)
1021
+ 232: <span class="ruby-keyword kw">else</span>
1022
+ 233: <span class="ruby-comment cmt"># Wait for the next job to complete.</span>
1023
+ 234: <span class="ruby-identifier">pid</span>, <span class="ruby-identifier">retVal</span> = <span class="ruby-constant">Process</span>.<span class="ruby-identifier">wait2</span>
1024
+ 235: <span class="ruby-identifier">job</span> = <span class="ruby-keyword kw">nil</span>
1025
+ 236: <span class="ruby-ivar">@lock</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1026
+ 237: <span class="ruby-comment cmt"># Get the JobInfo object that corresponds to the process ID. The</span>
1027
+ 238: <span class="ruby-comment cmt"># blocks passed to queue() or wait() may fork child processes as</span>
1028
+ 239: <span class="ruby-comment cmt"># well. If we get their PID, we can just ignore them.</span>
1029
+ 240: <span class="ruby-keyword kw">next</span> <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">job</span> = <span class="ruby-ivar">@runningJobs</span>[<span class="ruby-identifier">pid</span>]).<span class="ruby-identifier">nil?</span>
1030
+ 241: <span class="ruby-comment cmt"># Remove the job from the @runningJobs Hash.</span>
1031
+ 242: <span class="ruby-ivar">@runningJobs</span>.<span class="ruby-identifier">delete</span>(<span class="ruby-identifier">pid</span>)
1032
+ 243: <span class="ruby-comment cmt"># Save the return value.</span>
1033
+ 244: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">retVal</span> = <span class="ruby-identifier">retVal</span>.<span class="ruby-identifier">dup</span>
1034
+ 245: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">retVal</span>.<span class="ruby-identifier">signaled?</span>
1035
+ 246: <span class="ruby-identifier">cleanPipes</span>(<span class="ruby-identifier">job</span>)
1036
+ 247: <span class="ruby-comment cmt"># Aborted jobs will probably not send an EOT. So we fastrack</span>
1037
+ 248: <span class="ruby-comment cmt"># them to the toDropQueue.</span>
1038
+ 249: <span class="ruby-ivar">@toDropQueue</span>.<span class="ruby-identifier">push</span>(<span class="ruby-identifier">job</span>)
1039
+ 250: <span class="ruby-keyword kw">else</span>
1040
+ 251: <span class="ruby-comment cmt"># Push the job into the @spoolingJobs list to wait for it to</span>
1041
+ 252: <span class="ruby-comment cmt"># finish writing IO.</span>
1042
+ 253: <span class="ruby-ivar">@spoolingJobs</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">job</span>
1043
+ 254: <span class="ruby-keyword kw">end</span>
1044
+ 255: <span class="ruby-keyword kw">end</span>
1045
+ 256: <span class="ruby-keyword kw">end</span>
1046
+ 257: <span class="ruby-keyword kw">end</span>
1047
+ 258: <span class="ruby-keyword kw">end</span></pre>
1042
1048
  </div>
1043
1049
 
1044
1050
  </div>
@@ -1073,52 +1079,52 @@ processes for them.
1073
1079
  <div class="method-source-code"
1074
1080
  id="pusher-source">
1075
1081
  <pre>
1076
- <span class="ruby-comment cmt"># File lib/BatchProcessor.rb, line 177</span>
1077
- 177: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">pusher</span>
1078
- 178: <span class="ruby-comment cmt"># Run until the terminate flag is set.</span>
1079
- 179: <span class="ruby-keyword kw">until</span> <span class="ruby-ivar">@terminate</span>
1080
- 180: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@toRunQueue</span>.<span class="ruby-identifier">empty?</span> <span class="ruby-operator">||</span> <span class="ruby-ivar">@runningJobs</span>.<span class="ruby-identifier">length</span> <span class="ruby-operator">&gt;=</span> <span class="ruby-ivar">@maxCpuCores</span>
1081
- 181: <span class="ruby-comment cmt"># We have no jobs in the @toRunQueue or all CPU cores in use already.</span>
1082
- 182: <span class="ruby-identifier">sleep</span>(<span class="ruby-ivar">@timeout</span>)
1083
- 183: <span class="ruby-keyword kw">else</span>
1084
- 184: <span class="ruby-comment cmt"># Get a new job from the @toRunQueue</span>
1085
- 185: <span class="ruby-identifier">job</span> = <span class="ruby-ivar">@toRunQueue</span>.<span class="ruby-identifier">pop</span>
1086
- 186:
1087
- 187: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">openPipes</span>
1088
- 188: <span class="ruby-comment cmt"># Add the receiver end of the pipe to the @pipes Array.</span>
1089
- 189: <span class="ruby-ivar">@pipes</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutP</span>
1090
- 190: <span class="ruby-comment cmt"># Map the pipe end to this JobInfo object.</span>
1091
- 191: <span class="ruby-ivar">@pipeToJob</span>[<span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutP</span>] = <span class="ruby-identifier">job</span>
1092
- 192: <span class="ruby-comment cmt"># Same for $stderr.</span>
1093
- 193: <span class="ruby-ivar">@pipes</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrP</span>
1094
- 194: <span class="ruby-ivar">@pipeToJob</span>[<span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrP</span>] = <span class="ruby-identifier">job</span>
1095
- 195:
1096
- 196: <span class="ruby-ivar">@lock</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1097
- 197: <span class="ruby-identifier">pid</span> = <span class="ruby-identifier">fork</span> <span class="ruby-keyword kw">do</span>
1098
- 198: <span class="ruby-comment cmt"># This is the child process now. Connect $stdout and $stderr to</span>
1099
- 199: <span class="ruby-comment cmt"># the pipes.</span>
1100
- 200: <span class="ruby-identifier">$stdout</span>.<span class="ruby-identifier">reopen</span>(<span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutC</span>)
1101
- 201: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutC</span>.<span class="ruby-identifier">close</span>
1102
- 202: <span class="ruby-identifier">$stderr</span>.<span class="ruby-identifier">reopen</span>(<span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrC</span>)
1103
- 203: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrC</span>.<span class="ruby-identifier">close</span>
1104
- 204: <span class="ruby-comment cmt"># Call the Ruby code block</span>
1105
- 205: <span class="ruby-identifier">retVal</span> = <span class="ruby-identifier">job</span>.<span class="ruby-identifier">block</span>.<span class="ruby-identifier">call</span>
1106
- 206: <span class="ruby-comment cmt"># Send EOT character to mark the end of the text.</span>
1107
- 207: <span class="ruby-identifier">$stdout</span>.<span class="ruby-identifier">putc</span> <span class="ruby-value">4</span>
1108
- 208: <span class="ruby-identifier">$stdout</span>.<span class="ruby-identifier">close</span>
1109
- 209: <span class="ruby-identifier">$stderr</span>.<span class="ruby-identifier">putc</span> <span class="ruby-value">4</span>
1110
- 210: <span class="ruby-identifier">$stderr</span>.<span class="ruby-identifier">close</span>
1111
- 211: <span class="ruby-comment cmt"># Now exit the child process and return the return value of the</span>
1112
- 212: <span class="ruby-comment cmt"># block as process return value.</span>
1113
- 213: <span class="ruby-identifier">exit</span> <span class="ruby-identifier">retVal</span>
1114
- 214: <span class="ruby-keyword kw">end</span>
1115
- 215: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">pid</span> = <span class="ruby-identifier">pid</span>
1116
- 216: <span class="ruby-comment cmt"># Save the process ID in the PID to JobInfo hash.</span>
1117
- 217: <span class="ruby-ivar">@runningJobs</span>[<span class="ruby-identifier">pid</span>] = <span class="ruby-identifier">job</span>
1118
- 218: <span class="ruby-keyword kw">end</span>
1119
- 219: <span class="ruby-keyword kw">end</span>
1120
- 220: <span class="ruby-keyword kw">end</span>
1121
- 221: <span class="ruby-keyword kw">end</span></pre>
1082
+ <span class="ruby-comment cmt"># File lib/BatchProcessor.rb, line 178</span>
1083
+ 178: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">pusher</span>
1084
+ 179: <span class="ruby-comment cmt"># Run until the terminate flag is set.</span>
1085
+ 180: <span class="ruby-keyword kw">until</span> <span class="ruby-ivar">@terminate</span>
1086
+ 181: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@toRunQueue</span>.<span class="ruby-identifier">empty?</span> <span class="ruby-operator">||</span> <span class="ruby-ivar">@runningJobs</span>.<span class="ruby-identifier">length</span> <span class="ruby-operator">&gt;=</span> <span class="ruby-ivar">@maxCpuCores</span>
1087
+ 182: <span class="ruby-comment cmt"># We have no jobs in the @toRunQueue or all CPU cores in use already.</span>
1088
+ 183: <span class="ruby-identifier">sleep</span>(<span class="ruby-ivar">@timeout</span>)
1089
+ 184: <span class="ruby-keyword kw">else</span>
1090
+ 185: <span class="ruby-comment cmt"># Get a new job from the @toRunQueue</span>
1091
+ 186: <span class="ruby-identifier">job</span> = <span class="ruby-ivar">@toRunQueue</span>.<span class="ruby-identifier">pop</span>
1092
+ 187:
1093
+ 188: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">openPipes</span>
1094
+ 189: <span class="ruby-comment cmt"># Add the receiver end of the pipe to the @pipes Array.</span>
1095
+ 190: <span class="ruby-ivar">@pipes</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutP</span>
1096
+ 191: <span class="ruby-comment cmt"># Map the pipe end to this JobInfo object.</span>
1097
+ 192: <span class="ruby-ivar">@pipeToJob</span>[<span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutP</span>] = <span class="ruby-identifier">job</span>
1098
+ 193: <span class="ruby-comment cmt"># Same for $stderr.</span>
1099
+ 194: <span class="ruby-ivar">@pipes</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrP</span>
1100
+ 195: <span class="ruby-ivar">@pipeToJob</span>[<span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrP</span>] = <span class="ruby-identifier">job</span>
1101
+ 196:
1102
+ 197: <span class="ruby-ivar">@lock</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
1103
+ 198: <span class="ruby-identifier">pid</span> = <span class="ruby-identifier">fork</span> <span class="ruby-keyword kw">do</span>
1104
+ 199: <span class="ruby-comment cmt"># This is the child process now. Connect $stdout and $stderr to</span>
1105
+ 200: <span class="ruby-comment cmt"># the pipes.</span>
1106
+ 201: <span class="ruby-identifier">$stdout</span>.<span class="ruby-identifier">reopen</span>(<span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutC</span>)
1107
+ 202: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stdoutC</span>.<span class="ruby-identifier">close</span>
1108
+ 203: <span class="ruby-identifier">$stderr</span>.<span class="ruby-identifier">reopen</span>(<span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrC</span>)
1109
+ 204: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">stderrC</span>.<span class="ruby-identifier">close</span>
1110
+ 205: <span class="ruby-comment cmt"># Call the Ruby code block</span>
1111
+ 206: <span class="ruby-identifier">retVal</span> = <span class="ruby-identifier">job</span>.<span class="ruby-identifier">block</span>.<span class="ruby-identifier">call</span>
1112
+ 207: <span class="ruby-comment cmt"># Send EOT character to mark the end of the text.</span>
1113
+ 208: <span class="ruby-identifier">$stdout</span>.<span class="ruby-identifier">putc</span> <span class="ruby-value">4</span>
1114
+ 209: <span class="ruby-identifier">$stdout</span>.<span class="ruby-identifier">close</span>
1115
+ 210: <span class="ruby-identifier">$stderr</span>.<span class="ruby-identifier">putc</span> <span class="ruby-value">4</span>
1116
+ 211: <span class="ruby-identifier">$stderr</span>.<span class="ruby-identifier">close</span>
1117
+ 212: <span class="ruby-comment cmt"># Now exit the child process and return the return value of the</span>
1118
+ 213: <span class="ruby-comment cmt"># block as process return value.</span>
1119
+ 214: <span class="ruby-identifier">exit</span> <span class="ruby-identifier">retVal</span>
1120
+ 215: <span class="ruby-keyword kw">end</span>
1121
+ 216: <span class="ruby-identifier">job</span>.<span class="ruby-identifier">pid</span> = <span class="ruby-identifier">pid</span>
1122
+ 217: <span class="ruby-comment cmt"># Save the process ID in the PID to JobInfo hash.</span>
1123
+ 218: <span class="ruby-ivar">@runningJobs</span>[<span class="ruby-identifier">pid</span>] = <span class="ruby-identifier">job</span>
1124
+ 219: <span class="ruby-keyword kw">end</span>
1125
+ 220: <span class="ruby-keyword kw">end</span>
1126
+ 221: <span class="ruby-keyword kw">end</span>
1127
+ 222: <span class="ruby-keyword kw">end</span></pre>
1122
1128
  </div>
1123
1129
 
1124
1130
  </div>