mirror of
https://github.com/ComfyFactory/ComfyFactorio.git
synced 2025-01-24 03:47:58 +02:00
commit
6df0069a18
@ -37,7 +37,7 @@ global_pool_amount=Amount of XP that is stored inside the global xp pool.\nRaw V
|
|||||||
amount_harvested=Amount of trees/rocks harvested.
|
amount_harvested=Amount of trees/rocks harvested.
|
||||||
biters_killed=Amount of biters killed.
|
biters_killed=Amount of biters killed.
|
||||||
land_mine_placed=Amount of land-mines that can be built.
|
land_mine_placed=Amount of land-mines that can be built.
|
||||||
chest_placed=Amount of chests that can be placed near train.
|
chest_placed=Amount of chests that can be placed near train.\nLimit is per cargo-wagon.
|
||||||
flamethrowers_placed=Amount of flamethrower-turrets that can be built.
|
flamethrowers_placed=Amount of flamethrower-turrets that can be built.
|
||||||
train_upgrades=Amount of train upgrades.
|
train_upgrades=Amount of train upgrades.
|
||||||
info_tooltip=Shows statistics!
|
info_tooltip=Shows statistics!
|
||||||
@ -86,12 +86,10 @@ purchase_pickaxe=Upgrade the teams Pickaxe to tier: __1__
|
|||||||
sold_out=Sold out!
|
sold_out=Sold out!
|
||||||
flamethrower_turret=Upgrades the amount of flamethrowers that can be placed.
|
flamethrower_turret=Upgrades the amount of flamethrowers that can be placed.
|
||||||
land_mine=Upgrades the amount of landmines that can be placed.
|
land_mine=Upgrades the amount of landmines that can be placed.
|
||||||
skill_reset=For when you have picked the wrong RPG path and want to start over.\nPoints will be kept.
|
|
||||||
car=Portable Car Surface\nCan be killed easily.
|
car=Portable Car Surface\nCan be killed easily.
|
||||||
tank=Portable Tank Surface\nChonk tank, can resist heavy damage.
|
tank=Portable Tank Surface\nChonk tank, can resist heavy damage.
|
||||||
tank_cannon_na=Tank Cannon\nAvailable after wave 650.
|
tank_cannon_na=Tank Cannon\nAvailable after wave __1__.
|
||||||
tank_machine_gun_na=Tank Machine Gun\nAvailable after wave 400.
|
vehicle_machine_gun_na=Car Machine Gun\nAvailable after wave __1__.
|
||||||
vehicle_machine_gun_na=Car Machine Gun\nAvailable after wave 200.
|
|
||||||
|
|
||||||
[main]
|
[main]
|
||||||
death_message_1=__1__ should have watched where they walked!
|
death_message_1=__1__ should have watched where they walked!
|
||||||
|
@ -85,12 +85,10 @@ purchase_pickaxe=将团队镐升级到等级:__1__
|
|||||||
sold_out=售罄!
|
sold_out=售罄!
|
||||||
flamethrower_turret=升级可以放置的火焰喷射器的数量.
|
flamethrower_turret=升级可以放置的火焰喷射器的数量.
|
||||||
land_mine=升级可以放置的地雷数量.
|
land_mine=升级可以放置的地雷数量.
|
||||||
skill_reset=重置玩家技能点.\n将保留积分.
|
|
||||||
car=便携汽车操作\n可以更容易打死.
|
car=便携汽车操作\n可以更容易打死.
|
||||||
tank=便携坦克操作\n大坦克, 可以抵抗严重伤害.
|
tank=便携坦克操作\n大坦克, 可以抵抗严重伤害.
|
||||||
tank_cannon_na=坦克炮\n在650波之后可用.
|
tank_cannon_na=坦克炮\n在__1__波之后可用.
|
||||||
tank_machine_gun_na=坦克机枪\n在4000波之后可用.
|
vehicle_machine_gun_na=汽车机枪\n在__1__波后可用.
|
||||||
vehicle_machine_gun_na=汽车机枪\n在200波后可用.
|
|
||||||
|
|
||||||
[main]
|
[main]
|
||||||
death_message_1=__1__ 应该看着他们走的地方!
|
death_message_1=__1__ 应该看着他们走的地方!
|
||||||
|
@ -48,7 +48,7 @@ local function enemy_weapon_damage()
|
|||||||
|
|
||||||
local data = {
|
local data = {
|
||||||
['artillery-shell'] = 0.05,
|
['artillery-shell'] = 0.05,
|
||||||
['biological'] = 0.08,
|
['biological'] = 0.06,
|
||||||
['bullet'] = 0.08,
|
['bullet'] = 0.08,
|
||||||
['capsule'] = 0.08,
|
['capsule'] = 0.08,
|
||||||
['electric'] = 0.08,
|
['electric'] = 0.08,
|
||||||
|
@ -2,6 +2,7 @@ local Color = require 'utils.color_presets'
|
|||||||
local Task = require 'utils.task'
|
local Task = require 'utils.task'
|
||||||
local Server = require 'utils.server'
|
local Server = require 'utils.server'
|
||||||
local WPT = require 'maps.mountain_fortress_v3.table'
|
local WPT = require 'maps.mountain_fortress_v3.table'
|
||||||
|
local WD = require 'modules.wave_defense.table'
|
||||||
|
|
||||||
local mapkeeper = '[color=blue]Mapkeeper:[/color]'
|
local mapkeeper = '[color=blue]Mapkeeper:[/color]'
|
||||||
|
|
||||||
@ -121,6 +122,41 @@ commands.add_command(
|
|||||||
end
|
end
|
||||||
)
|
)
|
||||||
|
|
||||||
|
commands.add_command(
|
||||||
|
'disable_biters',
|
||||||
|
'Usable only for admins - sets the queue speed of this map!',
|
||||||
|
function(cmd)
|
||||||
|
local player = game.player
|
||||||
|
|
||||||
|
if not player and player.valid then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
if not player.admin then
|
||||||
|
player.print("[ERROR] You're not admin!", Color.fail)
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
local this = WPT.get()
|
||||||
|
local tbl = WD.get()
|
||||||
|
|
||||||
|
if not this.disable_biters_are_you_sure then
|
||||||
|
this.disable_biters_are_you_sure = true
|
||||||
|
player.print('[WARNING] This command will disable the wave_defense in-game, run this command again if you really want to do this!', Color.warning)
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
if not tbl.game_lost then
|
||||||
|
game.print(mapkeeper .. ' ' .. player.name .. ', has disabled the wave_defense module!', {r = 0.98, g = 0.66, b = 0.22})
|
||||||
|
tbl.game_lost = true
|
||||||
|
else
|
||||||
|
game.print(mapkeeper .. ' ' .. player.name .. ', has enabled the wave_defense module!', {r = 0.98, g = 0.66, b = 0.22})
|
||||||
|
tbl.game_lost = false
|
||||||
|
end
|
||||||
|
|
||||||
|
this.disable_biters_are_you_sure = nil
|
||||||
|
end
|
||||||
|
)
|
||||||
|
|
||||||
commands.add_command(
|
commands.add_command(
|
||||||
'get_queue_speed',
|
'get_queue_speed',
|
||||||
'Usable only for admins - gets the queue speed of this map!',
|
'Usable only for admins - gets the queue speed of this map!',
|
||||||
|
@ -78,7 +78,8 @@ local protect_types = {
|
|||||||
['fluid-wagon'] = true,
|
['fluid-wagon'] = true,
|
||||||
['locomotive'] = true,
|
['locomotive'] = true,
|
||||||
['reactor'] = true,
|
['reactor'] = true,
|
||||||
['spidertron'] = true
|
['spider-vehicle'] = true,
|
||||||
|
['car'] = true
|
||||||
}
|
}
|
||||||
|
|
||||||
local reset_game =
|
local reset_game =
|
||||||
@ -211,12 +212,19 @@ local function set_train_final_health(final_damage_amount)
|
|||||||
local locomotive_health = WPT.get('locomotive_health')
|
local locomotive_health = WPT.get('locomotive_health')
|
||||||
local locomotive_max_health = WPT.get('locomotive_max_health')
|
local locomotive_max_health = WPT.get('locomotive_max_health')
|
||||||
local poison_deployed = WPT.get('poison_deployed')
|
local poison_deployed = WPT.get('poison_deployed')
|
||||||
|
local robotics_deployed = WPT.get('robotics_deployed')
|
||||||
|
|
||||||
if locomotive_health <= 5000 then
|
if locomotive_health >= 4000 and locomotive_health <= 6000 then
|
||||||
if not poison_deployed then
|
if not poison_deployed then
|
||||||
for i = 1, 2, 1 do
|
local carriages = WPT.get('carriages')
|
||||||
Locomotive.enable_poison_defense()
|
|
||||||
|
if carriages then
|
||||||
|
for i = 1, #carriages do
|
||||||
|
local entity = carriages[i]
|
||||||
|
Locomotive.enable_poison_defense(entity.position)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local p = {
|
local p = {
|
||||||
position = locomotive.position
|
position = locomotive.position
|
||||||
}
|
}
|
||||||
@ -224,6 +232,25 @@ local function set_train_final_health(final_damage_amount)
|
|||||||
Alert.alert_all_players_location(p, msg)
|
Alert.alert_all_players_location(p, msg)
|
||||||
WPT.set().poison_deployed = true
|
WPT.set().poison_deployed = true
|
||||||
end
|
end
|
||||||
|
elseif locomotive_health >= 1500 and locomotive_health <= 3900 then
|
||||||
|
if not robotics_deployed then
|
||||||
|
local carriages = WPT.get('carriages')
|
||||||
|
|
||||||
|
if carriages then
|
||||||
|
for _ = 1, 10 do
|
||||||
|
for i = 1, #carriages do
|
||||||
|
local entity = carriages[i]
|
||||||
|
Locomotive.enable_robotic_defense(entity.position)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local p = {
|
||||||
|
position = locomotive.position
|
||||||
|
}
|
||||||
|
local msg = ({'entity.train_taking_damage'})
|
||||||
|
Alert.alert_all_players_location(p, msg)
|
||||||
|
WPT.set().robotics_deployed = true
|
||||||
|
end
|
||||||
elseif locomotive_health >= locomotive_max_health then
|
elseif locomotive_health >= locomotive_max_health then
|
||||||
WPT.set().poison_deployed = false
|
WPT.set().poison_deployed = false
|
||||||
end
|
end
|
||||||
@ -283,20 +310,22 @@ local function protect_entities(event)
|
|||||||
if (event.cause and event.cause.valid) then
|
if (event.cause and event.cause.valid) then
|
||||||
if event.cause.force.index == 2 then
|
if event.cause.force.index == 2 then
|
||||||
if units and units[entity.unit_number] then
|
if units and units[entity.unit_number] then
|
||||||
return set_train_final_health(dmg)
|
set_train_final_health(dmg)
|
||||||
|
return
|
||||||
|
else
|
||||||
|
entity.health = entity.health - dmg
|
||||||
|
return
|
||||||
end
|
end
|
||||||
elseif event.cause.force.index == 2 then
|
|
||||||
return
|
|
||||||
else
|
|
||||||
entity.health = entity.health + dmg
|
|
||||||
end
|
end
|
||||||
elseif not (event.cause and event.cause.valid) then
|
elseif not (event.cause and event.cause.valid) then
|
||||||
if event.force.index == 2 then
|
if event.force and event.force.index == 2 then
|
||||||
if units and units[entity.unit_number] then
|
if units and units[entity.unit_number] then
|
||||||
return set_train_final_health(dmg)
|
set_train_final_health(dmg)
|
||||||
|
return
|
||||||
|
else
|
||||||
|
entity.health = entity.health - dmg
|
||||||
|
return
|
||||||
end
|
end
|
||||||
entity.health = entity.health - dmg
|
|
||||||
return
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -203,8 +203,10 @@ function Public.add_player_to_permission_group(player, group, forced)
|
|||||||
|
|
||||||
local gulag = game.permissions.get_group('gulag')
|
local gulag = game.permissions.get_group('gulag')
|
||||||
local tbl = gulag and gulag.players
|
local tbl = gulag and gulag.players
|
||||||
if tbl[player.index] then
|
for i = 1, #tbl do
|
||||||
return
|
if tbl[i].index == player.index then
|
||||||
|
return
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if player.admin then
|
if player.admin then
|
||||||
@ -236,7 +238,6 @@ function Public.add_player_to_permission_group(player, group, forced)
|
|||||||
locomotive_group.set_allows_action(defines.input_action.admin_action, false)
|
locomotive_group.set_allows_action(defines.input_action.admin_action, false)
|
||||||
locomotive_group.set_allows_action(defines.input_action.drop_item, false)
|
locomotive_group.set_allows_action(defines.input_action.drop_item, false)
|
||||||
locomotive_group.set_allows_action(defines.input_action.place_equipment, false)
|
locomotive_group.set_allows_action(defines.input_action.place_equipment, false)
|
||||||
locomotive_group.set_allows_action(defines.input_action.take_equipment, false)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
if not game.permissions.get_group('plebs') then
|
if not game.permissions.get_group('plebs') then
|
||||||
@ -258,7 +259,6 @@ function Public.add_player_to_permission_group(player, group, forced)
|
|||||||
not_trusted.set_allows_action(defines.input_action.admin_action, false)
|
not_trusted.set_allows_action(defines.input_action.admin_action, false)
|
||||||
not_trusted.set_allows_action(defines.input_action.drop_item, false)
|
not_trusted.set_allows_action(defines.input_action.drop_item, false)
|
||||||
not_trusted.set_allows_action(defines.input_action.place_equipment, false)
|
not_trusted.set_allows_action(defines.input_action.place_equipment, false)
|
||||||
not_trusted.set_allows_action(defines.input_action.take_equipment, false)
|
|
||||||
not_trusted.set_allows_action(defines.input_action.disconnect_rolling_stock, false)
|
not_trusted.set_allows_action(defines.input_action.disconnect_rolling_stock, false)
|
||||||
not_trusted.set_allows_action(defines.input_action.connect_rolling_stock, false)
|
not_trusted.set_allows_action(defines.input_action.connect_rolling_stock, false)
|
||||||
end
|
end
|
||||||
@ -487,7 +487,7 @@ local function validate_index()
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local function create_poison_cloud(position)
|
local function create_defense_system(position, name, target)
|
||||||
local active_surface_index = WPT.get('active_surface_index')
|
local active_surface_index = WPT.get('active_surface_index')
|
||||||
local surface = game.surfaces[active_surface_index]
|
local surface = game.surfaces[active_surface_index]
|
||||||
|
|
||||||
@ -498,41 +498,61 @@ local function create_poison_cloud(position)
|
|||||||
rad(random(359))
|
rad(random(359))
|
||||||
}
|
}
|
||||||
|
|
||||||
surface.create_entity({name = 'poison-cloud', position = {x = position.x, y = position.y}})
|
|
||||||
surface.create_entity(
|
surface.create_entity(
|
||||||
{
|
{
|
||||||
name = 'poison-cloud',
|
name = name,
|
||||||
|
position = {x = position.x, y = position.y},
|
||||||
|
target = target,
|
||||||
|
speed = 1.5,
|
||||||
|
force = 'player'
|
||||||
|
}
|
||||||
|
)
|
||||||
|
surface.create_entity(
|
||||||
|
{
|
||||||
|
name = name,
|
||||||
position = {
|
position = {
|
||||||
x = position.x + 12 * cos(random_angles[1]),
|
x = position.x + 12 * cos(random_angles[1]),
|
||||||
y = position.y + 12 * sin(random_angles[1])
|
y = position.y + 12 * sin(random_angles[1])
|
||||||
}
|
},
|
||||||
|
target = target,
|
||||||
|
speed = 1.5,
|
||||||
|
force = 'player'
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
surface.create_entity(
|
surface.create_entity(
|
||||||
{
|
{
|
||||||
name = 'poison-cloud',
|
name = name,
|
||||||
position = {
|
position = {
|
||||||
x = position.x + 12 * cos(random_angles[2]),
|
x = position.x + 12 * cos(random_angles[2]),
|
||||||
y = position.y + 12 * sin(random_angles[2])
|
y = position.y + 12 * sin(random_angles[2])
|
||||||
}
|
},
|
||||||
|
target = target,
|
||||||
|
speed = 1.5,
|
||||||
|
force = 'player'
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
surface.create_entity(
|
surface.create_entity(
|
||||||
{
|
{
|
||||||
name = 'poison-cloud',
|
name = name,
|
||||||
position = {
|
position = {
|
||||||
x = position.x + 12 * cos(random_angles[3]),
|
x = position.x + 12 * cos(random_angles[3]),
|
||||||
y = position.y + 12 * sin(random_angles[3])
|
y = position.y + 12 * sin(random_angles[3])
|
||||||
}
|
},
|
||||||
|
target = target,
|
||||||
|
speed = 1.5,
|
||||||
|
force = 'player'
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
surface.create_entity(
|
surface.create_entity(
|
||||||
{
|
{
|
||||||
name = 'poison-cloud',
|
name = name,
|
||||||
position = {
|
position = {
|
||||||
x = position.x + 12 * cos(random_angles[4]),
|
x = position.x + 12 * cos(random_angles[4]),
|
||||||
y = position.y + 12 * sin(random_angles[4])
|
y = position.y + 12 * sin(random_angles[4])
|
||||||
}
|
},
|
||||||
|
target = target,
|
||||||
|
speed = 1.5,
|
||||||
|
force = 'player'
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
@ -1038,7 +1058,7 @@ local function gui_click(event)
|
|||||||
player.name .. ' has bought the locomotive health modifier for ' .. format_number(item.price, true) .. ' coins.'
|
player.name .. ' has bought the locomotive health modifier for ' .. format_number(item.price, true) .. ' coins.'
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
this.locomotive_max_health = this.locomotive_max_health + 2500 * item.stack
|
this.locomotive_max_health = this.locomotive_max_health + 4000 * item.stack
|
||||||
local m = this.locomotive_health / this.locomotive_max_health
|
local m = this.locomotive_health / this.locomotive_max_health
|
||||||
|
|
||||||
if this.carriages then
|
if this.carriages then
|
||||||
@ -1208,23 +1228,6 @@ local function gui_click(event)
|
|||||||
redraw_coins_left(data.coins_left, player)
|
redraw_coins_left(data.coins_left, player)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
if name == 'skill_reset' then
|
|
||||||
player.remove_item({name = item.value, count = item.price})
|
|
||||||
local message = ({
|
|
||||||
'locomotive.rpg_reset_bought_info',
|
|
||||||
shopkeeper,
|
|
||||||
player.name,
|
|
||||||
format_number(item.price, true)
|
|
||||||
})
|
|
||||||
|
|
||||||
Alert.alert_all_players(10, message)
|
|
||||||
|
|
||||||
Functions.rpg_reset_player(player, true)
|
|
||||||
|
|
||||||
redraw_market_items(data.item_frame, player, data.search_text)
|
|
||||||
redraw_coins_left(data.coins_left, player)
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
if player_item_count >= cost then
|
if player_item_count >= cost then
|
||||||
if player.can_insert({name = name, count = item_count}) then
|
if player.can_insert({name = name, count = item_count}) then
|
||||||
@ -1547,10 +1550,10 @@ local function on_player_and_robot_mined_entity(event)
|
|||||||
local chests_linked_to = WPT.get('chests_linked_to')
|
local chests_linked_to = WPT.get('chests_linked_to')
|
||||||
|
|
||||||
if outside_chests[entity.unit_number] then
|
if outside_chests[entity.unit_number] then
|
||||||
for k, v in pairs(chests_linked_to) do
|
for k, data in pairs(chests_linked_to) do
|
||||||
if v[entity.unit_number] then
|
if data[entity.unit_number] then
|
||||||
v.count = v.count - 1
|
data.count = data.count - 1
|
||||||
if v.count <= 0 then
|
if data.count <= 0 then
|
||||||
chests_linked_to[k] = nil
|
chests_linked_to[k] = nil
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -1974,7 +1977,6 @@ function Public.get_items()
|
|||||||
local explosive_bullets_cost = round(fixed_prices.explosive_bullets_cost)
|
local explosive_bullets_cost = round(fixed_prices.explosive_bullets_cost)
|
||||||
local flamethrower_turrets_cost = round(fixed_prices.flamethrower_turrets_cost * (1 + flame_turret))
|
local flamethrower_turrets_cost = round(fixed_prices.flamethrower_turrets_cost * (1 + flame_turret))
|
||||||
local land_mine_cost = round(fixed_prices.land_mine_cost * (1 + landmine))
|
local land_mine_cost = round(fixed_prices.land_mine_cost * (1 + landmine))
|
||||||
local skill_reset_cost = round(fixed_prices.skill_reset_cost)
|
|
||||||
|
|
||||||
local pickaxe_tiers = WPT.pickaxe_upgrades
|
local pickaxe_tiers = WPT.pickaxe_upgrades
|
||||||
local tier = WPT.get('pickaxe_tier')
|
local tier = WPT.get('pickaxe_tier')
|
||||||
@ -2100,16 +2102,7 @@ function Public.get_items()
|
|||||||
upgrade = true,
|
upgrade = true,
|
||||||
static = true
|
static = true
|
||||||
}
|
}
|
||||||
main_market_items['skill_reset'] = {
|
|
||||||
stack = 1,
|
|
||||||
value = 'coin',
|
|
||||||
price = skill_reset_cost,
|
|
||||||
tooltip = ({'main_market.skill_reset'}),
|
|
||||||
sprite = 'achievement/golem',
|
|
||||||
enabled = true,
|
|
||||||
upgrade = true,
|
|
||||||
static = true
|
|
||||||
}
|
|
||||||
if game.forces.player.technologies['logistics'].researched then
|
if game.forces.player.technologies['logistics'].researched then
|
||||||
main_market_items['loader'] = {
|
main_market_items['loader'] = {
|
||||||
stack = 1,
|
stack = 1,
|
||||||
@ -2261,13 +2254,13 @@ function Public.get_items()
|
|||||||
stack = 1,
|
stack = 1,
|
||||||
value = 'coin',
|
value = 'coin',
|
||||||
price = 25000,
|
price = 25000,
|
||||||
tooltip = ({'main_market.tank_cannon_na'}),
|
tooltip = ({'main_market.tank_cannon_na', 650}),
|
||||||
upgrade = false,
|
upgrade = false,
|
||||||
static = true,
|
static = true,
|
||||||
enabled = false
|
enabled = false
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
if wave_number >= 200 then
|
if wave_number >= 100 then
|
||||||
main_market_items['vehicle-machine-gun'] = {
|
main_market_items['vehicle-machine-gun'] = {
|
||||||
stack = 1,
|
stack = 1,
|
||||||
value = 'coin',
|
value = 'coin',
|
||||||
@ -2282,7 +2275,7 @@ function Public.get_items()
|
|||||||
stack = 1,
|
stack = 1,
|
||||||
value = 'coin',
|
value = 'coin',
|
||||||
price = 2000,
|
price = 2000,
|
||||||
tooltip = ({'main_market.vehicle_machine_gun_na'}),
|
tooltip = ({'main_market.vehicle_machine_gun_na', 100}),
|
||||||
upgrade = false,
|
upgrade = false,
|
||||||
static = true,
|
static = true,
|
||||||
enabled = false
|
enabled = false
|
||||||
@ -2317,7 +2310,7 @@ function Public.transfer_pollution()
|
|||||||
surface.clear_pollution()
|
surface.clear_pollution()
|
||||||
end
|
end
|
||||||
|
|
||||||
function Public.enable_poison_defense()
|
function Public.enable_poison_defense(pos)
|
||||||
local locomotive = WPT.get('locomotive')
|
local locomotive = WPT.get('locomotive')
|
||||||
if not locomotive then
|
if not locomotive then
|
||||||
return
|
return
|
||||||
@ -2325,11 +2318,27 @@ function Public.enable_poison_defense()
|
|||||||
if not locomotive.valid then
|
if not locomotive.valid then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
local pos = locomotive.position
|
pos = pos or locomotive.position
|
||||||
create_poison_cloud({x = pos.x, y = pos.y})
|
create_defense_system({x = pos.x, y = pos.y}, 'poison-cloud', pos)
|
||||||
if random(1, 4) == 1 then
|
if random(1, 4) == 1 then
|
||||||
local random_angles = {rad(random(359))}
|
local random_angles = {rad(random(344))}
|
||||||
create_poison_cloud({x = pos.x + 24 * cos(random_angles[1]), y = pos.y + -24 * sin(random_angles[1])})
|
create_defense_system({x = pos.x + 24 * cos(random_angles[1]), y = pos.y + -24 * sin(random_angles[1])}, 'poison-cloud', pos)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function Public.enable_robotic_defense(pos)
|
||||||
|
local locomotive = WPT.get('locomotive')
|
||||||
|
if not locomotive then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
if not locomotive.valid then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
pos = pos or locomotive.position
|
||||||
|
create_defense_system({x = pos.x, y = pos.y}, 'destroyer-capsule', pos)
|
||||||
|
if random(1, 4) == 1 then
|
||||||
|
local random_angles = {rad(random(324))}
|
||||||
|
create_defense_system({x = pos.x + 24 * cos(random_angles[1]), y = pos.y + -24 * sin(random_angles[1])}, 'destroyer-capsule', pos)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -108,7 +108,7 @@ function Public.reset_map()
|
|||||||
BuriedEnemies.reset()
|
BuriedEnemies.reset()
|
||||||
Commands.reset()
|
Commands.reset()
|
||||||
Commands.activate_custom_buttons(true)
|
Commands.activate_custom_buttons(true)
|
||||||
Commands.bottom_right(false)
|
Commands.bottom_right(true)
|
||||||
|
|
||||||
Poll.reset()
|
Poll.reset()
|
||||||
ICW.reset()
|
ICW.reset()
|
||||||
|
@ -117,6 +117,7 @@ function Public.reset_table()
|
|||||||
this.enable_arties = 6 -- default to callback 6
|
this.enable_arties = 6 -- default to callback 6
|
||||||
--!snip
|
--!snip
|
||||||
this.poison_deployed = false
|
this.poison_deployed = false
|
||||||
|
this.robotics_deployed = false
|
||||||
this.upgrades = {
|
this.upgrades = {
|
||||||
showed_text = false,
|
showed_text = false,
|
||||||
landmine = {
|
landmine = {
|
||||||
@ -165,14 +166,13 @@ function Public.reset_table()
|
|||||||
}
|
}
|
||||||
this.marked_fixed_prices = {
|
this.marked_fixed_prices = {
|
||||||
chest_limit_cost = 3000,
|
chest_limit_cost = 3000,
|
||||||
health_cost = 10000,
|
health_cost = 7000,
|
||||||
pickaxe_cost = 3000,
|
pickaxe_cost = 3000,
|
||||||
aura_cost = 4000,
|
aura_cost = 4000,
|
||||||
xp_point_boost_cost = 5000,
|
xp_point_boost_cost = 5000,
|
||||||
explosive_bullets_cost = 20000,
|
explosive_bullets_cost = 10000,
|
||||||
flamethrower_turrets_cost = 3000,
|
flamethrower_turrets_cost = 3000,
|
||||||
land_mine_cost = 2,
|
land_mine_cost = 2
|
||||||
skill_reset_cost = 100000
|
|
||||||
}
|
}
|
||||||
this.collapse_grace = true
|
this.collapse_grace = true
|
||||||
this.explosive_bullets = false
|
this.explosive_bullets = false
|
||||||
|
@ -432,14 +432,15 @@ local function create_gui_button(player)
|
|||||||
local tooltip
|
local tooltip
|
||||||
if this.insert_into_furnace and this.insert_into_wagon then
|
if this.insert_into_furnace and this.insert_into_wagon then
|
||||||
tooltip =
|
tooltip =
|
||||||
'Sort your inventory into nearby chests.\nLMB: Everything, excluding quickbar items.\nRMB: Only ores to nearby chests.\nCTRL+RMB: Fill nearby furnaces.\nSHIFT+LMB: Everything onto filtered slots to wagon.\nSHIFT+RMB: Only ores to wagon'
|
'Sort your inventory into nearby chests.\nLMB: Everything, excluding quickbar items.\nRMB: Only ores to nearby chests, excluding quickbar items.\nCTRL+RMB: Fill nearby furnaces.\nSHIFT+LMB: Everything onto filtered slots to wagon.\nSHIFT+RMB: Only ores to wagon'
|
||||||
elseif this.insert_into_furnace then
|
elseif this.insert_into_furnace then
|
||||||
tooltip = 'Sort your inventory into nearby chests.\nLMB: Everything, excluding quickbar items.\nRMB: Only ores to nearby chests.\nCTRL+RMB: Fill nearby furnaces.'
|
tooltip =
|
||||||
|
'Sort your inventory into nearby chests.\nLMB: Everything, excluding quickbar items.\nRMB: Only ores to nearby chests, excluding quickbar items.\nCTRL+RMB: Fill nearby furnaces.'
|
||||||
elseif this.insert_into_wagon then
|
elseif this.insert_into_wagon then
|
||||||
tooltip =
|
tooltip =
|
||||||
'Sort your inventory into nearby chests.\nLMB: Everything, excluding quickbar items.\nRMB: Only ores to nearby chests.\nSHIFT+LMB: Everything onto filtered slots to wagon.\nSHIFT+RMB: Only ores to wagon'
|
'Sort your inventory into nearby chests.\nLMB: Everything, excluding quickbar items.\nRMB: Only ores to nearby chests, excluding quickbar items.\nSHIFT+LMB: Everything onto filtered slots to wagon.\nSHIFT+RMB: Only ores to wagon'
|
||||||
else
|
else
|
||||||
tooltip = 'Sort your inventory into nearby chests.\nLMB: Everything, excluding quickbar items.\nRMB: Only ores to nearby chests.'
|
tooltip = 'Sort your inventory into nearby chests.\nLMB: Everything, excluding quickbar items.\nRMB: Only ores to nearby chests, excluding quickbar items.'
|
||||||
end
|
end
|
||||||
if this.bottom_button then
|
if this.bottom_button then
|
||||||
local data = Misc.get('bottom_quickbar_button')
|
local data = Misc.get('bottom_quickbar_button')
|
||||||
|
@ -117,7 +117,6 @@ local function level_up(player)
|
|||||||
end
|
end
|
||||||
RPG_GUI.draw_level_text(player)
|
RPG_GUI.draw_level_text(player)
|
||||||
rpg_t[player.index].points_to_distribute = rpg_t[player.index].points_to_distribute + distribute_points_gain
|
rpg_t[player.index].points_to_distribute = rpg_t[player.index].points_to_distribute + distribute_points_gain
|
||||||
RPG_GUI.update_char_button(player)
|
|
||||||
if rpg_t[player.index].allocate_index ~= 1 then
|
if rpg_t[player.index].allocate_index ~= 1 then
|
||||||
local node = rpg_t[player.index].allocate_index
|
local node = rpg_t[player.index].allocate_index
|
||||||
local index = names[node]:lower()
|
local index = names[node]:lower()
|
||||||
@ -127,6 +126,8 @@ local function level_up(player)
|
|||||||
rpg_t[player.index].total = rpg_t[player.index].total + distribute_points_gain
|
rpg_t[player.index].total = rpg_t[player.index].total + distribute_points_gain
|
||||||
end
|
end
|
||||||
RPG_GUI.update_player_stats(player)
|
RPG_GUI.update_player_stats(player)
|
||||||
|
else
|
||||||
|
RPG_GUI.update_char_button(player)
|
||||||
end
|
end
|
||||||
if player.gui.screen[main_frame_name] then
|
if player.gui.screen[main_frame_name] then
|
||||||
RPG_GUI.toggle(player, true)
|
RPG_GUI.toggle(player, true)
|
||||||
|
@ -516,6 +516,10 @@ local function on_entity_damaged(event)
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if event.entity.force.index == event.cause.force.index then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
Functions.reward_mana(event.cause.player, 2)
|
Functions.reward_mana(event.cause.player, 2)
|
||||||
|
|
||||||
--Grant the player life-on-hit.
|
--Grant the player life-on-hit.
|
||||||
|
@ -216,20 +216,6 @@ function Public.conjure_items()
|
|||||||
tick = 100,
|
tick = 100,
|
||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
|
||||||
name = {'spells.railgun_beam'},
|
|
||||||
obj_to_create = 'railgun-beam',
|
|
||||||
target = false,
|
|
||||||
amount = 3,
|
|
||||||
damage = true,
|
|
||||||
range = 240,
|
|
||||||
force = 'player',
|
|
||||||
level = 50,
|
|
||||||
type = 'special',
|
|
||||||
mana_cost = 75,
|
|
||||||
tick = 200,
|
|
||||||
enabled = true
|
|
||||||
}
|
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = {'spells.raw_fish'},
|
name = {'spells.raw_fish'},
|
||||||
obj_to_create = 'fish',
|
obj_to_create = 'fish',
|
||||||
@ -317,7 +303,6 @@ Public.projectile_types = {
|
|||||||
force = 'enemy'
|
force = 'enemy'
|
||||||
},
|
},
|
||||||
['lubricant-barrel'] = {name = 'acid-stream-spitter-big', count = 3, max_range = 16, tick_speed = 1},
|
['lubricant-barrel'] = {name = 'acid-stream-spitter-big', count = 3, max_range = 16, tick_speed = 1},
|
||||||
['railgun-beam'] = {name = 'railgun-beam', count = 5, max_range = 40, tick_speed = 5},
|
|
||||||
['shotgun-shell'] = {name = 'shotgun-pellet', count = 16, max_range = 24, tick_speed = 1},
|
['shotgun-shell'] = {name = 'shotgun-pellet', count = 16, max_range = 24, tick_speed = 1},
|
||||||
['piercing-shotgun-shell'] = {name = 'piercing-shotgun-pellet', count = 16, max_range = 24, tick_speed = 1},
|
['piercing-shotgun-shell'] = {name = 'piercing-shotgun-pellet', count = 16, max_range = 24, tick_speed = 1},
|
||||||
['firearm-magazine'] = {name = 'shotgun-pellet', count = 16, max_range = 24, tick_speed = 1},
|
['firearm-magazine'] = {name = 'shotgun-pellet', count = 16, max_range = 24, tick_speed = 1},
|
||||||
|
@ -350,25 +350,27 @@ local function update_gui()
|
|||||||
|
|
||||||
if valid then
|
if valid then
|
||||||
if success then
|
if success then
|
||||||
local main = target.get_main_inventory().get_contents()
|
if target then
|
||||||
local armor = target.get_inventory(defines.inventory.character_armor).get_contents()
|
local main = target.get_main_inventory().get_contents()
|
||||||
local guns = target.get_inventory(defines.inventory.character_guns).get_contents()
|
local armor = target.get_inventory(defines.inventory.character_armor).get_contents()
|
||||||
local ammo = target.get_inventory(defines.inventory.character_ammo).get_contents()
|
local guns = target.get_inventory(defines.inventory.character_guns).get_contents()
|
||||||
local trash = target.get_inventory(defines.inventory.character_trash).get_contents()
|
local ammo = target.get_inventory(defines.inventory.character_ammo).get_contents()
|
||||||
|
local trash = target.get_inventory(defines.inventory.character_trash).get_contents()
|
||||||
|
|
||||||
local types = {
|
local types = {
|
||||||
['Main'] = main,
|
['Main'] = main,
|
||||||
['Armor'] = armor,
|
['Armor'] = armor,
|
||||||
['Guns'] = guns,
|
['Guns'] = guns,
|
||||||
['Ammo'] = ammo,
|
['Ammo'] = ammo,
|
||||||
['Trash'] = trash
|
['Trash'] = trash
|
||||||
}
|
}
|
||||||
|
|
||||||
local frame = Public.get_active_frame(player)
|
local frame = Public.get_active_frame(player)
|
||||||
local panel_type = types[tab]
|
local panel_type = types[tab]
|
||||||
if frame then
|
if frame then
|
||||||
if frame.name == tab .. 'tab' then
|
if frame.name == tab .. 'tab' then
|
||||||
redraw_inventory(frame, player, target, tab, panel_type)
|
redraw_inventory(frame, player, target, tab, panel_type)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -822,7 +822,9 @@ local function give_main_command_to_group()
|
|||||||
for k, group in pairs(unit_groups) do
|
for k, group in pairs(unit_groups) do
|
||||||
if type(group) ~= 'number' then
|
if type(group) ~= 'number' then
|
||||||
if group.valid then
|
if group.valid then
|
||||||
command_to_main_target(group)
|
if group.surface.index == target.surface.index then
|
||||||
|
command_to_main_target(group)
|
||||||
|
end
|
||||||
else
|
else
|
||||||
get_active_unit_groups_count()
|
get_active_unit_groups_count()
|
||||||
end
|
end
|
||||||
|
@ -190,23 +190,28 @@ end
|
|||||||
local teleport_player_to_gulag = function(player, action)
|
local teleport_player_to_gulag = function(player, action)
|
||||||
local p_data = get_player_data(player)
|
local p_data = get_player_data(player)
|
||||||
|
|
||||||
local gulag_tp = function(surface)
|
|
||||||
get_player_data(player, true)
|
|
||||||
player.teleport(surface.find_non_colliding_position('character', game.forces.player.get_spawn_position(surface), 128, 1), surface.name)
|
|
||||||
end
|
|
||||||
|
|
||||||
if action == 'jail' then
|
if action == 'jail' then
|
||||||
local gulag = game.surfaces['gulag']
|
local gulag = game.surfaces['gulag']
|
||||||
p_data.fallback_surface_index = player.surface.index
|
if p_data and not p_data.locked then
|
||||||
p_data.position = player.position
|
p_data.fallback_surface_index = player.surface.index
|
||||||
p_data.p_group_id = player.permission_group.group_id
|
p_data.position = player.position
|
||||||
p_data.locked = true
|
p_data.p_group_id = player.permission_group.group_id
|
||||||
|
p_data.locked = true
|
||||||
|
end
|
||||||
player.teleport(gulag.find_non_colliding_position('character', {0, 0}, 128, 1), gulag.name)
|
player.teleport(gulag.find_non_colliding_position('character', {0, 0}, 128, 1), gulag.name)
|
||||||
local data = {
|
local data = {
|
||||||
player = player
|
player = player
|
||||||
}
|
}
|
||||||
Task.set_timeout_in_ticks(5, clear_gui, data)
|
Task.set_timeout_in_ticks(5, clear_gui, data)
|
||||||
elseif action == 'free' then
|
elseif action == 'free' then
|
||||||
|
jailed[player.name] = nil
|
||||||
|
if votejail[player.name] then
|
||||||
|
votejail[player.name] = nil
|
||||||
|
end
|
||||||
|
if votefree[player.name] then
|
||||||
|
votefree[player.name] = nil
|
||||||
|
end
|
||||||
|
|
||||||
local surface = game.surfaces[p_data.fallback_surface_index]
|
local surface = game.surfaces[p_data.fallback_surface_index]
|
||||||
local p = p_data.position
|
local p = p_data.position
|
||||||
local p_group = game.permissions.get_group(p_data.p_group_id)
|
local p_group = game.permissions.get_group(p_data.p_group_id)
|
||||||
@ -214,11 +219,12 @@ local teleport_player_to_gulag = function(player, action)
|
|||||||
local pos = {x = p.x, y = p.y}
|
local pos = {x = p.x, y = p.y}
|
||||||
local get_tile = surface.get_tile(pos)
|
local get_tile = surface.get_tile(pos)
|
||||||
if get_tile.valid and get_tile.name == 'out-of-map' then
|
if get_tile.valid and get_tile.name == 'out-of-map' then
|
||||||
gulag_tp(surface)
|
player.teleport(surface.find_non_colliding_position('character', game.forces.player.get_spawn_position(surface), 128, 1), surface.name)
|
||||||
else
|
else
|
||||||
get_player_data(player, true)
|
|
||||||
player.teleport(surface.find_non_colliding_position('character', p, 128, 1), surface.name)
|
player.teleport(surface.find_non_colliding_position('character', p, 128, 1), surface.name)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
get_player_data(player, true)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -241,6 +247,33 @@ local on_player_changed_surface = function(event)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local on_player_joined_game = function(event)
|
||||||
|
local player = game.players[event.player_index]
|
||||||
|
if not player or not player.valid then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
if not jailed[player.name] then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
local surface = game.surfaces['gulag']
|
||||||
|
|
||||||
|
if player.surface.index ~= surface.index then
|
||||||
|
local p_data = get_player_data(player)
|
||||||
|
if jailed[player.name] and p_data and p_data.locked then
|
||||||
|
teleport_player_to_gulag(player, 'jail')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local gulag = get_gulag_permission_group()
|
||||||
|
gulag.add_player(player)
|
||||||
|
|
||||||
|
if player.character and player.character.valid and player.character.driving then
|
||||||
|
player.character.driving = false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
local validate_args = function(data)
|
local validate_args = function(data)
|
||||||
local player = data.player
|
local player = data.player
|
||||||
local griefer = data.griefer
|
local griefer = data.griefer
|
||||||
@ -371,10 +404,9 @@ local jail = function(player, griefer, msg)
|
|||||||
local g = game.players[griefer]
|
local g = game.players[griefer]
|
||||||
teleport_player_to_gulag(g, 'jail')
|
teleport_player_to_gulag(g, 'jail')
|
||||||
|
|
||||||
if g.surface.name == 'gulag' then
|
local gulag = get_gulag_permission_group()
|
||||||
local gulag = get_gulag_permission_group()
|
gulag.add_player(griefer)
|
||||||
gulag.add_player(griefer)
|
|
||||||
end
|
|
||||||
local message = griefer .. ' has been jailed by ' .. player .. '. Cause: ' .. msg
|
local message = griefer .. ' has been jailed by ' .. player .. '. Cause: ' .. msg
|
||||||
|
|
||||||
if game.players[griefer].character and game.players[griefer].character.valid and game.players[griefer].character.driving then
|
if game.players[griefer].character and game.players[griefer].character.valid and game.players[griefer].character.driving then
|
||||||
@ -407,17 +439,8 @@ local free = function(player, griefer)
|
|||||||
|
|
||||||
local message = griefer .. ' was set free from jail by ' .. player .. '.'
|
local message = griefer .. ' was set free from jail by ' .. player .. '.'
|
||||||
|
|
||||||
jailed[griefer] = nil
|
|
||||||
|
|
||||||
set_data(jailed_data_set, griefer, nil)
|
set_data(jailed_data_set, griefer, nil)
|
||||||
|
|
||||||
if votejail[griefer] then
|
|
||||||
votejail[griefer] = nil
|
|
||||||
end
|
|
||||||
if votefree[griefer] then
|
|
||||||
votefree[griefer] = nil
|
|
||||||
end
|
|
||||||
|
|
||||||
Utils.print_to(nil, message)
|
Utils.print_to(nil, message)
|
||||||
Utils.action_warning_embed('{Jailed}', message)
|
Utils.action_warning_embed('{Jailed}', message)
|
||||||
return true
|
return true
|
||||||
@ -597,6 +620,7 @@ Event.add(
|
|||||||
end
|
end
|
||||||
)
|
)
|
||||||
|
|
||||||
|
Event.add(defines.events.on_player_joined_game, on_player_joined_game)
|
||||||
Event.add(defines.events.on_player_changed_surface, on_player_changed_surface)
|
Event.add(defines.events.on_player_changed_surface, on_player_changed_surface)
|
||||||
Event.on_init(create_gulag_surface)
|
Event.on_init(create_gulag_surface)
|
||||||
|
|
||||||
|
@ -20,33 +20,25 @@ local on_nth_tick_event_handlers = {}
|
|||||||
if not remote.interfaces['interface'] then
|
if not remote.interfaces['interface'] then
|
||||||
remote.add_interface('interface', interface)
|
remote.add_interface('interface', interface)
|
||||||
end ]]
|
end ]]
|
||||||
local pcall = pcall
|
local xpcall = xpcall
|
||||||
|
local trace = debug.traceback
|
||||||
local log = log
|
local log = log
|
||||||
local script_on_event = script.on_event
|
local script_on_event = script.on_event
|
||||||
local script_on_nth_tick = script.on_nth_tick
|
local script_on_nth_tick = script.on_nth_tick
|
||||||
|
|
||||||
local call_handlers
|
local function handler_error(err)
|
||||||
if _DEBUG then
|
log('\n\t' .. trace(err))
|
||||||
function call_handlers(handlers, event)
|
end
|
||||||
if not handlers then
|
|
||||||
return log('Handlers was nil!')
|
local function call_handlers(handlers, event)
|
||||||
end
|
if _DEBUG then
|
||||||
for i = 1, #handlers do
|
for i = 1, #handlers do
|
||||||
local handler = handlers[i]
|
local handler = handlers[i]
|
||||||
handler(event)
|
handler(event)
|
||||||
end
|
end
|
||||||
end
|
else
|
||||||
else
|
|
||||||
function call_handlers(handlers, event)
|
|
||||||
if not handlers then
|
|
||||||
return log('Handlers was nil!')
|
|
||||||
end
|
|
||||||
for i = 1, #handlers do
|
for i = 1, #handlers do
|
||||||
local handler = handlers[i]
|
xpcall(handlers[i], handler_error, event)
|
||||||
local success, error = pcall(handler, event)
|
|
||||||
if not success then
|
|
||||||
log(error)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
x
Reference in New Issue
Block a user