diff --git a/.vs/slnx.sqlite b/.vs/slnx.sqlite
new file mode 100644
index 000000000000..c5a6fa0a4926
Binary files /dev/null and b/.vs/slnx.sqlite differ
diff --git a/.vscode/extensions.json b/.vscode/extensions.json
index ca0e6ad9970d..f794162129c3 100644
--- a/.vscode/extensions.json
+++ b/.vscode/extensions.json
@@ -2,6 +2,7 @@
"recommendations": [
"gbasood.byond-dm-language-support",
"platymuus.dm-langclient",
- "EditorConfig.EditorConfig"
+ "EditorConfig.EditorConfig",
+ "dbaeumer.vscode-eslint"
]
}
diff --git a/code/game/objects/items/RPD.dm b/code/game/objects/items/RPD.dm
index 665082d1d2ff..942a9742e104 100644
--- a/code/game/objects/items/RPD.dm
+++ b/code/game/objects/items/RPD.dm
@@ -12,7 +12,6 @@ RPD
#define DESTROY_MODE (1<<2)
#define PAINT_MODE (1<<3)
-
GLOBAL_LIST_INIT(atmos_pipe_recipes, list(
"Pipes" = list(
new /datum/pipe_info/pipe("Pipe", /obj/machinery/atmospherics/pipe/simple),
@@ -175,6 +174,7 @@ GLOBAL_LIST_INIT(transit_tube_recipes, list(
if(dt == PIPE_UNARY_FLIPPABLE)
icon_state = "[icon_state]_preview"
+// SKYRAT CHANGE: Made BSRPD into a subtype of RPD, additionally made it work at range.
/obj/item/pipe_dispenser
name = "Rapid Piping Device (RPD)"
desc = "A device used to rapidly pipe things."
@@ -209,6 +209,7 @@ GLOBAL_LIST_INIT(transit_tube_recipes, list(
var/static/datum/pipe_info/first_disposal
var/static/datum/pipe_info/first_transit
var/mode = BUILD_MODE | DESTROY_MODE | WRENCH_MODE
+ var/has_bluespace_pipe = FALSE // Skyrat
/obj/item/pipe_dispenser/New()
. = ..()
@@ -266,7 +267,10 @@ GLOBAL_LIST_INIT(transit_tube_recipes, list(
var/list/recipes
switch(category)
if(ATMOS_CATEGORY)
- recipes = GLOB.atmos_pipe_recipes
+ if(has_bluespace_pipe) // stupid skyrat edit
+ recipes = GLOB.bsatmos_pipe_recipes
+ else
+ recipes = GLOB.atmos_pipe_recipes
if(DISPOSALS_CATEGORY)
recipes = GLOB.disposal_pipe_recipes
if(TRANSIT_CATEGORY)
@@ -307,7 +311,10 @@ GLOBAL_LIST_INIT(transit_tube_recipes, list(
if("pipe_type")
var/static/list/recipes
if(!recipes)
- recipes = GLOB.disposal_pipe_recipes + GLOB.atmos_pipe_recipes + GLOB.transit_tube_recipes
+ if(has_bluespace_pipe) // skyrat hack
+ recipes = GLOB.disposal_pipe_recipes + GLOB.bsatmos_pipe_recipes + GLOB.transit_tube_recipes
+ else
+ recipes = GLOB.disposal_pipe_recipes + GLOB.atmos_pipe_recipes + GLOB.transit_tube_recipes
recipe = recipes[params["category"]][text2num(params["pipe_type"])]
p_dir = NORTH
if("setdir")
@@ -327,10 +334,13 @@ GLOBAL_LIST_INIT(transit_tube_recipes, list(
playsound(get_turf(src), 'sound/effects/pop.ogg', 50, 0)
return TRUE
-/obj/item/pipe_dispenser/pre_attack(atom/A, mob/user)
+/obj/item/pipe_dispenser/pre_attack(atom/A, mob/user) // Skyrat: All functionality moved to proc/dispense
+ dispense(A, user)
+
+/obj/item/pipe_dispenser/proc/dispense(atom/A, mob/user)
var/turf/T = get_turf(A)
if(!user.IsAdvancedToolUser() || !T || istype(T, /turf/open/space/transit) || isindestructiblewall(T))
- return ..()
+ return
//So that changing the menu settings doesn't affect the pipes already being built.
var/queued_p_type = recipe.id
@@ -377,7 +387,7 @@ GLOBAL_LIST_INIT(transit_tube_recipes, list(
switch(category) //if we've gotten this var, the target is valid
if(ATMOS_CATEGORY) //Making pipes
if(!can_make_pipe)
- return ..()
+ return
A = T
if(is_type_in_typecache(recipe, GLOB.ventcrawl_machinery) && isclosedturf(A)) //wall escapism sanity check.
to_chat(user, "[src]'s error light flickers; there's something in the way!")
@@ -413,7 +423,7 @@ GLOBAL_LIST_INIT(transit_tube_recipes, list(
if(DISPOSALS_CATEGORY) //Making disposals pipes
if(!can_make_pipe)
- return ..()
+ return
A = T
if(isclosedturf(A))
to_chat(user, "[src]'s error light flickers; there's something in the way!")
@@ -438,7 +448,7 @@ GLOBAL_LIST_INIT(transit_tube_recipes, list(
if(TRANSIT_CATEGORY) //Making transit tubes
if(!can_make_pipe)
- return ..()
+ return
A = T
if(isclosedturf(A))
to_chat(user, "[src]'s error light flickers; there's something in the way!")
@@ -471,7 +481,8 @@ GLOBAL_LIST_INIT(transit_tube_recipes, list(
return
else
- return ..()
+ return
+// End skyrat edit
/obj/item/pipe_dispenser/proc/activate()
playsound(get_turf(src), 'sound/items/deconstruct.ogg', 50, 1)
diff --git a/code/game/objects/structures/crates_lockers/closets/secure/engineering.dm b/code/game/objects/structures/crates_lockers/closets/secure/engineering.dm
index 05798df953e5..4d11bb0ac1f4 100644
--- a/code/game/objects/structures/crates_lockers/closets/secure/engineering.dm
+++ b/code/game/objects/structures/crates_lockers/closets/secure/engineering.dm
@@ -5,6 +5,9 @@
/obj/structure/closet/secure_closet/engineering_chief/PopulateContents()
..()
+ //SKYRAT EDIT - ATMS
+ new /obj/item/pipe_dispenser/bluespace(src) // SKYRAT: CE gets BPRPD instead of RPD, since they start with all other power tools too
+ //SKYRAT EDIT END
new /obj/item/clothing/neck/cloak/ce(src)
new /obj/item/clothing/head/beret/ce(src)
new /obj/item/clothing/under/rank/engineering/chief_engineer(src)
@@ -21,7 +24,6 @@
new /obj/item/assembly/flash/handheld(src)
new /obj/item/clothing/glasses/meson/engine(src)
new /obj/item/door_remote/chief_engineer(src)
- new /obj/item/pipe_dispenser(src)
new /obj/item/inducer(src)
new /obj/item/circuitboard/machine/techfab/department/engineering(src)
new /obj/item/extinguisher/advanced(src)
diff --git a/sandcode/code/game/machinery/pipe/construction.dm b/sandcode/code/game/machinery/pipe/construction.dm
new file mode 100644
index 000000000000..fc16dcc2ba47
--- /dev/null
+++ b/sandcode/code/game/machinery/pipe/construction.dm
@@ -0,0 +1,24 @@
+/obj/item/pipe/bluespace
+ pipe_type = /obj/machinery/atmospherics/pipe/bluespace
+ var/bluespace_network_name = "default"
+ icon_state = "bluespace"
+ desc = "Transmits gas across large distances of space. Developed using bluespace technology. Use a multitool on it to set its network."
+
+/obj/item/pipe/bluespace/attackby(obj/item/W, mob/user, params)
+ if(istype(W, /obj/item/multitool))
+ var/new_name = input(user, "Enter identifier for bluespace pipe network", "bluespace pipe", bluespace_network_name) as text|null
+ if(!isnull(new_name))
+ bluespace_network_name = new_name
+ else
+ return
+
+/obj/item/pipe/bluespace/make_from_existing(obj/machinery/atmospherics/pipe/bluespace/make_from)
+ bluespace_network_name = make_from.bluespace_network_name
+ return ..()
+
+/obj/item/pipe/bluespace/build_pipe(obj/machinery/atmospherics/pipe/bluespace/A)
+ A.bluespace_network_name = bluespace_network_name
+ return ..()
+
+/obj/item/pipe/bluespace/directional
+ RPD_type = PIPE_UNARY
diff --git a/sandcode/code/game/objects/items/BSRPD.dm b/sandcode/code/game/objects/items/BSRPD.dm
new file mode 100644
index 000000000000..0f8426d0fe0f
--- /dev/null
+++ b/sandcode/code/game/objects/items/BSRPD.dm
@@ -0,0 +1,76 @@
+/*
+CONTAINS:
+BSRPD
+*/
+
+#define ATMOS_CATEGORY 0
+#define DISPOSALS_CATEGORY 1
+#define TRANSIT_CATEGORY 2
+
+#define BUILD_MODE (1<<0)
+#define WRENCH_MODE (1<<1)
+#define DESTROY_MODE (1<<2)
+#define PAINT_MODE (1<<3)
+
+
+GLOBAL_LIST_INIT(bsatmos_pipe_recipes, list(
+ "Pipes" = list(
+ new /datum/pipe_info/pipe("Pipe", /obj/machinery/atmospherics/pipe/simple),
+ new /datum/pipe_info/pipe("Manifold", /obj/machinery/atmospherics/pipe/manifold),
+ new /datum/pipe_info/pipe("4-Way Manifold", /obj/machinery/atmospherics/pipe/manifold4w),
+ new /datum/pipe_info/pipe("Layer Manifold", /obj/machinery/atmospherics/pipe/layer_manifold),
+ new /datum/pipe_info/pipe("Bluespace Pipe", /obj/machinery/atmospherics/pipe/bluespace),
+ ),
+ "Devices" = list(
+ new /datum/pipe_info/pipe("Connector", /obj/machinery/atmospherics/components/unary/portables_connector),
+ new /datum/pipe_info/pipe("Gas Pump", /obj/machinery/atmospherics/components/binary/pump),
+ new /datum/pipe_info/pipe("Volume Pump", /obj/machinery/atmospherics/components/binary/volume_pump),
+ new /datum/pipe_info/pipe("Gas Filter", /obj/machinery/atmospherics/components/trinary/filter),
+ new /datum/pipe_info/pipe("Gas Mixer", /obj/machinery/atmospherics/components/trinary/mixer),
+ new /datum/pipe_info/pipe("Passive Gate", /obj/machinery/atmospherics/components/binary/passive_gate),
+ new /datum/pipe_info/pipe("Injector", /obj/machinery/atmospherics/components/unary/outlet_injector),
+ new /datum/pipe_info/pipe("Scrubber", /obj/machinery/atmospherics/components/unary/vent_scrubber),
+ new /datum/pipe_info/pipe("Unary Vent", /obj/machinery/atmospherics/components/unary/vent_pump),
+ new /datum/pipe_info/pipe("Passive Vent", /obj/machinery/atmospherics/components/unary/passive_vent),
+ new /datum/pipe_info/pipe("Manual Valve", /obj/machinery/atmospherics/components/binary/valve),
+ new /datum/pipe_info/pipe("Digital Valve", /obj/machinery/atmospherics/components/binary/valve/digital),
+ new /datum/pipe_info/pipe("Relief Valve (Binary)", /obj/machinery/atmospherics/components/binary/relief_valve),
+ new /datum/pipe_info/pipe("Relief Valve (Unary)", /obj/machinery/atmospherics/components/unary/relief_valve),
+ new /datum/pipe_info/meter("Meter"),
+ ),
+ "Heat Exchange" = list(
+ new /datum/pipe_info/pipe("Pipe", /obj/machinery/atmospherics/pipe/heat_exchanging/simple),
+ new /datum/pipe_info/pipe("Manifold", /obj/machinery/atmospherics/pipe/heat_exchanging/manifold),
+ new /datum/pipe_info/pipe("4-Way Manifold", /obj/machinery/atmospherics/pipe/heat_exchanging/manifold4w),
+ new /datum/pipe_info/pipe("Junction", /obj/machinery/atmospherics/pipe/heat_exchanging/junction),
+ new /datum/pipe_info/pipe("Heat Exchanger", /obj/machinery/atmospherics/components/unary/heat_exchanger),
+ )
+))
+
+// SKYRAT CHANGE: Made BSRPD into a subtype of RPD, additionally made it work at range.
+/obj/item/pipe_dispenser/bluespace
+ name = "Bluespace Rapid Piping Device (BSRPD)"
+ desc = "A device used to rapidly pipe things at a distance."
+ icon = 'sandcode/icons/obj/tools.dmi'
+ icon_state = "bsrpd"
+ lefthand_file = 'sandcode/icons/mob/inhands/equipment/tools_lefthand.dmi'
+ righthand_file = 'sandcode/icons/mob/inhands/equipment/tools_righthand.dmi'
+ custom_materials = list(/datum/material/iron=75000, /datum/material/glass=37500, /datum/material/bluespace=1000)
+ has_bluespace_pipe = TRUE
+
+/obj/item/pipe_dispenser/bluespace/afterattack(atom/target, mob/user, proximity_flag, click_parameters)
+ if(proximity_flag)
+ return // this will be handled in pre_attack in RPD.dm
+ user.Beam(target, icon_state = "rped_upgrade", time = 5)
+ playsound(src, 'sound/items/pshoom.ogg', 30, TRUE)
+ dispense(target, user)
+
+// End skyrat edit
+#undef ATMOS_CATEGORY
+#undef DISPOSALS_CATEGORY
+#undef TRANSIT_CATEGORY
+
+#undef BUILD_MODE
+#undef DESTROY_MODE
+#undef PAINT_MODE
+#undef WRENCH_MODE
diff --git a/sandcode/code/game/objects/items/robot/robot_upgrades.dm b/sandcode/code/game/objects/items/robot/robot_upgrades.dm
new file mode 100644
index 000000000000..1664200e6045
--- /dev/null
+++ b/sandcode/code/game/objects/items/robot/robot_upgrades.dm
@@ -0,0 +1,34 @@
+/obj/item/borg/upgrade/bsrpd
+ name = "engineering cyborg bluespace RPD"
+ desc = "A bluespace RPD replacement for the engineering module's standard RPD."
+ icon_state = "cyborg_upgrade3"
+ require_module = 1
+ module_type = list(/obj/item/robot_module/engineering)
+
+/obj/item/borg/upgrade/bsrpd/action(mob/living/silicon/robot/R, user = usr)
+ . = ..()
+ if(.)
+ var/obj/item/pipe_dispenser/PD = locate() in R
+ var/obj/item/pipe_dispenser/bluespace/BD = locate() in R // Skyrat edit
+ if(!PD)
+ PD = locate() in R.module
+ if(!BD)
+ BD = locate() in R.module //There's gotta be a smarter way to do this.
+ if(BD)
+ to_chat(user, "This unit is already equipped with a BSRPD module.")
+ return FALSE
+
+ BD = new(R.module)
+ qdel(PD)
+ R.module.basic_modules += BD
+ R.module.add_module(BD, FALSE, TRUE)
+
+/obj/item/borg/upgrade/bsrpd/deactivate(mob/living/silicon/robot/R, user = usr)
+ . = ..()
+ if (.)
+ for(var/obj/item/pipe_dispenser/bluespace/BD in R.module) // Skyrat edit
+ R.module.remove_module(BD, TRUE)
+
+ var/obj/item/pipe_dispenser/PD = new (R.module)
+ R.module.basic_modules += PD
+ R.module.add_module(PD, FALSE, TRUE)
diff --git a/sandcode/code/modules/atmospherics/machinery/pipes/bluespace.dm b/sandcode/code/modules/atmospherics/machinery/pipes/bluespace.dm
new file mode 100644
index 000000000000..0be835803181
--- /dev/null
+++ b/sandcode/code/modules/atmospherics/machinery/pipes/bluespace.dm
@@ -0,0 +1,103 @@
+GLOBAL_LIST_EMPTY(bluespace_pipe_networks)
+/obj/machinery/atmospherics/pipe/bluespace
+ name = "bluespace pipe"
+ desc = "Transmits gas across large distances of space. Developed using bluespace technology. Use a multitool on it to set its network."
+ icon = 'sandcode/icons/obj/atmospherics/pipes/bluespace.dmi'
+ icon_state = "blue_map-2"
+ pipe_state = "bluespace"
+ dir = SOUTH
+ initialize_directions = SOUTH
+ device_type = UNARY
+ can_buckle = FALSE
+ construction_type = /obj/item/pipe/bluespace/directional
+ var/bluespace_network_name
+
+/obj/machinery/atmospherics/pipe/bluespace/New()
+ icon_state = "map"
+ if(bluespace_network_name) // in case someone maps one in for some reason
+ if(!GLOB.bluespace_pipe_networks[bluespace_network_name])
+ GLOB.bluespace_pipe_networks[bluespace_network_name] = list()
+ GLOB.bluespace_pipe_networks[bluespace_network_name] |= src
+ ..()
+
+/obj/machinery/atmospherics/pipe/bluespace/on_construction()
+ . = ..()
+ if(bluespace_network_name)
+ if(!GLOB.bluespace_pipe_networks[bluespace_network_name])
+ GLOB.bluespace_pipe_networks[bluespace_network_name] = list()
+ GLOB.bluespace_pipe_networks[bluespace_network_name] |= src
+
+/obj/machinery/atmospherics/pipe/bluespace/Destroy()
+ if(GLOB.bluespace_pipe_networks[bluespace_network_name])
+ GLOB.bluespace_pipe_networks[bluespace_network_name] -= src
+ for(var/p in GLOB.bluespace_pipe_networks[bluespace_network_name])
+ var/obj/machinery/atmospherics/pipe/bluespace/P = p
+ QDEL_NULL(P.parent)
+ P.build_network()
+ return ..()
+
+/obj/machinery/atmospherics/pipe/bluespace/examine(user)
+ . = ..()
+ to_chat(user, "This one is connected to the \"[html_encode(bluespace_network_name)]\" network")
+
+/obj/machinery/atmospherics/pipe/bluespace/SetInitDirections()
+ initialize_directions = dir
+
+/obj/machinery/atmospherics/pipe/bluespace/pipeline_expansion()
+ return ..() + GLOB.bluespace_pipe_networks[bluespace_network_name] - src
+
+/obj/machinery/atmospherics/pipe/bluespace/hide()
+ update_icon()
+
+/obj/machinery/atmospherics/pipe/bluespace/update_icon(showpipe)
+ underlays.Cut()
+
+ var/turf/T = loc
+ if(level == 2 || !T.intact)
+ icon_state = "blue_map-2"
+ showpipe = TRUE
+ plane = GAME_PLANE
+ else
+ showpipe = FALSE
+ plane = FLOOR_PLANE
+
+ if(!showpipe)
+ return //no need to update the pipes if they aren't showing
+/* This shit aint in here
+ var/connected = 0 //Direction bitset
+
+ for(var/i in 1 to device_type) //adds intact pieces
+ if(nodes[i])
+ connected |= icon_addintact(nodes[i])
+
+ icon_addbroken(connected) //adds broken pieces//adds broken pieces
+*/
+ if(piping_layer == 1)
+ icon_state = "blue_map-1"
+ else if(piping_layer == 2)
+ icon_state = "blue_map-2"
+ else if(piping_layer == 3)
+ icon_state = "blue_map-3"
+
+/obj/machinery/atmospherics/pipe/bluespace/paint()
+ return FALSE
+
+/obj/machinery/atmospherics/pipe/bluespace/attackby(obj/item/W, mob/user, params)
+ if(istype(W, /obj/item/multitool))
+ var/new_name = input(user, "Enter identifier for bluespace pipe network", "bluespace pipe", bluespace_network_name) as text|null
+ if(!isnull(new_name))
+ bluespace_network_name = new_name
+ else
+ return
+
+/obj/machinery/atmospherics/pipe/bluespace/layer1
+ piping_layer = 1
+ icon_state = "blue_map-1"
+
+/obj/machinery/atmospherics/pipe/bluespace/layer2
+ piping_layer = 2
+ icon_state = "blue_map-2"
+
+/obj/machinery/atmospherics/pipe/bluespace/layer3
+ piping_layer = 3
+ icon_state = "blue_map-3"
diff --git a/sandcode/code/modules/research/designs/mechfabricator_designs.dm b/sandcode/code/modules/research/designs/mechfabricator_designs.dm
new file mode 100644
index 000000000000..a41bef3e5d5a
--- /dev/null
+++ b/sandcode/code/modules/research/designs/mechfabricator_designs.dm
@@ -0,0 +1,8 @@
+/datum/design/borg_upgrade_bsrpd
+ name = "Cyborg Upgrade (Bluespace RPD)"
+ id = "borg_upgrade_bsrpd"
+ build_type = MECHFAB
+ build_path = /obj/item/borg/upgrade/bsrpd
+ materials = list(/datum/material/iron = 1000, /datum/material/glass = 1000, /datum/material/bluespace = 500)
+ construction_time = 100
+ category = list("Cyborg Upgrade Modules")
diff --git a/sandcode/code/modules/research/designs/tool_designs.dm b/sandcode/code/modules/research/designs/tool_designs.dm
new file mode 100644
index 000000000000..a4b644d6d78a
--- /dev/null
+++ b/sandcode/code/modules/research/designs/tool_designs.dm
@@ -0,0 +1,9 @@
+/datum/design/bsrpd
+ name = "Bluespace Rapid Pipe Dispenser"
+ desc = "A tool that can construct and deconstruct pipes on the fly."
+ id = "bsrpd"
+ build_type = PROTOLATHE
+ materials = list(/datum/material/iron = 75000, /datum/material/glass = 37500, /datum/material/bluespace = 1000)
+ build_path = /obj/item/pipe_dispenser/bluespace // Skyrat edit
+ category = list("Tool Designs")
+ departmental_flags = DEPARTMENTAL_FLAG_ENGINEERING
diff --git a/sandcode/code/modules/research/techweb/all_nodes.dm b/sandcode/code/modules/research/techweb/all_nodes.dm
index 78fc61c28579..29908610da46 100644
--- a/sandcode/code/modules/research/techweb/all_nodes.dm
+++ b/sandcode/code/modules/research/techweb/all_nodes.dm
@@ -46,3 +46,8 @@
prereq_ids = list("alien_bio")
design_ids = list("ci-toolset-adv","ci-surgery-adv")
research_costs = list(TECHWEB_POINT_TYPE_GENERIC = 5000)
+
+/datum/techweb_node/bluespace_portal/New()
+ design_ids += "borg_upgrade_bsrpd"
+ design_ids += "bsrpd"
+ . = ..()
diff --git a/sandcode/code/modules/research/techweb/bluespace_nodes.dm b/sandcode/code/modules/research/techweb/bluespace_nodes.dm
new file mode 100644
index 000000000000..a5878292a3bb
--- /dev/null
+++ b/sandcode/code/modules/research/techweb/bluespace_nodes.dm
@@ -0,0 +1,4 @@
+/datum/techweb_node/bluespace_portal/New()
+ design_ids += "borg_upgrade_bsrpd"
+ design_ids += "bsrpd"
+ . = ..()
diff --git a/sandcode/icons/mob/inhands/equipment/tools_lefthand.dmi b/sandcode/icons/mob/inhands/equipment/tools_lefthand.dmi
new file mode 100644
index 000000000000..70a0ff4700f2
Binary files /dev/null and b/sandcode/icons/mob/inhands/equipment/tools_lefthand.dmi differ
diff --git a/sandcode/icons/mob/inhands/equipment/tools_righthand.dmi b/sandcode/icons/mob/inhands/equipment/tools_righthand.dmi
new file mode 100644
index 000000000000..99f0d2d58ff0
Binary files /dev/null and b/sandcode/icons/mob/inhands/equipment/tools_righthand.dmi differ
diff --git a/sandcode/icons/obj/atmospherics/pipes/bluespace.dmi b/sandcode/icons/obj/atmospherics/pipes/bluespace.dmi
new file mode 100644
index 000000000000..56d9a3ceada3
Binary files /dev/null and b/sandcode/icons/obj/atmospherics/pipes/bluespace.dmi differ
diff --git a/sandcode/icons/obj/tools.dmi b/sandcode/icons/obj/tools.dmi
index bbc7e1ce8194..2a181409c6ad 100644
Binary files a/sandcode/icons/obj/tools.dmi and b/sandcode/icons/obj/tools.dmi differ
diff --git a/tgstation.dme b/tgstation.dme
index 4858a94d57f7..bbe9ddd31b7d 100644
--- a/tgstation.dme
+++ b/tgstation.dme
@@ -3495,14 +3495,18 @@
#include "sandcode\code\datums\traits\negative.dm"
#include "sandcode\code\datums\traits\neutral.dm"
#include "sandcode\code\game\area\ship_area.dm"
+#include "sandcode\code\game\machinery\pipe\construction.dm"
#include "sandcode\code\game\mecha\mech_fabricator.dm"
#include "sandcode\code\game\objects\effects\contraband.dm"
+#include "sandcode\code\game\objects\items\BSRPD.dm"
#include "sandcode\code\game\objects\items\circuitboards\computer_circuitboards.dm"
#include "sandcode\code\game\objects\items\circuitboards\machine_circuitboards.dm"
#include "sandcode\code\game\objects\items\devices\extra_arm.dm"
#include "sandcode\code\game\objects\items\devices\floor_painter.dm"
+#include "sandcode\code\game\objects\items\robot\robot_upgrades.dm"
#include "sandcode\code\game\objects\items\storage\backpack.dm"
#include "sandcode\code\game\objects\items\storage\bags.dm"
+#include "sandcode\code\modules\atmospherics\machinery\pipes\bluespace.dm"
#include "sandcode\code\modules\cargo\packs\emergency.dm"
#include "sandcode\code\modules\clothing\masks\miscellaneous.dm"
#include "sandcode\code\modules\crafting\recipes\recipes_misc.dm"
@@ -3520,9 +3524,12 @@
#include "sandcode\code\modules\research\designs\autolathe_designs.dm"
#include "sandcode\code\modules\research\designs\biogenerator_designs.dm"
#include "sandcode\code\modules\research\designs\machine_designs.dm"
+#include "sandcode\code\modules\research\designs\mechfabricator_designs.dm"
#include "sandcode\code\modules\research\designs\misc_designs.dm"
+#include "sandcode\code\modules\research\designs\tool_designs.dm"
#include "sandcode\code\modules\research\designs\weapon_designs.dm"
#include "sandcode\code\modules\research\techweb\all_nodes.dm"
+#include "sandcode\code\modules\research\techweb\bluespace_nodes.dm"
#include "sandcode\code\modules\shuttle\spaceship_navigation_beacon.dm"
#include "sandcode\code\modules\spells\spell_types\shapeshift.dm"
#include "sandcode\code\modules\surgery\organs\augments_arms.dm"