Added Inventory.OnDefinitionsUpdated

This commit is contained in:
Garry Newman 2018-03-21 11:27:18 +00:00
parent 144f401d2c
commit 7b7cfa29c4
3 changed files with 93 additions and 39 deletions

View File

@ -15,6 +15,12 @@ namespace Facepunch.Steamworks.Test
{ {
using ( var client = new Facepunch.Steamworks.Client( 252490 ) ) using ( var client = new Facepunch.Steamworks.Client( 252490 ) )
{ {
while ( client.Inventory.Definitions == null )
{
client.Update();
System.Threading.Thread.Sleep( 10 );
}
Assert.IsNotNull( client.Inventory.Definitions ); Assert.IsNotNull( client.Inventory.Definitions );
Assert.AreNotEqual( 0, client.Inventory.Definitions.Length ); Assert.AreNotEqual( 0, client.Inventory.Definitions.Length );
@ -36,6 +42,12 @@ namespace Facepunch.Steamworks.Test
{ {
using ( var client = new Facepunch.Steamworks.Client( 252490 ) ) using ( var client = new Facepunch.Steamworks.Client( 252490 ) )
{ {
while ( client.Inventory.Definitions == null )
{
client.Update();
System.Threading.Thread.Sleep( 10 );
}
Assert.IsNotNull( client.Inventory.Definitions ); Assert.IsNotNull( client.Inventory.Definitions );
Assert.AreNotEqual( 0, client.Inventory.Definitions.Length ); Assert.AreNotEqual( 0, client.Inventory.Definitions.Length );
@ -58,6 +70,12 @@ namespace Facepunch.Steamworks.Test
{ {
using ( var client = new Facepunch.Steamworks.Client( 252490 ) ) using ( var client = new Facepunch.Steamworks.Client( 252490 ) )
{ {
while ( client.Inventory.Definitions == null )
{
client.Update();
System.Threading.Thread.Sleep( 10 );
}
Assert.IsNotNull( client.Inventory.Definitions ); Assert.IsNotNull( client.Inventory.Definitions );
Assert.AreNotEqual( 0, client.Inventory.Definitions.Length ); Assert.AreNotEqual( 0, client.Inventory.Definitions.Length );
@ -80,6 +98,12 @@ namespace Facepunch.Steamworks.Test
{ {
using ( var client = new Facepunch.Steamworks.Client( 252490 ) ) using ( var client = new Facepunch.Steamworks.Client( 252490 ) )
{ {
while ( client.Inventory.Definitions == null )
{
client.Update();
System.Threading.Thread.Sleep( 10 );
}
bool CallbackCalled = false; bool CallbackCalled = false;
// OnUpdate hsould be called when we receive a list of our items // OnUpdate hsould be called when we receive a list of our items
@ -146,6 +170,12 @@ namespace Facepunch.Steamworks.Test
{ {
using ( var client = new Facepunch.Steamworks.Client( 252490 ) ) using ( var client = new Facepunch.Steamworks.Client( 252490 ) )
{ {
while ( client.Inventory.Definitions == null )
{
client.Update();
System.Threading.Thread.Sleep( 10 );
}
Assert.IsTrue( client.IsValid ); Assert.IsTrue( client.IsValid );
Assert.IsNotNull(client.Inventory.Definitions); Assert.IsNotNull(client.Inventory.Definitions);
Assert.AreNotEqual(0, client.Inventory.Definitions.Length); Assert.AreNotEqual(0, client.Inventory.Definitions.Length);
@ -202,6 +232,12 @@ namespace Facepunch.Steamworks.Test
{ {
using (var client = new Facepunch.Steamworks.Client(252490)) using (var client = new Facepunch.Steamworks.Client(252490))
{ {
while ( client.Inventory.Definitions == null )
{
client.Update();
System.Threading.Thread.Sleep( 10 );
}
Assert.IsNotNull(client.Inventory.Definitions); Assert.IsNotNull(client.Inventory.Definitions);
Assert.AreNotEqual(0, client.Inventory.Definitions.Length); Assert.AreNotEqual(0, client.Inventory.Definitions.Length);
@ -235,6 +271,12 @@ namespace Facepunch.Steamworks.Test
{ {
using (var client = new Facepunch.Steamworks.Client(252490)) using (var client = new Facepunch.Steamworks.Client(252490))
{ {
while ( client.Inventory.Definitions == null )
{
client.Update();
System.Threading.Thread.Sleep( 10 );
}
Assert.IsNotNull(client.Inventory.Definitions); Assert.IsNotNull(client.Inventory.Definitions);
Assert.AreNotEqual(0, client.Inventory.Definitions.Length); Assert.AreNotEqual(0, client.Inventory.Definitions.Length);

View File

@ -128,8 +128,6 @@ namespace Facepunch.Steamworks
public virtual void Update() public virtual void Update()
{ {
Inventory.Update();
Networking.Update(); Networking.Update();
RunUpdateCallbacks(); RunUpdateCallbacks();
@ -169,6 +167,11 @@ namespace Facepunch.Steamworks
} }
} }
/// <summary>
/// Debug function, called for every callback. Only really used to confirm that callbacks are working properly.
/// </summary>
public Action<object> OnAnyCallback;
Dictionary<Type, List<Action<object>>> Callbacks = new Dictionary<Type, List<Action<object>>>(); Dictionary<Type, List<Action<object>>> Callbacks = new Dictionary<Type, List<Action<object>>>();
internal List<Action<object>> CallbackList( Type T ) internal List<Action<object>> CallbackList( Type T )
@ -192,6 +195,11 @@ namespace Facepunch.Steamworks
{ {
i( data ); i( data );
} }
if ( OnAnyCallback != null )
{
OnAnyCallback.Invoke( data );
}
} }
internal void RegisterCallback<T>( Action<T> func ) internal void RegisterCallback<T>( Action<T> func )

View File

@ -37,25 +37,27 @@ namespace Facepunch.Steamworks
internal SteamNative.SteamInventory inventory; internal SteamNative.SteamInventory inventory;
private Stopwatch fetchRetryTimer;
private bool IsServer { get; set; } private bool IsServer { get; set; }
public event Action OnDefinitionsUpdated;
internal Inventory( BaseSteamworks steamworks, SteamNative.SteamInventory c, bool server ) internal Inventory( BaseSteamworks steamworks, SteamNative.SteamInventory c, bool server )
{ {
IsServer = server; IsServer = server;
inventory = c; inventory = c;
steamworks.RegisterCallback<SteamNative.SteamInventoryDefinitionUpdate_t>( onDefinitionsUpdated );
Result.Pending = new Dictionary<int, Result>(); Result.Pending = new Dictionary<int, Result>();
FetchItemDefinitions(); FetchItemDefinitions(); // onDefinitionsUpdated should get called on next Update
UpdatePrices();
if ( !server ) if ( !server )
{ {
steamworks.RegisterCallback<SteamNative.SteamInventoryResultReady_t>( onResultReady ); steamworks.RegisterCallback<SteamNative.SteamInventoryResultReady_t>( onResultReady );
steamworks.RegisterCallback<SteamNative.SteamInventoryFullUpdate_t>( onFullUpdate ); steamworks.RegisterCallback<SteamNative.SteamInventoryFullUpdate_t>( onFullUpdate );
// //
// Get a list of our items immediately // Get a list of our items immediately
// //
@ -63,6 +65,37 @@ namespace Facepunch.Steamworks
} }
} }
/// <summary>
/// Should get called when the definitions get updated from Steam.
/// </summary>
private void onDefinitionsUpdated( SteamInventoryDefinitionUpdate_t obj )
{
Console.WriteLine( "onDefinitionsUpdated" );
LoadDefinitions();
UpdatePrices();
if ( OnDefinitionsUpdated != null )
{
OnDefinitionsUpdated.Invoke();
}
}
private bool LoadDefinitions()
{
var ids = inventory.GetItemDefinitionIDs();
if ( ids == null )
return false;
Definitions = ids.Select( x => CreateDefinition( x ) ).ToArray();
foreach ( var def in Definitions )
{
def.Link( Definitions );
}
return true;
}
/// <summary> /// <summary>
/// We've received a FULL update /// We've received a FULL update
/// </summary> /// </summary>
@ -202,22 +235,7 @@ namespace Facepunch.Steamworks
/// </summary> /// </summary>
public void FetchItemDefinitions() public void FetchItemDefinitions()
{ {
//
// Make sure item definitions are loaded, because we're going to be using them.
//
inventory.LoadItemDefinitions(); inventory.LoadItemDefinitions();
var ids = inventory.GetItemDefinitionIDs();
if ( ids == null )
return;
Definitions = ids.Select( x => CreateDefinition( x ) ).ToArray();
foreach ( var def in Definitions )
{
def.Link( Definitions );
}
} }
/// <summary> /// <summary>
@ -225,24 +243,7 @@ namespace Facepunch.Steamworks
/// </summary> /// </summary>
public void Update() public void Update()
{ {
if ( Definitions == null )
{
//
// Don't try every frame, just try every 10 seconds.
//
{
if ( fetchRetryTimer != null && fetchRetryTimer.Elapsed.TotalSeconds < 10.0f )
return;
if ( fetchRetryTimer == null )
fetchRetryTimer = Stopwatch.StartNew();
fetchRetryTimer.Reset();
fetchRetryTimer.Start();
}
FetchItemDefinitions();
}
} }
/// <summary> /// <summary>
@ -258,7 +259,10 @@ namespace Facepunch.Steamworks
{ {
get get
{ {
for( int i=0; i< Definitions.Length; i++ ) if ( Definitions == null )
yield break;
for ( int i=0; i< Definitions.Length; i++ )
{ {
if (Definitions[i].LocalPrice > 0) if (Definitions[i].LocalPrice > 0)
yield return Definitions[i]; yield return Definitions[i];