/datum/computer_file/program
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 2"
Vars | |
alert_able | Whether this program can send alerts while minimized or closed. Used to show a mute button per program in the file manager |
---|---|
alert_pending | Whether to highlight our program in the main screen. Intended for alerts, but loosely available for any need to notify of changed conditions. Think Windows task bar highlighting. Available even if alerts are muted. |
alert_silenced | Whether the user has muted this program's ability to send alerts. |
available_on_ntnet | Whether the program can be downloaded from NTNet. Set to 0 to disable. |
available_on_syndinet | Whether the program can be downloaded from SyndiNet (accessible via emagging the computer). Set to 1 to enable. |
computer | Device that runs this program. |
extended_desc | Short description of this program's function. |
filedesc | User-friendly name of this program. |
filename | File name. FILE NAME MUST BE UNIQUE IF YOU WANT THE PROGRAM TO BE DOWNLOADABLE FROM NTNET! |
ntnet_status | NTNet status, updated every tick by computer running this program. Don't use this for checks if NTNet works, computers do that. Use this for calculations, etc. |
program_icon | Font Awesome icon to use as this program's icon in the modular computer main menu. Defaults to a basic program maximize window icon if not overridden. |
program_icon_state | Program-specific screen icon state |
program_state | PROGRAM_STATE_KILLED or PROGRAM_STATE_BACKGROUND or PROGRAM_STATE_ACTIVE - specifies whether this program is running. |
required_access | List of required accesses to run the program. |
requires_ntnet | Set to 1 for program to require nonstop NTNet connection to run. If NTNet connection is lost program crashes. |
requires_ntnet_feature | Optional, if above is set to 1 checks for specific function of NTNet (currently NTNET_SOFTWAREDOWNLOAD, NTNET_PEERTOPEER, NTNET_SYSTEMCONTROL and NTNET_COMMUNICATION) |
tgui_id | Name of the tgui interface |
transfer_access | List of required access to download or file host the program |
ui_header | Example: "something.gif" - a header image that will be rendered in computer's UI when this program is running at background. Images are taken from /icons/program_icons. Be careful not to use too large images! |
usage_flags | Bitflags (PROGRAM_CONSOLE, PROGRAM_LAPTOP, PROGRAM_TABLET combination) or PROGRAM_ALL |
Procs | |
run_emag | Called by the device when it is emagged. |
Var Details
alert_able
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 39"
Whether this program can send alerts while minimized or closed. Used to show a mute button per program in the file manager
alert_pending
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 43"
Whether to highlight our program in the main screen. Intended for alerts, but loosely available for any need to notify of changed conditions. Think Windows task bar highlighting. Available even if alerts are muted.
alert_silenced
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 41"
Whether the user has muted this program's ability to send alerts.
available_on_ntnet
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 29"
Whether the program can be downloaded from NTNet. Set to 0 to disable.
available_on_syndinet
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 31"
Whether the program can be downloaded from SyndiNet (accessible via emagging the computer). Set to 1 to enable.
computer
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 13"
Device that runs this program.
extended_desc
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 17"
Short description of this program's function.
filedesc
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 15"
User-friendly name of this program.
filename
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 5"
File name. FILE NAME MUST BE UNIQUE IF YOU WANT THE PROGRAM TO BE DOWNLOADABLE FROM NTNET!
ntnet_status
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 25"
NTNet status, updated every tick by computer running this program. Don't use this for checks if NTNet works, computers do that. Use this for calculations, etc.
program_icon
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 37"
Font Awesome icon to use as this program's icon in the modular computer main menu. Defaults to a basic program maximize window icon if not overridden.
program_icon_state
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 19"
Program-specific screen icon state
program_state
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 11"
PROGRAM_STATE_KILLED or PROGRAM_STATE_BACKGROUND or PROGRAM_STATE_ACTIVE - specifies whether this program is running.
required_access
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 7"
List of required accesses to run the program.
requires_ntnet
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 21"
Set to 1 for program to require nonstop NTNet connection to run. If NTNet connection is lost program crashes.
requires_ntnet_feature
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 23"
Optional, if above is set to 1 checks for specific function of NTNet (currently NTNET_SOFTWAREDOWNLOAD, NTNET_PEERTOPEER, NTNET_SYSTEMCONTROL and NTNET_COMMUNICATION)
tgui_id
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 33"
Name of the tgui interface
transfer_access
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 9"
List of required access to download or file host the program
ui_header
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 35"
Example: "something.gif" - a header image that will be rendered in computer's UI when this program is running at background. Images are taken from /icons/program_icons. Be careful not to use too large images!
usage_flags
data:image/s3,"s3://crabby-images/7ff88/7ff885c601007d82d7f5180fb42b5862025ccfec" alt="code/modules/modular_computers/file_system/program.dm 27"
Bitflags (PROGRAM_CONSOLE, PROGRAM_LAPTOP, PROGRAM_TABLET combination) or PROGRAM_ALL
Proc Details
run_emag
Called by the device when it is emagged.
Emagging the device allows certain programs to unlock new functions. However, the program will need to be downloaded first, and then handle the unlock on their own in their run_emag() proc. The device will allow an emag to be run multiple times, so the user can re-emag to run the override again, should they download something new. The run_emag() proc should return TRUE if the emagging affected anything, and FALSE if no change was made (already emagged, or has no emag functions).