taskjuggler 0.0.8 → 0.0.9

Sign up to get free protection for your applications and to get access to all the features.
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>