mirror of
https://github.com/ParadiseSS13/Paradise.git
synced 2025-12-20 15:21:29 +00:00
* Handlers converted, now to fix 3532 compile errors * 3532 compile fixes later, got runtimes on startup * Well the server loads now atleast * Take 2 * Oops
51 lines
1.7 KiB
Plaintext
51 lines
1.7 KiB
Plaintext
GLOBAL_VAR_INIT(file_uid, 0)
|
|
|
|
/datum/computer_file
|
|
var/filename = "NewFile" // Placeholder. No spacebars
|
|
var/filetype = "XXX" // File full names are [filename].[filetype] so like NewFile.XXX in this case
|
|
var/size = 1 // File size in GQ. Integers only!
|
|
var/obj/item/computer_hardware/hard_drive/holder // Holder that contains this file.
|
|
var/unsendable = 0 // Whether the file may be sent to someone via NTNet transfer or other means.
|
|
var/undeletable = 0 // Whether the file may be deleted. Setting to 1 prevents deletion/renaming/etc.
|
|
var/uid // UID of this file
|
|
var/password = "" // Placeholder for password.
|
|
|
|
/datum/computer_file/New()
|
|
..()
|
|
uid = GLOB.file_uid
|
|
GLOB.file_uid++
|
|
|
|
/datum/computer_file/Destroy()
|
|
if(!holder)
|
|
return ..()
|
|
|
|
holder.remove_file(src)
|
|
// holder.holder is the computer that has drive installed. If we are Destroy()ing program that's currently running kill it.
|
|
if(holder.holder && holder.holder.active_program == src)
|
|
holder.holder.kill_program(forced = TRUE)
|
|
holder = null
|
|
return ..()
|
|
|
|
// Returns independent copy of this file.
|
|
/datum/computer_file/proc/clone(rename = 0)
|
|
var/datum/computer_file/temp = new type
|
|
temp.unsendable = unsendable
|
|
temp.undeletable = undeletable
|
|
temp.size = size
|
|
if(rename)
|
|
temp.filename = filename + "(Copy)"
|
|
else
|
|
temp.filename = filename
|
|
temp.filetype = filetype
|
|
temp.password = password
|
|
return temp
|
|
|
|
/datum/computer_file/proc/can_access_file(mob/user, input_password = "")
|
|
if(!password)
|
|
return TRUE
|
|
if(!input_password)
|
|
input_password = sanitize(input(user, "Please enter a password to access file '[filename]':"))
|
|
if(input_password == password)
|
|
return TRUE
|
|
return FALSE
|