SIMD-accelerated gas mixtures. (SIMD atmos) (#2479)
* SIMD atmos * Moles will always be a multiple of four. * Component dependencies for grid atmos. * Let's optimize allocations while we're at it! * Inline this * A bunch of atmos optimizations * Fix crimes against atmos * Microsoft moment * Remove nuget.config * do not reference Robust.UnitTests in Content.Benchmarks as it's unneeded. * Revert "Remove nuget.config" This reverts commit 872604ae6a51365af4075bb23687bd005befd8ac. * Gas overlay optimization and fixes * Lattice is now spess * minor atmos tweaks
This commit is contained in:
committed by
GitHub
parent
89f72c4cb2
commit
b18ee3ec49
@@ -25,6 +25,7 @@ namespace Content.Shared.Maps
|
||||
public float Friction { get; set; }
|
||||
public float ThermalConductivity { get; set; }
|
||||
public string ItemDropPrototypeName { get; private set; }
|
||||
public bool IsSpace { get; private set; }
|
||||
|
||||
public void AssignTileId(ushort id)
|
||||
{
|
||||
@@ -47,6 +48,11 @@ namespace Content.Shared.Maps
|
||||
else
|
||||
BaseTurfs = new List<string>();
|
||||
|
||||
if (mapping.TryGetNode("is_space", out node))
|
||||
{
|
||||
IsSpace = node.AsBool();
|
||||
}
|
||||
|
||||
if (mapping.TryGetNode("can_crowbar", out node))
|
||||
{
|
||||
CanCrowbar = node.AsBool();
|
||||
|
||||
@@ -9,6 +9,7 @@ using Robust.Shared.Interfaces.GameObjects;
|
||||
using Robust.Shared.Interfaces.Map;
|
||||
using Robust.Shared.Interfaces.Physics;
|
||||
using Robust.Shared.IoC;
|
||||
using Robust.Shared.Log;
|
||||
using Robust.Shared.Map;
|
||||
using Robust.Shared.Maths;
|
||||
|
||||
@@ -16,15 +17,6 @@ namespace Content.Shared.Maps
|
||||
{
|
||||
public static class TurfHelpers
|
||||
{
|
||||
/// <summary>
|
||||
/// Returns the content tile definition for a tile.
|
||||
/// </summary>
|
||||
public static ContentTileDefinition GetContentTileDefinition(this Tile tile)
|
||||
{
|
||||
var tileDefinitionManager = IoCManager.Resolve<ITileDefinitionManager>();
|
||||
return (ContentTileDefinition)tileDefinitionManager[tile.TypeId];
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Attempts to get the turf at map indices with grid id or null if no such turf is found.
|
||||
/// </summary>
|
||||
@@ -72,6 +64,39 @@ namespace Content.Shared.Maps
|
||||
return (turf = coordinates.GetTileRef()) != null;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Returns the content tile definition for a tile.
|
||||
/// </summary>
|
||||
public static ContentTileDefinition GetContentTileDefinition(this Tile tile, ITileDefinitionManager? tileDefinitionManager = null)
|
||||
{
|
||||
tileDefinitionManager ??= IoCManager.Resolve<ITileDefinitionManager>();
|
||||
return (ContentTileDefinition)tileDefinitionManager[tile.TypeId];
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Returns whether a tile is considered space.
|
||||
/// </summary>
|
||||
public static bool IsSpace(this Tile tile, ITileDefinitionManager? tileDefinitionManager = null)
|
||||
{
|
||||
return tile.GetContentTileDefinition(tileDefinitionManager).IsSpace;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Returns the content tile definition for a tile ref.
|
||||
/// </summary>
|
||||
public static ContentTileDefinition GetContentTileDefinition(this TileRef tile, ITileDefinitionManager? tileDefinitionManager = null)
|
||||
{
|
||||
return tile.Tile.GetContentTileDefinition(tileDefinitionManager);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Returns whether a tile ref is considered space.
|
||||
/// </summary>
|
||||
public static bool IsSpace(this TileRef tile, ITileDefinitionManager? tileDefinitionManager = null)
|
||||
{
|
||||
return tile.Tile.IsSpace(tileDefinitionManager);
|
||||
}
|
||||
|
||||
public static bool PryTile(this EntityCoordinates coordinates, IEntityManager? entityManager = null,
|
||||
IMapManager? mapManager = null)
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user