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

Wizard Item Recall Spell #34411

Open
wants to merge 15 commits into
base: master
Choose a base branch
from

Conversation

ScarKy0
Copy link
Contributor

@ScarKy0 ScarKy0 commented Jan 13, 2025

About the PR

Title.

Why / Balance

Missing feature for wizard.

Technical details

Added an ItemRecallSystem that handles the Item Recall spell.
Added RaiseOnAction to the BaseActionComponent to allow raising events on the action itself.

Media

2025-01-13.23-50-15.mp4

Requirements

Breaking changes

Changelog

not player facing (wizard when :( )

@github-actions github-actions bot added S: Untriaged Status: Indicates an item has not been triaged and doesn't have appropriate labels. size/M Denotes a PR that changes 100-999 lines. labels Jan 13, 2025
@SlimmSlamm
Copy link
Contributor

would this work if its in someone elses inventory/locker?

@ScarKy0
Copy link
Contributor Author

ScarKy0 commented Jan 13, 2025

would this work if its in someone elses inventory/locker?

If the item exists, no matter where, it WILL return to you

@SlimmSlamm
Copy link
Contributor

would this work if its in someone elses inventory/locker?

If the item exists, no matter where, it WILL return to you

thats awesome. hope to see some interactions with storage implanters or something. that would be hilarious.

@0x6273
Copy link
Contributor

0x6273 commented Jan 13, 2025

Isn't there a freeze on wizard and new spells?

@keronshb
Copy link
Contributor

Isn't there a freeze on wizard and new spells?

This has permission from me.

@ScarKy0 ScarKy0 marked this pull request as ready for review January 13, 2025 23:09
@ScarKy0 ScarKy0 changed the title [Draft] Wizard Item Recall Spell Wizard Item Recall Spell Jan 13, 2025
@github-actions github-actions bot added the S: Needs Review Status: Requires additional reviews before being fully accepted label Jan 13, 2025
@everydayeldergod
Copy link

should it do some damage if it uh... rips a storage implanter out of someone's chest? or is it more of a magical teleport?

Copy link
Member

@slarticodefast slarticodefast left a comment

Choose a reason for hiding this comment

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

I did not test it in game yet.
Design-wise, did you ask Keron if it should be one or two actions? One for marking, one for recalling. That way you change the mark to another item if you wanted to.

Content.Client/ItemRecall/ItemRecallSystem.cs Show resolved Hide resolved
Content.Server/ItemRecall/ItemRecallSystem.cs Show resolved Hide resolved
Content.Shared/Projectiles/SharedProjectileSystem.cs Outdated Show resolved Hide resolved
Content.Shared/Actions/SharedActionsSystem.cs Outdated Show resolved Hide resolved
Content.Shared/ItemRecall/ItemRecallEvents.cs Outdated Show resolved Hide resolved
Content.Shared/ItemRecall/SharedItemRecallSystem.cs Outdated Show resolved Hide resolved
Content.Shared/ItemRecall/SharedItemRecallSystem.cs Outdated Show resolved Hide resolved
Content.Shared/ItemRecall/SharedItemRecallSystem.cs Outdated Show resolved Hide resolved
Content.Shared/ItemRecall/SharedItemRecallSystem.cs Outdated Show resolved Hide resolved
Content.Shared/ItemRecall/SharedItemRecallSystem.cs Outdated Show resolved Hide resolved
@ScarKy0
Copy link
Contributor Author

ScarKy0 commented Jan 14, 2025

I did not test it in game yet.
Design-wise, did you ask Keron if it should be one or two actions? One for marking, one for recalling. That way you change the mark to another item if you wanted to.

Spoke with Keron, youre not supposed to be able to mark another item(mark is permanent unless item somehow is destroyed) and it should be one action.
Thanks for the review ill address it all later

@slarticodefast slarticodefast added S: Awaiting Changes Status: Changes are required before another review can happen and removed S: Needs Review Status: Requires additional reviews before being fully accepted labels Jan 14, 2025
@ScarKy0
Copy link
Contributor Author

ScarKy0 commented Jan 14, 2025

should it do some damage if it uh... rips a storage implanter out of someone's chest? or is it more of a magical teleport?

As cool as this sounds, magical teleport

@github-actions github-actions bot added S: Needs Review Status: Requires additional reviews before being fully accepted and removed S: Awaiting Changes Status: Changes are required before another review can happen labels Jan 15, 2025
@ScarKy0
Copy link
Contributor Author

ScarKy0 commented Jan 15, 2025

Only thing that doesn't work is the popup when an item is unmarked, but it's something to do with the action system being weird.

@ScarKy0 ScarKy0 added P2: Raised Priority: Item has a raised priority, indicating it might get increased maintainer attention. T: New Feature Type: New feature or content, or extending existing content D2: Medium Difficulty: A good amount of codebase knowledge required. A: Combat Area: Combat features and changes, balancing, feel A: Roundflow/Antag Area: Roundflow - "What happens in the game", including antagonist roles and their capabilities and removed S: Untriaged Status: Indicates an item has not been triaged and doesn't have appropriate labels. labels Jan 16, 2025
@github-actions github-actions bot added the Changes: Sprites Changes: Might require knowledge of spriting or visual design. label Jan 16, 2025
Copy link
Contributor

github-actions bot commented Jan 16, 2025

RSI Diff Bot; head commit b81ca5d merging into b308589
This PR makes changes to 1 or more RSIs. Here is a summary of all changes:

Resources/Textures/Objects/Magic/magicactions.rsi

State Old New Status
item_recall Added

Edit: diff updated after b81ca5d

@ScarKy0 ScarKy0 requested a review from keronshb January 19, 2025 21:13
Comment on lines +9 to +47
/// <summary>
/// System for handling the ItemRecall ability for wizards.
/// </summary>
public sealed partial class ItemRecallSystem : SharedItemRecallSystem
{
[Dependency] private readonly SharedHandsSystem _hands = default!;
[Dependency] private readonly SharedProjectileSystem _proj = default!;
[Dependency] private readonly SharedPopupSystem _popups = default!;

public override void Initialize()
{
base.Initialize();

SubscribeLocalEvent<RecallMarkerComponent, RecallItemEvent>(OnItemRecall);
}

private void OnItemRecall(Entity<RecallMarkerComponent> ent, ref RecallItemEvent args)
{
RecallItem(ent);
}

private void RecallItem(Entity<RecallMarkerComponent> ent)
{
if (!TryComp<InstantActionComponent>(ent.Comp.MarkedByAction, out var instantAction))
return;

var actionOwner = instantAction.AttachedEntity;

if (actionOwner == null)
return;

if (TryComp<EmbeddableProjectileComponent>(ent, out var projectile))
_proj.UnEmbed(ent, projectile, actionOwner.Value);

_popups.PopupEntity(Loc.GetString("item-recall-item-summon", ("item", ent)), actionOwner.Value, actionOwner.Value);

_hands.TryForcePickupAnyHand(actionOwner.Value, ent);
}
}
Copy link
Contributor

@metalgearsloth metalgearsloth Jan 19, 2025

Choose a reason for hiding this comment

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

All new code needs prediction please.

If your issue is range use pvs session overrides.

Comment on lines +5 to +8

[RegisterComponent, NetworkedComponent, AutoGenerateComponentState, Access(typeof(SharedItemRecallSystem))]
public sealed partial class RecallMarkerComponent : Component
{
Copy link
Contributor

Choose a reason for hiding this comment

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

Doc comments.

Comment on lines +64 to +70

private void TryMarkItem(Entity<ItemRecallComponent> ent, EntityUid item, EntityUid markedBy)
{
EnsureComp<RecallMarkerComponent>(item, out var marker);
ent.Comp.MarkedEntity = item;
Dirty(ent);

Copy link
Contributor

Choose a reason for hiding this comment

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

This is already checked for component existence above but if you're doing ensures then you should actually be checking if the item should be dirtied or not as dirtying is expensive and this might be unnecessary.

Comment on lines +89 to +94

if (TryComp<ItemRecallComponent>(marker.MarkedByAction, out var action))
{
// For some reason client thinks the station grid owns the action on client and this doesn't work. It doesn't work in PopupEntity(mispredicts) and PopupPredicted either(doesnt show).
// I don't have the heart to move this code to server because of this small thing.
// This line will only do something once that is fixed.
Copy link
Contributor

Choose a reason for hiding this comment

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

This sounds like a pretty bad bug here that should be fixed.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Messing with the action system is not something I am knowledgable enough to do. Especially since I have no idea what causes this.

Comment on lines +104 to +132

private void UpdateActionAppearance(Entity<ItemRecallComponent> action)
{
if (!TryComp<InstantActionComponent>(action, out var instantAction))
return;

var proto = Prototype(action);

if (proto == null)
return;

if (action.Comp.MarkedEntity == null)
{
_metaData.SetEntityName(action, proto.Name);
_metaData.SetEntityDescription(action, proto.Description);
_actions.SetEntityIcon(action, null, instantAction);
}
else
{
if (action.Comp.WhileMarkedName != null)
_metaData.SetEntityName(action, Loc.GetString(action.Comp.WhileMarkedName,
("item", action.Comp.MarkedEntity.Value)));

if (action.Comp.WhileMarkedDescription != null)
_metaData.SetEntityDescription(action, Loc.GetString(action.Comp.WhileMarkedDescription,
("item", action.Comp.MarkedEntity.Value)));

_actions.SetEntityIcon(action, action.Comp.MarkedEntity, instantAction);
}
Copy link
Contributor

Choose a reason for hiding this comment

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

You should be getting the entity's actual data not prototype data, this can vary significantly as prototypes are only for initialisation values.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I do mean to get the initial state of the action here though. Since if the item for recall is destroyed the initial sprite should be restored.

Content.Shared/Actions/BaseActionComponent.cs Show resolved Hide resolved
Comment on lines +76 to +89

private void TryUnmarkItem(EntityUid item)
{
if (!TryComp<RecallMarkerComponent>(item, out var marker))
return;

if (!TryComp<InstantActionComponent>(item, out var instantAction))
return;

var actionOwner = instantAction.AttachedEntity;

if (actionOwner == null)
return;

Copy link
Contributor

Choose a reason for hiding this comment

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

If the item is being recalled the attached entity can be completely different? Not sure why the action is even being checked here.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

If you use mind swap and then recall an item you would recall it to your old body. This is supposed to recall it to whoever currently holds the action.

Comment on lines +132 to +139
// Reset whether the projectile has damaged anything if it successfully was removed
if (TryComp<ProjectileComponent>(uid, out var projectile))
{
projectile.Shooter = null;
projectile.Weapon = null;
projectile.DamagedEntity = false;
}

Copy link
Contributor

Choose a reason for hiding this comment

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

This should be getting dirtied, looks like bug in original code.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A: Combat Area: Combat features and changes, balancing, feel A: Roundflow/Antag Area: Roundflow - "What happens in the game", including antagonist roles and their capabilities Changes: Sprites Changes: Might require knowledge of spriting or visual design. D2: Medium Difficulty: A good amount of codebase knowledge required. P2: Raised Priority: Item has a raised priority, indicating it might get increased maintainer attention. S: Needs Review Status: Requires additional reviews before being fully accepted size/M Denotes a PR that changes 100-999 lines. T: New Feature Type: New feature or content, or extending existing content
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants