taskjuggler 0.0.8 → 0.0.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/CHANGELOG +1144 -2047
- data/README +1 -1
- data/Rakefile +6 -6
- data/data/css/tjmanual.css +20 -0
- data/data/css/tjreport.css +7 -6
- data/doc/AppConfig.html +136 -130
- data/doc/Arguments.html +46 -40
- data/doc/CHANGELOG.html +1162 -2057
- data/doc/COPYING.html +8 -2
- data/doc/Object.html +205 -199
- data/doc/README.html +9 -3
- data/doc/RuntimeConfig.html +75 -69
- data/doc/String.html +69 -63
- data/doc/TaskJuggler.html +350 -291
- data/doc/TaskJuggler/Account.html +26 -20
- data/doc/TaskJuggler/AccountAttribute.html +24 -18
- data/doc/TaskJuggler/AccountScenario.html +24 -18
- data/doc/TaskJuggler/Allocation.html +74 -68
- data/doc/TaskJuggler/AllocationAttribute.html +54 -48
- data/doc/TaskJuggler/AttributeBase.html +172 -93
- data/doc/TaskJuggler/AttributeDefinition.html +22 -16
- data/doc/TaskJuggler/AttributeOverwrite.html +586 -0
- data/doc/TaskJuggler/BatchProcessor.html +263 -257
- data/doc/TaskJuggler/Booking.html +44 -38
- data/doc/TaskJuggler/BookingListAttribute.html +25 -21
- data/doc/TaskJuggler/BooleanAttribute.html +24 -18
- data/doc/TaskJuggler/CSVFile.html +193 -187
- data/doc/TaskJuggler/CellSettingPattern.html +13 -7
- data/doc/TaskJuggler/CellSettingPatternList.html +25 -19
- data/doc/TaskJuggler/Charge.html +49 -43
- data/doc/TaskJuggler/ChargeListAttribute.html +21 -15
- data/doc/TaskJuggler/ChargeSet.html +94 -88
- data/doc/TaskJuggler/ChargeSetListAttribute.html +29 -25
- data/doc/TaskJuggler/CollisionDetector.html +142 -136
- data/doc/TaskJuggler/ColumnListAttribute.html +21 -17
- data/doc/TaskJuggler/ColumnTable.html +50 -44
- data/doc/TaskJuggler/Daemon.html +71 -50
- data/doc/TaskJuggler/DataCache.html +110 -58
- data/doc/TaskJuggler/DataCacheEntry.html +22 -16
- data/doc/TaskJuggler/DateAttribute.html +24 -18
- data/doc/TaskJuggler/DefinitionListAttribute.html +12 -6
- data/doc/TaskJuggler/DependencyListAttribute.html +29 -25
- data/doc/TaskJuggler/DurationAttribute.html +25 -19
- data/doc/TaskJuggler/FileList.html +25 -19
- data/doc/TaskJuggler/FileRecord.html +17 -11
- data/doc/TaskJuggler/FixnumAttribute.html +16 -10
- data/doc/TaskJuggler/FlagListAttribute.html +25 -21
- data/doc/TaskJuggler/FloatAttribute.html +20 -14
- data/doc/TaskJuggler/FormatListAttribute.html +17 -11
- data/doc/TaskJuggler/GanttChart.html +242 -236
- data/doc/TaskJuggler/GanttContainer.html +71 -67
- data/doc/TaskJuggler/GanttHeader.html +113 -107
- data/doc/TaskJuggler/GanttHeaderScaleItem.html +26 -20
- data/doc/TaskJuggler/GanttLine.html +217 -210
- data/doc/TaskJuggler/GanttLoadStack.html +89 -83
- data/doc/TaskJuggler/GanttMilestone.html +11 -6
- data/doc/TaskJuggler/GanttRouter.html +194 -186
- data/doc/TaskJuggler/GanttTaskBar.html +41 -34
- data/doc/TaskJuggler/HTMLDocument.html +52 -46
- data/doc/TaskJuggler/HTMLGraphics.html +58 -52
- data/doc/TaskJuggler/Interval.html +90 -84
- data/doc/TaskJuggler/IntervalList.html +777 -0
- data/doc/TaskJuggler/IntervalListAttribute.html +29 -25
- data/doc/TaskJuggler/JobInfo.html +36 -30
- data/doc/TaskJuggler/Journal.html +188 -177
- data/doc/TaskJuggler/JournalEntry.html +36 -30
- data/doc/TaskJuggler/JournalEntryList.html +88 -82
- data/doc/TaskJuggler/KeywordArray.html +12 -6
- data/doc/TaskJuggler/KeywordDocumentation.html +512 -503
- data/doc/TaskJuggler/Limits.html +111 -105
- data/doc/TaskJuggler/Limits/Limit.html +71 -65
- data/doc/TaskJuggler/LimitsAttribute.html +21 -15
- data/doc/TaskJuggler/ListAttributeBase.html +16 -10
- data/doc/TaskJuggler/Log.html +111 -105
- data/doc/TaskJuggler/LogFile.html +54 -48
- data/doc/TaskJuggler/LogicalAttribute.html +35 -29
- data/doc/TaskJuggler/LogicalExpression.html +32 -26
- data/doc/TaskJuggler/LogicalExpressionAttribute.html +16 -10
- data/doc/TaskJuggler/LogicalExpressionListAttribute.html +671 -0
- data/doc/TaskJuggler/LogicalFlag.html +24 -18
- data/doc/TaskJuggler/LogicalFunction.html +164 -158
- data/doc/TaskJuggler/LogicalOperation.html +138 -132
- data/doc/TaskJuggler/Macro.html +14 -8
- data/doc/TaskJuggler/MacroTable.html +42 -36
- data/doc/TaskJuggler/ManagerResponsibilities.html +19 -13
- data/doc/TaskJuggler/ManagerStatusRecord.html +23 -17
- data/doc/TaskJuggler/Message.html +56 -50
- data/doc/TaskJuggler/MessageHandler.html +73 -67
- data/doc/TaskJuggler/Navigator.html +92 -86
- data/doc/TaskJuggler/NavigatorElement.html +88 -82
- data/doc/TaskJuggler/NikuProject.html +15 -9
- data/doc/TaskJuggler/NikuReport.html +405 -370
- data/doc/TaskJuggler/NikuResource.html +13 -7
- data/doc/TaskJuggler/NodeListAttribute.html +13 -9
- data/doc/TaskJuggler/PlaceHolderCell.html +22 -16
- data/doc/TaskJuggler/ProcessIntercom.html +116 -110
- data/doc/TaskJuggler/ProcessIntercomIface.html +39 -33
- data/doc/TaskJuggler/Project.html +1064 -895
- data/doc/TaskJuggler/ProjectBroker.html +439 -366
- data/doc/TaskJuggler/ProjectBrokerIface.html +63 -53
- data/doc/TaskJuggler/ProjectFileParser.html +329 -319
- data/doc/TaskJuggler/ProjectFileScanner.html +351 -345
- data/doc/TaskJuggler/ProjectRecord.html +66 -60
- data/doc/TaskJuggler/ProjectServer.html +287 -280
- data/doc/TaskJuggler/ProjectServerIface.html +43 -37
- data/doc/TaskJuggler/PropertyAttribute.html +16 -10
- data/doc/TaskJuggler/PropertyList.html +205 -199
- data/doc/TaskJuggler/PropertySet.html +264 -296
- data/doc/TaskJuggler/PropertyTreeNode.html +455 -505
- data/doc/TaskJuggler/Query.html +309 -524
- data/doc/TaskJuggler/RTFHandlers.html +17 -11
- data/doc/TaskJuggler/RTFNavigator.html +33 -27
- data/doc/TaskJuggler/RTFQuery.html +135 -129
- data/doc/TaskJuggler/RTFReport.html +63 -57
- data/doc/TaskJuggler/RTFReportLink.html +55 -49
- data/doc/TaskJuggler/RTFWithQuerySupport.html +17 -11
- data/doc/TaskJuggler/RealFormat.html +64 -58
- data/doc/TaskJuggler/RealFormatAttribute.html +12 -6
- data/doc/TaskJuggler/ReferenceAttribute.html +35 -29
- data/doc/TaskJuggler/Report.html +294 -249
- data/doc/TaskJuggler/ReportBase.html +229 -223
- data/doc/TaskJuggler/ReportContext.html +52 -46
- data/doc/TaskJuggler/ReportServer.html +143 -137
- data/doc/TaskJuggler/ReportServerIface.html +51 -43
- data/doc/TaskJuggler/ReportServerRecord.html +36 -30
- data/doc/TaskJuggler/ReportServlet.html +167 -140
- data/doc/TaskJuggler/ReportTable.html +137 -131
- data/doc/TaskJuggler/ReportTableCell.html +332 -292
- data/doc/TaskJuggler/ReportTableColumn.html +46 -40
- data/doc/TaskJuggler/ReportTableLegend.html +43 -38
- data/doc/TaskJuggler/ReportTableLine.html +66 -60
- data/doc/TaskJuggler/Resource.html +166 -160
- data/doc/TaskJuggler/ResourceListAttribute.html +54 -32
- data/doc/TaskJuggler/ResourceListRE.html +47 -41
- data/doc/TaskJuggler/ResourceScenario.html +671 -644
- data/doc/TaskJuggler/RichText.html +51 -45
- data/doc/TaskJuggler/RichTextAttribute.html +28 -22
- data/doc/TaskJuggler/RichTextDocument.html +96 -90
- data/doc/TaskJuggler/RichTextElement.html +503 -497
- data/doc/TaskJuggler/RichTextFunctionExample.html +41 -35
- data/doc/TaskJuggler/RichTextFunctionHandler.html +19 -13
- data/doc/TaskJuggler/RichTextImage.html +14 -8
- data/doc/TaskJuggler/RichTextIntermediate.html +86 -80
- data/doc/TaskJuggler/RichTextParser.html +59 -53
- data/doc/TaskJuggler/RichTextScanner.html +184 -178
- data/doc/TaskJuggler/RichTextSnip.html +69 -63
- data/doc/TaskJuggler/RichTextSyntaxRules.html +416 -410
- data/doc/TaskJuggler/Scenario.html +13 -7
- data/doc/TaskJuggler/ScenarioData.html +40 -34
- data/doc/TaskJuggler/ScenarioListAttribute.html +21 -15
- data/doc/TaskJuggler/Scoreboard.html +129 -107
- data/doc/TaskJuggler/SheetHandlerBase.html +245 -239
- data/doc/TaskJuggler/SheetReceiver.html +333 -327
- data/doc/TaskJuggler/SheetSender.html +227 -221
- data/doc/TaskJuggler/Shift.html +26 -20
- data/doc/TaskJuggler/ShiftAssignment.html +45 -39
- data/doc/TaskJuggler/ShiftAssignments.html +178 -172
- data/doc/TaskJuggler/ShiftAssignmentsAttribute.html +21 -15
- data/doc/TaskJuggler/ShiftScenario.html +29 -23
- data/doc/TaskJuggler/SimpleQueryExpander.html +36 -30
- data/doc/TaskJuggler/SortListAttribute.html +17 -13
- data/doc/TaskJuggler/SourceFileInfo.html +19 -13
- data/doc/TaskJuggler/StatusSheetReceiver.html +31 -25
- data/doc/TaskJuggler/StatusSheetReport.html +166 -159
- data/doc/TaskJuggler/StatusSheetSender.html +80 -74
- data/doc/TaskJuggler/StringAttribute.html +20 -14
- data/doc/TaskJuggler/SymbolAttribute.html +16 -10
- data/doc/TaskJuggler/SyntaxReference.html +231 -225
- data/doc/TaskJuggler/TOCEntry.html +46 -40
- data/doc/TaskJuggler/TSResourceRecord.html +15 -9
- data/doc/TaskJuggler/TSTaskRecord.html +16 -10
- data/doc/TaskJuggler/TableColumnDefinition.html +84 -39
- data/doc/TaskJuggler/TableOfContents.html +28 -22
- data/doc/TaskJuggler/TableReport.html +906 -866
- data/doc/TaskJuggler/Task.html +99 -93
- data/doc/TaskJuggler/TaskDependency.html +24 -18
- data/doc/TaskJuggler/TaskListAttribute.html +29 -25
- data/doc/TaskJuggler/TaskListRE.html +46 -39
- data/doc/TaskJuggler/TaskScenario.html +2218 -1965
- data/doc/TaskJuggler/TextFormatter.html +154 -148
- data/doc/TaskJuggler/TextParser.html +362 -348
- data/doc/TaskJuggler/TextParser/Pattern.html +313 -307
- data/doc/TaskJuggler/TextParser/Rule.html +147 -141
- data/doc/TaskJuggler/TextParser/StackElement.html +58 -52
- data/doc/TaskJuggler/TextParser/State.html +88 -82
- data/doc/TaskJuggler/TextParser/StateTransition.html +42 -36
- data/doc/TaskJuggler/TextParser/TextParserResultArray.html +20 -14
- data/doc/TaskJuggler/TextParser/TokenDoc.html +19 -13
- data/doc/TaskJuggler/TextReport.html +80 -74
- data/doc/TaskJuggler/TextScanner.html +284 -272
- data/doc/TaskJuggler/TextScanner/BufferStreamHandle.html +14 -8
- data/doc/TaskJuggler/TextScanner/FileStreamHandle.html +21 -15
- data/doc/TaskJuggler/TextScanner/MacroStackEntry.html +15 -9
- data/doc/TaskJuggler/TextScanner/StreamHandle.html +102 -96
- data/doc/TaskJuggler/TimeSheet.html +123 -117
- data/doc/TaskJuggler/TimeSheetReceiver.html +28 -22
- data/doc/TaskJuggler/TimeSheetRecord.html +212 -206
- data/doc/TaskJuggler/TimeSheetReport.html +206 -199
- data/doc/TaskJuggler/TimeSheetSender.html +27 -21
- data/doc/TaskJuggler/TimeSheetSummary.html +140 -134
- data/doc/TaskJuggler/TimeSheets.html +20 -14
- data/doc/TaskJuggler/Tj3AppBase.html +100 -94
- data/doc/TaskJuggler/Tj3Client.html +407 -483
- data/doc/TaskJuggler/Tj3Daemon.html +116 -107
- data/doc/TaskJuggler/Tj3SheetAppBase.html +45 -39
- data/doc/TaskJuggler/Tj3SsReceiver.html +31 -25
- data/doc/TaskJuggler/Tj3SsSender.html +64 -58
- data/doc/TaskJuggler/Tj3TsReceiver.html +31 -25
- data/doc/TaskJuggler/Tj3TsSender.html +51 -45
- data/doc/TaskJuggler/Tj3TsSummary.html +59 -53
- data/doc/TaskJuggler/TjException.html +13 -7
- data/doc/TaskJuggler/TjTime.html +444 -438
- data/doc/TaskJuggler/TjpExample.html +84 -78
- data/doc/TaskJuggler/TjpExportRE.html +356 -349
- data/doc/TaskJuggler/TjpSyntaxRules.html +4279 -4151
- data/doc/TaskJuggler/URLParameter.html +16 -10
- data/doc/TaskJuggler/UserManual.html +185 -179
- data/doc/TaskJuggler/VimSyntax.html +144 -138
- data/doc/TaskJuggler/WebServer.html +46 -39
- data/doc/TaskJuggler/WelcomePage.html +769 -0
- data/doc/TaskJuggler/WorkingHours.html +185 -179
- data/doc/TaskJuggler/WorkingHoursAttribute.html +42 -36
- data/doc/TaskJuggler/XMLBlob.html +21 -15
- data/doc/TaskJuggler/XMLComment.html +17 -11
- data/doc/TaskJuggler/XMLDocument.html +33 -27
- data/doc/TaskJuggler/XMLElement.html +97 -91
- data/doc/TaskJuggler/XMLNamedText.html +13 -7
- data/doc/TaskJuggler/XMLText.html +32 -26
- data/doc/index.html +601 -563
- data/doc/lib/AccountScenario_rb.html +5 -3
- data/doc/lib/Account_rb.html +5 -3
- data/doc/lib/Allocation_rb.html +5 -3
- data/doc/lib/AppConfig_rb.html +5 -3
- data/doc/lib/AttributeBase_rb.html +5 -3
- data/doc/lib/AttributeDefinition_rb.html +5 -3
- data/doc/lib/Attributes_rb.html +5 -3
- data/doc/lib/BatchProcessor_rb.html +5 -3
- data/doc/lib/Booking_rb.html +5 -3
- data/doc/lib/ChargeSet_rb.html +5 -3
- data/doc/lib/Charge_rb.html +5 -3
- data/doc/lib/DataCache_rb.html +5 -3
- data/doc/lib/FileList_rb.html +5 -3
- data/doc/lib/HTMLDocument_rb.html +5 -3
- data/doc/lib/IntervalList_rb.html +69 -0
- data/doc/lib/Interval_rb.html +5 -3
- data/doc/lib/Journal_rb.html +5 -3
- data/doc/lib/KeywordArray_rb.html +5 -3
- data/doc/lib/KeywordDocumentation_rb.html +5 -3
- data/doc/lib/Limits_rb.html +5 -3
- data/doc/lib/LogFile_rb.html +5 -3
- data/doc/lib/Log_rb.html +5 -3
- data/doc/lib/LogicalExpression_rb.html +5 -3
- data/doc/lib/LogicalFunction_rb.html +5 -3
- data/doc/lib/LogicalOperation_rb.html +5 -3
- data/doc/lib/MacroTable_rb.html +5 -3
- data/doc/lib/MessageHandler_rb.html +5 -3
- data/doc/lib/ProjectFileParser_rb.html +5 -3
- data/doc/lib/ProjectFileScanner_rb.html +5 -3
- data/doc/lib/Project_rb.html +5 -3
- data/doc/lib/PropertyList_rb.html +5 -3
- data/doc/lib/PropertySet_rb.html +5 -3
- data/doc/lib/PropertyTreeNode_rb.html +5 -3
- data/doc/lib/Query_rb.html +5 -3
- data/doc/lib/RTFHandlers_rb.html +5 -3
- data/doc/lib/RTFNavigator_rb.html +5 -3
- data/doc/lib/RTFQuery_rb.html +5 -3
- data/doc/lib/RTFReportLink_rb.html +5 -3
- data/doc/lib/RTFReport_rb.html +5 -3
- data/doc/lib/RTFWithQuerySupport_rb.html +5 -3
- data/doc/lib/RealFormat_rb.html +5 -3
- data/doc/lib/ResourceScenario_rb.html +5 -3
- data/doc/lib/Resource_rb.html +5 -3
- data/doc/lib/RichTextDocument_rb.html +5 -3
- data/doc/lib/RichTextElement_rb.html +5 -3
- data/doc/lib/RichTextFunctionExample_rb.html +5 -3
- data/doc/lib/RichTextFunctionHandler_rb.html +5 -3
- data/doc/lib/RichTextParser_rb.html +5 -3
- data/doc/lib/RichTextScanner_rb.html +5 -3
- data/doc/lib/RichTextSnip_rb.html +5 -3
- data/doc/lib/RichTextSyntaxRules_rb.html +5 -3
- data/doc/lib/RichText_rb.html +5 -3
- data/doc/lib/RuntimeConfig_rb.html +5 -3
- data/doc/lib/ScenarioData_rb.html +5 -3
- data/doc/lib/Scenario_rb.html +5 -3
- data/doc/lib/Scoreboard_rb.html +7 -3
- data/doc/lib/SheetHandlerBase_rb.html +5 -3
- data/doc/lib/SheetReceiver_rb.html +5 -3
- data/doc/lib/SheetSender_rb.html +5 -3
- data/doc/lib/ShiftAssignments_rb.html +5 -3
- data/doc/lib/ShiftScenario_rb.html +5 -3
- data/doc/lib/Shift_rb.html +5 -3
- data/doc/lib/SimpleQueryExpander_rb.html +5 -3
- data/doc/lib/SourceFileInfo_rb.html +5 -3
- data/doc/lib/StatusSheetReceiver_rb.html +5 -3
- data/doc/lib/StatusSheetSender_rb.html +5 -3
- data/doc/lib/SyntaxReference_rb.html +5 -3
- data/doc/lib/TOCEntry_rb.html +5 -3
- data/doc/lib/TableColumnDefinition_rb.html +5 -3
- data/doc/lib/TableOfContents_rb.html +5 -3
- data/doc/lib/TaskDependency_rb.html +5 -3
- data/doc/lib/TaskJuggler_rb.html +5 -3
- data/doc/lib/TaskScenario_rb.html +5 -3
- data/doc/lib/Task_rb.html +5 -3
- data/doc/lib/TextFormatter_rb.html +6 -4
- data/doc/lib/TextParser/Pattern_rb.html +5 -3
- data/doc/lib/TextParser/Rule_rb.html +5 -3
- data/doc/lib/TextParser/StackElement_rb.html +5 -3
- data/doc/lib/TextParser/State_rb.html +6 -4
- data/doc/lib/TextParser/TokenDoc_rb.html +5 -3
- data/doc/lib/TextParser_rb.html +5 -3
- data/doc/lib/TextScanner_rb.html +5 -3
- data/doc/lib/TimeSheetReceiver_rb.html +5 -3
- data/doc/lib/TimeSheetSender_rb.html +5 -3
- data/doc/lib/TimeSheetSummary_rb.html +6 -4
- data/doc/lib/TimeSheets_rb.html +5 -3
- data/doc/lib/Tj3AppBase_rb.html +5 -3
- data/doc/lib/Tj3Config_rb.html +5 -3
- data/doc/lib/Tj3SheetAppBase_rb.html +5 -3
- data/doc/lib/TjException_rb.html +5 -3
- data/doc/lib/TjTime_rb.html +5 -3
- data/doc/lib/TjpExample_rb.html +5 -3
- data/doc/lib/TjpSyntaxRules_rb.html +5 -3
- data/doc/lib/URLParameter_rb.html +5 -3
- data/doc/lib/UTF8String_rb.html +5 -3
- data/doc/lib/UserManual_rb.html +5 -3
- data/doc/lib/VimSyntax_rb.html +6 -4
- data/doc/lib/WorkingHours_rb.html +5 -3
- data/doc/lib/XMLDocument_rb.html +5 -3
- data/doc/lib/XMLElement_rb.html +5 -3
- data/doc/lib/daemon/Daemon_rb.html +5 -3
- data/doc/lib/daemon/ProcessIntercom_rb.html +7 -3
- data/doc/lib/daemon/ProjectBroker_rb.html +5 -3
- data/doc/lib/daemon/ProjectServer_rb.html +5 -3
- data/doc/lib/daemon/ReportServer_rb.html +5 -3
- data/doc/lib/daemon/ReportServlet_rb.html +69 -0
- data/doc/lib/daemon/WebServer_rb.html +9 -3
- data/doc/lib/daemon/WelcomePage_rb.html +71 -0
- data/doc/lib/deep_copy_rb.html +5 -3
- data/doc/lib/reports/CSVFile_rb.html +5 -3
- data/doc/lib/reports/CollisionDetector_rb.html +5 -3
- data/doc/lib/reports/ColumnTable_rb.html +5 -3
- data/doc/lib/reports/GanttChart_rb.html +5 -3
- data/doc/lib/reports/GanttContainer_rb.html +5 -3
- data/doc/lib/reports/GanttHeaderScaleItem_rb.html +5 -3
- data/doc/lib/reports/GanttHeader_rb.html +5 -3
- data/doc/lib/reports/GanttLine_rb.html +5 -3
- data/doc/lib/reports/GanttLoadStack_rb.html +5 -3
- data/doc/lib/reports/GanttMilestone_rb.html +5 -3
- data/doc/lib/reports/GanttRouter_rb.html +5 -3
- data/doc/lib/reports/GanttTaskBar_rb.html +5 -3
- data/doc/lib/reports/HTMLGraphics_rb.html +5 -3
- data/doc/lib/reports/Navigator_rb.html +5 -3
- data/doc/lib/reports/NikuReport_rb.html +5 -3
- data/doc/lib/reports/ReportBase_rb.html +5 -3
- data/doc/lib/reports/ReportContext_rb.html +5 -3
- data/doc/lib/reports/ReportTableCell_rb.html +5 -3
- data/doc/lib/reports/ReportTableColumn_rb.html +5 -3
- data/doc/lib/reports/ReportTableLegend_rb.html +5 -3
- data/doc/lib/reports/ReportTableLine_rb.html +5 -3
- data/doc/lib/reports/ReportTable_rb.html +5 -3
- data/doc/lib/reports/Report_rb.html +5 -3
- data/doc/lib/reports/ResourceListRE_rb.html +5 -3
- data/doc/lib/reports/StatusSheetReport_rb.html +5 -3
- data/doc/lib/reports/TableReport_rb.html +5 -3
- data/doc/lib/reports/TaskListRE_rb.html +5 -3
- data/doc/lib/reports/TextReport_rb.html +5 -3
- data/doc/lib/reports/TimeSheetReport_rb.html +5 -3
- data/doc/lib/reports/TjpExportRE_rb.html +5 -3
- data/doc/lib/{taskjuggler3_rb.html → tj3_rb.html} +7 -5
- data/doc/lib/tj3client_rb.html +5 -3
- data/doc/lib/tj3d_rb.html +6 -4
- data/doc/lib/tj3man_rb.html +5 -3
- data/doc/lib/tj3ss_receiver_rb.html +5 -3
- data/doc/lib/tj3ss_sender_rb.html +5 -3
- data/doc/lib/tj3ts_receiver_rb.html +5 -3
- data/doc/lib/tj3ts_sender_rb.html +5 -3
- data/doc/lib/tj3ts_summary_rb.html +5 -3
- data/examples/tutorial.tjp +13 -5
- data/gem_spec.rb +3 -0
- data/lib/Account.rb +2 -1
- data/lib/AccountScenario.rb +2 -1
- data/lib/Allocation.rb +2 -1
- data/lib/AppConfig.rb +2 -1
- data/lib/AttributeBase.rb +19 -5
- data/lib/AttributeDefinition.rb +2 -1
- data/lib/Attributes.rb +49 -38
- data/lib/BatchProcessor.rb +2 -1
- data/lib/Booking.rb +2 -1
- data/lib/Charge.rb +2 -1
- data/lib/ChargeSet.rb +2 -1
- data/lib/DataCache.rb +15 -1
- data/lib/FileList.rb +2 -1
- data/lib/HTMLDocument.rb +2 -1
- data/lib/Interval.rb +2 -1
- data/lib/IntervalList.rb +100 -0
- data/lib/Journal.rb +8 -2
- data/lib/KeywordArray.rb +2 -1
- data/lib/KeywordDocumentation.rb +10 -6
- data/lib/Limits.rb +2 -1
- data/lib/Log.rb +3 -2
- data/lib/LogFile.rb +2 -1
- data/lib/LogicalExpression.rb +2 -1
- data/lib/LogicalFunction.rb +2 -1
- data/lib/LogicalOperation.rb +2 -1
- data/lib/MacroTable.rb +2 -1
- data/lib/MessageHandler.rb +2 -1
- data/lib/Project.rb +92 -25
- data/lib/ProjectFileParser.rb +7 -2
- data/lib/ProjectFileScanner.rb +2 -1
- data/lib/PropertyList.rb +2 -1
- data/lib/PropertySet.rb +2 -6
- data/lib/PropertyTreeNode.rb +22 -44
- data/lib/Query.rb +32 -13
- data/lib/RTFHandlers.rb +2 -1
- data/lib/RTFNavigator.rb +2 -1
- data/lib/RTFQuery.rb +3 -2
- data/lib/RTFReport.rb +2 -1
- data/lib/RTFReportLink.rb +2 -1
- data/lib/RTFWithQuerySupport.rb +2 -1
- data/lib/RealFormat.rb +2 -1
- data/lib/Resource.rb +2 -1
- data/lib/ResourceScenario.rb +35 -14
- data/lib/RichText.rb +2 -1
- data/lib/RichTextDocument.rb +2 -1
- data/lib/RichTextElement.rb +2 -1
- data/lib/RichTextFunctionExample.rb +2 -1
- data/lib/RichTextFunctionHandler.rb +2 -1
- data/lib/RichTextParser.rb +2 -1
- data/lib/RichTextScanner.rb +2 -1
- data/lib/RichTextSnip.rb +2 -1
- data/lib/RichTextSyntaxRules.rb +2 -1
- data/lib/RuntimeConfig.rb +2 -1
- data/lib/Scenario.rb +2 -1
- data/lib/ScenarioData.rb +2 -1
- data/lib/Scoreboard.rb +27 -8
- data/lib/SheetHandlerBase.rb +2 -1
- data/lib/SheetReceiver.rb +2 -1
- data/lib/SheetSender.rb +2 -1
- data/lib/Shift.rb +2 -1
- data/lib/ShiftAssignments.rb +2 -1
- data/lib/ShiftScenario.rb +2 -1
- data/lib/SimpleQueryExpander.rb +2 -1
- data/lib/SourceFileInfo.rb +2 -1
- data/lib/StatusSheetReceiver.rb +2 -1
- data/lib/StatusSheetSender.rb +2 -1
- data/lib/SyntaxReference.rb +2 -1
- data/lib/TOCEntry.rb +2 -1
- data/lib/TableColumnDefinition.rb +9 -2
- data/lib/TableOfContents.rb +2 -1
- data/lib/Task.rb +2 -1
- data/lib/TaskDependency.rb +2 -1
- data/lib/TaskJuggler.rb +8 -6
- data/lib/TaskScenario.rb +337 -153
- data/lib/TextFormatter.rb +3 -2
- data/lib/TextParser.rb +7 -2
- data/lib/TextParser/Pattern.rb +2 -1
- data/lib/TextParser/Rule.rb +2 -1
- data/lib/TextParser/StackElement.rb +2 -1
- data/lib/TextParser/State.rb +3 -2
- data/lib/TextParser/TokenDoc.rb +2 -1
- data/lib/TextScanner.rb +12 -5
- data/lib/TimeSheetReceiver.rb +2 -1
- data/lib/TimeSheetSender.rb +2 -1
- data/lib/TimeSheetSummary.rb +3 -2
- data/lib/TimeSheets.rb +2 -1
- data/lib/Tj3AppBase.rb +6 -5
- data/lib/Tj3Config.rb +5 -4
- data/lib/Tj3SheetAppBase.rb +2 -1
- data/lib/TjException.rb +2 -1
- data/lib/TjTime.rb +2 -1
- data/lib/TjpExample.rb +2 -1
- data/lib/TjpSyntaxRules.rb +264 -65
- data/lib/URLParameter.rb +2 -1
- data/lib/UTF8String.rb +2 -1
- data/lib/UserManual.rb +2 -1
- data/lib/VimSyntax.rb +3 -2
- data/lib/WorkingHours.rb +2 -1
- data/lib/XMLDocument.rb +2 -1
- data/lib/XMLElement.rb +2 -1
- data/lib/daemon/Daemon.rb +3 -1
- data/lib/daemon/ProcessIntercom.rb +3 -1
- data/lib/daemon/ProjectBroker.rb +84 -32
- data/lib/daemon/ProjectServer.rb +5 -3
- data/lib/daemon/ReportServer.rb +8 -5
- data/lib/daemon/ReportServlet.rb +166 -0
- data/lib/daemon/WebServer.rb +6 -150
- data/lib/daemon/WelcomePage.rb +80 -0
- data/lib/deep_copy.rb +2 -1
- data/lib/reports/CSVFile.rb +2 -1
- data/lib/reports/CollisionDetector.rb +2 -1
- data/lib/reports/ColumnTable.rb +2 -1
- data/lib/reports/GanttChart.rb +2 -1
- data/lib/reports/GanttContainer.rb +3 -4
- data/lib/reports/GanttHeader.rb +2 -1
- data/lib/reports/GanttHeaderScaleItem.rb +2 -1
- data/lib/reports/GanttLine.rb +12 -10
- data/lib/reports/GanttLoadStack.rb +2 -1
- data/lib/reports/GanttMilestone.rb +3 -3
- data/lib/reports/GanttRouter.rb +4 -1
- data/lib/reports/GanttTaskBar.rb +9 -7
- data/lib/reports/HTMLGraphics.rb +2 -1
- data/lib/reports/Navigator.rb +2 -1
- data/lib/reports/NikuReport.rb +79 -49
- data/lib/reports/Report.rb +42 -10
- data/lib/reports/ReportBase.rb +2 -1
- data/lib/reports/ReportContext.rb +2 -1
- data/lib/reports/ReportTable.rb +2 -1
- data/lib/reports/ReportTableCell.rb +63 -28
- data/lib/reports/ReportTableColumn.rb +2 -1
- data/lib/reports/ReportTableLegend.rb +5 -5
- data/lib/reports/ReportTableLine.rb +2 -1
- data/lib/reports/ResourceListRE.rb +2 -1
- data/lib/reports/StatusSheetReport.rb +4 -2
- data/lib/reports/TableReport.rb +42 -38
- data/lib/reports/TaskListRE.rb +4 -2
- data/lib/reports/TextReport.rb +2 -1
- data/lib/reports/TimeSheetReport.rb +4 -2
- data/lib/reports/TjpExportRE.rb +4 -2
- data/lib/{taskjuggler3.rb → tj3.rb} +6 -5
- data/lib/tj3client.rb +19 -36
- data/lib/tj3d.rb +6 -2
- data/lib/tj3man.rb +4 -3
- data/lib/tj3ss_receiver.rb +2 -1
- data/lib/tj3ss_sender.rb +2 -1
- data/lib/tj3ts_receiver.rb +2 -1
- data/lib/tj3ts_sender.rb +2 -1
- data/lib/tj3ts_summary.rb +2 -1
- data/manual/Day_To_Day_Juggling +36 -0
- data/manual/How_To_Contribute +9 -4
- data/manual/Installation +10 -3
- data/manual/TaskJuggler_Internals +0 -2
- data/manual/Tutorial +25 -3
- data/prj_cfg.rb +4 -2
- data/spec/IntervalList_spec.rb +138 -0
- data/spec/ProjectBroker_spec.rb +133 -0
- data/tasks/changelog.rake +41 -24
- data/tasks/csts.rake +1 -0
- data/tasks/gem.rake +1 -0
- data/tasks/rcov.rake +1 -1
- data/tasks/spec.rake +7 -0
- data/tasks/test.rake +1 -0
- data/test/MessageChecker.rb +2 -1
- data/test/TestSuite/CSV-Reports/niku.tjp +70 -0
- data/test/TestSuite/CSV-Reports/{celltext-Reference.csv → refs/celltext.csv} +0 -0
- data/test/TestSuite/CSV-Reports/refs/niku.csv +5 -0
- data/test/TestSuite/CSV-Reports/{resourcereport-Reference.csv → refs/resourcereport.csv} +0 -0
- data/test/TestSuite/CSV-Reports/{resourcereport_with_tasks-Reference.csv → refs/resourcereport_with_tasks.csv} +0 -0
- data/test/TestSuite/CSV-Reports/{sortByTree-Reference.csv → refs/sortByTree.csv} +0 -0
- data/test/TestSuite/CSV-Reports/{sortBy_duration.down-Reference.csv → refs/sortBy_duration.down.csv} +0 -0
- data/test/TestSuite/CSV-Reports/{sortBy_effort.up-Reference.csv → refs/sortBy_effort.up.csv} +0 -0
- data/test/TestSuite/CSV-Reports/{sortBy_plan.start.down-Reference.csv → refs/sortBy_plan.start.down.csv} +0 -0
- data/test/TestSuite/CSV-Reports/{taskreport-Reference.csv → refs/taskreport.csv} +0 -0
- data/test/TestSuite/CSV-Reports/{taskreport_with_resources-Reference.csv → refs/taskreport_with_resources.csv} +0 -0
- data/test/TestSuite/CSV-Reports/{weekly-Reference.csv → refs/weekly.csv} +0 -0
- data/test/TestSuite/HTML-Reports/Alerts.tjp +12 -0
- data/test/TestSuite/Scheduler/Correct/Allocate.tjp +2 -2
- data/test/TestSuite/Scheduler/Correct/Container-2.tjp +1 -2
- data/test/TestSuite/Scheduler/Correct/InheritedAttributes.tjp +77 -0
- data/test/TestSuite/Scheduler/Correct/WeakDeps.tjp +40 -0
- data/test/TestSuite/Scheduler/Errors/loop_detected_12.tjp +2 -2
- data/test/TestSuite/Scheduler/Errors/loop_detected_13.tjp +3 -4
- data/test/TestSuite/Scheduler/Errors/loop_detected_3.tjp +2 -2
- data/test/TestSuite/Scheduler/Errors/loop_detected_6.tjp +8 -7
- data/test/TestSuite/Scheduler/Errors/onend_wrong_direction.tjp +19 -0
- data/test/TestSuite/Scheduler/Errors/onstart_wrong_direction.tjp +18 -0
- data/test/TestSuite/Scheduler/Errors/task_depend_multi.tjp +1 -2
- data/test/TestSuite/StatusSheets/StatusSheetTemplates/2002-03-02/boss_2002-03-02.tji +46 -0
- data/test/TestSuite/StatusSheets/StatusSheetTemplates/2002-03-02/dev2_2002-03-02.tji +22 -0
- data/test/TestSuite/StatusSheets/StatusSheetTemplates/2002-03-02/resources.yml +11 -0
- data/test/TestSuite/StatusSheets/StatusSheetTemplates/acceptable_intervals +1 -0
- data/test/TestSuite/StatusSheets/sender.log +256 -0
- data/test/TestSuite/StatusSheets/statussheets.log +9 -0
- data/test/TestSuite/StatusSheets/tj3d.log +395 -0
- data/test/TestSuite/Syntax/Correct/Limits-1.tjp +2 -0
- data/test/TestSuite/Syntax/Correct/Niku.tjp +6 -1
- data/test/TestSuite/Syntax/Correct/Scenario.tjp +4 -1
- data/test/TestSuite/Syntax/Correct/Supplement.tjp +12 -5
- data/test/TestSuite/Syntax/Correct/TaskPrefix.tji +3 -0
- data/test/TestSuite/Syntax/Correct/TaskPrefix.tjp +24 -0
- data/test/TestSuite/Syntax/Correct/css/tjreport.css +7 -2
- data/test/TestSuite/Syntax/Correct/tutorial.tjp +15 -5
- data/test/all.rb +2 -4
- data/test/test_BatchProcessor.rb +2 -1
- data/test/test_CSV-Reports.rb +34 -23
- data/test/test_CSVFile.rb +2 -1
- data/test/test_CollisionDetector.rb +3 -2
- data/test/test_Journal.rb +2 -1
- data/test/test_Limits.rb +2 -1
- data/test/test_LogicalExpression.rb +2 -1
- data/test/test_MacroTable.rb +2 -1
- data/test/test_Project.rb +3 -2
- data/test/test_ProjectFileScanner.rb +2 -1
- data/test/test_PropertySet.rb +2 -1
- data/test/test_Query.rb +2 -1
- data/test/test_RealFormat.rb +2 -1
- data/test/test_ReportGenerator.rb +2 -1
- data/test/test_RichText.rb +2 -1
- data/test/test_Scheduler.rb +2 -1
- data/test/test_ShiftAssignments.rb +2 -1
- data/test/test_SimpleQueryExpander.rb +2 -1
- data/test/test_Syntax.rb +2 -1
- data/test/test_TextFormatter.rb +3 -2
- data/test/test_TjTime.rb +2 -1
- data/test/test_TjpExample.rb +2 -1
- data/test/test_URLParameter.rb +2 -1
- data/test/test_UTF8String.rb +2 -1
- data/test/test_WorkingHours.rb +2 -1
- data/test/test_deep_copy.rb +2 -1
- metadata +74 -20
- data/doc/StringIO.html +0 -595
- data/test/TestSuite/Scheduler/Errors/loop_detected_7.tjp +0 -46
- data/test/TestSuite/Scheduler/Errors/loop_detected_8.tjp +0 -51
- 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
|
|
625
|
-
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
|
|
631
|
-
|
|
632
|
-
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
645
|
-
|
|
646
|
-
|
|
647
|
-
|
|
648
|
-
|
|
649
|
-
|
|
650
|
-
|
|
651
|
-
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
|
|
655
|
-
|
|
656
|
-
|
|
657
|
-
|
|
658
|
-
|
|
659
|
-
|
|
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
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
|
|
705
|
-
|
|
706
|
-
|
|
707
|
-
|
|
708
|
-
|
|
709
|
-
|
|
710
|
-
|
|
711
|
-
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
|
|
715
|
-
|
|
716
|
-
|
|
717
|
-
|
|
718
|
-
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
724
|
-
|
|
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>, &<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">></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
|
|
760
|
-
|
|
761
|
-
|
|
762
|
-
|
|
763
|
-
|
|
764
|
-
|
|
765
|
-
|
|
766
|
-
|
|
767
|
-
|
|
768
|
-
|
|
769
|
-
|
|
770
|
-
|
|
771
|
-
|
|
772
|
-
|
|
773
|
-
|
|
774
|
-
|
|
775
|
-
|
|
776
|
-
|
|
777
|
-
|
|
778
|
-
|
|
779
|
-
|
|
780
|
-
|
|
781
|
-
|
|
782
|
-
|
|
783
|
-
|
|
784
|
-
|
|
785
|
-
|
|
786
|
-
|
|
787
|
-
|
|
788
|
-
|
|
789
|
-
|
|
790
|
-
|
|
791
|
-
|
|
792
|
-
|
|
793
|
-
|
|
794
|
-
|
|
795
|
-
|
|
796
|
-
|
|
797
|
-
|
|
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
|
|
835
|
-
|
|
836
|
-
|
|
837
|
-
|
|
838
|
-
|
|
839
|
-
|
|
840
|
-
|
|
841
|
-
|
|
842
|
-
|
|
843
|
-
|
|
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">"toRunQueue not empty!"</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">"runningJobs list not empty!"</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">"spoolingJobs list not empty!"</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">"toDropQueue not empty!"</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">"pipe list not empty!"</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">"pipe map not empty!"</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
|
|
875
|
-
|
|
876
|
-
|
|
877
|
-
|
|
878
|
-
|
|
879
|
-
|
|
880
|
-
|
|
881
|
-
|
|
882
|
-
|
|
883
|
-
|
|
884
|
-
|
|
885
|
-
|
|
886
|
-
|
|
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
|
|
923
|
-
|
|
924
|
-
|
|
925
|
-
|
|
926
|
-
|
|
927
|
-
|
|
928
|
-
|
|
929
|
-
|
|
930
|
-
|
|
931
|
-
|
|
932
|
-
|
|
933
|
-
|
|
934
|
-
|
|
935
|
-
|
|
936
|
-
|
|
937
|
-
|
|
938
|
-
|
|
939
|
-
|
|
940
|
-
|
|
941
|
-
|
|
942
|
-
|
|
943
|
-
|
|
944
|
-
|
|
945
|
-
|
|
946
|
-
|
|
947
|
-
|
|
948
|
-
|
|
949
|
-
|
|
950
|
-
|
|
951
|
-
|
|
952
|
-
|
|
953
|
-
|
|
954
|
-
|
|
955
|
-
|
|
956
|
-
|
|
957
|
-
|
|
958
|
-
|
|
959
|
-
|
|
960
|
-
|
|
961
|
-
|
|
962
|
-
|
|
963
|
-
|
|
964
|
-
|
|
965
|
-
|
|
966
|
-
|
|
967
|
-
|
|
968
|
-
|
|
969
|
-
|
|
970
|
-
|
|
971
|
-
|
|
972
|
-
|
|
973
|
-
|
|
974
|
-
|
|
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"><<</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"><<</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">&&</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
|
|
1010
|
-
|
|
1011
|
-
|
|
1012
|
-
|
|
1013
|
-
|
|
1014
|
-
|
|
1015
|
-
|
|
1016
|
-
|
|
1017
|
-
|
|
1018
|
-
|
|
1019
|
-
|
|
1020
|
-
|
|
1021
|
-
|
|
1022
|
-
|
|
1023
|
-
|
|
1024
|
-
|
|
1025
|
-
|
|
1026
|
-
|
|
1027
|
-
|
|
1028
|
-
|
|
1029
|
-
|
|
1030
|
-
|
|
1031
|
-
|
|
1032
|
-
|
|
1033
|
-
|
|
1034
|
-
|
|
1035
|
-
|
|
1036
|
-
|
|
1037
|
-
|
|
1038
|
-
|
|
1039
|
-
|
|
1040
|
-
|
|
1041
|
-
|
|
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"><<</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
|
|
1077
|
-
|
|
1078
|
-
|
|
1079
|
-
|
|
1080
|
-
|
|
1081
|
-
|
|
1082
|
-
|
|
1083
|
-
|
|
1084
|
-
|
|
1085
|
-
|
|
1086
|
-
|
|
1087
|
-
|
|
1088
|
-
|
|
1089
|
-
|
|
1090
|
-
|
|
1091
|
-
|
|
1092
|
-
|
|
1093
|
-
|
|
1094
|
-
|
|
1095
|
-
|
|
1096
|
-
|
|
1097
|
-
|
|
1098
|
-
|
|
1099
|
-
|
|
1100
|
-
|
|
1101
|
-
|
|
1102
|
-
|
|
1103
|
-
|
|
1104
|
-
|
|
1105
|
-
|
|
1106
|
-
|
|
1107
|
-
|
|
1108
|
-
|
|
1109
|
-
|
|
1110
|
-
|
|
1111
|
-
|
|
1112
|
-
|
|
1113
|
-
|
|
1114
|
-
|
|
1115
|
-
|
|
1116
|
-
|
|
1117
|
-
|
|
1118
|
-
|
|
1119
|
-
|
|
1120
|
-
|
|
1121
|
-
|
|
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">>=</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"><<</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"><<</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>
|