forked from JumpyDuke/UniversalProcessKit_FS15
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathUPK_PalletTrigger.lua
209 lines (178 loc) · 6.38 KB
/
UPK_PalletTrigger.lua
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
-- by mor2000
--------------------
-- PalletTrigger
local UPK_PalletTrigger_mt = ClassUPK(UPK_PalletTrigger,UniversalProcessKit)
InitObjectClass(UPK_PalletTrigger, "UPK_PalletTrigger")
UniversalProcessKit.addModule("pallettrigger",UPK_PalletTrigger)
function UPK_PalletTrigger:new(nodeId, parent)
printFn('UPK_PalletTrigger:new(',nodeId,', ',parent,')')
local self = UniversalProcessKit:new(nodeId, parent, UPK_PalletTrigger_mt)
registerObjectClassName(self, "UPK_PalletTrigger")
-- acceptedFillTypes
self.acceptedFillTypes = {}
local acceptedFillTypesArr = getArrayFromUserAttribute(nodeId, "acceptedFillTypes")
for _,fillType in pairs(UniversalProcessKit.fillTypeNameToInt(acceptedFillTypesArr)) do
self:printInfo('accepting '..tostring(UniversalProcessKit.fillTypeIntToName[fillType])..' ('..tostring(fillType)..')')
self.acceptedFillTypes[fillType] = true
--self.fillTypesConversionMatrix = self.fillTypesConversionMatrix + FillTypesConversionMatrix:new(fillType)
end
self.revenuePerLiter = getNumberFromUserAttribute(nodeId, "revenuePerLiter", nil)
self.revenuesPerLiter = {}
local revenuesPerLiterArr = getArrayFromUserAttribute(nodeId, "revenuesPerLiter")
for i=1,#revenuesPerLiterArr,2 do
local revenue=tonumber(revenuesPerLiterArr[i])
local fillType=unpack(UniversalProcessKit.fillTypeNameToInt(revenuesPerLiterArr[i+1]))
if revenue~=nil and fillType~=nil then
self.revenuesPerLiter[fillType] = revenue
end
end
local revenues_mt = {
__index=function(t,k)
return self.revenuePerLiter
end
}
setmetatable(self.revenuesPerLiter,revenues_mt)
self.ignorePallets = getNumberFromUserAttribute(nodeId, "ignorePallets", 0)
self.useFirstPallet = getBoolFromUserAttribute(nodeId, "useFirstPallet", true)
self.delay = getNumberFromUserAttribute(nodeId, "delay", 0.1, 0)*1000
self.allowPallets = true
self.allowWalker = false
self.allowedVehicles={}
self.palletsInTrigger = {}
self.nrPalletsInTrigger = 0
self.mode = getStringFromUserAttribute(nodeId, "mode", "sell")
self.revenueMultiplier = getVectorFromUserAttribute(nodeId, "revenueMultiplier", "1 0.5 0.25")
self.statName=getStringFromUserAttribute(nodeId, "statName")
local validStatName=false
if self.statName~=nil then
for _,v in pairs(FinanceStats.statNames) do
if self.statName==v then
validStatName=true
break
end
end
end
if not validStatName then
self.statName="other"
end
self.palletsInLine = {}
self.runningUpdate = false
self:addTrigger()
self:printFn('UPK_PalletTrigger:new done')
return self
end
function UPK_PalletTrigger:delete()
self:printFn('UPK_PalletTrigger:delete()')
UniversalProcessKitListener.removeUpdateable(self)
UPK_PalletTrigger:superClass().delete(self)
end
function UPK_PalletTrigger:postLoad()
self:printFn('UPK_PalletTrigger:postLoad()')
UPK_PalletTrigger:superClass().postLoad(self)
self:triggerUpdate(false,false)
end
function UPK_PalletTrigger:triggerUpdate(vehicle,isInTrigger)
self:printFn('UPK_PalletTrigger:triggerUpdate(',vehicle,', ',isInTrigger,')')
if self.isEnabled then
self:printAll('vehicle is: ',vehicle)
if type(vehicle)=="table" and vehicle.isPallet then
self:printAll('isInTrigger is: ',isInTrigger)
if isInTrigger then
if not self.palletsInTrigger[vehicle] then
local fillType = vehicle:getFillType()
self:printAll('fillType is: ',fillType)
self:printAll('self.acceptedFillTypes[fillType] is: ',self.acceptedFillTypes[fillType])
if self.acceptedFillTypes[fillType] then
self.palletsInTrigger[vehicle]=true
table.insert(self.palletsInLine,vehicle)
self.nrPalletsInTrigger = self.nrPalletsInTrigger +1
self:printAll('self.nrPalletsInTrigger is: ',self.nrPalletsInTrigger)
if self.nrPalletsInTrigger>self.ignorePallets then
if not self.runningUpdate then
self.runningUpdate = true
self.dtsum = 0
UniversalProcessKitListener.addUpdateable(self)
end
end
else
self:printInfo('This kind of pallet is not accepted')
end
end
else
self.palletsInTrigger[vehicle]=nil
self.nrPalletsInTrigger = self.nrPalletsInTrigger -1
end
end
end
end
function UPK_PalletTrigger:update(dt)
self:printAll('UPK_PalletTrigger:update(',dt,')')
self.dtsum = self.dtsum + dt
if self.dtsum>self.delay then
self.dtsum = self.dtsum-self.delay
if #self.palletsInLine>self.ignorePallets then
local palletIndex = 1
if not self.useFirstPallet then
palletIndex = #self.palletsInLine
end
local pallet = self.palletsInLine[palletIndex]
if type(pallet)=="table" and self.palletsInTrigger[pallet] then
if self.mode=="dissolve" then
local fillLevel = pallet:getFillLevel()
local fillType = pallet:getFillType()
local added = self:addFillLevel(fillLevel, fillType)
if added > 0 then
self.palletsInTrigger[pallet]=nil
table.remove(self.palletsInLine,palletIndex)
self:triggerUpdate(pallet,false)
if self.isServer then
pallet:delete()
end
end
elseif self.mode=="delete" then
self.palletsInTrigger[pallet]=nil
table.remove(self.palletsInLine,palletIndex)
self:triggerUpdate(pallet,false)
if self.isServer then
pallet:delete()
end
elseif self.mode=="save" then
-- nothing yet
else
self:printAll('want to sell pallet for ',pallet:getValue())
self.palletsInTrigger[pallet]=nil
self.nrPalletsInTrigger = self.nrPalletsInTrigger -1
local fillType = pallet:getFillType()
local difficulty = g_currentMission.missionStats.difficulty
local revenue = 0
if self.revenuesPerLiter[fillType]~=nil then
revenue = self.revenuesPerLiter[fillType] * pallet.fillLevel * self.revenueMultiplier[difficulty]
else
revenue = pallet:getValue() * self.revenueMultiplier[difficulty]
end
if revenue~=0 then
g_currentMission:addSharedMoney(revenue, self.statName)
end
self.palletsInTrigger[pallet]=nil
table.remove(self.palletsInLine,palletIndex)
self:triggerUpdate(pallet,false)
if self.isServer then
pallet:delete()
end
end
else
self.palletsInTrigger[pallet]=nil
table.remove(self.palletsInLine,palletIndex)
self:update(0)
end
end
end
if #self.palletsInLine<=self.ignorePallets then
self.runningUpdate = false
UniversalProcessKitListener.removeUpdateable(self)
else
if self.dtsum>self.delay then
self:update(0)
end
end
end