mirror of
https://github.com/space-wizards/RobustToolbox.git
synced 2026-02-15 03:30:53 +01:00
These allow Assert(Foo != null) to suppress nullability warnings. No way to configure it for AssertNotNull though.
156 lines
5.3 KiB
C#
156 lines
5.3 KiB
C#
using System;
|
|
using System.Diagnostics;
|
|
using System.Diagnostics.CodeAnalysis;
|
|
using System.Runtime.CompilerServices;
|
|
using JetBrains.Annotations;
|
|
|
|
namespace Robust.Shared.Utility
|
|
{
|
|
public static class DebugTools
|
|
{
|
|
/// <summary>
|
|
/// An assertion that will always <see langword="throw" /> an exception.
|
|
/// </summary>
|
|
/// <param name="message">Exception message.</param>
|
|
[Conditional("DEBUG")]
|
|
[ContractAnnotation("=> halt")]
|
|
[DoesNotReturn]
|
|
public static void Assert(string message)
|
|
{
|
|
throw new DebugAssertException(message);
|
|
}
|
|
|
|
/// <summary>
|
|
/// An assertion that will <see langword="throw" /> an exception if the
|
|
/// <paramref name="condition" /> is not true.
|
|
/// </summary>
|
|
/// <param name="condition">Condition that must be true.</param>
|
|
[Conditional("DEBUG")]
|
|
[AssertionMethod]
|
|
public static void Assert(
|
|
[AssertionCondition(AssertionConditionType.IS_TRUE)]
|
|
[DoesNotReturnIf(false)]
|
|
bool condition)
|
|
{
|
|
if (!condition)
|
|
throw new DebugAssertException();
|
|
}
|
|
|
|
/// <summary>
|
|
/// An assertion that will <see langword="throw" /> an exception if the
|
|
/// <paramref name="condition" /> is not true.
|
|
/// </summary>
|
|
/// <param name="condition">Condition that must be true.</param>
|
|
/// <param name="message">Exception message.</param>
|
|
[Conditional("DEBUG")]
|
|
[AssertionMethod]
|
|
public static void Assert(
|
|
[AssertionCondition(AssertionConditionType.IS_TRUE)]
|
|
[DoesNotReturnIf(false)]
|
|
bool condition,
|
|
string message)
|
|
{
|
|
if (!condition)
|
|
throw new DebugAssertException(message);
|
|
}
|
|
|
|
/// <summary>
|
|
/// An assertion that will <see langword="throw" /> an exception if the
|
|
/// <paramref name="condition" /> is not true.
|
|
/// </summary>
|
|
/// <param name="condition">Condition that must be true.</param>
|
|
/// <param name="message">Exception message.</param>
|
|
[Conditional("DEBUG")]
|
|
[AssertionMethod]
|
|
public static void Assert(
|
|
[AssertionCondition(AssertionConditionType.IS_TRUE)]
|
|
[DoesNotReturnIf(false)]
|
|
bool condition,
|
|
[InterpolatedStringHandlerArgument("condition")]
|
|
ref AssertInterpolatedStringHandler message)
|
|
{
|
|
if (!condition)
|
|
throw new DebugAssertException(message.ToStringAndClear());
|
|
}
|
|
|
|
/// <summary>
|
|
/// An assertion that will <see langword="throw" /> an exception if the
|
|
/// <paramref name="arg" /> is <see langword="null" />.
|
|
/// </summary>
|
|
/// <param name="arg">Condition that must be true.</param>
|
|
[Conditional("DEBUG")]
|
|
[AssertionMethod]
|
|
public static void AssertNotNull([AssertionCondition(AssertionConditionType.IS_NOT_NULL)]
|
|
object? arg)
|
|
{
|
|
if (arg == null)
|
|
{
|
|
throw new DebugAssertException();
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// An assertion that will <see langword="throw" /> an exception if the
|
|
/// <paramref name="arg" /> is not <see langword="null" />.
|
|
/// </summary>
|
|
/// <param name="arg">Condition that must be true.</param>
|
|
[Conditional("DEBUG")]
|
|
[AssertionMethod]
|
|
public static void AssertNull([AssertionCondition(AssertionConditionType.IS_NULL)]
|
|
object? arg)
|
|
{
|
|
if (arg != null)
|
|
{
|
|
throw new DebugAssertException();
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// If a debugger is attached to the process, calling this function will cause the
|
|
/// debugger to break. Equivalent to a software interrupt (INT 3).
|
|
/// </summary>
|
|
public static void Break()
|
|
{
|
|
Debugger.Break();
|
|
}
|
|
|
|
[InterpolatedStringHandler]
|
|
public ref struct AssertInterpolatedStringHandler
|
|
{
|
|
private DefaultInterpolatedStringHandler _handler;
|
|
|
|
public AssertInterpolatedStringHandler(int literalLength, int formattedCount, bool condition, out bool shouldAppend)
|
|
{
|
|
if (condition)
|
|
{
|
|
shouldAppend = false;
|
|
_handler = default;
|
|
}
|
|
else
|
|
{
|
|
shouldAppend = true;
|
|
_handler = new DefaultInterpolatedStringHandler(literalLength, formattedCount);
|
|
}
|
|
}
|
|
|
|
public string ToStringAndClear() => _handler.ToStringAndClear();
|
|
public override string ToString() => _handler.ToString();
|
|
public void AppendLiteral(string value) => _handler.AppendLiteral(value);
|
|
public void AppendFormatted<T>(T value) => _handler.AppendFormatted(value);
|
|
public void AppendFormatted<T>(T value, string? format) => _handler.AppendFormatted(value, format);
|
|
}
|
|
}
|
|
|
|
[Virtual]
|
|
public class DebugAssertException : Exception
|
|
{
|
|
public DebugAssertException()
|
|
{
|
|
}
|
|
|
|
public DebugAssertException(string message) : base(message)
|
|
{
|
|
}
|
|
}
|
|
}
|