mirror of
https://github.com/Aurorastation/Aurora.3.git
synced 2025-12-27 02:22:26 +00:00
* Replace SSingulo with SScalamity; processing cleanup
- SScalamity now handles blobs as well as singularity-types.
- Processing subtypes have been simplified to not require a stop_processing definition.
* this is probably important
* Remove cascade disabling SSgarbage
* Fixed a bug where dust() did not qdel the target mob
* Misc fixes
* Fix decals surviving break-to-plating
* Subsystem flag tweaks
* Apparently subsystems are new'd before config is.
* Fix paper icons
* Speculative fix for insane lag
* Better machinery stat
* Make organs not use SSoverlay
* Misc bugfixes & tweaks
* Nightmode fixes
* Changelog for SMC
* Port /tg/'s improved MC crash handling
* Add some more SS Recover() procs
* supply_controller -> SScargo
* More New() -> Initialize()
* pAI and robot construction overlays
* Fix cargo unit tests
* Merge the DMM Suite's atom/New() into atoms_init
* Lighting pre-baking
* Lighting initialization logging
* Fix some bad SS init orders
* Fix SSlighting logging; rename Processes to MC
* Speculative fix for insane GC lag
* Prebaked openturf/icon_smooth & fix lighting prebake
* SS init status; SSatoms LATEQDEL
* Fix bug with MC init stat panel
* Fix parallax
* Misc
* Ignore SS_NO_DISPLAY during init
* apparently this is important
* REEEEEE
* Image GC fixes; broadcaster radio-new sanity
* RCON Cleanup
* Move pAI recruiter into subsystem
* Move global solars list into sun subsystem
* Make chickens not use a global
* Demote SSdisposals to SS_BACKGROUND; garbage-debug cleanup
* Speed up space init a little
* Fix bad timer flags on floor drying
* Subsystem panic-restart verb for mins
* Explosion speedup
* Minor subsystem & MC logging tweaks
* SSopenturf improvements
* Make pipenet actually initialize (whoops)
* Minor tweaks
* Implement lighting rounding
* comments are hard okay
* Minor lattice tweaks
* Fix some timer issues & better closet init
* Timer sanity
* Request console tweaks + Storage init sanity
* Minor SSmachiner RCON improvements
* Further reduce world-start timer count
* Standardize subsystem logging
* Garbage hard delete profiling from /tg/
* Timer hang detection & recovery
* Log machines that sleep in process() and fuck up SSmachinery
* Fix an issue with external airlocks sleeping in process()
* Failsafe logging
* Minor tweaks
* Revert "Request console tweaks + Storage init sanity"
This reverts commit 98d3579e35.
* Re-implement RC changes
* Fix SQL FT saving
* Fix SSmachinery sleep in disposals
* Minor SS tweaks
* Paper fixes
* Blood drying fixes
* Merge gameticker and SSticker
* Minor global list init cleanup
* Lagcheck biogenerator & bags
* Tweak SScargo init order; RIG Initialize()
* Caching tweaks
* Remove rogue comma
* Initialize fixes
* Lighting destroy cleanup
* Fix emagging airlocks
* Initial SSicon implementation
* Tweaks & Fixes
* Fire + Air alarm queued icon updates
* Overlays + Queued icon cleanup
* Runtime & background fixes
* Kill some meaningless set statements
* Kill some image qdels
* Bump up lighting rounding val
* Fix adv. scanner destroy runtimes
* Remove unneeded icon update limiting
* Move icon smoothing into helpers
* Show a warning if DM 510 compiles without memory leak hack enabled
* Re-organize subsystems & MC defines a little
* Airlock SFX
* Log of Changes
* Make SSicon_update disable itself when not doing anything
* Fix respawn verb runtime when used early in server-init
* Add more information to MC's stat_entry()
* Replace direct refernces to gcDestroyed with QDEL* macros
* plant_controller -> SSplants
* More plant tweaks
* Add more humor to changelog
* Move parallax globals into SSparallax
* Lighting responsiveness tweaks
* Fix parallax init order & better MC init panel stat
* Make mobs GC
* More overlays + Remove intercom spawn()
* SSfast_process; make pinpointers not use spawn-recursion to process
Also made the SM Cascade beach process with SSprocessing instead of a spawn loop.
* Update changelog
* Mob GC tweaks
* Del() cleanup
* Fix insomniac ZAS connection edges
* Minor pAI cleanup
* Convert more things to SSoverlay; fix duplicated overlay in field gens
* SM Bluespace turf tweaks
* Update SSgarbage debug globals list
* Human-type qdel tweaks
* Subsystem suspension; stat_entry improvements
* SQL Statistics cleanup
* Fix runtimes with ambrosia
* More disable() -> suspend(); fix nightmode again
* Human qdel fix; minor tweaks
* Update turbolift to work with StonedMC
* Make lifts use timers instead of a subsystem
* Make SSassets start earlier
* Convert the radio controller into a subsystem
* Fix some missing CHECK_TICKs in asteroid generation
* MC stat tweaks; make shouldnt_see a typecache
* Kill some redundant debug-controller entries
* radio_controller -> SSradio
* Better SSgarbage hard-del logging from /tg/ upstream
* Logging tweaks + GELF
* Misc client caching improvements
* Slime SSoverlay
* Oven icon fixes
* Implant fixes
- Death implants will no longer spam Common on death of user.
- Death implants should handle a deleted user better.
* Holder tweaks + Welding tool Initialize()
* Fix some bad subsystem logging
* Fix suit cooling units spawning without cells
* Starlight tweaks
* Gibber infinite gib fix
* More SSoverlay stuff
* Make crates use CUT_OVERLAY_IN
* Make SSarrivals suspend instead of disable
* Make openturf use split/phased tick checks
* Speculative fix for unwet timer runtimes
* Blood overlay tweaks/fixes
* Update crusher to play nice with SMC + SSoverlay
* Openturf improvements and fixes
* Minor turbolift tweaks
* Lighting performance improvements + ChangeTurf tweaks
* this is probably important
* Fix wall weld noises on changeturf
* More ChangeTurf tweaks
* Explosion tweaks
* Pre-game lobby tweaks
* Openturf tweaks
* Prevent admins from starting the game before init finishes
* Fix Travis
* Kill an unused var
* Fix ChangeTurf runtimes on openturfs
* Fixes
* Browser datum fixes, asset caching
* Update changelog
* Changelog
* Lobby tweaks
* Ticker tweaks; kill ticker var
* Further lobby tweaks
* Cascade tweaks
* air_master -> SSair
* Reduce overhead from radio autosay
* alarm_manager -> SSalarm
* bomb_processor -> SSexplosives
* corp_regs -> SSlaw
* ZAS overlay fixes
* Small wall icon optimization
* Fix effects master
* Assembly tweaks
* Megavend fixes
* Shuttle fixes
* Camera alert performance improvements
* Fix some world.log spam from lighting overlays
* Fix some Initialize() procs
* Openspace responsiveness tweaks
* Make HE pipes animate through openturfs
* Kill a spawn
343 lines
11 KiB
Plaintext
343 lines
11 KiB
Plaintext
/* Windoor (window door) assembly -Nodrak
|
|
* Step 1: Create a windoor out of rglass
|
|
* Step 2: Add r-glass to the assembly to make a secure windoor (Optional)
|
|
* Step 3: Rotate or Flip the assembly to face and open the way you want
|
|
* Step 4: Wrench the assembly in place
|
|
* Step 5: Add cables to the assembly
|
|
* Step 6: Set access for the door.
|
|
* Step 7: Screwdriver the door to complete
|
|
*/
|
|
|
|
|
|
obj/structure/windoor_assembly
|
|
name = "windoor assembly"
|
|
icon = 'icons/obj/doors/windoor.dmi'
|
|
icon_state = "l_windoor_assembly01"
|
|
anchored = 0
|
|
density = 0
|
|
dir = NORTH
|
|
w_class = 3
|
|
flags = ON_BORDER
|
|
|
|
var/obj/item/weapon/airlock_electronics/electronics = null
|
|
|
|
//Vars to help with the icon's name
|
|
var/facing = "l" //Does the windoor open to the left or right?
|
|
var/secure = "" //Whether or not this creates a secure windoor
|
|
var/state = "01" //How far the door assembly has progressed in terms of sprites
|
|
|
|
obj/structure/windoor_assembly/New(Loc, start_dir=NORTH, constructed=0)
|
|
..()
|
|
if(constructed)
|
|
state = "01"
|
|
anchored = 0
|
|
switch(start_dir)
|
|
if(NORTH, SOUTH, EAST, WEST)
|
|
set_dir(start_dir)
|
|
else //If the user is facing northeast. northwest, southeast, southwest or north, default to north
|
|
set_dir(NORTH)
|
|
|
|
update_nearby_tiles(need_rebuild=1)
|
|
|
|
obj/structure/windoor_assembly/Destroy()
|
|
density = 0
|
|
update_nearby_tiles()
|
|
return ..()
|
|
|
|
/obj/structure/windoor_assembly/update_icon()
|
|
icon_state = "[facing]_[secure]windoor_assembly[state]"
|
|
|
|
/obj/structure/windoor_assembly/CanPass(atom/movable/mover, turf/target, height=0, air_group=0)
|
|
if(istype(mover) && mover.checkpass(PASSGLASS))
|
|
return 1
|
|
if(get_dir(loc, target) == dir) //Make sure looking at appropriate border
|
|
if(air_group) return 0
|
|
return !density
|
|
else
|
|
return 1
|
|
|
|
/obj/structure/windoor_assembly/CheckExit(atom/movable/mover as mob|obj, turf/target as turf)
|
|
if(istype(mover) && mover.checkpass(PASSGLASS))
|
|
return 1
|
|
if(get_dir(loc, target) == dir)
|
|
return !density
|
|
else
|
|
return 1
|
|
|
|
|
|
/obj/structure/windoor_assembly/attackby(obj/item/W as obj, mob/user as mob)
|
|
//I really should have spread this out across more states but thin little windoors are hard to sprite.
|
|
switch(state)
|
|
if("01")
|
|
if(istype(W, /obj/item/weapon/weldingtool) && !anchored )
|
|
var/obj/item/weapon/weldingtool/WT = W
|
|
if (WT.remove_fuel(0,user))
|
|
user.visible_message("[user] dissassembles the windoor assembly.", "You start to dissassemble the windoor assembly.")
|
|
playsound(src.loc, 'sound/items/Welder2.ogg', 50, 1)
|
|
|
|
if(do_after(user, 40))
|
|
if(!src || !WT.isOn()) return
|
|
user << "<span class='notice'>You dissasembled the windoor assembly!</span>"
|
|
new /obj/item/stack/material/glass/reinforced(get_turf(src), 5)
|
|
if(secure)
|
|
new /obj/item/stack/rods(get_turf(src), 4)
|
|
qdel(src)
|
|
else
|
|
user << "<span class='notice'>You need more welding fuel to dissassemble the windoor assembly.</span>"
|
|
return
|
|
|
|
//Wrenching an unsecure assembly anchors it in place. Step 4 complete
|
|
if(istype(W, /obj/item/weapon/wrench) && !anchored)
|
|
playsound(src.loc, 'sound/items/Ratchet.ogg', 100, 1)
|
|
user.visible_message("[user] secures the windoor assembly to the floor.", "You start to secure the windoor assembly to the floor.")
|
|
|
|
if(do_after(user, 40))
|
|
if(!src) return
|
|
user << "<span class='notice'>You've secured the windoor assembly!</span>"
|
|
src.anchored = 1
|
|
if(src.secure)
|
|
src.name = "Secure Anchored Windoor Assembly"
|
|
else
|
|
src.name = "Anchored Windoor Assembly"
|
|
|
|
//Unwrenching an unsecure assembly un-anchors it. Step 4 undone
|
|
else if(istype(W, /obj/item/weapon/wrench) && anchored)
|
|
playsound(src.loc, 'sound/items/Ratchet.ogg', 100, 1)
|
|
user.visible_message("[user] unsecures the windoor assembly to the floor.", "You start to unsecure the windoor assembly to the floor.")
|
|
|
|
if(do_after(user, 40))
|
|
if(!src) return
|
|
user << "<span class='notice'>You've unsecured the windoor assembly!</span>"
|
|
src.anchored = 0
|
|
if(src.secure)
|
|
src.name = "Secure Windoor Assembly"
|
|
else
|
|
src.name = "Windoor Assembly"
|
|
|
|
//Adding plasteel makes the assembly a secure windoor assembly. Step 2 (optional) complete.
|
|
else if(istype(W, /obj/item/stack/rods) && !secure)
|
|
var/obj/item/stack/rods/R = W
|
|
if(R.get_amount() < 4)
|
|
user << "<span class='warning'>You need more rods to do this.</span>"
|
|
return
|
|
user << "<span class='notice'>You start to reinforce the windoor with rods.</span>"
|
|
|
|
if(do_after(user,40) && !secure)
|
|
if (R.use(4))
|
|
user << "<span class='notice'>You reinforce the windoor.</span>"
|
|
src.secure = "secure_"
|
|
if(src.anchored)
|
|
src.name = "Secure Anchored Windoor Assembly"
|
|
else
|
|
src.name = "Secure Windoor Assembly"
|
|
|
|
//Adding cable to the assembly. Step 5 complete.
|
|
else if(istype(W, /obj/item/stack/cable_coil) && anchored)
|
|
user.visible_message("[user] wires the windoor assembly.", "You start to wire the windoor assembly.")
|
|
|
|
var/obj/item/stack/cable_coil/CC = W
|
|
if(do_after(user, 40))
|
|
if (CC.use(1))
|
|
user << "<span class='notice'>You wire the windoor!</span>"
|
|
src.state = "02"
|
|
if(src.secure)
|
|
src.name = "Secure Wired Windoor Assembly"
|
|
else
|
|
src.name = "Wired Windoor Assembly"
|
|
else
|
|
..()
|
|
|
|
if("02")
|
|
|
|
//Removing wire from the assembly. Step 5 undone.
|
|
if(istype(W, /obj/item/weapon/wirecutters) && !src.electronics)
|
|
playsound(src.loc, 'sound/items/Wirecutter.ogg', 100, 1)
|
|
user.visible_message("[user] cuts the wires from the airlock assembly.", "You start to cut the wires from airlock assembly.")
|
|
|
|
if(do_after(user, 40))
|
|
if(!src) return
|
|
|
|
user << "<span class='notice'>You cut the windoor wires.!</span>"
|
|
new/obj/item/stack/cable_coil(get_turf(user), 1)
|
|
src.state = "01"
|
|
if(src.secure)
|
|
src.name = "Secure Anchored Windoor Assembly"
|
|
else
|
|
src.name = "Anchored Windoor Assembly"
|
|
|
|
//Adding airlock electronics for access. Step 6 complete.
|
|
else if(istype(W, /obj/item/weapon/airlock_electronics) && W:icon_state != "door_electronics_smoked")
|
|
var/obj/item/weapon/airlock_electronics/EL = W
|
|
if(!EL.inuse)
|
|
playsound(src.loc, 'sound/items/Screwdriver.ogg', 100, 1)
|
|
user.visible_message("[user] installs the electronics into the airlock assembly.", "You start to install electronics into the airlock assembly.")
|
|
EL.inuse = 1
|
|
if(do_after(user, 40))
|
|
EL.inuse = 0
|
|
if(!src) return
|
|
user.drop_item()
|
|
EL.forceMove(src)
|
|
user << "<span class='notice'>You've installed the airlock electronics!</span>"
|
|
src.name = "Near finished Windoor Assembly"
|
|
src.electronics = EL
|
|
else
|
|
EL.inuse = 0
|
|
|
|
//Screwdriver to remove airlock electronics. Step 6 undone.
|
|
else if(istype(W, /obj/item/weapon/screwdriver) && src.electronics)
|
|
playsound(src.loc, 'sound/items/Screwdriver.ogg', 100, 1)
|
|
user.visible_message("[user] removes the electronics from the airlock assembly.", "You start to uninstall electronics from the airlock assembly.")
|
|
|
|
if(do_after(user, 40))
|
|
if(!src || !src.electronics) return
|
|
user << "<span class='notice'>You've removed the airlock electronics!</span>"
|
|
if(src.secure)
|
|
src.name = "Secure Wired Windoor Assembly"
|
|
else
|
|
src.name = "Wired Windoor Assembly"
|
|
var/obj/item/weapon/airlock_electronics/ae = electronics
|
|
electronics = null
|
|
ae.loc = src.loc
|
|
|
|
//Crowbar to complete the assembly, Step 7 complete.
|
|
else if(istype(W, /obj/item/weapon/crowbar))
|
|
if(!src.electronics)
|
|
usr << "<span class='warning'>The assembly is missing electronics.</span>"
|
|
return
|
|
usr << browse(null, "window=windoor_access")
|
|
playsound(src.loc, 'sound/items/Crowbar.ogg', 100, 1)
|
|
user.visible_message("[user] pries the windoor into the frame.", "You start prying the windoor into the frame.")
|
|
|
|
if(do_after(user, 40))
|
|
|
|
if(!src) return
|
|
|
|
density = 1 //Shouldn't matter but just incase
|
|
user << "<span class='notice'>You finish the windoor!</span>"
|
|
|
|
if(secure)
|
|
var/obj/machinery/door/window/brigdoor/windoor = new /obj/machinery/door/window/brigdoor(src.loc)
|
|
if(src.facing == "l")
|
|
windoor.icon_state = "leftsecureopen"
|
|
windoor.base_state = "leftsecure"
|
|
else
|
|
windoor.icon_state = "rightsecureopen"
|
|
windoor.base_state = "rightsecure"
|
|
windoor.set_dir(src.dir)
|
|
windoor.density = 0
|
|
|
|
if(src.electronics.one_access)
|
|
windoor.req_access = null
|
|
windoor.req_one_access = src.electronics.conf_access
|
|
else
|
|
windoor.req_access = src.electronics.conf_access
|
|
windoor.electronics = src.electronics
|
|
src.electronics.loc = windoor
|
|
else
|
|
var/obj/machinery/door/window/windoor = new /obj/machinery/door/window(src.loc)
|
|
if(src.facing == "l")
|
|
windoor.icon_state = "leftopen"
|
|
windoor.base_state = "left"
|
|
else
|
|
windoor.icon_state = "rightopen"
|
|
windoor.base_state = "right"
|
|
windoor.set_dir(src.dir)
|
|
windoor.density = 0
|
|
|
|
if(src.electronics.one_access)
|
|
windoor.req_access = null
|
|
windoor.req_one_access = src.electronics.conf_access
|
|
else
|
|
windoor.req_access = src.electronics.conf_access
|
|
windoor.electronics = src.electronics
|
|
src.electronics.loc = windoor
|
|
|
|
|
|
qdel(src)
|
|
|
|
|
|
else
|
|
..()
|
|
|
|
//Update to reflect changes(if applicable)
|
|
update_icon()
|
|
|
|
|
|
//Rotates the windoor assembly clockwise
|
|
//These directions are fucked up, apparently dm rotates anticlockwise by default
|
|
/obj/structure/windoor_assembly/verb/rotate()
|
|
set name = "Rotate Windoor Clockwise"
|
|
set category = "Object"
|
|
set src in oview(1)
|
|
|
|
var/targetdir = turn(src.dir, 270)
|
|
|
|
for(var/obj/obstacle in get_turf(src))
|
|
if (obstacle == src)
|
|
continue
|
|
|
|
if((obstacle.flags & ON_BORDER) && obstacle.dir == targetdir)
|
|
usr << span("danger", "You can't turn the windoor assembly that way, there's already something there!")
|
|
return
|
|
|
|
if (src.anchored)
|
|
usr << "It is fastened to the floor; therefore, you can't rotate it!"
|
|
return 0
|
|
if(src.state != "01")
|
|
update_nearby_tiles(need_rebuild=1) //Compel updates before
|
|
|
|
src.set_dir(targetdir)
|
|
|
|
if(src.state != "01")
|
|
update_nearby_tiles(need_rebuild=1)
|
|
|
|
update_icon()
|
|
return
|
|
|
|
|
|
//Rotates the windoor assembly anticlockwise
|
|
/obj/structure/windoor_assembly/verb/revrotate()
|
|
set name = "Rotate Windoor Anticlockwise"
|
|
set category = "Object"
|
|
set src in oview(1)
|
|
|
|
var/targetdir = turn(src.dir, 90)
|
|
|
|
for(var/obj/obstacle in get_turf(src))
|
|
if (obstacle == src)
|
|
continue
|
|
|
|
if((obstacle.flags & ON_BORDER) && obstacle.dir == targetdir)
|
|
usr << span("danger", "You can't turn the windoor assembly that way, there's already something there!")
|
|
return
|
|
|
|
if (src.anchored)
|
|
usr << "It is fastened to the floor; therefore, you can't rotate it!"
|
|
return 0
|
|
if(src.state != "01")
|
|
update_nearby_tiles(need_rebuild=1) //Compel updates before
|
|
|
|
src.set_dir(targetdir)
|
|
|
|
if(src.state != "01")
|
|
update_nearby_tiles(need_rebuild=1)
|
|
|
|
update_icon()
|
|
return
|
|
|
|
//Flips the windoor assembly, determines whather the door opens to the left or the right
|
|
/obj/structure/windoor_assembly/verb/flip()
|
|
set name = "Flip Windoor Assembly"
|
|
set category = "Object"
|
|
set src in oview(1)
|
|
|
|
if(src.facing == "l")
|
|
usr << "The windoor will now slide to the right."
|
|
src.facing = "r"
|
|
else
|
|
src.facing = "l"
|
|
usr << "The windoor will now slide to the left."
|
|
|
|
update_icon()
|
|
return
|