Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Adds the mining breach type #2615

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

vampirebat74
Copy link
Contributor

@vampirebat74 vampirebat74 commented Dec 17, 2024

About The Pull Request

What it says on the tin. This breach type is primarily used in the Enkephalin Rush gamemode, though it is also used by monoliths that may appear elsewhere in the future. The main appeal of this breach type is that it prevents most forms of teleportation on the initial breach, as well as addressing gameplay issues related to mining threats.

A few abnormalities are "disabled" through this by deleting themselves immediately. This mainly applies to superbosses such as whitenight and distortedform, whos cores will be used to present an optional fight instead. (TODO: reduce the monetary value of these abnormality cores to zero)

In addition, the scope of this PR includes new breaches entirely, which are planned for meat lantern and rose sign. Their current mechanics impose unreasonable challenges due to the nature of the gamemode this PR affects.

A handful of abnormalities whom lack regular breaches have also been given abilities for this specific breach type. Those who are inanimate objects like A Poor Screenwriter's Note and Book Without Pictures or Dialogue are now unable to move or attack adjacent targets. Additionally, many abnormalities who use this feature to summon one or more hostile units have been given damage coefficients and increased HP.

Singing Machine will now perform its music until suppressed, boasting high HP and decent defenses.

Three "summoner" archetypes have been created.

Type 1:
Immobile, tanky unit that summons many units over time, until suppressed.
YMBS, Book, Rose Sign

Type 2:
Controls a subordinate entity
La Luna, Screenwriter

Type 3:
Capable of combat and movement, slower summons and lesser quantities permitted.
Laetitia, Fairy Festival, Contract

Bloodbath now has a unique hostile breach recycling assets from its Distorted Form variant.

ZAYIN abnormalities will utilize this breach type for an easier version of their respective pink midnight breaches, excluding Fairy Festival who has a unique breach.

Why It's Good For The Game

LC13 has normally imposed many restrictions on how abnormalities should behave for the main gameplay loop. I wish for my gamemode to eventually include every abnormality in the game, each imposing a challenge to the player. I hope that these new features will be used for more creative projects in the future.

Changelog

🆑
add: breach_mining to abnormalities defines
fix: rose sign's roses now remove statuses when qdeleted
imageadd: fairy festival breach
soundadd: fairy queen sfx, one sin attack
code: new breach types, monolith changes
/:cl:

@vampirebat74 vampirebat74 marked this pull request as draft December 17, 2024 06:36
@Kitsunemitsu Kitsunemitsu added the Feature Something new being added. label Dec 17, 2024
@vampirebat74 vampirebat74 force-pushed the breach_mining branch 3 times, most recently from feda92b to 8ce18a3 Compare December 24, 2024 06:59
@vampirebat74 vampirebat74 marked this pull request as ready for review January 1, 2025 07:47
HE level

he, teth, waw

linters, some zayins

rose sign stuff

summoners + singing machine

fairy festival changes

Apply suggestions from code review

Co-authored-by: Gboster-0 <[email protected]>

oracle and fixes
Copy link
Collaborator

@Gboster-0 Gboster-0 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Somethings

icon_state = "nanoimplant"
var/breach_type = BREACH_NORMAL
var/list/breach_list = list(
BREACH_NORMAL, BREACH_PINK, BREACH_MINING,
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why have a multi-line list, just to put all its contents on the same line?
Bit weird, also lists are supposed to end on the same line they start at, AKA:

var/list/something = list(
    object,
)

and not

var/list/something = list(
    object,
    )

Blackify()
SpawnAdds()//set its alpha to 0 and make it non-dense
if(breach_type == BREACH_MINING)
for(var/i = 1 to 3)
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
for(var/i = 1 to 3)
for(var/i in 1 to 3)

if(!killed || !status_target)
return ..()
if(flower_damage_type && master)
master.summoned_roses -= src
master.ChangeResistance(flower_damage_type, (master.damage_coeff.getCoeff(flower_damage_type) + 0.3), update = TRUE)
if(status_target.has_status_effect(/datum/status_effect/stacking/crownthorns))
status_target.remove_status_effect(STATUS_EFFECT_THORNS)
density = FALSE
animate(src, alpha = 0, time = 10 SECONDS)
QDEL_IN(src, 10 SECONDS)
..()
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Since you changed this from death() to Destroy(), remember that it HAS to end with return ..()

Suggested change
..()
return ..()

if(A)
A.death()
EndScenario()
..()
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
..()
return ..()

persistant = TRUE
if(breach_type == BREACH_MINING)//nerfed to a ZAYIN statline since this is something you'll typically fight roundstart
name = "Weakened " + name
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
name = "Weakened " + name
name = "Weakened [name]"


/mob/living/simple_animal/hostile/fairy_mass/AttackingTarget()
. = ..()
if(ishuman(target))
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
if(ishuman(target))
if(iscarbon(target))

Comment on lines +143 to +144
..()
return
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can compress this

Suggested change
..()
return
return ..()

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Feature Something new being added.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants