using System; using Cpp2IlInjected; using Steamworks; using UnityEngine; // Token: 0x02000105 RID: 261 [Token(Token = "0x2000105")] public class SteamAchievementSystem : IAchievementSystem { // Token: 0x06000E5D RID: 3677 RVA: 0x000229E4 File Offset: 0x00020BE4 [Token(Token = "0x6000E5D")] [Address(RVA = "0x492D20", Offset = "0x491520", VA = "0x180492D20")] public SteamAchievementSystem(string[] achievementKeys) { /* An exception occurred when decompiling this method (06000E5D) ICSharpCode.Decompiler.DecompilerException: Error decompiling System.Void SteamAchievementSystem::.ctor(System.String[]) ---> System.Exception: Basic block has to end with unconditional control flow. {; Block_0:; call:void(object::.ctor, ldloc:SteamAchievementSystem[exp:object](this)); stfld:string[](SteamAchievementSystem::achievementKeys, ldloc:SteamAchievementSystem(this), ldloc:string[](achievementKeys)); }; at ICSharpCode.Decompiler.ILAst.ILAstOptimizer.FlattenBasicBlocks(ILNode node) in D:\a\dnSpy\dnSpy\Extensions\ILSpy.Decompiler\ICSharpCode.Decompiler\ICSharpCode.Decompiler\ILAst\ILAstOptimizer.cs:line 1810 at ICSharpCode.Decompiler.ILAst.ILAstOptimizer.Optimize(DecompilerContext context, ILBlock method, AutoPropertyProvider autoPropertyProvider, StateMachineKind& stateMachineKind, MethodDef& inlinedMethod, AsyncMethodDebugInfo& asyncInfo, ILAstOptimizationStep abortBeforeStep) in D:\a\dnSpy\dnSpy\Extensions\ILSpy.Decompiler\ICSharpCode.Decompiler\ICSharpCode.Decompiler\ILAst\ILAstOptimizer.cs:line 344 at ICSharpCode.Decompiler.Ast.AstMethodBodyBuilder.CreateMethodBody(IEnumerable`1 parameters, MethodDebugInfoBuilder& builder) in D:\a\dnSpy\dnSpy\Extensions\ILSpy.Decompiler\ICSharpCode.Decompiler\ICSharpCode.Decompiler\Ast\AstMethodBodyBuilder.cs:line 123 at ICSharpCode.Decompiler.Ast.AstMethodBodyBuilder.CreateMethodBody(MethodDef methodDef, DecompilerContext context, AutoPropertyProvider autoPropertyProvider, IEnumerable`1 parameters, Boolean valueParameterIsKeyword, StringBuilder sb, MethodDebugInfoBuilder& stmtsBuilder) in D:\a\dnSpy\dnSpy\Extensions\ILSpy.Decompiler\ICSharpCode.Decompiler\ICSharpCode.Decompiler\Ast\AstMethodBodyBuilder.cs:line 88 --- End of inner exception stack trace --- at ICSharpCode.Decompiler.Ast.AstMethodBodyBuilder.CreateMethodBody(MethodDef methodDef, DecompilerContext context, AutoPropertyProvider autoPropertyProvider, IEnumerable`1 parameters, Boolean valueParameterIsKeyword, StringBuilder sb, MethodDebugInfoBuilder& stmtsBuilder) in D:\a\dnSpy\dnSpy\Extensions\ILSpy.Decompiler\ICSharpCode.Decompiler\ICSharpCode.Decompiler\Ast\AstMethodBodyBuilder.cs:line 92 at ICSharpCode.Decompiler.Ast.AstBuilder.AddMethodBody(EntityDeclaration methodNode, EntityDeclaration& updatedNode, MethodDef method, IEnumerable`1 parameters, Boolean valueParameterIsKeyword, MethodKind methodKind) in D:\a\dnSpy\dnSpy\Extensions\ILSpy.Decompiler\ICSharpCode.Decompiler\ICSharpCode.Decompiler\Ast\AstBuilder.cs:line 1618 */; } // Token: 0x06000E5E RID: 3678 RVA: 0x000020D3 File Offset: 0x000002D3 [Token(Token = "0x6000E5E")] [Address(RVA = "0xB19B50", Offset = "0xB18350", VA = "0x180B19B50", Slot = "4")] public bool HasUnlocked(int index) { throw new AnalysisFailedException("CPP2IL failed to recover any usable IL for this method."); } // Token: 0x06000E5F RID: 3679 RVA: 0x00022A00 File Offset: 0x00020C00 [Token(Token = "0x6000E5F")] [Address(RVA = "0xB19BA0", Offset = "0xB183A0", VA = "0x180B19BA0", Slot = "5")] public void Unlock(int index) { bool flag = SteamUserStats.SetAchievement(this.achievementKeys[index]); bool flag2 = SteamUserStats.StoreStats(); } // Token: 0x06000E60 RID: 3680 RVA: 0x00022A30 File Offset: 0x00020C30 [Token(Token = "0x6000E60")] [Address(RVA = "0xB19930", Offset = "0xB18130", VA = "0x180B19930")] public void ClearAll() { string[] array = this.achievementKeys; int num = 0; if (num < array.Length) { string text = this.achievementKeys[num]; if (!SteamUserStats.ClearAchievement(text)) { Debug.LogError("Clear steam achievement failed: " + text); } string[] array2 = this.achievementKeys; num++; } if (!SteamUserStats.StoreStats()) { Debug.LogError("Store all steam achievements failed."); } } // Token: 0x06000E61 RID: 3681 RVA: 0x00022A9C File Offset: 0x00020C9C [Token(Token = "0x6000E61")] [Address(RVA = "0xB19A90", Offset = "0xB18290", VA = "0x180B19A90")] private void Clear(int index) { string text = this.achievementKeys[index]; if (!SteamUserStats.ClearAchievement(text)) { Debug.LogError("Clear steam achievement failed: " + text); } } // Token: 0x04001924 RID: 6436 [FieldOffset(Offset = "0x10")] [Token(Token = "0x4001924")] private string[] achievementKeys; }