1
0
Fork 0
mirror of https://github.com/beefytech/Beef.git synced 2025-06-10 12:32:20 +02:00
Beef/BeefLibs/corlib/src/Diagnostics/Debug.bf

106 lines
2.4 KiB
Beef
Raw Normal View History

2019-08-23 11:56:54 -07:00
namespace System.Diagnostics
{
class Debug
{
#if !DEBUG
[SkipCall]
#endif
public static void Assert(bool condition, String error = Compiler.CallerExpression[0], String filePath = Compiler.CallerFilePath, int line = Compiler.CallerLineNum)
2019-08-23 11:56:54 -07:00
{
if (!condition)
{
String failStr = scope .()..AppendF("Assert failed: {} at line {} in {}", error, line, filePath);
Internal.FatalError(failStr, 1);
}
2019-08-23 11:56:54 -07:00
}
#if !DEBUG
[SkipCall]
#endif
public static void FatalError(String msg = "Fatal error encountered", String filePath = Compiler.CallerFilePath, int line = Compiler.CallerLineNum)
2019-08-23 11:56:54 -07:00
{
String failStr = scope .()..AppendF("{} at line {} in {}", msg, line, filePath);
Internal.FatalError(failStr, 1);
2019-08-23 11:56:54 -07:00
}
#if !DEBUG
[SkipCall]
#endif
public static void AssertNotStack(Object obj)
{
#if BF_ENABLE_OBJECT_DEBUG_FLAGS
if ((obj != null) && (obj.[Friend]GetFlags() & 8 != 0))
2019-08-23 11:56:54 -07:00
Internal.FatalError("Assert failed", 1);
#endif
}
[CallingConvention(.Cdecl)]
2019-08-23 11:56:54 -07:00
static extern void Write(char8* str, int strLen);
2020-12-17 04:51:05 -08:00
[CallingConvention(.Cdecl)]
static extern void Write(int val);
2019-08-23 11:56:54 -07:00
2020-03-25 09:17:53 -07:00
public static void Write(String line)
{
Write(line.Ptr, line.Length);
}
public static void Write(String fmt, params Object[] args)
{
String str = scope String(4096);
2020-03-25 09:17:53 -07:00
str.AppendF(fmt, params args);
Write(str);
}
public static void Write(Object obj)
{
String str = scope String(4096);
2020-03-25 09:17:53 -07:00
obj.ToString(str);
Write(str);
}
public static void WriteLine()
{
2020-10-08 12:48:24 -07:00
Write((char8*)"\n", 1);
2020-03-25 09:17:53 -07:00
}
2019-08-23 11:56:54 -07:00
public static void WriteLine(StringView line)
{
String lineStr = scope String(Math.Min(line.Length, 4096));
lineStr.Append(line);
lineStr.Append('\n');
Write(lineStr.Ptr, lineStr.Length);
2019-08-23 11:56:54 -07:00
}
public static void WriteLine(StringView strFormat, params Object[] args)
{
String paramStr = scope String(4096);
2019-08-23 11:56:54 -07:00
paramStr.AppendF(strFormat, params args);
paramStr.Append('\n');
Write(paramStr.Ptr, paramStr.Length);
}
static bool gIsDebuggerPresent = IsDebuggerPresent;
[LinkName("IsDebuggerPresent"), CallingConvention(.Stdcall)]
static extern int32 Internal_IsDebuggerPresent();
public static bool IsDebuggerPresent
{
#if BF_PLATFORM_WINDOWS
get => gIsDebuggerPresent = Internal_IsDebuggerPresent() != 0;
#else
get => false;
#endif
}
[Intrinsic("debugtrap")]
public static extern void Break();
[NoDebug]
public static void SafeBreak()
{
if (gIsDebuggerPresent)
Break();
}
2019-08-23 11:56:54 -07:00
}
}