Merge pull request #8099 from MistakeNot4892/chirp

Tweaks to emote system to avoid memory overhead and make runtime validation easier.
This commit is contained in:
Atermonera
2021-06-06 02:13:39 -07:00
committed by GitHub
22 changed files with 75 additions and 67 deletions

View File

@@ -396,10 +396,6 @@ var/global/list/valid_bloodtypes = list("A+", "A-", "B+", "B-", "AB+", "AB-", "O
else
pref.body_descriptors[entry] = CLAMP(last_descriptors[entry], 1, LAZYLEN(descriptor.standalone_value_descriptors))
character.update_emotes()
return
/datum/category_item/player_setup_item/general/body/content(var/mob/user)
. = list()
if(!pref.preview_icon)

View File

@@ -24,18 +24,3 @@ var/list/_default_mob_emotes = list(
/decl/emote/audible/moan,
/decl/emote/audible/gnarl,
)
/mob
var/list/usable_emotes
/mob/proc/update_emotes(var/skip_sort)
usable_emotes = list()
for(var/emote in get_default_emotes())
var/decl/emote/emote_datum = decls_repository.get_decl(emote)
if(emote_datum.check_user(src))
usable_emotes[emote_datum.key] = emote_datum
if(!skip_sort)
usable_emotes = sortAssoc(usable_emotes)
/mob/proc/get_default_emotes()
return global._default_mob_emotes

View File

@@ -1,11 +1,7 @@
/datum/species
var/list/default_emotes = list()
/mob/living/carbon/update_emotes(var/skip_sort)
. = ..(skip_sort = TRUE)
if(species)
for(var/emote in species.default_emotes)
var/decl/emote/emote_datum = decls_repository.get_decl(emote)
if(emote_datum.check_user(src))
usable_emotes[emote_datum.key] = emote_datum
usable_emotes = sortAssoc(usable_emotes)
/mob/living/carbon/get_available_emotes()
. = ..()
if(length(species?.default_emotes))
. |= species.default_emotes

View File

@@ -4,7 +4,7 @@
emote_message_1p = "You are sweating heavily."
emote_message_3p = "is sweating heavily."
/decl/emote/exertion/biological/check_user(mob/living/user)
/decl/emote/exertion/biological/mob_can_use(mob/living/user)
if(istype(user) && !user.isSynthetic())
return ..()
return FALSE
@@ -29,7 +29,7 @@
emote_message_1p = "You overstress your actuators."
emote_message_3p = "USER's actuators whine with strain."
/decl/emote/exertion/synthetic/check_user(mob/living/user)
/decl/emote/exertion/synthetic/mob_can_use(mob/living/user)
if(istype(user) && user.isSynthetic())
return ..()
return FALSE

View File

@@ -1,11 +1,5 @@
/decl/emote/human
key = "vomit"
/decl/emote/human/check_user(var/mob/living/carbon/human/user)
return (istype(user) && user.check_has_mouth() && !user.isSynthetic())
/decl/emote/human/do_emote(var/mob/living/carbon/human/user)
user.vomit()
/decl/emote/human/mob_can_use(var/mob/living/carbon/human/user)
return ..() && istype(user) && user.check_has_mouth() && !user.isSynthetic()
/decl/emote/human/deathgasp
key = "deathgasp"

View File

@@ -8,8 +8,8 @@
user.mood = mood
user.update_icon()
/decl/emote/slime/check_user(var/atom/user)
return isslime(user)
/decl/emote/slime/mob_can_use(var/atom/user)
return ..() && isslime(user)
/decl/emote/slime/pout
key = "pout"

View File

@@ -3,7 +3,7 @@
emote_message_3p = "beeps."
emote_sound = 'sound/machines/twobeep.ogg'
/decl/emote/audible/synth/check_user(var/mob/living/user)
/decl/emote/audible/synth/mob_can_use(var/mob/living/user)
if(istype(user) && user.isSynthetic())
return ..()
return FALSE
@@ -34,8 +34,8 @@
emote_message_3p_target = "shows TARGET USER_THEIR legal authorization barcode."
emote_sound = 'sound/voice/biamthelaw.ogg'
/decl/emote/audible/synth/security/check_user(var/mob/living/silicon/robot/user)
return (istype(user) && istype(user.module, /obj/item/weapon/robot_module/robot/security))
/decl/emote/audible/synth/security/mob_can_use(var/mob/living/silicon/robot/user)
return ..() && istype(user) && istype(user.module, /obj/item/weapon/robot_module/robot/security)
/decl/emote/audible/synth/security/halt
key = "halt"

View File

@@ -237,9 +237,6 @@
emote_message_3p = "signals."
check_restraints = TRUE
/decl/emote/visible/signal/check_user(atom/user)
return ismob(user)
/decl/emote/visible/signal/get_emote_message_3p(var/mob/living/user, var/atom/target, var/extra_params)
if(istype(user) && (!user.get_active_hand() || !user.get_inactive_hand()))
var/t1 = round(text2num(extra_params))

View File

@@ -2,6 +2,7 @@
key = "spin"
check_restraints = TRUE
emote_message_3p = "spins!"
emote_delay = 2 SECONDS
/decl/emote/visible/spin/do_extra(mob/user)
if(istype(user))
@@ -11,6 +12,7 @@
key = "sidestep"
check_restraints = TRUE
emote_message_3p = "steps rhythmically and moves side to side."
emote_delay = 1.2 SECONDS
/decl/emote/visible/sidestep/do_extra(mob/user)
if(istype(user))
@@ -24,6 +26,7 @@
emote_message_1p = "You do a flip!"
emote_message_3p = "does a flip!"
emote_sound = 'sound/effects/bodyfall4.ogg'
emote_delay = 1.2 SECONDS
/decl/emote/visible/flip/do_extra(mob/user)
. = ..()
@@ -34,6 +37,7 @@
key = "floorspin"
emote_message_1p = "You spin around on the floor!"
emote_message_3p = "spins around on the floor!"
emote_delay = 1.2 SECONDS
var/static/list/spin_dirs = list(
NORTH,
SOUTH,

View File

@@ -4,6 +4,13 @@
// gender-appropriate version of the same.
// - Impaired messages do not do any substitutions.
var/global/list/emotes_by_key
/proc/get_emote_by_key(var/key)
if(!global.emotes_by_key)
decls_repository.get_decls_of_type(/decl/emote) // emotes_by_key will be updated in emote Initialize()
return global.emotes_by_key[key]
/decl/emote
var/key // Command to use emote ie. '*[key]'
var/emote_message_1p // First person message ('You do a flip!')
@@ -28,6 +35,7 @@
var/list/emote_sound_synthetic // As above, but used when check_synthetic() is true.
var/emote_volume = 50 // Volume of sound to play.
var/emote_volume_synthetic = 50 // As above, but used when check_synthetic() is true.
var/emote_delay = 0 // Time in ds that this emote will block further emote use (spam prevention).
var/message_type = VISIBLE_MESSAGE // Audible/visual flag
var/check_restraints // Can this emote be used while restrained?
@@ -35,6 +43,11 @@
var/conscious = TRUE // Do we need to be awake to emote this?
var/emote_range = 0 // If >0, restricts emote visibility to viewers within range.
/decl/emote/Initialize()
. = ..()
if(key)
LAZYSET(global.emotes_by_key, key, src)
/decl/emote/proc/get_emote_message_1p(var/atom/user, var/atom/target, var/extra_params)
if(target)
if(emote_message_synthetic_1p_target && check_synthetic(user))
@@ -162,8 +175,8 @@
if(sound_to_play)
playsound(user.loc, sound_to_play, use_sound["vol"], 0)
/decl/emote/proc/check_user(var/atom/user)
return TRUE
/decl/emote/proc/mob_can_use(var/mob/user)
return istype(user) && user.stat != DEAD && (type in user.get_available_emotes())
/decl/emote/proc/can_target()
return (emote_message_1p_target || emote_message_3p_target)

View File

@@ -1,9 +1,18 @@
/mob
var/next_emote
var/next_emote_refresh
var/last_emote_summary
/mob/proc/get_available_emotes()
return global._default_mob_emotes
/mob/proc/can_emote(var/emote_type)
return (stat == CONSCIOUS)
/mob/living/can_emote(var/emote_type)
return (..() && !(silent && emote_type == AUDIBLE_MESSAGE))
#define EMOTE_REFRESH_SPAM_COOLDOWN (5 SECONDS)
/mob/proc/emote(var/act, var/m_type, var/message)
set waitfor = FALSE
// s-s-snowflake
@@ -15,8 +24,20 @@
to_chat(src, "<span class='warning'>You cannot send IC messages (muted).</span>")
return
if(world.time < next_emote)
to_chat(src, SPAN_WARNING("You cannot use another emote yet."))
return
if(act == "help")
to_chat(src,"<b>Usable emotes:</b> [english_list(usable_emotes)].")
if(world.time >= next_emote_refresh)
var/list/usable_emotes = list()
next_emote_refresh = world.time + EMOTE_REFRESH_SPAM_COOLDOWN
for(var/emote in get_available_emotes())
var/decl/emote/emote_datum = decls_repository.get_decl(emote)
if(emote_datum.mob_can_use(src))
usable_emotes[emote_datum.key] = emote_datum
last_emote_summary = english_list(sortAssoc(usable_emotes))
to_chat(src,"<b>Usable emotes:</b> [last_emote_summary].")
return
if(!can_emote(m_type))
@@ -44,24 +65,30 @@
act = copytext(tempstr,1,splitpoint)
message = copytext(tempstr,splitpoint+1,0)
var/decl/emote/use_emote = usable_emotes[act]
if(!use_emote)
var/decl/emote/use_emote = get_emote_by_key(act)
if(!istype(use_emote))
to_chat(src, SPAN_WARNING("Unknown emote '[act]'. Type <b>say *help</b> for a list of usable emotes."))
return
if(!use_emote.mob_can_use(src))
to_chat(src, SPAN_WARNING("You cannot use the emote '[act]'. Type <b>say *help</b> for a list of usable emotes."))
return
if(m_type != use_emote.message_type && use_emote.conscious && stat != CONSCIOUS)
return
if(use_emote.message_type == AUDIBLE_MESSAGE && is_muzzled())
audible_message("<b>\The [src]</b> [use_emote.emote_message_muffled || "makes a muffled sound."]")
return
else
use_emote.do_emote(src, message)
next_emote = world.time + use_emote.emote_delay
use_emote.do_emote(src, message)
for (var/obj/item/weapon/implant/I in src)
if (I.implanted)
I.trigger(act, src)
#undef EMOTE_REFRESH_SPAM_COOLDOWN
/mob/proc/format_emote(var/emoter = null, var/message = null)
var/pretext
var/subtext

View File

@@ -46,7 +46,7 @@ var/list/_nymph_default_emotes = list(
holder_type = /obj/item/weapon/holder/diona
var/obj/item/hat
/mob/living/carbon/alien/diona/get_default_emotes()
/mob/living/carbon/alien/diona/get_available_emotes()
return global._nymph_default_emotes
/mob/living/carbon/alien/diona/Initialize()

View File

@@ -27,5 +27,5 @@ var/list/_alien_default_emotes = list(
/decl/emote/audible/chirp
)
/mob/living/carbon/alien/get_default_emotes()
/mob/living/carbon/alien/get_available_emotes()
. = global._alien_default_emotes

View File

@@ -13,5 +13,5 @@ var/list/_brain_default_emotes = list(
/mob/living/carbon/brain/can_emote()
return (istype(container, /obj/item/device/mmi) && ..())
/mob/living/carbon/brain/get_default_emotes()
/mob/living/carbon/brain/get_available_emotes()
return global._brain_default_emotes

View File

@@ -33,7 +33,6 @@ var/list/_human_default_emotes = list(
/decl/emote/audible/grunt,
/decl/emote/audible/slap,
/decl/emote/audible/crack,
/decl/emote/human,
/decl/emote/human/deathgasp,
/decl/emote/audible/giggle,
/decl/emote/audible/scream,
@@ -94,8 +93,10 @@ var/list/_human_default_emotes = list(
/decl/emote/visible/flip
)
/mob/living/carbon/human/get_default_emotes()
return global._human_default_emotes
/mob/living/carbon/human/get_available_emotes()
. = global._human_default_emotes
if(length(species?.default_emotes))
. |= species.default_emotes
/mob/living/carbon/human/verb/pose()
set name = "Set Pose"

View File

@@ -1134,9 +1134,6 @@
//A slew of bits that may be affected by our species change
regenerate_icons()
// Update our available emote list.
update_emotes()
if(species)
if(mind)
apply_traits()

View File

@@ -9,5 +9,5 @@ var/list/_silicon_default_emotes = list(
/decl/emote/audible/synth/security/halt
)
/mob/living/silicon/get_default_emotes()
/mob/living/silicon/get_available_emotes()
return global._silicon_default_emotes

View File

@@ -25,5 +25,5 @@ var/list/_robot_default_emotes = list(
/decl/emote/audible/synth/security/halt
)
/mob/living/silicon/robot/get_default_emotes()
/mob/living/silicon/robot/get_available_emotes()
return global._robot_default_emotes

View File

@@ -56,7 +56,7 @@ var/list/_cat_default_emotes = list(
update_icon()
return ..()
/mob/living/simple_mob/animal/passive/cat/get_default_emotes()
/mob/living/simple_mob/animal/passive/cat/get_available_emotes()
return global._cat_default_emotes
/mob/living/simple_mob/animal/passive/cat/handle_special()

View File

@@ -80,7 +80,7 @@ var/list/_slime_default_emotes = list(
can_enter_vent_with = list(/obj/item/clothing/head)
/mob/living/simple_mob/slime/get_default_emotes()
/mob/living/simple_mob/slime/get_available_emotes()
return global._slime_default_emotes
/datum/say_list/slime

View File

@@ -41,7 +41,6 @@
living_mob_list += src
lastarea = get_area(src)
update_transform() // Some mobs may start bigger or smaller than normal.
update_emotes()
return ..()
/mob/proc/show_message(msg, type, alt, alt_type)//Message, type of message (1 or 2), alternative message, alt message type (1 or 2)

View File

@@ -37,7 +37,6 @@
if(!R)
log_error("A torso was robotize() but has no model that can be found: [model]. May affect FBPs.")
owner.synthetic = R
owner.update_emotes()
return FALSE
/obj/item/organ/external/chest/handle_germ_effects()