9c525cf9
 
  gaofengduan
 
add car smithy
 | 
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 
 | 
  local ipairs = ipairs
  local table = table
  local math = math
  local redisproxy = redisproxy
  local MsgPack = MsgPack
  
  local _M = {}
  
  function _M.makePotionRpc( agent, data )
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local potionId = msg.id
  	local count = msg.count
  	if count < 1 then return 0 end
  	local potionBag = role:getProperty("potionBag")
  	local potionLv = role.dinerData:getProperty("dishTree"):getv(potionId, 0)
  	if potionLv < 1 then return 1 end
  
  	local potionSet = csvdb["adv_potionCsv"][potionId]
  	if not potionSet then return 2 end
  
  	local potionData = potionSet[potionLv]
  	if not potionData then return 3 end
  
  	local own = potionBag[potionId] or 0
  	if own+count > potionData.limit then
  		return 4
  	end
  
  	local cost = potionData.material:toNumMap()
 
 | 
e668f4d0
 
  gaofengduan
 
fix cost
 | 
31
32 
 | 
  	for k, n in pairs(cost) do
  		cost[k] = n * count
 
 | 
9c525cf9
 
  gaofengduan
 
add car smithy
 | 
33
34
35
36
37 
 | 
  	end
  	if not role:checkItemEnough(cost) then
  		return 5
  	end
  
 
 | 
3133cb76
 
  zhouhaihai
 
日志
 | 
38 
 | 
  	role:costItems(cost, {log = {desc = "makePotion", int1 = potionId, int2 = count}})
 
 | 
9c525cf9
 
  gaofengduan
 
add car smithy
 | 
39
40 
 | 
  	potionBag[potionId] = own + count
  	role:updateProperty({field = "potionBag", value = potionBag})
 
 | 
53e8037e
 
  zhouhaihai
 
任务
 | 
41 
 | 
  	role:checkTaskEnter("PotionMake", {count = count, id = potionId})
 
 | 
3133cb76
 
  zhouhaihai
 
日志
 | 
42
43 
 | 
  
  	role:log("role_action", {desc = "makePotion", int1 = potionId, int2 = count})
 
 | 
9c525cf9
 
  gaofengduan
 
add car smithy
 | 
44
45
46
47
48
49
50
51
52 
 | 
  	SendPacket(actionCodes.Car_makePotionRpc, MsgPack.pack({potionBag = potionBag}))
  	return true
  end
  
  function _M.equipUpRpc( agent, data )
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local id = msg.id
  	local count = msg.count
 
 | 
056c01a0
 
  zhouhaihai
 
简化装备
 | 
53 
 | 
  
 
 | 
9c525cf9
 
  gaofengduan
 
add car smithy
 | 
54
55
56
57
58
59
60
61 
 | 
  	local typ = math.floor((id-7000)/100)
  	local lv = (id-7000)%100
  
  	local dataSet = csvdb["equipCsv"][typ]
  	if not dataSet then return 1 end
  	local equipData = dataSet[lv]
  	if not equipData then return 21 end
  	if equipData.merge < 1 then return 22 end
 
 | 
056c01a0
 
  zhouhaihai
 
简化装备
 | 
62 
 | 
  
 
 | 
9c525cf9
 
  gaofengduan
 
add car smithy
 | 
63
64
65
66
67
68
69
70 
 | 
  	local maxLv = 3
  	local nextLv = lv+1
  	if nextLv%10 > maxLv then
  		nextLv = nextLv+10-maxLv
  	end
  	local nextEquip = dataSet[nextLv]
  	if not nextEquip then return 23 end
  
 
 | 
912f7d2c
 
  zhouhaihai
 
bug
 | 
71 
 | 
  	local limit = csvdb["itemCsv"][nextEquip.id].limit ~= 0 and csvdb["itemCsv"][nextEquip.id].limit or math.huge
 
 | 
056c01a0
 
  zhouhaihai
 
简化装备
 | 
72
73 
 | 
  
  	if math.illegalNum(count, 1, limit)  then return 0 end
 
 | 
43cc5f51
 
  gaofengduan
 
调整 equip 数据结构
 | 
74
75 
 | 
  
  	local own = role:getEquipCount(typ,lv)
 
 | 
056c01a0
 
  zhouhaihai
 
简化装备
 | 
76 
 | 
  	local costCount = equipData.merge * count
 
 | 
43cc5f51
 
  gaofengduan
 
调整 equip 数据结构
 | 
77 
 | 
  	if own < costCount then
 
 | 
9c525cf9
 
  gaofengduan
 
add car smithy
 | 
78
79
80
81 
 | 
  		return 3
  	end
  
  	local cost = equipData.cost:toNumMap()
 
 | 
e668f4d0
 
  gaofengduan
 
fix cost
 | 
