mirror of
https://github.com/vgstation-coders/vgstation13.git
synced 2025-12-10 18:32:03 +00:00
Moved the spacecraft folder into the unused section, moved syndiebeacon into machinery. Research moved into Modules. Virus2 moved into WIP - is anyone even working on this, it looks almost done? Computer2,optics,pda2,experimental moved unto unused. WIP Chemistry things moved into Chemical Module Cameras.dm moved into weapons GameKit.dm moved into unused BrokenInHands.dm moved into unused Removed Grillify.dm Moved all of the files listed as unused in the mining module to unused Removed several empty folders in modules Moved cloning.dm into machinery Moved NewBan.dm into admin Changed humanoid aliens new_life.dm into life.dm Moved beast mob into unused Moved hivebot into unused Moved carpedexplosion.dm into unused Moved ai_lockdown.dm verb into unused and removed it from the AIs verb list as it didn't actually do anything. Removed mastercontroler2.dm Moved savefile.dm from human to new_player Bugfix People spawning on the starting screen on rev/cult should be fixed. git-svn-id: http://tgstation13.googlecode.com/svn/trunk@1964 316c924e-a436-60f5-8080-3fe189b3f50e
263 lines
6.9 KiB
Plaintext
263 lines
6.9 KiB
Plaintext
/datum/computer
|
|
var/size = 4.0
|
|
var/obj/item/weapon/disk/data/holder = null
|
|
var/datum/computer/folder/holding_folder = null
|
|
folder
|
|
name = "Folder"
|
|
size = 0.0
|
|
var/gen = 0
|
|
Del()
|
|
for(var/datum/computer/F in src.contents)
|
|
del(F)
|
|
..()
|
|
proc
|
|
add_file(datum/computer/R)
|
|
if(!holder || holder.read_only || !R)
|
|
return 0
|
|
if(istype(R,/datum/computer/folder) && (src.gen>=10))
|
|
return 0
|
|
if((holder.file_used + R.size) <= holder.file_amount)
|
|
src.contents.Add(R)
|
|
R.holder = holder
|
|
R.holding_folder = src
|
|
src.holder.file_used -= src.size
|
|
src.size += R.size
|
|
src.holder.file_used += src.size
|
|
if(istype(R,/datum/computer/folder))
|
|
R:gen = (src.gen+1)
|
|
return 1
|
|
return 0
|
|
|
|
remove_file(datum/computer/R)
|
|
if(holder && !holder.read_only || !R)
|
|
// world << "Removing file [R]. File_used: [src.holder.file_used]"
|
|
src.contents.Remove(R)
|
|
src.holder.file_used -= src.size
|
|
src.size -= R.size
|
|
src.holder.file_used += src.size
|
|
src.holder.file_used = max(src.holder.file_used, 0)
|
|
// world << "Removed file [R]. File_used: [src.holder.file_used]"
|
|
return 1
|
|
return 0
|
|
file
|
|
name = "File"
|
|
var/extension = "FILE" //Differentiate between types of files, why not
|
|
proc
|
|
copy_file_to_folder(datum/computer/folder/newfolder)
|
|
if(!newfolder || (!istype(newfolder)) || (!newfolder.holder) || (newfolder.holder.read_only))
|
|
return 0
|
|
|
|
if((newfolder.holder.file_used + src.size) <= newfolder.holder.file_amount)
|
|
var/datum/computer/file/newfile = new src.type
|
|
|
|
for(var/V in src.vars)
|
|
if (issaved(src.vars[V]) && V != "holder")
|
|
newfile.vars[V] = src.vars[V]
|
|
|
|
if(!newfolder.add_file(newfile))
|
|
del(newfile)
|
|
|
|
return 1
|
|
|
|
return 0
|
|
|
|
|
|
Del()
|
|
if(holder && holding_folder)
|
|
holding_folder.remove_file(src)
|
|
..()
|
|
|
|
|
|
/datum/computer/file/computer_program
|
|
name = "blank program"
|
|
extension = "PROG"
|
|
//var/size = 4.0
|
|
//var/obj/item/weapon/disk/data/holder = null
|
|
var/obj/machinery/computer2/master = null
|
|
var/active_icon = null
|
|
var/id_tag = null
|
|
var/list/req_access = list()
|
|
|
|
New(obj/holding as obj)
|
|
if(holding)
|
|
src.holder = holding
|
|
|
|
if(istype(src.holder.loc,/obj/machinery/computer2))
|
|
src.master = src.holder.loc
|
|
|
|
Del()
|
|
if(master)
|
|
master.processing_programs.Remove(src)
|
|
..()
|
|
|
|
proc
|
|
return_text()
|
|
if((!src.holder) || (!src.master))
|
|
return 1
|
|
|
|
if((!istype(holder)) || (!istype(master)))
|
|
return 1
|
|
|
|
if(master.stat & (NOPOWER|BROKEN))
|
|
return 1
|
|
|
|
if(!(holder in src.master.contents))
|
|
//world << "Holder [holder] not in [master] of prg:[src]"
|
|
if(master.active_program == src)
|
|
master.active_program = null
|
|
return 1
|
|
|
|
if(!src.holder.root)
|
|
src.holder.root = new /datum/computer/folder
|
|
src.holder.root.holder = src
|
|
src.holder.root.name = "root"
|
|
|
|
return 0
|
|
|
|
process()
|
|
if((!src.holder) || (!src.master))
|
|
return 1
|
|
|
|
if((!istype(holder)) || (!istype(master)))
|
|
return 1
|
|
|
|
if(!(holder in src.master.contents))
|
|
if(master.active_program == src)
|
|
master.active_program = null
|
|
master.processing_programs.Remove(src)
|
|
return 1
|
|
|
|
if(!src.holder.root)
|
|
src.holder.root = new /datum/computer/folder
|
|
src.holder.root.holder = src
|
|
src.holder.root.name = "root"
|
|
|
|
return 0
|
|
|
|
receive_command(obj/source, command, datum/signal/signal)
|
|
if((!src.holder) || (!src.master) || (!source) || (source != src.master))
|
|
return 1
|
|
|
|
if((!istype(holder)) || (!istype(master)))
|
|
return 1
|
|
|
|
if(master.stat & (NOPOWER|BROKEN))
|
|
return 1
|
|
|
|
if(!(holder in src.master.contents))
|
|
if(master.active_program == src)
|
|
master.active_program = null
|
|
return 1
|
|
|
|
return 0
|
|
|
|
peripheral_command(command, datum/signal/signal)
|
|
if(master)
|
|
master.send_command(command, signal)
|
|
else
|
|
del(signal)
|
|
|
|
transfer_holder(obj/item/weapon/disk/data/newholder,datum/computer/folder/newfolder)
|
|
|
|
if((newholder.file_used + src.size) > newholder.file_amount)
|
|
return 0
|
|
|
|
if(!newholder.root)
|
|
newholder.root = new /datum/computer/folder
|
|
newholder.root.holder = newholder
|
|
newholder.root.name = "root"
|
|
|
|
if(!newfolder)
|
|
newfolder = newholder.root
|
|
|
|
if((src.holder && src.holder.read_only) || newholder.read_only)
|
|
return 0
|
|
|
|
if((src.holder) && (src.holder.root))
|
|
src.holder.root.remove_file(src)
|
|
|
|
newfolder.add_file(src)
|
|
|
|
if(istype(newholder.loc,/obj/machinery/computer2))
|
|
src.master = newholder.loc
|
|
|
|
//world << "Setting [src.holder] to [newholder]"
|
|
src.holder = newholder
|
|
return 1
|
|
|
|
//Check access per program.
|
|
allowed(mob/M)
|
|
//check if it doesn't require any access at all
|
|
if(src.check_access(null))
|
|
return 1
|
|
if(istype(M, /mob/living/silicon))
|
|
//AI can do whatever he wants
|
|
return 1
|
|
else if(istype(M, /mob/living/carbon/human))
|
|
var/mob/living/carbon/human/H = M
|
|
//if they are holding or wearing a card that has access, that works
|
|
if(src.check_access(H.equipped()) || src.check_access(H.wear_id))
|
|
return 1
|
|
else if(istype(M, /mob/living/carbon/monkey))
|
|
var/mob/living/carbon/monkey/george = M
|
|
//they can only hold things :(
|
|
if(george.equipped() && istype(george.equipped(), /obj/item/weapon/card/id) && src.check_access(george.equipped()))
|
|
return 1
|
|
return 0
|
|
|
|
check_access(obj/item/weapon/card/id/I)
|
|
if(!src.req_access) //no requirements
|
|
return 1
|
|
if(!istype(src.req_access, /list)) //something's very wrong
|
|
return 1
|
|
|
|
var/list/L = src.req_access
|
|
if(!L.len) //no requirements
|
|
return 1
|
|
if(!I || !istype(I, /obj/item/weapon/card/id) || !I.access) //not ID or no access
|
|
return 0
|
|
for(var/req in src.req_access)
|
|
if(!(req in I.access)) //doesn't have this access
|
|
return 0
|
|
return 1
|
|
|
|
Topic(href, href_list)
|
|
if((!src.holder) || (!src.master))
|
|
return 1
|
|
|
|
if((!istype(holder)) || (!istype(master)))
|
|
return 1
|
|
|
|
if(master.stat & (NOPOWER|BROKEN))
|
|
return 1
|
|
|
|
if(src.master.active_program != src)
|
|
return 1
|
|
|
|
if ((!usr.contents.Find(src.master) && (!in_range(src.master, usr) || !istype(src.master.loc, /turf))) && (!istype(usr, /mob/living/silicon)))
|
|
return 1
|
|
|
|
if(!(holder in src.master.contents))
|
|
if(master.active_program == src)
|
|
master.active_program = null
|
|
return 1
|
|
|
|
usr.machine = src.master
|
|
|
|
if (href_list["close"])
|
|
usr.machine = null
|
|
usr << browse(null, "window=comp2")
|
|
return 0
|
|
|
|
if (href_list["quit"])
|
|
// src.master.processing_programs.Remove(src)
|
|
if(src.master.host_program && src.master.host_program.holder && (src.master.host_program.holder in src.master.contents))
|
|
src.master.run_program(src.master.host_program)
|
|
src.master.updateUsrDialog()
|
|
return 1
|
|
else
|
|
src.master.active_program = null
|
|
src.master.updateUsrDialog()
|
|
return 1
|
|
|
|
return 0 |