Skip to content

Commit

Permalink
Add IsInitialized + IsUninitialized api
Browse files Browse the repository at this point in the history
Fix tests

Check IsInitialized in ValueLifetimed + add an assertion that the passed lifetime is initialized
  • Loading branch information
Iliya-usov authored and ForNeVeR committed Jan 16, 2025
1 parent 8d28f49 commit 12a68a9
Show file tree
Hide file tree
Showing 3 changed files with 47 additions and 17 deletions.
35 changes: 27 additions & 8 deletions rd-net/Lifetimes/Lifetimes/Lifetime.cs
Original file line number Diff line number Diff line change
Expand Up @@ -117,18 +117,26 @@ internal LifetimeDefinition Definition
var def = myDefinition;
if (def != null) return def;

if (LogErrorIfLifetimeIsNotInitialized)
{
Log.Root.Error("Lifetime is not initialized. " +
"This may cause a memory leak as default(Lifetime) is treated as Eternal. " +
"Please provide a properly initialized Lifetime or use `Lifetime?` if you need to handle both cases. " +
"Use Lifetime.Eternal explicitly if that behavior is intended.");
}

Assertion.Assert(IsUninitialized);

AssertInitialized();
return LifetimeDefinition.Eternal;
}
}

internal void AssertInitialized()
{
if (!Mode.IsAssertion) return;

if (LogErrorIfLifetimeIsNotInitialized && IsUninitialized)
{
Log.Root.Error("Lifetime is not initialized. " +
"This may cause a memory leak as default(Lifetime) is treated as Eternal. " +
"Please provide a properly initialized Lifetime or use `Lifetime?` if you need to handle both cases. " +
"Use Lifetime.Eternal explicitly if that behavior is intended.");
}
}

//ctor
internal Lifetime(LifetimeDefinition definition)
{
Expand Down Expand Up @@ -167,6 +175,17 @@ internal Lifetime(LifetimeDefinition definition)
/// Whether current lifetime is equal to <see cref="Eternal"/> and never be terminated
/// </summary>
[PublicAPI] public bool IsEternal => Definition.IsEternal;


/// <summary>
/// Whether current lifetime is not properly initialized (created by default(Lifetime))
/// </summary>
[PublicAPI] public bool IsUninitialized => !IsInitialized;

/// <summary>
/// Whether current lifetime is properly initialized
/// </summary>
[PublicAPI] public bool IsInitialized => myDefinition != null;

/// <summary>
/// Is <see cref="Status"/> of this lifetime equal to <see cref="LifetimeStatus.Alive"/>
Expand Down
4 changes: 3 additions & 1 deletion rd-net/Lifetimes/Lifetimes/ValueLifetimed.cs
Original file line number Diff line number Diff line change
Expand Up @@ -20,13 +20,15 @@ public void Deconstruct(out Lifetime lifetime, out T? value)

public ValueLifetimed(Lifetime lifetime, T value)
{
lifetime.AssertInitialized();

Lifetime = lifetime;
Value = value;
}

public void ClearValueIfNotAlive()
{
if (!Lifetime.IsAlive)
if (Lifetime is { IsInitialized: true, IsAlive: false })
Value = default(T);
}
}
Expand Down
25 changes: 17 additions & 8 deletions rd-net/Test.Lifetimes/Lifetimes/LifetimeTest.cs
Original file line number Diff line number Diff line change
Expand Up @@ -152,16 +152,25 @@ public void TestEternal()
[Test]
public void TestEquals()
{
Lifetime eternal = default;
Assert.AreEqual(Lifetime.Eternal, eternal);
Assert.AreEqual(Lifetime.Eternal, Lifetime.Eternal);
Assert.AreEqual(eternal, eternal);
var old = Lifetime.LogErrorIfLifetimeIsNotInitialized;
Lifetime.LogErrorIfLifetimeIsNotInitialized = false;
try
{
Lifetime eternal = default;
Assert.AreEqual(Lifetime.Eternal, eternal);
Assert.AreEqual(Lifetime.Eternal, Lifetime.Eternal);
Assert.AreEqual(eternal, eternal);

Assert.True(Lifetime.Eternal == eternal);
Assert.True(Lifetime.Eternal == eternal);

Assert.AreNotEqual(Lifetime.Eternal, Lifetime.Terminated);
Assert.False(Lifetime.Eternal == Lifetime.Terminated);
Assert.False(eternal == Lifetime.Terminated);
Assert.AreNotEqual(Lifetime.Eternal, Lifetime.Terminated);
Assert.False(Lifetime.Eternal == Lifetime.Terminated);
Assert.False(eternal == Lifetime.Terminated);
}
finally
{
Lifetime.LogErrorIfLifetimeIsNotInitialized = old;
}
}

[Test]
Expand Down

0 comments on commit 12a68a9

Please sign in to comment.