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