82
83 
 | 
  	for k, n in pairs(cost) do
  		cost[k] = n * count
 
 | 
9c525cf9
 
  gaofengduan
 
add car smithy
 | 
84
85
86
87
88 
 | 
  	end
  	if not role:checkItemEnough(cost) then
  		return 4
  	end
  
 
 | 
3133cb76
 
  zhouhaihai
 
日志
 | 
89
90
91 
 | 
  	role:costItems(cost, {log = {desc = "equipUp", int1 = id, int2 = count}})
  	role:addEquip(typ, lv, -costCount, {log = {desc = "equipUp"}})
  	role:addEquip(typ, nextLv ,count, {log = {desc = "equipUp"}})
 
 | 
f60b89b1
 
  zhouhaihai
 
奖励副本
 | 
92 
 | 
  	role:checkTaskEnter("EquipUp", {count = count})
 
 | 
3133cb76
 
  zhouhaihai
 
日志
 | 
93
94
95 
 | 
  
  	role:log("role_action", {desc = "equipUp", int1 = id, int2 = count})
  
 
 | 
9c525cf9
 
  gaofengduan
 
add car smithy
 | 
96
97
98
99 
 | 
  	SendPacket(actionCodes.Car_equipUpRpc, '')
  	return true
  end
  
 
 | 
fb321075
 
  gaofengduan
 
add rune up
 | 
100
101
102
103
104
105 
 | 
  function _M.runeUpRpc( agent, data )
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local uid = msg.uid
  	local ownRune = role.runeBag[uid]
  	if not ownRune then return 1 end
 
 | 
f52efe51
 
  zhouhaihai
 
符文升级
 | 
106 
 | 
  
 
 | 
fb321075
 
  gaofengduan
 
add rune up
 | 
107
108
109
110
111
112
113
114
115
116 
 | 
  
  	local typ = ownRune:getProperty("type")
  	local id = ownRune:getProperty("id")
  	local level = ownRune:getProperty("level")
  
  	local runeSet = csvdb["runeCsv"][typ]
  	if not runeSet then return 4 end
  	local runeData = runeSet[id]
  	if not runeData then return 5 end
  
 
 | 
3f50410e
 
  zhouhaihai
 
判断错误
 | 
117
118 
 | 
  	local maxLv = #csvdb["rune_buildCsv"]
  	if level >= maxLv then return 6 end
 
 | 
04c7448f
 
  gaofengduan
 
fix rune up
 | 
119 
 | 
  	local lvData = csvdb["rune_buildCsv"][level]
 
 | 
fb321075
 
  gaofengduan
 
add rune up
 | 
120
121
122
123
124 
 | 
  	local cost = lvData.cost:toNumMap()
  	if not role:checkItemEnough(cost) then
  		return 7
  	end
  
 
 | 
3133cb76
 
  zhouhaihai
 
日志
 | 
125 
 | 
  	role:costItems(cost, {log = {desc = "runeUp", int1 = uid, int2 = level}})
 
 | 
fb321075
 
  gaofengduan
 
add rune up
 | 
126 
 | 
  	ownRune:updateProperty({field = "level",value = level+1})
 
 | 
53e8037e
 
  zhouhaihai
 
任务
 | 
127 
 | 
  	role:checkTaskEnter("RuneUp")
 
 | 
3133cb76
 
  zhouhaihai
 
日志
 | 
128 
 | 
  
 
 | 
f52efe51
 
  zhouhaihai
 
符文升级
 | 
129
130
131
132
133
134 
 | 
  	if ownRune:getProperty("refer") ~= 0 then
  		local hero = role.heros[ownRune:getProperty("refer")]
  		if hero then
  			hero:updateProperty({field = "battleV", value = hero:getBattleValue()})
  		end
  	end
 
 | 
3133cb76
 
  zhouhaihai
 
日志
 | 
135
136 
 | 
  	ownRune:log({desc = "runeUp", int1 = level + 1})
  
 
 | 
fb321075
 
  gaofengduan
 
add rune up
 | 
137
138
139
140 
 | 
  	SendPacket(actionCodes.Car_runeUpRpc, '')
  	return true
  end
  
 
 | 
912f7d2c
 
  zhouhaihai
 
bug
 | 
141 
 | 
  function _M.saleEquipRpc(agent, data )
 
 | 
056c01a0
 
  zhouhaihai
 
简化装备
 | 
142
143 
 | 
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
 
 | 
9dd0add2
 
  zhouhaihai
 
批量分解装备
 | 
144
145
146 
 | 
  	local backs = msg.backs
  	if not backs then return end
  	for id, count in pairs(backs) do
 
 | 
2445248d
 
  zhouhaihai
 
去掉热门料理
 | 
147 
 | 
  		if not csvdb["itemCsv"][id] then return end
 
 | 
9dd0add2
 
  zhouhaihai
 
