mirror of
https://github.com/Facepunch/Facepunch.Steamworks.git
synced 2025-01-12 22:58:01 +03:00
Workshop file downloading
This commit is contained in:
parent
1a61766b2b
commit
3ff2b304a5
@ -30,6 +30,9 @@ namespace Facepunch.Steamworks.Test
|
|||||||
Assert.IsTrue( Query.TotalResults > 0 );
|
Assert.IsTrue( Query.TotalResults > 0 );
|
||||||
Assert.IsTrue( Query.Items.Length > 0 );
|
Assert.IsTrue( Query.Items.Length > 0 );
|
||||||
|
|
||||||
|
Console.WriteLine( "Query.TotalResults: {0}", Query.TotalResults );
|
||||||
|
Console.WriteLine( "Query.Items.Length: {0}", Query.Items.Length );
|
||||||
|
|
||||||
// results
|
// results
|
||||||
|
|
||||||
Console.WriteLine( "Searching" );
|
Console.WriteLine( "Searching" );
|
||||||
@ -196,7 +199,7 @@ namespace Facepunch.Steamworks.Test
|
|||||||
|
|
||||||
using ( var Query = client.Workshop.CreateQuery() )
|
using ( var Query = client.Workshop.CreateQuery() )
|
||||||
{
|
{
|
||||||
Query.FileId.Add( 751993251 );
|
Query.FileId.Add( 661319648 );
|
||||||
Query.Run();
|
Query.Run();
|
||||||
|
|
||||||
Assert.IsTrue( Query.IsRunning );
|
Assert.IsTrue( Query.IsRunning );
|
||||||
@ -209,7 +212,26 @@ namespace Facepunch.Steamworks.Test
|
|||||||
|
|
||||||
var item = Query.Items[0];
|
var item = Query.Items[0];
|
||||||
|
|
||||||
item.Download();
|
if ( !item.Installed )
|
||||||
|
{
|
||||||
|
item.Download();
|
||||||
|
|
||||||
|
while ( item.Downloading )
|
||||||
|
{
|
||||||
|
Thread.Sleep( 500 );
|
||||||
|
client.Update();
|
||||||
|
Console.WriteLine( "Download Progress: {0}", item.DownloadProgress );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Assert.IsNotNull( item.Directory );
|
||||||
|
Assert.AreNotEqual( 0, item.Size );
|
||||||
|
|
||||||
|
Console.WriteLine( "item.Installed: {0}", item.Installed );
|
||||||
|
Console.WriteLine( "item.Downloading: {0}", item.Downloading );
|
||||||
|
Console.WriteLine( "item.DownloadPending: {0}", item.DownloadPending );
|
||||||
|
Console.WriteLine( "item.Directory: {0}", item.Directory );
|
||||||
|
Console.WriteLine( "item.Size: {0}mb", (item.Size / 1024 / 1024) );
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -65,7 +65,7 @@ namespace Facepunch.Steamworks
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
internal void AddCallback<T>( Action<T> Callback, int id )
|
internal void AddCallback<T>( Action<T> Callback, int id )
|
||||||
{
|
{
|
||||||
var callback = new Facepunch.Steamworks.Interop.Callback<T>( IsGameServer, id, Callback );
|
var callback = new Callback<T>( IsGameServer, id, Callback );
|
||||||
Disposables.Add( callback );
|
Disposables.Add( callback );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -12,4 +12,113 @@ namespace Facepunch.Steamworks.Callbacks
|
|||||||
internal const int RemoteStorage = 1300;
|
internal const int RemoteStorage = 1300;
|
||||||
internal const int UGC = 3400;
|
internal const int UGC = 3400;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public enum Result : int
|
||||||
|
{
|
||||||
|
OK = 1, // success
|
||||||
|
Fail = 2, // generic failure
|
||||||
|
NoConnection = 3, // no/failed network connection
|
||||||
|
// k_EResultNoConnectionRetry = 4, // OBSOLETE - removed
|
||||||
|
InvalidPassword = 5, // password/ticket is invalid
|
||||||
|
LoggedInElsewhere = 6, // same user logged in elsewhere
|
||||||
|
InvalidProtocolVer = 7, // protocol version is incorrect
|
||||||
|
InvalidParam = 8, // a parameter is incorrect
|
||||||
|
FileNotFound = 9, // file was not found
|
||||||
|
Busy = 10, // called method busy - action not taken
|
||||||
|
InvalidState = 11, // called object was in an invalid state
|
||||||
|
InvalidName = 12, // name is invalid
|
||||||
|
InvalidEmail = 13, // email is invalid
|
||||||
|
DuplicateName = 14, // name is not unique
|
||||||
|
AccessDenied = 15, // access is denied
|
||||||
|
Timeout = 16, // operation timed out
|
||||||
|
Banned = 17, // VAC2 banned
|
||||||
|
AccountNotFound = 18, // account not found
|
||||||
|
InvalidSteamID = 19, // steamID is invalid
|
||||||
|
ServiceUnavailable = 20, // The requested service is currently unavailable
|
||||||
|
NotLoggedOn = 21, // The user is not logged on
|
||||||
|
Pending = 22, // Request is pending (may be in process, or waiting on third party)
|
||||||
|
EncryptionFailure = 23, // Encryption or Decryption failed
|
||||||
|
InsufficientPrivilege = 24, // Insufficient privilege
|
||||||
|
LimitExceeded = 25, // Too much of a good thing
|
||||||
|
Revoked = 26, // Access has been revoked (used for revoked guest passes)
|
||||||
|
Expired = 27, // License/Guest pass the user is trying to access is expired
|
||||||
|
AlreadyRedeemed = 28, // Guest pass has already been redeemed by account, cannot be acked again
|
||||||
|
DuplicateRequest = 29, // The request is a duplicate and the action has already occurred in the past, ignored this time
|
||||||
|
AlreadyOwned = 30, // All the games in this guest pass redemption request are already owned by the user
|
||||||
|
IPNotFound = 31, // IP address not found
|
||||||
|
PersistFailed = 32, // failed to write change to the data store
|
||||||
|
LockingFailed = 33, // failed to acquire access lock for this operation
|
||||||
|
LogonSessionReplaced = 34,
|
||||||
|
ConnectFailed = 35,
|
||||||
|
HandshakeFailed = 36,
|
||||||
|
IOFailure = 37,
|
||||||
|
RemoteDisconnect = 38,
|
||||||
|
ShoppingCartNotFound = 39, // failed to find the shopping cart requested
|
||||||
|
Blocked = 40, // a user didn't allow it
|
||||||
|
Ignored = 41, // target is ignoring sender
|
||||||
|
NoMatch = 42, // nothing matching the request found
|
||||||
|
AccountDisabled = 43,
|
||||||
|
ServiceReadOnly = 44, // this service is not accepting content changes right now
|
||||||
|
AccountNotFeatured = 45, // account doesn't have value, so this feature isn't available
|
||||||
|
AdministratorOK = 46, // allowed to take this action, but only because requester is admin
|
||||||
|
ContentVersion = 47, // A Version mismatch in content transmitted within the Steam protocol.
|
||||||
|
TryAnotherCM = 48, // The current CM can't service the user making a request, user should try another.
|
||||||
|
PasswordRequiredToKickSession = 49,// You are already logged in elsewhere, this cached credential login has failed.
|
||||||
|
AlreadyLoggedInElsewhere = 50, // You are already logged in elsewhere, you must wait
|
||||||
|
Suspended = 51, // Long running operation (content download) suspended/paused
|
||||||
|
Cancelled = 52, // Operation canceled (typically by user: content download)
|
||||||
|
DataCorruption = 53, // Operation canceled because data is ill formed or unrecoverable
|
||||||
|
DiskFull = 54, // Operation canceled - not enough disk space.
|
||||||
|
RemoteCallFailed = 55, // an remote call or IPC call failed
|
||||||
|
PasswordUnset = 56, // Password could not be verified as it's unset server side
|
||||||
|
ExternalAccountUnlinked = 57, // External account (PSN, Facebook...) is not linked to a Steam account
|
||||||
|
PSNTicketInvalid = 58, // PSN ticket was invalid
|
||||||
|
ExternalAccountAlreadyLinked = 59, // External account (PSN, Facebook...) is already linked to some other account, must explicitly request to replace/delete the link first
|
||||||
|
RemoteFileConflict = 60, // The sync cannot resume due to a conflict between the local and remote files
|
||||||
|
IllegalPassword = 61, // The requested new password is not legal
|
||||||
|
SameAsPreviousValue = 62, // new value is the same as the old one ( secret question and answer )
|
||||||
|
AccountLogonDenied = 63, // account login denied due to 2nd factor authentication failure
|
||||||
|
CannotUseOldPassword = 64, // The requested new password is not legal
|
||||||
|
InvalidLoginAuthCode = 65, // account login denied due to auth code invalid
|
||||||
|
AccountLogonDeniedNoMail = 66, // account login denied due to 2nd factor auth failure - and no mail has been sent
|
||||||
|
HardwareNotCapableOfIPT = 67, //
|
||||||
|
IPTInitError = 68, //
|
||||||
|
ParentalControlRestricted = 69, // operation failed due to parental control restrictions for current user
|
||||||
|
FacebookQueryError = 70, // Facebook query returned an error
|
||||||
|
ExpiredLoginAuthCode = 71, // account login denied due to auth code expired
|
||||||
|
IPLoginRestrictionFailed = 72,
|
||||||
|
AccountLockedDown = 73,
|
||||||
|
AccountLogonDeniedVerifiedEmailRequired = 74,
|
||||||
|
NoMatchingURL = 75,
|
||||||
|
BadResponse = 76, // parse failure, missing field, etc.
|
||||||
|
RequirePasswordReEntry = 77, // The user cannot complete the action until they re-enter their password
|
||||||
|
ValueOutOfRange = 78, // the value entered is outside the acceptable range
|
||||||
|
UnexpectedError = 79, // something happened that we didn't expect to ever happen
|
||||||
|
Disabled = 80, // The requested service has been configured to be unavailable
|
||||||
|
InvalidCEGSubmission = 81, // The set of files submitted to the CEG server are not valid !
|
||||||
|
RestrictedDevice = 82, // The device being used is not allowed to perform this action
|
||||||
|
RegionLocked = 83, // The action could not be complete because it is region restricted
|
||||||
|
RateLimitExceeded = 84, // Temporary rate limit exceeded, try again later, different from k_EResultLimitExceeded which may be permanent
|
||||||
|
AccountLoginDeniedNeedTwoFactor = 85, // Need two-factor code to login
|
||||||
|
ItemDeleted = 86, // The thing we're trying to access has been deleted
|
||||||
|
AccountLoginDeniedThrottle = 87, // login attempt failed, try to throttle response to possible attacker
|
||||||
|
TwoFactorCodeMismatch = 88, // two factor code mismatch
|
||||||
|
TwoFactorActivationCodeMismatch = 89, // activation code for two-factor didn't match
|
||||||
|
AccountAssociatedToMultiplePartners = 90, // account has been associated with multiple partners
|
||||||
|
NotModified = 91, // data not modified
|
||||||
|
NoMobileDevice = 92, // the account does not have a mobile device associated with it
|
||||||
|
TimeNotSynced = 93, // the time presented is out of range or tolerance
|
||||||
|
SmsCodeFailed = 94, // SMS code failure (no match, none pending, etc.)
|
||||||
|
AccountLimitExceeded = 95, // Too many accounts access this resource
|
||||||
|
AccountActivityLimitExceeded = 96, // Too many changes to this account
|
||||||
|
PhoneActivityLimitExceeded = 97, // Too many changes to this phone
|
||||||
|
RefundToWallet = 98, // Cannot refund to payment method, must use wallet
|
||||||
|
EmailSendFailure = 99, // Cannot send an email
|
||||||
|
NotSettled = 100, // Can't perform operation till payment has settled
|
||||||
|
NeedCaptcha = 101, // Needs to provide a valid captcha
|
||||||
|
GSLTDenied = 102, // a game server login token owned by this token's owner has been banned
|
||||||
|
GSOwnerDenied = 103, // game server owner is denied for other reason (account lock, community ban, vac ban, missing phone)
|
||||||
|
InvalidItemType = 104, // the type of thing we were requested to act on is invalid
|
||||||
|
IPBanned = 105, // the ip address has been banned from taking this action
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
@ -7,9 +7,36 @@ using Facepunch.Steamworks.Interop;
|
|||||||
|
|
||||||
namespace Facepunch.Steamworks.Callbacks.Workshop
|
namespace Facepunch.Steamworks.Callbacks.Workshop
|
||||||
{
|
{
|
||||||
|
|
||||||
|
[StructLayout( LayoutKind.Explicit )]
|
||||||
|
internal class ItemInstalled
|
||||||
|
{
|
||||||
|
[FieldOffset(0)]
|
||||||
|
public uint AppId;
|
||||||
|
[FieldOffset(4)]
|
||||||
|
public ulong FileId;
|
||||||
|
|
||||||
|
public const int CallbackId = Index.UGC + 5;
|
||||||
|
};
|
||||||
|
|
||||||
|
[StructLayout( LayoutKind.Explicit )]
|
||||||
|
internal class DownloadResult
|
||||||
|
{
|
||||||
|
[FieldOffset(0)]
|
||||||
|
public uint AppId;
|
||||||
|
[FieldOffset(4)]
|
||||||
|
public ulong FileId;
|
||||||
|
[FieldOffset(12)]
|
||||||
|
public Result Result;
|
||||||
|
|
||||||
|
public const int CallbackId = Index.UGC + 6;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
internal class QueryCompleted : CallResult<QueryCompleted.Data>
|
internal class QueryCompleted : CallResult<QueryCompleted.Data>
|
||||||
{
|
{
|
||||||
public override int CallbackId { get { return Callbacks.Index.UGC + 1; } }
|
public override int CallbackId { get { return Index.UGC + 1; } }
|
||||||
|
|
||||||
[StructLayout( LayoutKind.Sequential )]
|
[StructLayout( LayoutKind.Sequential )]
|
||||||
internal struct Data
|
internal struct Data
|
||||||
|
@ -15,7 +15,7 @@ namespace Facepunch.Steamworks
|
|||||||
{
|
{
|
||||||
public class Item
|
public class Item
|
||||||
{
|
{
|
||||||
internal ISteamUGC ugc;
|
internal Workshop workshop;
|
||||||
|
|
||||||
public string Description { get; private set; }
|
public string Description { get; private set; }
|
||||||
public ulong Id { get; private set; }
|
public ulong Id { get; private set; }
|
||||||
@ -26,11 +26,11 @@ namespace Facepunch.Steamworks
|
|||||||
public uint VotesDown { get; private set; }
|
public uint VotesDown { get; private set; }
|
||||||
public uint VotesUp { get; private set; }
|
public uint VotesUp { get; private set; }
|
||||||
|
|
||||||
internal static Item From( SteamUGCDetails_t details, ISteamUGC ugc )
|
internal static Item From( SteamUGCDetails_t details, Workshop workshop )
|
||||||
{
|
{
|
||||||
var item = new Item();
|
var item = new Item();
|
||||||
|
|
||||||
item.ugc = ugc;
|
item.workshop = workshop;
|
||||||
item.Id = details.m_nPublishedFileId;
|
item.Id = details.m_nPublishedFileId;
|
||||||
item.Title = details.m_rgchTitle;
|
item.Title = details.m_rgchTitle;
|
||||||
item.Description = details.m_rgchDescription;
|
item.Description = details.m_rgchDescription;
|
||||||
@ -39,13 +39,103 @@ namespace Facepunch.Steamworks
|
|||||||
item.Score = details.m_flScore;
|
item.Score = details.m_flScore;
|
||||||
item.VotesUp = details.m_unVotesUp;
|
item.VotesUp = details.m_unVotesUp;
|
||||||
item.VotesDown = details.m_unVotesDown;
|
item.VotesDown = details.m_unVotesDown;
|
||||||
|
item.UpdateState();
|
||||||
|
|
||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Download()
|
public void Download( bool highPriority = true )
|
||||||
{
|
{
|
||||||
|
UpdateState();
|
||||||
|
|
||||||
|
if ( Installed ) return;
|
||||||
|
if ( Downloading ) return;
|
||||||
|
|
||||||
|
if ( !workshop.ugc.DownloadItem( Id, highPriority ) )
|
||||||
|
{
|
||||||
|
Console.WriteLine( "Download Failed" );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
workshop.OnFileDownloaded += OnFileDownloaded;
|
||||||
|
UpdateState();
|
||||||
|
Downloading = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnFileDownloaded( ulong fileid, Callbacks.Result result )
|
||||||
|
{
|
||||||
|
workshop.OnFileDownloaded -= OnFileDownloaded;
|
||||||
|
UpdateState();
|
||||||
|
}
|
||||||
|
|
||||||
|
public ulong BytesDownloaded { get { UpdateDownloadProgress(); return _BytesDownloaded; } }
|
||||||
|
public ulong BytesTotalDownload { get { UpdateDownloadProgress(); return _BytesTotal; } }
|
||||||
|
|
||||||
|
public double DownloadProgress
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
UpdateDownloadProgress();
|
||||||
|
if ( _BytesTotal == 0 ) return 0;
|
||||||
|
return (double)_BytesDownloaded / (double)_BytesTotal;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool Installed { get; private set; }
|
||||||
|
public bool Downloading { get; private set; }
|
||||||
|
public bool DownloadPending { get; private set; }
|
||||||
|
public bool Subscribed { get; private set; }
|
||||||
|
public bool NeedsUpdate { get; private set; }
|
||||||
|
|
||||||
|
public DirectoryInfo Directory { get; private set; }
|
||||||
|
|
||||||
|
public ulong Size { get; private set; }
|
||||||
|
|
||||||
|
private ulong _BytesDownloaded, _BytesTotal;
|
||||||
|
|
||||||
|
internal void UpdateDownloadProgress()
|
||||||
|
{
|
||||||
|
workshop.ugc.GetItemDownloadInfo( Id, out _BytesDownloaded, out _BytesTotal );
|
||||||
|
}
|
||||||
|
|
||||||
|
internal void UpdateState()
|
||||||
|
{
|
||||||
|
var state = workshop.ugc.GetItemState( Id );
|
||||||
|
|
||||||
|
Installed = ( state & (uint) EItemState.k_EItemStateInstalled ) != 0;
|
||||||
|
Downloading = ( state & (uint) EItemState.k_EItemStateDownloading ) != 0;
|
||||||
|
DownloadPending = ( state & (uint) EItemState.k_EItemStateDownloadPending ) != 0;
|
||||||
|
Subscribed = ( state & (uint) EItemState.k_EItemStateSubscribed ) != 0;
|
||||||
|
NeedsUpdate = ( state & (uint) EItemState.k_EItemStateNeedsUpdate ) != 0;
|
||||||
|
|
||||||
|
if ( Installed && Directory == null )
|
||||||
|
{
|
||||||
|
ulong sizeOnDisk;
|
||||||
|
string folder;
|
||||||
|
uint timestamp;
|
||||||
|
workshop.ugc.GetItemInstallInfo( Id, out sizeOnDisk, out folder, out timestamp );
|
||||||
|
|
||||||
|
Directory = new DirectoryInfo( folder );
|
||||||
|
Size = sizeOnDisk;
|
||||||
|
|
||||||
|
if ( !Directory.Exists )
|
||||||
|
{
|
||||||
|
Size = 0;
|
||||||
|
Directory = null;
|
||||||
|
Installed = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void VoteUp()
|
||||||
|
{
|
||||||
|
workshop.ugc.SetUserItemVote( Id, true );
|
||||||
|
}
|
||||||
|
|
||||||
|
public void VoteDown()
|
||||||
|
{
|
||||||
|
workshop.ugc.SetUserItemVote( Id, false );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,7 +4,6 @@ using System.IO;
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using Facepunch.Steamworks.Callbacks.Networking;
|
|
||||||
using Facepunch.Steamworks.Callbacks.Workshop;
|
using Facepunch.Steamworks.Callbacks.Workshop;
|
||||||
using Facepunch.Steamworks.Interop;
|
using Facepunch.Steamworks.Interop;
|
||||||
using Valve.Steamworks;
|
using Valve.Steamworks;
|
||||||
@ -18,13 +17,32 @@ namespace Facepunch.Steamworks
|
|||||||
internal ISteamUGC ugc;
|
internal ISteamUGC ugc;
|
||||||
internal BaseSteamworks steamworks;
|
internal BaseSteamworks steamworks;
|
||||||
|
|
||||||
|
internal event Action<ulong, Callbacks.Result> OnFileDownloaded;
|
||||||
|
internal event Action<ulong> OnItemInstalled;
|
||||||
|
|
||||||
internal Workshop( BaseSteamworks sw, ISteamUGC ugc )
|
internal Workshop( BaseSteamworks sw, ISteamUGC ugc )
|
||||||
{
|
{
|
||||||
this.ugc = ugc;
|
this.ugc = ugc;
|
||||||
this.steamworks = sw;
|
this.steamworks = sw;
|
||||||
|
|
||||||
// sw.AddCallback<P2PSessionRequest>( onP2PConnectionRequest, P2PSessionRequest.CallbackId );
|
sw.AddCallback<DownloadResult>( onDownloadResult, DownloadResult.CallbackId );
|
||||||
|
sw.AddCallback<ItemInstalled>( onItemInstalled, ItemInstalled.CallbackId );
|
||||||
|
}
|
||||||
|
|
||||||
|
private void onItemInstalled( ItemInstalled obj )
|
||||||
|
{
|
||||||
|
Console.WriteLine( "OnItemInstalled" );
|
||||||
|
|
||||||
|
if ( OnItemInstalled != null )
|
||||||
|
OnItemInstalled( obj.FileId );
|
||||||
|
}
|
||||||
|
|
||||||
|
private void onDownloadResult( DownloadResult obj )
|
||||||
|
{
|
||||||
|
Console.WriteLine( "onDownloadResult" );
|
||||||
|
|
||||||
|
if ( OnFileDownloaded != null )
|
||||||
|
OnFileDownloaded( obj.FileId, obj.Result );
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum Order
|
public enum Order
|
||||||
@ -148,7 +166,7 @@ namespace Facepunch.Steamworks
|
|||||||
SteamUGCDetails_t details = new SteamUGCDetails_t();
|
SteamUGCDetails_t details = new SteamUGCDetails_t();
|
||||||
workshop.ugc.GetQueryUGCResult( data.Handle, (uint) i, ref details );
|
workshop.ugc.GetQueryUGCResult( data.Handle, (uint) i, ref details );
|
||||||
|
|
||||||
Items[i] = Item.From( details, workshop.ugc );
|
Items[i] = Item.From( details, workshop );
|
||||||
}
|
}
|
||||||
|
|
||||||
TotalResults = (int) data.m_unTotalMatchingResults;
|
TotalResults = (int) data.m_unTotalMatchingResults;
|
||||||
@ -199,7 +217,7 @@ namespace Facepunch.Steamworks
|
|||||||
|
|
||||||
public void Dispose()
|
public void Dispose()
|
||||||
{
|
{
|
||||||
|
// ReleaseQueryUGCRequest
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -732,7 +732,7 @@ namespace Valve.Interop
|
|||||||
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamApps_GetLaunchQueryParam" )]
|
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamApps_GetLaunchQueryParam" )]
|
||||||
internal static extern IntPtr SteamAPI_ISteamApps_GetLaunchQueryParam( IntPtr instancePtr, string pchKey );
|
internal static extern IntPtr SteamAPI_ISteamApps_GetLaunchQueryParam( IntPtr instancePtr, string pchKey );
|
||||||
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamApps_GetDlcDownloadProgress" )]
|
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamApps_GetDlcDownloadProgress" )]
|
||||||
[return: MarshalAs(UnmanagedType.I1)] internal static extern bool SteamAPI_ISteamApps_GetDlcDownloadProgress( IntPtr instancePtr, uint nAppID, ref ulong punBytesDownloaded, ref ulong punBytesTotal );
|
[return: MarshalAs(UnmanagedType.I1)] internal static extern bool SteamAPI_ISteamApps_GetDlcDownloadProgress( IntPtr instancePtr, uint nAppID, out ulong punBytesDownloaded, out ulong punBytesTotal );
|
||||||
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamApps_GetAppBuildId" )]
|
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamApps_GetAppBuildId" )]
|
||||||
internal static extern int SteamAPI_ISteamApps_GetAppBuildId( IntPtr instancePtr );
|
internal static extern int SteamAPI_ISteamApps_GetAppBuildId( IntPtr instancePtr );
|
||||||
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamApps_RequestAllProofOfPurchaseKeys" )]
|
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamApps_RequestAllProofOfPurchaseKeys" )]
|
||||||
@ -1088,9 +1088,9 @@ namespace Valve.Interop
|
|||||||
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamUGC_GetItemState" )]
|
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamUGC_GetItemState" )]
|
||||||
internal static extern uint SteamAPI_ISteamUGC_GetItemState( IntPtr instancePtr, ulong nPublishedFileID );
|
internal static extern uint SteamAPI_ISteamUGC_GetItemState( IntPtr instancePtr, ulong nPublishedFileID );
|
||||||
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamUGC_GetItemInstallInfo" )]
|
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamUGC_GetItemInstallInfo" )]
|
||||||
[return: MarshalAs(UnmanagedType.I1)] internal static extern bool SteamAPI_ISteamUGC_GetItemInstallInfo( IntPtr instancePtr, ulong nPublishedFileID, ref ulong punSizeOnDisk, System.Text.StringBuilder pchFolder, uint cchFolderSize, ref uint punTimeStamp );
|
[return: MarshalAs(UnmanagedType.I1)] internal static extern bool SteamAPI_ISteamUGC_GetItemInstallInfo( IntPtr instancePtr, ulong nPublishedFileID, out ulong punSizeOnDisk, System.Text.StringBuilder pchFolder, uint cchFolderSize, out uint punTimeStamp );
|
||||||
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamUGC_GetItemDownloadInfo" )]
|
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamUGC_GetItemDownloadInfo" )]
|
||||||
[return: MarshalAs(UnmanagedType.I1)] internal static extern bool SteamAPI_ISteamUGC_GetItemDownloadInfo( IntPtr instancePtr, ulong nPublishedFileID, ref ulong punBytesDownloaded, ref ulong punBytesTotal );
|
[return: MarshalAs(UnmanagedType.I1)] internal static extern bool SteamAPI_ISteamUGC_GetItemDownloadInfo( IntPtr instancePtr, ulong nPublishedFileID, out ulong punBytesDownloaded, out ulong punBytesTotal );
|
||||||
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamUGC_DownloadItem" )]
|
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamUGC_DownloadItem" )]
|
||||||
[return: MarshalAs(UnmanagedType.I1)] internal static extern bool SteamAPI_ISteamUGC_DownloadItem( IntPtr instancePtr, ulong nPublishedFileID, bool bHighPriority );
|
[return: MarshalAs(UnmanagedType.I1)] internal static extern bool SteamAPI_ISteamUGC_DownloadItem( IntPtr instancePtr, ulong nPublishedFileID, bool bHighPriority );
|
||||||
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamUGC_BInitWorkshopForGameServer" )]
|
[DllImportAttribute( Config.LibraryName, CallingConvention = CallingConvention.Cdecl, EntryPoint = "SteamAPI_ISteamUGC_BInitWorkshopForGameServer" )]
|
||||||
@ -2003,7 +2003,7 @@ namespace Valve.Steamworks
|
|||||||
internal abstract bool BIsAppInstalled( uint appID );
|
internal abstract bool BIsAppInstalled( uint appID );
|
||||||
internal abstract ulong GetAppOwner();
|
internal abstract ulong GetAppOwner();
|
||||||
internal abstract string GetLaunchQueryParam( string pchKey );
|
internal abstract string GetLaunchQueryParam( string pchKey );
|
||||||
internal abstract bool GetDlcDownloadProgress( uint nAppID, ref ulong punBytesDownloaded, ref ulong punBytesTotal );
|
internal abstract bool GetDlcDownloadProgress( uint nAppID, out ulong punBytesDownloaded, out ulong punBytesTotal );
|
||||||
internal abstract int GetAppBuildId();
|
internal abstract int GetAppBuildId();
|
||||||
internal abstract void RequestAllProofOfPurchaseKeys();
|
internal abstract void RequestAllProofOfPurchaseKeys();
|
||||||
}
|
}
|
||||||
@ -2229,8 +2229,8 @@ namespace Valve.Steamworks
|
|||||||
internal abstract uint GetNumSubscribedItems();
|
internal abstract uint GetNumSubscribedItems();
|
||||||
internal abstract uint GetSubscribedItems( ref ulong pvecPublishedFileID, uint cMaxEntries );
|
internal abstract uint GetSubscribedItems( ref ulong pvecPublishedFileID, uint cMaxEntries );
|
||||||
internal abstract uint GetItemState( ulong nPublishedFileID );
|
internal abstract uint GetItemState( ulong nPublishedFileID );
|
||||||
internal abstract bool GetItemInstallInfo( ulong nPublishedFileID, ref ulong punSizeOnDisk, out string pchFolder, ref uint punTimeStamp );
|
internal abstract bool GetItemInstallInfo( ulong nPublishedFileID, out ulong punSizeOnDisk, out string pchFolder, out uint punTimeStamp );
|
||||||
internal abstract bool GetItemDownloadInfo( ulong nPublishedFileID, ref ulong punBytesDownloaded, ref ulong punBytesTotal );
|
internal abstract bool GetItemDownloadInfo( ulong nPublishedFileID, out ulong punBytesDownloaded, out ulong punBytesTotal );
|
||||||
internal abstract bool DownloadItem( ulong nPublishedFileID, bool bHighPriority );
|
internal abstract bool DownloadItem( ulong nPublishedFileID, bool bHighPriority );
|
||||||
internal abstract bool BInitWorkshopForGameServer( uint unWorkshopDepotID, string pszFolder );
|
internal abstract bool BInitWorkshopForGameServer( uint unWorkshopDepotID, string pszFolder );
|
||||||
internal abstract void SuspendDownloads( bool bSuspend );
|
internal abstract void SuspendDownloads( bool bSuspend );
|
||||||
@ -4726,12 +4726,12 @@ namespace Valve.Steamworks
|
|||||||
IntPtr result = NativeEntrypoints.SteamAPI_ISteamApps_GetLaunchQueryParam(m_pSteamApps,pchKey);
|
IntPtr result = NativeEntrypoints.SteamAPI_ISteamApps_GetLaunchQueryParam(m_pSteamApps,pchKey);
|
||||||
return Marshal.PtrToStringAnsi( result );
|
return Marshal.PtrToStringAnsi( result );
|
||||||
}
|
}
|
||||||
internal override bool GetDlcDownloadProgress( uint nAppID, ref ulong punBytesDownloaded, ref ulong punBytesTotal )
|
internal override bool GetDlcDownloadProgress( uint nAppID, out ulong punBytesDownloaded, out ulong punBytesTotal )
|
||||||
{
|
{
|
||||||
CheckIfUsable();
|
CheckIfUsable();
|
||||||
punBytesDownloaded = 0;
|
punBytesDownloaded = 0;
|
||||||
punBytesTotal = 0;
|
punBytesTotal = 0;
|
||||||
bool result = NativeEntrypoints.SteamAPI_ISteamApps_GetDlcDownloadProgress(m_pSteamApps,nAppID,ref punBytesDownloaded,ref punBytesTotal);
|
bool result = NativeEntrypoints.SteamAPI_ISteamApps_GetDlcDownloadProgress(m_pSteamApps,nAppID,out punBytesDownloaded,out punBytesTotal);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
internal override int GetAppBuildId()
|
internal override int GetAppBuildId()
|
||||||
@ -5985,22 +5985,25 @@ namespace Valve.Steamworks
|
|||||||
uint result = NativeEntrypoints.SteamAPI_ISteamUGC_GetItemState(m_pSteamUGC,nPublishedFileID);
|
uint result = NativeEntrypoints.SteamAPI_ISteamUGC_GetItemState(m_pSteamUGC,nPublishedFileID);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
internal override bool GetItemInstallInfo( ulong nPublishedFileID, ref ulong punSizeOnDisk, out string pchFolder, ref uint punTimeStamp )
|
|
||||||
|
static System.Text.StringBuilder StringBuffer = new System.Text.StringBuilder(1024 * 16);
|
||||||
|
|
||||||
|
internal override bool GetItemInstallInfo( ulong nPublishedFileID, out ulong punSizeOnDisk, out string pchFolder, out uint punTimeStamp )
|
||||||
{
|
{
|
||||||
CheckIfUsable();
|
CheckIfUsable();
|
||||||
punSizeOnDisk = 0;
|
punSizeOnDisk = 0;
|
||||||
punTimeStamp = 0;
|
punTimeStamp = 0;
|
||||||
System.Text.StringBuilder pStrBuffer1 = new System.Text.StringBuilder(2048);
|
|
||||||
bool result = NativeEntrypoints.SteamAPI_ISteamUGC_GetItemInstallInfo(m_pSteamUGC,nPublishedFileID,ref punSizeOnDisk,pStrBuffer1,2048,ref punTimeStamp);
|
bool result = NativeEntrypoints.SteamAPI_ISteamUGC_GetItemInstallInfo (m_pSteamUGC,nPublishedFileID, out punSizeOnDisk, StringBuffer, (uint)StringBuffer.Capacity, out punTimeStamp );
|
||||||
pchFolder = pStrBuffer1.ToString();
|
pchFolder = StringBuffer.ToString();
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
internal override bool GetItemDownloadInfo( ulong nPublishedFileID, ref ulong punBytesDownloaded, ref ulong punBytesTotal )
|
internal override bool GetItemDownloadInfo( ulong nPublishedFileID, out ulong punBytesDownloaded, out ulong punBytesTotal )
|
||||||
{
|
{
|
||||||
CheckIfUsable();
|
CheckIfUsable();
|
||||||
punBytesDownloaded = 0;
|
punBytesDownloaded = 0;
|
||||||
punBytesTotal = 0;
|
punBytesTotal = 0;
|
||||||
bool result = NativeEntrypoints.SteamAPI_ISteamUGC_GetItemDownloadInfo(m_pSteamUGC,nPublishedFileID,ref punBytesDownloaded,ref punBytesTotal);
|
bool result = NativeEntrypoints.SteamAPI_ISteamUGC_GetItemDownloadInfo(m_pSteamUGC,nPublishedFileID,out punBytesDownloaded,out punBytesTotal);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
internal override bool DownloadItem( ulong nPublishedFileID, bool bHighPriority )
|
internal override bool DownloadItem( ulong nPublishedFileID, bool bHighPriority )
|
||||||
|
Loading…
x
Reference in New Issue
Block a user