Files
Alexis 21b4095dfd [MDB IGNORE] [IDB IGNORE] Upstream Sync - 04/17/2026 (#5453)
Upstream 04/17/2026

fixes https://github.com/Bubberstation/Bubberstation/issues/5549

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: tgstation-ci[bot] <179393467+tgstation-ci[bot]@users.noreply.github.com>
Co-authored-by: ArcaneMusic <41715314+ArcaneMusic@users.noreply.github.com>
Co-authored-by: MrMelbert <51863163+MrMelbert@users.noreply.github.com>
Co-authored-by: Rhials <28870487+Rhials@users.noreply.github.com>
Co-authored-by: rageguy505 <54517726+rageguy505@users.noreply.github.com>
Co-authored-by: LemonInTheDark <58055496+LemonInTheDark@users.noreply.github.com>
Co-authored-by: John Willard <53777086+JohnFulpWillard@users.noreply.github.com>
Co-authored-by: Aliceee2ch <160794176+Aliceee2ch@users.noreply.github.com>
Co-authored-by: Time-Green <7501474+Time-Green@users.noreply.github.com>
Co-authored-by: Tsar-Salat <62388554+Tsar-Salat@users.noreply.github.com>
Co-authored-by: SmArtKar <44720187+SmArtKar@users.noreply.github.com>
Co-authored-by: Maxipat <108554989+Maxipat112@users.noreply.github.com>
Co-authored-by: SyncIt21 <110812394+SyncIt21@users.noreply.github.com>
Co-authored-by: deltanedas <39013340+deltanedas@users.noreply.github.com>
Co-authored-by: SimplyLogan <47579821+loganuk@users.noreply.github.com>
Co-authored-by: loganuk <fakeemail123@aol.com>
Co-authored-by: Leland Kemble <70413276+lelandkemble@users.noreply.github.com>
Co-authored-by: FalloutFalcon <86381784+FalloutFalcon@users.noreply.github.com>
Co-authored-by: Roxy <75404941+TealSeer@users.noreply.github.com>
Co-authored-by: Lucy <lucy@absolucy.moe>
Co-authored-by: siliconOpossum <138069572+siliconOpossum@users.noreply.github.com>
Co-authored-by: Isratosh <Isratosh@hotmail.com>
Co-authored-by: TheRyeGuyWhoWillNowDie <70169560+TheRyeGuyWhoWillNowDie@users.noreply.github.com>
Co-authored-by: Neocloudy <88008002+Neocloudy@users.noreply.github.com>
Co-authored-by: Alexander V. <volas@ya.ru>
Co-authored-by: ElGitificador <168473461+ElGitificador@users.noreply.github.com>
Co-authored-by: Twaticus <46540570+Twaticus@users.noreply.github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Bloop <13398309+vinylspiders@users.noreply.github.com>
Co-authored-by: Cameron Lennox <killer65311@gmail.com>
Co-authored-by: Tim <timothymtorres@gmail.com>
Co-authored-by: Iamgoofball <iamgoofball@gmail.com>
Co-authored-by: Layzu666 <121319428+Layzu666@users.noreply.github.com>
Co-authored-by: Arturlang <24881678+Arturlang@users.noreply.github.com>
Co-authored-by: _0Steven <42909981+00-Steven@users.noreply.github.com>
Co-authored-by: mrmanlikesbt <99309552+mrmanlikesbt@users.noreply.github.com>
Co-authored-by: Ben10Omintrix <138636438+Ben10Omintrix@users.noreply.github.com>
Co-authored-by: John F. Kennedy <54908920+MacaroniCritter@users.noreply.github.com>
Co-authored-by: Cursor <102828457+theselfish@users.noreply.github.com>
Co-authored-by: Josh <josh.adam.powell@gmail.com>
Co-authored-by: Josh Powell <josh.powell@softwire.com>
Co-authored-by: Yobrocharlie <Charliemiller5617@gmail.com>
Co-authored-by: Hardly3D <66234359+Hardly3D@users.noreply.github.com>
Co-authored-by: shayoki <96078776+shayoki@users.noreply.github.com>
Co-authored-by: LT3 <83487515+lessthnthree@users.noreply.github.com>
2026-05-16 00:56:00 +02:00

130 lines
4.2 KiB
Plaintext

/**
* store_file
*
* Adds an already initialized file to the computer, checking if one already exists.
* Returns TRUE if successfully stored, FALSE otherwise.
* user is optional: If set, the action was done by a mob/player
*/
/obj/item/modular_computer/proc/store_file(datum/computer_file/file_storing, mob/user)
if(!file_storing || !istype(file_storing))
return FALSE
if(!can_store_file(file_storing))
return FALSE
// This file is already stored. Don't store it again.
if(file_storing in stored_files)
return FALSE
file_storing.computer = src
used_capacity += file_storing.size
SEND_SIGNAL(file_storing, COMSIG_COMPUTER_FILE_STORE, src, user)
SEND_SIGNAL(src, COMSIG_MODULAR_COMPUTER_FILE_STORE, file_storing, user)
return TRUE
/**
* remove_file
*
* Removes a given file from the computer, if possible.
* Properly checking if the file even exists and is in the computer.
* Returns TRUE if successfully completed, FALSE otherwise
*/
/obj/item/modular_computer/proc/remove_file(datum/computer_file/file_removing)
if(!file_removing || !istype(file_removing))
return FALSE
if(!(file_removing in stored_files))
return FALSE
if(istype(file_removing, /datum/computer_file/program))
var/datum/computer_file/program/program_file = file_removing
program_file.kill_program()
stored_files.Remove(file_removing)
used_capacity -= file_removing.size
SEND_SIGNAL(src, COMSIG_MODULAR_COMPUTER_FILE_DELETE, file_removing)
SEND_SIGNAL(file_removing, COMSIG_COMPUTER_FILE_DELETE, src)
qdel(file_removing)
return TRUE
/**
* can_store_file
*
* Checks if a computer can store a file, as computers can only store unique files.
* returns TRUE if possible, FALSE otherwise.
*/
/obj/item/modular_computer/proc/can_store_file(datum/computer_file/file)
if(!file || !istype(file))
return FALSE
if(file in stored_files)
return FALSE
if(find_file_by_name(file.filename))
return FALSE
// In the unlikely event someone manages to create that many files.
// BYOND is acting weird with numbers above 999 in loops (infinite loop prevention)
if(stored_files.len >= 999)
return FALSE
if((used_capacity + file.size) > max_capacity)
return FALSE
if(!file.can_store_file(src))
return FALSE
return TRUE
/**
* find_file_by_name
*
* Will check all applications in a tablet for files and, if they have \
* the same filename (disregarding extension), will return it.
* If a computer disk is passed instead, it will check the disk over the computer.
*/
/obj/item/modular_computer/proc/find_file_by_name(filename, obj/item/disk/computer/target_disk)
if(!istext(filename))
return null
if(isnull(target_disk))
for(var/datum/computer_file/file as anything in stored_files)
if(file.filename == filename)
return file
else
for(var/datum/computer_file/file as anything in target_disk.stored_files)
if(file.filename == filename)
return file
return null
/**
* find_file_by_full_name
*
* Will check all applications in a tablet for files and, if they have \
* the same filename AND extension, will return it.
* If a computer disk is passed instead, it will check the disk over the computer.
*/
/obj/item/modular_computer/proc/find_file_by_full_name(full_path, obj/item/disk/computer/target_disk)
if(!istext(full_path))
return null
if(isnull(target_disk))
for(var/datum/computer_file/file as anything in stored_files)
if("[file.filename].[file.filetype]" == full_path)
return file
else
for(var/datum/computer_file/file as anything in target_disk.stored_files)
if("[file.filename].[file.filetype]" == full_path)
return file
return null
/**
* find_file_by_uid
*
* Will check all files in this computer and returns the file with the matching uid.
* A file's uid is always unique to them, so this proc is sometimes preferable over find_file_by_name.
* If a computer disk is passed instead, it will check the disk over the computer.
*/
/obj/item/modular_computer/proc/find_file_by_uid(uid, obj/item/disk/computer/target_disk)
if(!isnum(uid))
return null
if(isnull(target_disk))
for(var/datum/computer_file/file as anything in stored_files)
if(file.uid == uid)
return file
else
for(var/datum/computer_file/file as anything in target_disk.stored_files)
if(file.uid == uid)
return file
return null