* Revert "- fix: YAML linter fixes. (#598)" This reverts commit012bf3c357. * Revert "Automatic changelog update" This reverts commitcf1c3a9af5. * Revert "[Fix] Base Layer Prototype (#597)" This reverts commitb000423999. * Revert "Modules update (#596)" This reverts commit00fbdead77. * Revert "Automatic changelog update" This reverts commit0d7a12b2a2. * Revert "Fixes (#593)" This reverts commit943c77031c. * Revert "minor loadout fixes (#594)" This reverts commit143c010a89. * Revert "Update DryDock.yml (#595)" This reverts commit4cd0100ac7. * Revert "Automatic changelog update" This reverts commit08eadc690f. * Revert "fix: Maximum message size (#591)" This reverts commit343f3612eb. * Revert "Черри пики 7 (#592)" This reverts commit3f97bdce2f. * Revert "Automatic changelog update" This reverts commit0678eca250. * Revert "Рандомфиксы (#590)" This reverts commit2b9e5e2437. * Revert "Нижнее бельё в лодауты (#580)" This reverts commite01a47b089. * Revert "add lathe sounds (#588)" This reverts commitc80a2985f2. * Revert "Добавил параметр группы для некоторых реагентов (#585)" This reverts commit713b16bb98. * Revert "add hrp ++++ aspect (#587)" This reverts commita6a69cc60f. * Revert "Новые амбиенты и пару песен (#586)" This reverts commit48c86bd846. * Revert "Сообщения в ПДА 2 (#583)" This reverts commitcced3cc98b. * Revert "Automatic changelog update" This reverts commitabf435b11d. * Revert "Chem stuff and more (#584)" This reverts commit3608960f5c. * Revert "JobRequiremet refactor (#579)" This reverts commit9a9c9598e0. * Revert "Revert "Reapply "Нижнее бельё в лодауты""" This reverts commit44447d573f. * Revert "Reapply "Нижнее бельё в лодауты"" This reverts commit0c4d082ad3. * Revert "Revert "Нижнее бельё в лодауты"" This reverts commit56473c5492. * Revert "Нижнее бельё в лодауты" This reverts commitd1cb0cb364. * Revert "DryDock and WhiteMoose update (#578)" This reverts commit14755808af. * Revert "Automatic changelog update" This reverts commit0133f82722. * Revert "Fixes (#576)" This reverts commitb7cc49896c. * Revert "порт системы регенерации солюшена цинки (#574)" This reverts commita22cf3d50b. * Revert "Воровские перчатки (#573)" This reverts commitbb7140f3d4. * Revert "mood resprite (#572)" This reverts commit4db96dc569. * Revert "fix missing letter (#571)" This reverts commit94ea756794. * Revert "Сообщения в ПДА (#564)" This reverts commitd023d29e54. * Revert "- fix: No visible aghost." This reverts commit27e7f25f7e. * Revert "- tweak: Nerf cult shield." This reverts commit6a384246b8.
104 lines
3.9 KiB
C#
104 lines
3.9 KiB
C#
using Content.Shared.Database;
|
|
using Content.Shared.Fluids.Components;
|
|
using Content.Shared.Interaction;
|
|
using Content.Shared.Maps;
|
|
using Content.Shared.Physics;
|
|
using Content.Shared.Tools.Components;
|
|
using Robust.Shared.Map;
|
|
using Robust.Shared.Map.Components;
|
|
using Robust.Shared.Network;
|
|
using Robust.Shared.Utility;
|
|
|
|
namespace Content.Shared.Tools.Systems;
|
|
|
|
public abstract partial class SharedToolSystem
|
|
{
|
|
[Dependency] private readonly INetManager _net = default!;
|
|
|
|
public void InitializeTile()
|
|
{
|
|
SubscribeLocalEvent<ToolTileCompatibleComponent, AfterInteractEvent>(OnToolTileAfterInteract);
|
|
SubscribeLocalEvent<ToolTileCompatibleComponent, TileToolDoAfterEvent>(OnToolTileComplete);
|
|
}
|
|
|
|
private void OnToolTileAfterInteract(Entity<ToolTileCompatibleComponent> ent, ref AfterInteractEvent args)
|
|
{
|
|
if (args.Handled || args.Target != null && !HasComp<PuddleComponent>(args.Target))
|
|
return;
|
|
|
|
args.Handled = UseToolOnTile((ent, ent, null), args.User, args.ClickLocation);
|
|
}
|
|
|
|
private void OnToolTileComplete(Entity<ToolTileCompatibleComponent> ent, ref TileToolDoAfterEvent args)
|
|
{
|
|
var comp = ent.Comp;
|
|
if (args.Handled || args.Cancelled)
|
|
return;
|
|
|
|
if (!TryComp<ToolComponent>(ent, out var tool))
|
|
return;
|
|
var coordinates = GetCoordinates(args.Coordinates);
|
|
|
|
var gridUid = coordinates.GetGridUid(EntityManager);
|
|
if (!TryComp<MapGridComponent>(gridUid, out var grid))
|
|
{
|
|
Log.Error("Attempted use tool on a non-existent grid?");
|
|
return;
|
|
}
|
|
|
|
var tileRef = _maps.GetTileRef(gridUid.Value, grid, coordinates);
|
|
if (comp.RequiresUnobstructed && _turfs.IsTileBlocked(gridUid.Value, tileRef.GridIndices, CollisionGroup.MobMask))
|
|
return;
|
|
|
|
if (!TryDeconstructWithToolQualities(tileRef, tool.Qualities))
|
|
return;
|
|
|
|
AdminLogger.Add(LogType.LatticeCut, LogImpact.Medium,
|
|
$"{ToPrettyString(args.User):player} used {ToPrettyString(ent)} to edit the tile at {args.Coordinates}");
|
|
args.Handled = true;
|
|
}
|
|
|
|
private bool UseToolOnTile(Entity<ToolTileCompatibleComponent?, ToolComponent?> ent, EntityUid user, EntityCoordinates clickLocation)
|
|
{
|
|
if (!Resolve(ent, ref ent.Comp1, ref ent.Comp2, false))
|
|
return false;
|
|
|
|
var comp = ent.Comp1!;
|
|
var tool = ent.Comp2!;
|
|
|
|
if (!_mapManager.TryFindGridAt(clickLocation.ToMap(EntityManager, _transformSystem), out var gridUid, out var mapGrid))
|
|
return false;
|
|
|
|
var tileRef = _maps.GetTileRef(gridUid, mapGrid, clickLocation);
|
|
var tileDef = (ContentTileDefinition) _tileDefManager[tileRef.Tile.TypeId];
|
|
|
|
if (!tool.Qualities.ContainsAny(tileDef.DeconstructTools))
|
|
return false;
|
|
|
|
if (string.IsNullOrWhiteSpace(tileDef.BaseTurf))
|
|
return false;
|
|
|
|
if (comp.RequiresUnobstructed && _turfs.IsTileBlocked(gridUid, tileRef.GridIndices, CollisionGroup.MobMask))
|
|
return false;
|
|
|
|
var coordinates = _maps.GridTileToLocal(gridUid, mapGrid, tileRef.GridIndices);
|
|
if (!InteractionSystem.InRangeUnobstructed(user, coordinates, popup: false))
|
|
return false;
|
|
|
|
var args = new TileToolDoAfterEvent(GetNetCoordinates(coordinates));
|
|
UseTool(ent, user, ent, comp.Delay, tool.Qualities, args, out _, toolComponent: tool);
|
|
return true;
|
|
}
|
|
|
|
public bool TryDeconstructWithToolQualities(TileRef tileRef, PrototypeFlags<ToolQualityPrototype> withToolQualities)
|
|
{
|
|
var tileDef = (ContentTileDefinition) _tileDefManager[tileRef.Tile.TypeId];
|
|
if (withToolQualities.ContainsAny(tileDef.DeconstructTools))
|
|
{
|
|
// don't do this on the client or else the tile entity spawn mispredicts and looks horrible
|
|
return _net.IsClient || _tiles.DeconstructTile(tileRef);
|
|
}
|
|
return false;
|
|
}
|
|
}
|