FaGe.Steamworks.NET.Extensions
1.1.1
dotnet add package FaGe.Steamworks.NET.Extensions --version 1.1.1
NuGet\Install-Package FaGe.Steamworks.NET.Extensions -Version 1.1.1
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="FaGe.Steamworks.NET.Extensions" Version="1.1.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add FaGe.Steamworks.NET.Extensions --version 1.1.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: FaGe.Steamworks.NET.Extensions, 1.1.1"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install FaGe.Steamworks.NET.Extensions as a Cake Addin #addin nuget:?package=FaGe.Steamworks.NET.Extensions&version=1.1.1 // Install FaGe.Steamworks.NET.Extensions as a Cake Tool #tool nuget:?package=FaGe.Steamworks.NET.Extensions&version=1.1.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
FaGe's Steamworks.NET Extension for .NET 8+
As you can see, this project is aimed to extend modern features to Steamworks.NET
on regular .NET projects that targeting to up to date framework.
Extended features list
- Allow get Steam API CallResult by
await
, achived byToValueTask<T>()
extension method series onSteamAPICall_t
. These methods build on top of originalCallResult<T>
and can be accessed by using namespaceFaGe.Steamworks.NET.Extensions
. In current version, there are 2 variants.- Method
ToValueTask<T>()
is suitable for those call-results that don't considering cancellation. Example:var queryResult = await SteamUGC.SendQueryUGCRequest(queryHandle).ToValueTask<SteamUGCQueryCompleted_t>();
- Method
ToValueTaskWithCancellation<T>()
returns aValueTask<T>
and carry out aCancellationTokenSource
for cancellation, you can later cancel this operation by thatCancellationTokenSource
. Example:// do async operation var result = await SteamUGC.SendQueryUGCRequest(queryHandle).ToValueTaskWithCancellation<SteamUGCQueryCompleted_t>(out ctsInSomeField); // somewhere else that want to cancel ctsInSomeField.Cancel()
SteamAPICallException
will thrown if call-result is failed.
- Method
- Spawn automatic steam callback dispatcher thread by
SteamCallbackDispatch.Singleton.SpawnCallbackDispatchThread()
method.- Stop the dispatcher thread by the returned
CancellationTokenSource
.SteamCallbackDispatch.Singleton.StopDispatchSource
is also the same. Beware, once the thread is stopped, it can't be restarted. - Lived in namespace
FaGe.Steamworks.NET.Extensions
- Stop the dispatcher thread by the returned
- Wrap
UgcQueryHandle_t
for both query and result.- Create fluent query builder from methods in static class
FaGe.Steamworks.NET.Extensions.Ugc.UgcQueryBuilders
. Each factory method wraps a correspondingCreateQuery*UGCRequest()
.- Exception
UgcQueryBuildException
: query operator is failed to apply.
- If you want to abandon a query, you should call
*UgcQueryBuilder.AbandonQuery()
to release handle. - For now in the unit test project
DetailsUgcQueryBuilder.FilterCloudFileName()
will fail due to unknown reason, no corresponding IPC log found in steam console. Not sure if real application will fail too.
- Exception
- Once query built, call
UgcQuery.Send()
to get result wrapped inUgcQueryResult
.UgcQueryFailedException
will thrown for failed query.
- The
UgcQueryResult
is a collection of query result, each item is aUgcQueryResultItem
. Methods likeGetDetails()
andGetTags()
are used to retrieve information of a single UGC item. There are also some count properties.
- Create fluent query builder from methods in static class
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net8.0
- Steamworks.NET (>= 2024.8.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.