mirror of
https://github.com/FlightControl-Master/MOOSE.git
synced 2025-08-15 10:47:21 +00:00
OPS Cargo
This commit is contained in:
parent
dcf1a56756
commit
2c92bb9d61
@ -438,7 +438,7 @@ OPSGROUP.TransportStatus={
|
|||||||
|
|
||||||
--- OpsGroup version.
|
--- OpsGroup version.
|
||||||
-- @field #string version
|
-- @field #string version
|
||||||
OPSGROUP.version="0.7.1"
|
OPSGROUP.version="0.7.2"
|
||||||
|
|
||||||
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
-- TODO list
|
-- TODO list
|
||||||
@ -4625,8 +4625,8 @@ function OPSGROUP:_CheckCargoTransport()
|
|||||||
if self.verbose>=1 then
|
if self.verbose>=1 then
|
||||||
local text=""
|
local text=""
|
||||||
for i,_transport in pairs(self.cargoqueue) do
|
for i,_transport in pairs(self.cargoqueue) do
|
||||||
local transport=_transport --#OPSGROUP.CargoTransport
|
local transport=_transport --#Ops.OpsTransport#OPSTRANSPORT
|
||||||
text=text..string.format("\n[%d] UID=%d Status=%s: %s --> %s", i, transport.uid, transport.status, transport.pickupzone:GetName(), transport.deployzone:GetName())
|
text=text..string.format("\n[%d] UID=%d Status=%s: %s --> %s", i, transport.uid, transport:GetState(), transport.pickupzone:GetName(), transport.deployzone:GetName())
|
||||||
for j,_cargo in pairs(transport.cargos) do
|
for j,_cargo in pairs(transport.cargos) do
|
||||||
local cargo=_cargo --#OPSGROUP.CargoGroup
|
local cargo=_cargo --#OPSGROUP.CargoGroup
|
||||||
local state=cargo.opsgroup:GetState()
|
local state=cargo.opsgroup:GetState()
|
||||||
@ -4837,10 +4837,11 @@ function OPSGROUP:_GetNextCargoTransport()
|
|||||||
|
|
||||||
-- Find next transport assignment.
|
-- Find next transport assignment.
|
||||||
for _,_cargotransport in pairs(self.cargoqueue) do
|
for _,_cargotransport in pairs(self.cargoqueue) do
|
||||||
local cargotransport=_cargotransport --#OPSGROUP.CargoTransport
|
local cargotransport=_cargotransport --Ops.OpsTransport#OPSTRANSPORT
|
||||||
|
|
||||||
if Time>=cargotransport.Tstart and cargotransport.status~=OPSGROUP.TransportStatus.DELIVERED and (cargotransport.importance==nil or cargotransport.importance<=vip) and not self:_CheckDelivered(cargotransport) then
|
if Time>=cargotransport.Tstart and cargotransport:GetCarrierTransportStatus(self)==OPSTRANSPORT.Status.SCHEDULED and (cargotransport.importance==nil or cargotransport.importance<=vip) and not self:_CheckDelivered(cargotransport) then
|
||||||
cargotransport.status=OPSGROUP.TransportStatus.EXECUTING
|
cargotransport:Executing()
|
||||||
|
cargotransport:SetCarrierTransportStatus(self, OPSTRANSPORT.Status.EXECUTING)
|
||||||
return cargotransport
|
return cargotransport
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -4851,7 +4852,7 @@ end
|
|||||||
|
|
||||||
--- Check if all cargo of this transport assignment was delivered.
|
--- Check if all cargo of this transport assignment was delivered.
|
||||||
-- @param #OPSGROUP self
|
-- @param #OPSGROUP self
|
||||||
-- @param #OPSGROUP.CargoTransport CargoTransport The next due cargo transport or `nil`.
|
-- @param Ops.OpsTransport#OPSTRANSPORT CargoTransport The next due cargo transport or `nil`.
|
||||||
-- @return #boolean If true, all cargo was delivered.
|
-- @return #boolean If true, all cargo was delivered.
|
||||||
function OPSGROUP:_CheckDelivered(CargoTransport)
|
function OPSGROUP:_CheckDelivered(CargoTransport)
|
||||||
|
|
||||||
@ -4874,7 +4875,7 @@ function OPSGROUP:_CheckDelivered(CargoTransport)
|
|||||||
end
|
end
|
||||||
|
|
||||||
-- Debug info.
|
-- Debug info.
|
||||||
self:T(self.lid..string.format("Cargotransport UID=%d Status=%s: delivered=%s", CargoTransport.uid, CargoTransport.status, tostring(done)))
|
self:T(self.lid..string.format("Cargotransport UID=%d Status=%s: delivered=%s", CargoTransport.uid, CargoTransport:GetState(), tostring(done)))
|
||||||
|
|
||||||
return done
|
return done
|
||||||
end
|
end
|
||||||
@ -4914,8 +4915,9 @@ end
|
|||||||
-- @param Ops.OpsTransport#OPSTRANSPORT OpsTransport The troop transport assignment.
|
-- @param Ops.OpsTransport#OPSTRANSPORT OpsTransport The troop transport assignment.
|
||||||
function OPSGROUP:AddOpsTransport(OpsTransport)
|
function OPSGROUP:AddOpsTransport(OpsTransport)
|
||||||
|
|
||||||
-- Set state to SCHEDULED.
|
-- Add this group as carrier for the transport.
|
||||||
OpsTransport.status=OPSTRANSPORT.Status.SCHEDULED
|
OpsTransport:_AddCarrier(self)
|
||||||
|
|
||||||
|
|
||||||
--Add to cargo queue
|
--Add to cargo queue
|
||||||
table.insert(self.cargoqueue, OpsTransport)
|
table.insert(self.cargoqueue, OpsTransport)
|
||||||
@ -5868,7 +5870,10 @@ function OPSGROUP:onafterDelivered(From, Event, To, CargoTransport)
|
|||||||
if self:IsFlightgroup() then
|
if self:IsFlightgroup() then
|
||||||
if self:IsUncontrolled() then
|
if self:IsUncontrolled() then
|
||||||
self:StartUncontrolled()
|
self:StartUncontrolled()
|
||||||
end
|
elseif self:IsLandedAt() then
|
||||||
|
local Task=self:GetTaskCurrent()
|
||||||
|
self:TaskCancel(Task)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Check group done.
|
-- Check group done.
|
||||||
|
|||||||
@ -23,7 +23,11 @@
|
|||||||
--- OPSTRANSPORT class.
|
--- OPSTRANSPORT class.
|
||||||
-- @type OPSTRANSPORT
|
-- @type OPSTRANSPORT
|
||||||
-- @field #string ClassName Name of the class.
|
-- @field #string ClassName Name of the class.
|
||||||
|
-- @field #string lid Log ID.
|
||||||
|
-- @field #number uid Unique ID of the transport.
|
||||||
|
-- @field #number verbose Verbosity level.
|
||||||
-- @field #table cargos Cargos. Each element is a @{#OPSGROUP.Cargo}.
|
-- @field #table cargos Cargos. Each element is a @{#OPSGROUP.Cargo}.
|
||||||
|
-- @field #table carriers Carriers assigned for this transport.
|
||||||
-- @field #string status Status of the transport. See @{#OPSTRANSPORT.Status}.
|
-- @field #string status Status of the transport. See @{#OPSTRANSPORT.Status}.
|
||||||
-- @field #number prio Priority of this transport. Should be a number between 0 (high prio) and 100 (low prio).
|
-- @field #number prio Priority of this transport. Should be a number between 0 (high prio) and 100 (low prio).
|
||||||
-- @field #number importance Importance of this transport. Smaller=higher.
|
-- @field #number importance Importance of this transport. Smaller=higher.
|
||||||
@ -50,6 +54,8 @@ OPSTRANSPORT = {
|
|||||||
ClassName = "OPSTRANSPORT",
|
ClassName = "OPSTRANSPORT",
|
||||||
verbose = 1,
|
verbose = 1,
|
||||||
cargos = {},
|
cargos = {},
|
||||||
|
carriers = {},
|
||||||
|
carrierTransportStatus = {},
|
||||||
}
|
}
|
||||||
|
|
||||||
--- Cargo transport status.
|
--- Cargo transport status.
|
||||||
@ -59,17 +65,18 @@ OPSTRANSPORT = {
|
|||||||
-- @field #string EXECUTING Transport is being executed.
|
-- @field #string EXECUTING Transport is being executed.
|
||||||
-- @field #string DELIVERED Transport was delivered.
|
-- @field #string DELIVERED Transport was delivered.
|
||||||
OPSTRANSPORT.Status={
|
OPSTRANSPORT.Status={
|
||||||
PLANNING="planning",
|
PLANNED="planned",
|
||||||
SCHEDULED="scheduled",
|
SCHEDULED="scheduled",
|
||||||
EXECUTING="executing",
|
EXECUTING="executing",
|
||||||
DELIVERED="delivered",
|
DELIVERED="delivered",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
--- Transport ID.
|
||||||
_OPSTRANSPORTID=0
|
_OPSTRANSPORTID=0
|
||||||
|
|
||||||
--- Army Group version.
|
--- Army Group version.
|
||||||
-- @field #string version
|
-- @field #string version
|
||||||
OPSTRANSPORT.version="0.0.1"
|
OPSTRANSPORT.version="0.0.2"
|
||||||
|
|
||||||
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
-- TODO list
|
-- TODO list
|
||||||
@ -92,10 +99,10 @@ function OPSTRANSPORT:New(GroupSet, Pickupzone, Deployzone)
|
|||||||
-- Inherit everything from FSM class.
|
-- Inherit everything from FSM class.
|
||||||
local self=BASE:Inherit(self, FSM:New()) -- #OPSTRANSPORT
|
local self=BASE:Inherit(self, FSM:New()) -- #OPSTRANSPORT
|
||||||
|
|
||||||
|
_OPSTRANSPORTID=_OPSTRANSPORTID+1
|
||||||
|
|
||||||
-- Set some string id for output to DCS.log file.
|
-- Set some string id for output to DCS.log file.
|
||||||
self.lid=string.format("OPSTRANSPORT %s --> %s | ", Pickupzone:GetName(), Deployzone:GetName())
|
self.lid=string.format("OPSTRANSPORT [UID=%d] %s --> %s | ", _OPSTRANSPORTID, Pickupzone:GetName(), Deployzone:GetName())
|
||||||
|
|
||||||
_OPSTRANSPORTID=_OPSTRANSPORTID+1
|
|
||||||
|
|
||||||
self.uid=_OPSTRANSPORTID
|
self.uid=_OPSTRANSPORTID
|
||||||
self.status=OPSTRANSPORT.Status.PLANNING
|
self.status=OPSTRANSPORT.Status.PLANNING
|
||||||
@ -107,14 +114,16 @@ function OPSTRANSPORT:New(GroupSet, Pickupzone, Deployzone)
|
|||||||
self.importance=nil
|
self.importance=nil
|
||||||
self.Tstart=timer.getAbsTime()
|
self.Tstart=timer.getAbsTime()
|
||||||
self.carrierGroup=nil
|
self.carrierGroup=nil
|
||||||
self.cargos={}
|
self.cargos={}
|
||||||
|
self.carriers={}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- Check type of GroupSet provided.
|
-- Check type of GroupSet provided.
|
||||||
if GroupSet:IsInstanceOf("GROUP") or GroupSet:IsInstanceOf("OPSGROUP") then
|
if GroupSet:IsInstanceOf("GROUP") or GroupSet:IsInstanceOf("OPSGROUP") then
|
||||||
|
|
||||||
-- We got a single GROUP or OPSGROUP objectg.
|
-- We got a single GROUP or OPSGROUP object.
|
||||||
local cargo=self:CreateCargoGroupData(GroupSet, Pickupzone, Deployzone)
|
local cargo=self:_CreateCargoGroupData(GroupSet, Pickupzone, Deployzone)
|
||||||
|
|
||||||
if cargo then --and self:CanCargo(cargo.opsgroup)
|
if cargo then --and self:CanCargo(cargo.opsgroup)
|
||||||
table.insert(self.cargos, cargo)
|
table.insert(self.cargos, cargo)
|
||||||
@ -149,6 +158,22 @@ function OPSTRANSPORT:New(GroupSet, Pickupzone, Deployzone)
|
|||||||
text=text..string.format("\nTOTAL: Ncargo=%d, Weight=%.1f kg", #self.cargos, Weight)
|
text=text..string.format("\nTOTAL: Ncargo=%d, Weight=%.1f kg", #self.cargos, Weight)
|
||||||
self:I(self.lid..text)
|
self:I(self.lid..text)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
-- FMS start state is PLANNED.
|
||||||
|
self:SetStartState(OPSTRANSPORT.Status.PLANNED)
|
||||||
|
|
||||||
|
-- PLANNED --> SCHEDULED --> EXECUTING --> DELIVERED
|
||||||
|
self:AddTransition("*", "Planned", OPSTRANSPORT.Status.PLANNED) -- Cargo transport was planned.
|
||||||
|
self:AddTransition(OPSTRANSPORT.Status.PLANNED, "Scheduled", OPSTRANSPORT.Status.SCHEDULED) -- Cargo is queued at at least one carrier.
|
||||||
|
self:AddTransition(OPSTRANSPORT.Status.SCHEDULED, "Executing", OPSTRANSPORT.Status.EXECUTING) -- Cargo is being transported.
|
||||||
|
self:AddTransition(OPSTRANSPORT.Status.EXECUTING, "Delivered", OPSTRANSPORT.Status.DELIVERED) -- Cargo was delivered.
|
||||||
|
|
||||||
|
self:AddTransition("*", "Status", "*")
|
||||||
|
self:AddTransition("*", "Stop", "*")
|
||||||
|
|
||||||
|
-- Call status update
|
||||||
|
self:__Status(-1)
|
||||||
|
|
||||||
return self
|
return self
|
||||||
end
|
end
|
||||||
@ -157,7 +182,7 @@ end
|
|||||||
-- User Functions
|
-- User Functions
|
||||||
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
--- Create a new OPSTRANSPORT class object.
|
--- Set embark zone.
|
||||||
-- @param #OPSTRANSPORT self
|
-- @param #OPSTRANSPORT self
|
||||||
-- @param Core.Zone#ZONE EmbarkZone Zone where the troops are embarked.
|
-- @param Core.Zone#ZONE EmbarkZone Zone where the troops are embarked.
|
||||||
-- @return #OPSTRANSPORT self
|
-- @return #OPSTRANSPORT self
|
||||||
@ -166,6 +191,42 @@ function OPSTRANSPORT:SetEmbarkZone(EmbarkZone)
|
|||||||
return self
|
return self
|
||||||
end
|
end
|
||||||
|
|
||||||
|
--- Add a carrier assigned for this transport.
|
||||||
|
-- @param #OPSTRANSPORT self
|
||||||
|
-- @param Ops.OpsGroup#OPSGROUP CarrierGroup Carrier OPSGROUP.
|
||||||
|
-- @return #OPSTRANSPORT self
|
||||||
|
function OPSTRANSPORT:_AddCarrier(CarrierGroup)
|
||||||
|
|
||||||
|
self:SetCarrierTransportStatus(CarrierGroup, OPSTRANSPORT.Status.SCHEDULED)
|
||||||
|
|
||||||
|
self:Scheduled()
|
||||||
|
|
||||||
|
table.insert(self.carriers, CarrierGroup)
|
||||||
|
|
||||||
|
return self
|
||||||
|
end
|
||||||
|
|
||||||
|
--- Add a carrier assigned for this transport.
|
||||||
|
-- @param #OPSTRANSPORT self
|
||||||
|
-- @param Ops.OpsGroup#OPSGROUP CarrierGroup Carrier OPSGROUP.
|
||||||
|
-- @param #string Status Carrier Status.
|
||||||
|
-- @return #OPSTRANSPORT self
|
||||||
|
function OPSTRANSPORT:SetCarrierTransportStatus(CarrierGroup, Status)
|
||||||
|
|
||||||
|
self.carrierTransportStatus[CarrierGroup.groupname]=Status
|
||||||
|
|
||||||
|
return self
|
||||||
|
end
|
||||||
|
|
||||||
|
--- Get carrier transport status.
|
||||||
|
-- @param #OPSTRANSPORT self
|
||||||
|
-- @param Ops.OpsGroup#OPSGROUP CarrierGroup Carrier OPSGROUP.
|
||||||
|
-- @return #string Carrier status.
|
||||||
|
function OPSTRANSPORT:GetCarrierTransportStatus(CarrierGroup)
|
||||||
|
return self.carrierTransportStatus[CarrierGroup.groupname]
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--- Create a cargo group data structure.
|
--- Create a cargo group data structure.
|
||||||
-- @param #OPSTRANSPORT self
|
-- @param #OPSTRANSPORT self
|
||||||
@ -207,3 +268,113 @@ function OPSTRANSPORT:_CreateCargoGroupData(group, Pickupzone, Deployzone)
|
|||||||
|
|
||||||
return cargo
|
return cargo
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
-- Status Update
|
||||||
|
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
--- On after "Status" event.
|
||||||
|
-- @param #OPSTRANSPORT self
|
||||||
|
-- @param #string From From state.
|
||||||
|
-- @param #string Event Event.
|
||||||
|
-- @param #string To To state.
|
||||||
|
function OPSTRANSPORT:onafterStatus(From, Event, To)
|
||||||
|
|
||||||
|
local fsmstate=self:GetState()
|
||||||
|
|
||||||
|
local text=string.format("State=%s", fsmstate)
|
||||||
|
|
||||||
|
for _,_cargo in pairs(self.cargos) do
|
||||||
|
local cargo=_cargo --Ops.OpsGroup#OPSGROUP.CargoGroup
|
||||||
|
end
|
||||||
|
|
||||||
|
for _,_carrier in pairs(self.carriers) do
|
||||||
|
local carrier=_carrier
|
||||||
|
end
|
||||||
|
|
||||||
|
self:I(self.lid..text)
|
||||||
|
|
||||||
|
-- Check if all cargo was delivered (or is dead).
|
||||||
|
self:_CheckDelivered()
|
||||||
|
|
||||||
|
self:__Status(-30)
|
||||||
|
end
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
-- FSM Event Functions
|
||||||
|
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
--- On after "Planned" event.
|
||||||
|
-- @param #OPSTRANSPORT self
|
||||||
|
-- @param #string From From state.
|
||||||
|
-- @param #string Event Event.
|
||||||
|
-- @param #string To To state.
|
||||||
|
function OPSTRANSPORT:onafterPlanned(From, Event, To)
|
||||||
|
self:I(self.lid..string.format("New status %s", OPSTRANSPORT.Status.PLANNED))
|
||||||
|
end
|
||||||
|
|
||||||
|
--- On after "Scheduled" event.
|
||||||
|
-- @param #OPSTRANSPORT self
|
||||||
|
-- @param #string From From state.
|
||||||
|
-- @param #string Event Event.
|
||||||
|
-- @param #string To To state.
|
||||||
|
function OPSTRANSPORT:onafterScheduled(From, Event, To)
|
||||||
|
self:I(self.lid..string.format("New status %s", OPSTRANSPORT.Status.SCHEDULED))
|
||||||
|
end
|
||||||
|
|
||||||
|
--- On after "Executing" event.
|
||||||
|
-- @param #OPSTRANSPORT self
|
||||||
|
-- @param #string From From state.
|
||||||
|
-- @param #string Event Event.
|
||||||
|
-- @param #string To To state.
|
||||||
|
function OPSTRANSPORT:onafterExecuting(From, Event, To)
|
||||||
|
self:I(self.lid..string.format("New status %s", OPSTRANSPORT.Status.EXECUTING))
|
||||||
|
end
|
||||||
|
|
||||||
|
--- On after "Delivered" event.
|
||||||
|
-- @param #OPSTRANSPORT self
|
||||||
|
-- @param #string From From state.
|
||||||
|
-- @param #string Event Event.
|
||||||
|
-- @param #string To To state.
|
||||||
|
function OPSTRANSPORT:onafterDelivered(From, Event, To)
|
||||||
|
self:I(self.lid..string.format("New status %s", OPSTRANSPORT.Status.DELIVERED))
|
||||||
|
|
||||||
|
-- TODO: Inform all assigned carriers that cargo was delivered. They can have this in the queue or are currently processing this transport.
|
||||||
|
|
||||||
|
for _,_carrier in pairs(self.carriers) do
|
||||||
|
local carrier=_carrier --Ops.OpsGroup#OPSGROUP
|
||||||
|
if self:GetCarrierTransportStatus(carrier)~=OPSTRANSPORT.Status.DELIVERED then
|
||||||
|
carrier:Delivered(self)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
-- Misc Functions
|
||||||
|
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
|
--- Check if all cargo of this transport assignment was delivered.
|
||||||
|
-- @param #OPSTRANSPORT self
|
||||||
|
function OPSTRANSPORT:_CheckDelivered()
|
||||||
|
|
||||||
|
local done=true
|
||||||
|
for _,_cargo in pairs(self.cargos) do
|
||||||
|
local cargo=_cargo --Ops.OpsGroup#OPSGROUP.CargoGroup
|
||||||
|
|
||||||
|
if cargo.delivered then
|
||||||
|
-- This one is delivered.
|
||||||
|
elseif cargo.opsgroup==nil or cargo.opsgroup:IsDead() or cargo.opsgroup:IsStopped() then
|
||||||
|
-- This one is dead.
|
||||||
|
else
|
||||||
|
done=false --Someone is not done!
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
if done then
|
||||||
|
self:Delivered()
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user