批量分解装备
 | 
148
149
150
151
152
153 
 | 
  		local typ = math.floor((id-7000)/100)
  		local lv = (id-7000)%100
  		local own = role:getEquipCount(typ,lv)
  		if math.illegalNum(count, 1, own)  then return end
  	end
  	local reward = {}
 
 | 
03a6166a
 
  zhouhaihai
 
餐厅优化
 | 
154 
 | 
  	local allCount = 0
 
 | 
9dd0add2
 
  zhouhaihai
 
批量分解装备
 | 
155 
 | 
  	for id, count in pairs(backs) do
 
 | 
03a6166a
 
  zhouhaihai
 
餐厅优化
 | 
156 
 | 
  		allCount = allCount + count
 
 | 
2445248d
 
  zhouhaihai
 
去掉热门料理
 | 
157 
 | 
  		local itemData = csvdb["itemCsv"][id]
 
 | 
9dd0add2
 
  zhouhaihai
 
批量分解装备
 | 
158
159 
 | 
  		local typ = math.floor((id-7000)/100)
  		local lv = (id-7000)%100
 
 | 
3133cb76
 
  zhouhaihai
 
日志
 | 
160 
 | 
  		role:addEquip(typ, lv, -count, {log = {desc = "saleEquip"}}) -- 删掉装备
 
 | 
9dd0add2
 
  zhouhaihai
 
批量分解装备
 | 
161
162
163
164
165 
 | 
  		-- 发奖励
  		local one = itemData.sell_effect:toNumMap()
  		for k ,v in pairs(one) do
  			reward[k] = (reward[k] or 0) + v * count 
  		end
 
 | 
056c01a0
 
  zhouhaihai
 
简化装备
 | 
166 
 | 
  	end
 
 | 
03a6166a
 
  zhouhaihai
 
餐厅优化
 | 
167 
 | 
  	role:checkTaskEnter("SaleEquip", {count = allCount})
 
 | 
3133cb76
 
  zhouhaihai
 
日志
 | 
168
169
170
171 
 | 
  	reward = role:award(reward, {log = {desc = "saleEquip"}})
  
  	role:log("role_action", {desc = "saleEquip", int1 = allCount})
  
 
 | 
056c01a0
 
  zhouhaihai
 
简化装备
 | 
172
173
174
175 
 | 
  	SendPacket(actionCodes.Car_saleEquipRpc, MsgPack.pack({reward = reward}))
  	return true
  end
  
 
 | 
497f9a67
 
  zhouhaihai
 
卖零件
 | 
176
177
178
179
180
181
182 
 | 
  function _M.saleRuneRpc(agent, data )
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local backs = msg.backs
  	if not backs then return end
  
  	local reward = {}
 
 | 
03a6166a
 
  zhouhaihai
 
餐厅优化
 | 
183 
 | 
  	local count = 0
 
 | 
2445248d
 
  zhouhaihai
 
去掉热门料理
 | 
184 
 | 
  	for _, uid in pairs(backs) do
 
 | 
03a6166a
 
  zhouhaihai
 
餐厅优化
 | 
185 
 | 
  		count = count + 1
 
 | 
497f9a67
 
  zhouhaihai
 
卖零件
 | 
186
187
188 
 | 
  		local rune = role.runeBag[uid]
  		if not rune then return end
  		if rune:getProperty("refer") ~= 0 then return end
 
 | 
2445248d
 
  zhouhaihai
 
去掉热门料理
 | 
189 
 | 
  		local itemData = csvdb["itemCsv"][rune:getProperty("id")]
 
 | 
497f9a67
 
  zhouhaihai
 
卖零件
 | 
190
191
192
193
194
195
196 
 | 
  		if not itemData then return end
  		local one = itemData.sell_effect:toNumMap()
  		for k ,v in pairs(one) do
  			reward[k] = (reward[k] or 0) + v
  		end
  	end
  
 
 | 
3133cb76
 
  zhouhaihai
 
日志
 | 
197 
 | 
  	role:delRunes(backs, {log = {desc = "saleRune"}})
 
 | 
03a6166a
 
  zhouhaihai
 
餐厅优化
 | 
198 
 | 
  	role:checkTaskEnter("DecoRune", {count = count})
 
 | 
3133cb76
 
  zhouhaihai
 
日志
 | 
199
200 
 | 
  	reward = role:award(reward, {log = {desc = "saleRune"}})
  	
 
 | 
497f9a67
 
  zhouhaihai
 
卖零件
 | 
201
202
203
204 
 | 
  	SendPacket(actionCodes.Car_saleRuneRpc, MsgPack.pack({reward = reward}))
  	return true
  end
  
 
 | 
9c525cf9
 
  gaofengduan
 
add car smithy
 | 
205 
 | 
  return _M
 
 |