Decompiled source of MapStation v0.19.1
MapStation.API.dll
Decompiled a week agousing System; using System.Collections.ObjectModel; using System.Diagnostics; using System.Reflection; using System.Runtime.CompilerServices; using System.Runtime.Versioning; using System.Security; using System.Security.Permissions; using Microsoft.CodeAnalysis; [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: TargetFramework(".NETFramework,Version=v4.7.1", FrameworkDisplayName = ".NET Framework 4.7.1")] [assembly: AssemblyCompany("MapStation.API")] [assembly: AssemblyConfiguration("Release")] [assembly: AssemblyFileVersion("1.0.0.0")] [assembly: AssemblyInformationalVersion("1.0.0+b563dbbebaa7f606b3f17d667187816fc03f215e")] [assembly: AssemblyProduct("MapStation.API")] [assembly: AssemblyTitle("MapStation.API")] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("1.0.0.0")] [module: UnverifiableCode] [module: RefSafetyRules(11)] namespace Microsoft.CodeAnalysis { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] internal sealed class EmbeddedAttribute : Attribute { } } namespace System.Runtime.CompilerServices { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Module, AllowMultiple = false, Inherited = false)] internal sealed class RefSafetyRulesAttribute : Attribute { public readonly int Version; public RefSafetyRulesAttribute(int P_0) { Version = P_0; } } } namespace MapStation.API { public static class APIManager { public static IMapStationAPI API; public static bool Initialized; public static event Action OnInitialized; public static void Initialize(IMapStationAPI api) { API = api; Initialized = true; APIManager.OnInitialized?.Invoke(); } } public interface ICustomStage { string DisplayName { get; } string InternalName { get; } string AuthorName { get; } int StageID { get; } } public interface IMapStationAPI { ReadOnlyCollection<ICustomStage> CustomStages { get; } ICustomStage GetCustomStageByID(int stageID); int GetStageID(string stageInternalName); } }
MapStation.Common.dll
Decompiled a week agousing System; using System.Collections; using System.Collections.Generic; using System.Diagnostics; using System.IO; using System.IO.Compression; using System.Linq; using System.Reflection; using System.Runtime.CompilerServices; using System.Runtime.Versioning; using System.Security; using System.Security.Permissions; using BepInEx.Logging; using MapStation.Common.Runtime; using MapStation.Common.Serialization; using Microsoft.CodeAnalysis; using Microsoft.Win32; using Reptile; using UnityEngine; using UnityEngine.Audio; using UnityEngine.Playables; using UnityEngine.Rendering.PostProcessing; [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: TargetFramework(".NETFramework,Version=v4.7.1", FrameworkDisplayName = ".NET Framework 4.7.1")] [assembly: IgnoresAccessChecksTo("Assembly-CSharp")] [assembly: AssemblyCompany("MapStation.Common")] [assembly: AssemblyConfiguration("Release")] [assembly: AssemblyFileVersion("1.0.0.0")] [assembly: AssemblyInformationalVersion("1.0.0+b563dbbebaa7f606b3f17d667187816fc03f215e")] [assembly: AssemblyProduct("MapStation.Common")] [assembly: AssemblyTitle("MapStation.Common")] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("1.0.0.0")] [module: UnverifiableCode] [module: RefSafetyRules(11)] namespace Microsoft.CodeAnalysis { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] internal sealed class EmbeddedAttribute : Attribute { } } namespace System.Runtime.CompilerServices { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Module, AllowMultiple = false, Inherited = false)] internal sealed class RefSafetyRulesAttribute : Attribute { public readonly int Version; public RefSafetyRulesAttribute(int P_0) { Version = P_0; } } } [AttributeUsage(AttributeTargets.Field, Inherited = true)] public class UidAttribute : PropertyAttribute { } namespace cspotcode.UnityGUI { public static class GUIUtil { private class EndScrollViewDisposable : IDisposable { public void Dispose() { GUILayout.EndScrollView(); } } private class EndVerticalDisposable : IDisposable { public void Dispose() { GUILayout.EndVertical(); } } private class EndHorizontalDisposable : IDisposable { public void Dispose() { GUILayout.EndHorizontal(); } } private class EndDisabledDisposable : IDisposable { private readonly bool stateBefore; internal EndDisabledDisposable(bool stateBefore) { this.stateBefore = stateBefore; } public void Dispose() { GUI.enabled = stateBefore; } } private class IndentDisposable : IDisposable { private readonly int increment; internal IndentDisposable(int increment) { this.increment = increment; } public void Dispose() { indentLevel -= increment; } } private class ApplyIndentDisposable : IDisposable { public void Dispose() { GUILayout.EndVertical(); GUILayout.EndHorizontal(); } } public const char UpTriangle = '▲'; public const char DownTriangle = '▼'; public const char RightTriangle = '▶'; public static readonly IDisposable EndScrollView = new EndScrollViewDisposable(); public static readonly IDisposable EndHorizontal = new EndHorizontalDisposable(); private const int PixelsPerIndentLevel = 15; public static readonly IDisposable EndApplyIndent = new ApplyIndentDisposable(); public static int indentLevel { get; set; } public static IDisposable ScrollView(ref Vector2 position) { //IL_0001: Unknown result type (might be due to invalid IL or missing references) //IL_000b: Unknown result type (might be due to invalid IL or missing references) //IL_0011: Expected O, but got Unknown //IL_0013: Unknown result type (might be due to invalid IL or missing references) //IL_0018: Unknown result type (might be due to invalid IL or missing references) ScrollViewScope val = new ScrollViewScope(position, Array.Empty<GUILayoutOption>()); position = val.scrollPosition; return (IDisposable)val; } public static IDisposable Horizontal() { GUILayout.BeginHorizontal(Array.Empty<GUILayoutOption>()); return EndHorizontal; } public static IDisposable Disabled(bool disabled = true) { EndDisabledDisposable result = new EndDisabledDisposable(GUI.enabled); GUI.enabled = !disabled; return result; } public static IDisposable Indent(int increment = 1, bool apply = false, bool nativeEditorGuiIndent = true) { indentLevel += increment; IndentDisposable indentDisposable = new IndentDisposable(increment); IDisposable disposable = null; if (apply) { disposable = ApplyIndent((!nativeEditorGuiIndent) ? increment : 0); } return new CompositeDisposable(disposable, indentDisposable); } public static IDisposable ApplyIndent(int offset = 0) { GUILayout.BeginHorizontal(Array.Empty<GUILayoutOption>()); GUILayout.Label("", (GUILayoutOption[])(object)new GUILayoutOption[2] { GUILayout.Width((float)(15 * (indentLevel + offset))), GUILayout.ExpandWidth(false) }); GUILayout.BeginVertical((GUILayoutOption[])(object)new GUILayoutOption[1] { GUILayout.ExpandWidth(false) }); return EndApplyIndent; } } public static class Extensions { } public class CompositeDisposable : IDisposable { private readonly IDisposable[] disposables; public CompositeDisposable(params IDisposable[] disposables) { this.disposables = disposables; } public void Dispose() { IDisposable[] array = disposables; for (int i = 0; i < array.Length; i++) { array[i]?.Dispose(); } } } } namespace MapStation.Common { public abstract class AGameMapStationPlugin { public virtual void OnAddMapToDatabase(ZipArchive archive, string path, string mapName) { } public virtual void OnReload() { } } public class NoOpDynamicPickup : MonoBehaviour { private void Awake() { Object.Destroy((Object)(object)((Component)this).gameObject); } } public class GrindConstants { public const float MinTriggerRadius = 0f; public const float MaxTriggerRadius = 2f; public const float DefaultTriggerRadius = 0.28f; } public class PathConstants { public const string MapFileExtension = ".brcmap"; public const string ConfigDirectory = "MapStation"; public const string TestMapsDirectory = "TestMaps"; public static string AbsoluteTestMapsDirectoryFromBepInExProfile(string BepInExProfileDirectory) { return Path.Combine(BepInExProfileDirectory, "Config", "MapStation", "TestMaps"); } } public class AssetNames { public const string MapDirectory = "Maps"; public const string SceneBasenamePrefix = "Scene."; public const string PropertiesBasename = "Properties"; public const string BundlePrefix = "maps/"; public const string SceneBundleBasename = "scene"; public const string SceneBundleSuffix = "/scene"; public const string AssetsBundleBasename = "assets"; public const string AssetsBundleSuffix = "/assets"; public const string BundleVariant = ""; public static string GetMiniMapPathForMap(string name) { return "Assets/Maps/" + name + "/MiniMap.prefab"; } public static string GetAssetDirectoryForMap(string name) { return "Assets/Maps/" + name; } public static string GetScenePathForMap(string name) { return "Assets/Maps/" + name + "/Scene." + name + ".unity"; } public static string GetPropertiesPathForMap(string name) { return "Assets/Maps/" + name + "/Properties.asset"; } public static string GetReadmePathForMap(string name) { return "Assets/Maps/" + name + "/README.md"; } public static string GetIconPathForMap(string name) { return "Assets/Maps/" + name + "/icon.png"; } public static string GetChangelogPathForMap(string name) { return "Assets/Maps/" + name + "/CHANGELOG.md"; } public static string GetSceneBundleNameForMap(string name) { return "maps/" + name.ToLower() + "/scene"; } public static string GetAssetBundleNameForMap(string name) { return "maps/" + name.ToLower() + "/assets"; } } public static class EnumeratePairsExtensions { public static IEnumerable<KeyValuePair<int, T>> Pairs<T>(this T[] array) { for (int i = 0; i < array.Length; i++) { yield return new KeyValuePair<int, T>(i, array[i]); } } public static IEnumerable<KeyValuePair<int, T>> Pairs<T>(this List<T> list) { for (int i = 0; i < list.Count; i++) { yield return new KeyValuePair<int, T>(i, list[i]); } } } public static class DeconstructPairsExtensions { public static void Deconstruct<T, U>(this KeyValuePair<T, U> pair, out T key, out U value) { key = pair.Key; value = pair.Value; } } public static class EnumeratorExtensions { public static T TakeNext<T>(this IEnumerator<T> enumerator) { enumerator.MoveNext(); return enumerator.Current; } } public static class Log { public static ManualLogSource Logger; public static void Info(string message) { Logger.LogInfo((object)message); } public static void Error(string message) { Logger.LogError((object)message); } public static void Warning(string message) { Logger.LogWarning((object)message); } public static void Debug(string message) { Logger.LogDebug((object)message); } } public class BaseMapDatabaseEntry { public string Name; public string ScenePath; public string SceneBundleName => AssetNames.GetSceneBundleNameForMap(Name); public string AssetsBundleName => AssetNames.GetAssetBundleNameForMap(Name); } [Serializable] public class MapProperties { public int format = 1; public string internalName; public string version = "0.0.0"; public string displayName = ""; public string authorName = ""; public bool showInFastTravelMenus = true; public bool disableCops; [Tooltip("Override the shadow distance for your map. Can be used to avoid shadows fading out too close.")] public bool overrideShadowDistance = true; [Range(0f, 500f)] public float shadowDistance = 150f; } public class MapZip : IDisposable { public const string propertiesFilename = "properties.json"; public const string sceneBundleFilename = "scene"; public const string assetsBundleFilename = "assets"; private string path; private ZipArchive zip; public MapZip(string path) { this.path = path; } public ZipArchive WriteZip(string propertiesContents, string sceneBundlePath, string assetsBundlePath, bool compressed = true) { CompressionLevel compressionLevel = ((!compressed) ? CompressionLevel.NoCompression : CompressionLevel.Optimal); zip = ZipFile.Open(path, ZipArchiveMode.Create); zip.CreateEntryFromFile(sceneBundlePath, "scene", compressionLevel); zip.CreateEntryFromFile(assetsBundlePath, "assets", compressionLevel); using (Stream stream = zip.CreateEntry("properties.json", compressionLevel).Open()) { using StreamWriter streamWriter = new StreamWriter(stream); streamWriter.Write(propertiesContents); } return zip; } private void openForReading() { if (zip == null) { zip = ZipFile.Open(path, ZipArchiveMode.Read); } } public void DoPluginOnAddMapToDatabase(string mapName) { openForReading(); GamePluginManager.OnAddMapToDatabase(zip, path, mapName); } public string GetPropertiesText() { openForReading(); using Stream stream = zip.GetEntry("properties.json").Open(); using StreamReader streamReader = new StreamReader(stream); return streamReader.ReadToEnd(); } public Stream GetSceneBundleStream() { openForReading(); return zip.GetEntry("scene").Open(); } public Stream GetAssetsBundleStream() { openForReading(); return zip.GetEntry("assets").Open(); } public void Dispose() { zip?.Dispose(); } } public class MiniMapProperties : MonoBehaviour { [Header("Material that will change colors in phone and pause menu.")] public Material MapMaterial; } public class PathDetection { public const string RegistryKey = "HKEY_CURRENT_USER\\Software\\BRCMapStation\\MapStation"; public const string RegistryValueBepInExProfile = "BepInExProfile"; public const string RegistryValueBRCPath = "BRCPath"; public const string RegistryValueUnityEditorDataDir = "UnityEditorDataDir"; public static string GetBepInExProfileInRegistry() { return Registry.GetValue("HKEY_CURRENT_USER\\Software\\BRCMapStation\\MapStation", "BepInExProfile", "") as string; } public static void SetBepInExProfileInRegistry(string path) { Registry.SetValue("HKEY_CURRENT_USER\\Software\\BRCMapStation\\MapStation", "BepInExProfile", path); } public static string GetBRCPathInRegistry() { return Registry.GetValue("HKEY_CURRENT_USER\\Software\\BRCMapStation\\MapStation", "BRCPath", "") as string; } public static void SetBRCPathInRegistry(string path) { Registry.SetValue("HKEY_CURRENT_USER\\Software\\BRCMapStation\\MapStation", "BRCPath", path); } public static string GetUnityEditorDataDirInRegistry() { return Registry.GetValue("HKEY_CURRENT_USER\\Software\\BRCMapStation\\MapStation", "UnityEditorDataDir", "") as string; } public static void SetUnityEditorDataDirInRegistry(string path) { Registry.SetValue("HKEY_CURRENT_USER\\Software\\BRCMapStation\\MapStation", "UnityEditorDataDir", path); } } public class StageObject : MonoBehaviour { [Header("Name of the chunk GameObject. Leave this empty to automatically find a chunk.")] [SerializeField] private string chunkName = ""; public void PutInChunk() { //IL_00db: Unknown result type (might be due to invalid IL or missing references) //IL_0106: Unknown result type (might be due to invalid IL or missing references) //IL_0112: Unknown result type (might be due to invalid IL or missing references) if ((Object)(object)((Component)this).GetComponentInParent<StageChunk>(true) != (Object)null) { return; } StageObject componentInParent = ((Component)this).GetComponentInParent<StageObject>(true); if ((Object)(object)componentInParent != (Object)(object)this && (Object)(object)componentInParent != (Object)null) { componentInParent.PutInChunk(); return; } StageChunk[] array = Object.FindObjectsOfType<StageChunk>(true); StageChunk val = null; float num = 0f; StageChunk[] array2 = array; foreach (StageChunk val2 in array2) { if ((Object)(object)val2 == (Object)null || ((Object)((Component)val2).gameObject).name.StartsWith("!")) { continue; } if (!string.IsNullOrEmpty(chunkName)) { if (((Object)((Component)val2).gameObject).name == chunkName) { ((Component)this).transform.SetParent(((Component)val2).transform); return; } continue; } BoxCollider[] componentsInChildren = ((Component)val2).GetComponentsInChildren<BoxCollider>(true); bool flag = false; BoxCollider[] array3 = componentsInChildren; foreach (BoxCollider val3 in array3) { if (!((Object)(object)val3 == (Object)null) && StageChunk.PointInOBB(((Component)this).transform.position, val3)) { flag = true; break; } } if (flag) { float num2 = Vector3.Distance(((Component)this).transform.position, ((Component)val2).transform.position); if ((Object)(object)val == (Object)null) { val = val2; num = num2; } else if (num2 < num) { val = val2; num = num2; } } } if ((Object)(object)val != (Object)null) { ((Component)this).transform.SetParent(((Component)val).transform); } } } public static class StagePrefabHijacker { public class StagePrefabs { public GameObject Parent; public List<GameObject> Toilets = new List<GameObject>(); public GameObject GetToilet() { GameObject result = Toilets[0]; Toilets.RemoveAt(0); return result; } } public const Stage StageToHijackPrefabsFrom = 5; public static string[] ProtectedAssetBundles = new string[16] { "characters", "graffiti", "common_assets", "enemies", "enemy_animation", "character_animation", "in_game_assets", "mocap_animation_two", "mocap_animation", "finalboss_assets", "playeranimation", "finalboss_animation", "storyanimation", "minimap", "common_game_shaders", "city_assets" }; public static Stage ActualTargetStage = (Stage)(-1); public static bool Loaded = false; public static bool Active = false; public static StagePrefabs Prefabs; private const int PublicToiletPool = 100; public static void Log(string text) { MapStation.Common.Log.Info("[StagePrefabHijacker] " + text); } private static void CleanUp() { if (Prefabs != null && !((Object)(object)Prefabs.Parent == (Object)null)) { Object.Destroy((Object)(object)Prefabs.Parent); } } public static void RunOnHijackStage() { //IL_0019: Unknown result type (might be due to invalid IL or missing references) //IL_0023: Expected O, but got Unknown //IL_0079: Unknown result type (might be due to invalid IL or missing references) //IL_007e: Unknown result type (might be due to invalid IL or missing references) CleanUp(); Prefabs = new StagePrefabs(); Prefabs.Parent = new GameObject("Custom Stage Prefabs"); Object.DontDestroyOnLoad((Object)(object)Prefabs.Parent); Prefabs.Parent.SetActive(false); PublicToilet val = Object.FindObjectOfType<PublicToilet>(); for (int i = 0; i < 100; i++) { GameObject val2 = Object.Instantiate<GameObject>(((Component)val).gameObject); val2.transform.SetParent(Prefabs.Parent.transform, false); val2.transform.SetPositionAndRotation(Vector3.zero, Quaternion.identity); val2.GetComponent<PublicToilet>().OnDestroy(); Prefabs.Toilets.Add(val2); } } public static void RunOnCustomStage() { } } public class DebugShapeUtility { public static IEnumerable<Renderer> FindDebugShapes(GameObject root) { return root.GetComponentsInChildren<Renderer>(true).Where(delegate(Renderer r) { Material sharedMaterial = r.sharedMaterial; return ((sharedMaterial != null) ? ((Object)sharedMaterial).name : null) == "Debug"; }); } public static void SetDebugShapesVisibility(GameObject root, bool visible) { foreach (Renderer item in FindDebugShapes(root)) { item.enabled = visible; } } } public class DebugUI : MonoBehaviour { public abstract class DebugMenu { public abstract string Name { get; } public virtual int? Width { get; } public abstract void OnGUI(); } public const int DefaultWidth = 400; private const int Height = 1200; private List<DebugMenu> debugMenus = new List<DebugMenu>(); private bool show = true; private DebugMenu currentDebugMenu; public static DebugUI Instance { get; private set; } public bool UiEnabled { get { return ((Component)this).gameObject.activeSelf; } set { ((Component)this).gameObject.SetActive(value); } } public static void Create(bool enabled) { //IL_0013: Unknown result type (might be due to invalid IL or missing references) //IL_0018: Unknown result type (might be due to invalid IL or missing references) //IL_001f: Unknown result type (might be due to invalid IL or missing references) //IL_002f: Expected O, but got Unknown if (!((Object)(object)Instance != (Object)null)) { GameObject val = new GameObject("MapStation Debug UI"); val.SetActive(enabled); Instance = val.AddComponent<DebugUI>(); Object.DontDestroyOnLoad((Object)val); } } public void RegisterMenu(DebugMenu menu) { debugMenus.Add(menu); } public void RemoveMenu(DebugMenu menu) { debugMenus.Remove(menu); } private void OnGUI() { //IL_0051: Unknown result type (might be due to invalid IL or missing references) int num = ((show && currentDebugMenu != null && currentDebugMenu.Width.HasValue) ? currentDebugMenu.Width.Value : 400); GUILayout.BeginArea(new Rect(0f, 0f, (float)num, 1200f)); GUILayout.BeginVertical(GUI.skin.box, Array.Empty<GUILayoutOption>()); GUILayout.BeginVertical(GUI.skin.box, Array.Empty<GUILayoutOption>()); GUILayout.BeginVertical("Debug UI", GUI.skin.box, Array.Empty<GUILayoutOption>()); GUILayout.Space(20f); try { if (GUILayout.Button("Show/Hide", Array.Empty<GUILayoutOption>())) { show = !show; } if (!show) { return; } if (currentDebugMenu != null) { if (GUILayout.Button("Back", Array.Empty<GUILayoutOption>())) { currentDebugMenu = null; } else { currentDebugMenu.OnGUI(); } return; } foreach (DebugMenu debugMenu in debugMenus) { if (GUILayout.Button(debugMenu.Name, Array.Empty<GUILayoutOption>())) { currentDebugMenu = debugMenu; } } } finally { GUILayout.EndVertical(); GUILayout.EndVertical(); GUILayout.EndVertical(); GUILayout.EndArea(); } } } public static class PluginInfo { public const string PLUGIN_GUID = "MapStation.Common"; public const string PLUGIN_NAME = "MapStation.Common"; public const string PLUGIN_VERSION = "1.0.0"; } } namespace MapStation.Common.Serialization { internal class SerializationExample : MonoBehaviour { [Serializable] private class Conversation { public string showIfUnlockableIsUnlocked; } [Serializable] private class Dialog { public string say; public string animation; public bool askYesNo; } private class SList_NpcDialog : SList<Dialog> { } [SerializeReference] private Conversation conversation = new Conversation(); [SerializeReference] private SList_NpcDialog npcDialog_ = new SList_NpcDialog(); private List<Dialog> npcDialogs => npcDialog_.items; private void Awake() { string text = ""; text += string.Format("{0} serialized data:\n", "SerializationExample"); text += string.Format("{0}.{1}={2}\n", "Conversation", "showIfUnlockableIsUnlocked", conversation.showIfUnlockableIsUnlocked); text += string.Format("{0}.Count={1}\n", "npcDialogs", npcDialogs.Count); for (int i = 0; i < npcDialogs.Count; i++) { text += string.Format("{0}[{1}].{2}={3}\n", "npcDialogs", i, "say", npcDialogs[i].say); text += string.Format("{0}[{1}].{2}={3}\n", "npcDialogs", i, "animation", npcDialogs[i].animation); text += string.Format("{0}[{1}].{2}={3}\n", "npcDialogs", i, "askYesNo", npcDialogs[i].askYesNo); } Log.Info(text); } } public class SList { } [Serializable] public class SList<T> : SList, ISerializationCallbackReceiver where T : new() { [HideInInspector] [SerializeReference] private Node linkedList; [SerializeReference] public List<T> items; public void copyToLinkedList() { if (items == null || items.Count == 0) { linkedList = null; return; } if (linkedList == null) { linkedList = new Node(); } Node next = linkedList; int i = 0; for (int count = items.Count; i < count; i++) { next.value = items[i]; if (i < count - 1) { Node node = next; if (node.next == null) { node.next = new Node(); } next = next.next; } else { next.next = null; } } } public void copyToList() { if (items == null) { items = new List<T>(); } else { items.Clear(); } for (Node next = linkedList; next != null; next = next.next) { items.Add((T)next.value); } } private void instantiateNullList() { if (items == null) { items = new List<T>(); } } private void instantiateNullItemsInList() { int i = 0; for (int count = items.Count; i < count; i++) { if (items[i] == null) { items[i] = new T(); } } } public void OnBeforeSerialize() { instantiateNullList(); instantiateNullItemsInList(); copyToLinkedList(); } public void OnAfterDeserialize() { if (!Application.isEditor) { copyToList(); } } } [Serializable] public class Node { [SerializeReference] public object value; [SerializeReference] public Node next; } } namespace MapStation.Common.Gameplay { [AddComponentMenu("")] public class GrindPath_FixComboBreakingProperty : MonoBehaviour { } public class MapStationVert : MonoBehaviour { } } namespace MapStation.Common.VanillaAssets { public class DeleteVanillaGameObjectsV1 : MonoBehaviour { public class SList_Deletion : SList<Deletion> { } [Serializable] public class Deletion { public string Path; } private HashSet<GameObject> disabledGameObjects = new HashSet<GameObject>(); [SerializeReference] private SList_Deletion deletions = new SList_Deletion(); public static DeleteVanillaGameObjectsV1 Instance { get; private set; } private List<Deletion> Deletions => deletions.items; private void Awake() { if (!Application.isEditor) { Instance = this; DeleteGameObjects(); } } public void DeleteGameObjects() { foreach (Deletion deletion in Deletions) { GameObject val = GameObject.Find(deletion.Path); if ((Object)(object)val == (Object)null) { Log.Info("DeleteVanillaGameObjectsV1 could not find GameObject to delete at path: " + deletion.Path); } else { HandleDeleteGameObject(val); } } } private void HandleDeleteGameObject(GameObject gameObject) { if ((Object)(object)gameObject.GetComponent<StreetLifeCluster>() != (Object)null) { DisableGameObject(gameObject); } else { Object.Destroy((Object)(object)gameObject); } } private void DisableGameObject(GameObject gameObject) { gameObject.SetActive(false); disabledGameObjects.Add(gameObject); } public bool IsDisabled(GameObject gameObject) { if (disabledGameObjects.Contains(gameObject)) { return true; } return false; } } public class MoveVanillaGameObjectV1 : MonoBehaviour { public string moveThis; public Transform targetLocation; private void Awake() { if (!Application.isEditor) { MoveGameObject(); } } public void MoveGameObject() { //IL_0017: Unknown result type (might be due to invalid IL or missing references) //IL_002c: Unknown result type (might be due to invalid IL or missing references) GameObject obj = GameObject.Find(moveThis); obj.transform.position = targetLocation.position; obj.transform.rotation = targetLocation.rotation; } } public class VanillaAssetReference : MonoBehaviour { public Component component; [TextArea(3, 10)] public List<string> fields = new List<string>(); public const BindingFlags UseTheseBindingFlags = BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.FlattenHierarchy; private void Awake() { AssignReferences(); } public void AssignReferences() { if ((Object)(object)component == (Object)null) { return; } foreach (string field in fields) { int num = field.IndexOf("="); int num2 = field.IndexOf(":"); string text = field.Substring(0, num); int num3 = -1; int num4 = text.IndexOf("["); if (num4 >= 0) { num3 = int.Parse(text.Substring(num4 + 1, -1)); ((Object)this).name = text.Substring(0, num4); } else { ((Object)this).name = text; } string text2 = field.Substring(num + 1, num2 - num - 1); string text3 = field.Substring(num2 + 1); Object val = Core.Instance.Assets.LoadAssetFromBundle<Object>(text2, text3); if (val == (Object)null) { Log.Info(string.Format("{0}: Restoring reference to vanilla asset failed, asset not found: {1}.{2} = LoadAssetFromBundle(\"{3}\", \"{4}\")", "VanillaAssetReference", ((object)component).GetType().Name, ((Object)this).name, text2, text3)); continue; } Type type = ((object)component).GetType(); MemberInfo memberInfo = type.GetMember(((Object)this).name, BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.FlattenHierarchy)[0]; string text4 = string.Format("VanillaAssetReference: Assigning {0}.{1} = asset {2}:{3} (asset found={4}, field found={5}, asset type={6})", type.Name, text, text2, text3, val != (Object)null, memberInfo != null, (val != (Object)null) ? ((object)val).GetType().Name : "<not found>"); try { if (num3 >= 0) { object obj = ((memberInfo is PropertyInfo propertyInfo) ? propertyInfo.GetValue(component) : ((FieldInfo)memberInfo).GetValue(component)); obj.GetType().GetProperty("Item").SetValue(obj, val, new object[1] { num3 }); } else if (memberInfo is PropertyInfo propertyInfo2) { propertyInfo2.SetValue(component, val); } else { ((FieldInfo)memberInfo).SetValue(component, val); } } catch (Exception ex) { Log.Info(text4 + "\nFailed with error:\n" + ex.Message + "\n" + ex.StackTrace); } } } } public class VanillaAssetReferenceV2 : MonoBehaviour { public class SList_Components : SList<ComponentEntry> { } [SerializeReference] private SList_Components components = new SList_Components(); public const BindingFlags UseTheseBindingFlags = BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.FlattenHierarchy; private List<ComponentEntry> Components => components.items; private void Awake() { AssignReferences(); } public void AssignReferences() { //IL_014a: Unknown result type (might be due to invalid IL or missing references) foreach (ComponentEntry component2 in Components) { Component component = component2.Component; foreach (FieldEntry field in component2.Fields) { Object val = null; Object[] array = null; if (field.SubAssetType == SubAssetType.FbxChild) { array = Core.Instance.Assets.availableBundles[field.BundleName].AssetBundle.LoadAssetWithSubAssets(field.Path); } else { val = Core.Instance.Assets.LoadAssetFromBundle<Object>(field.BundleName, field.Path); } if (val == (Object)null && array == null) { Log.Info(string.Format("{0}: Restoring reference to vanilla asset failed, asset not found: {1}.{2} = LoadAssetFromBundle(\"{3}\", \"{4}\")", "VanillaAssetReferenceV2", ((object)component).GetType().Name, field.Name, field.BundleName, field.Path)); continue; } switch (field.SubAssetType) { case SubAssetType.FbxChild: { Object[] array2 = array; foreach (Object val2 in array2) { if (val2.name == field.SubPath && !(val2 is GameObject) && !(val2 is Component)) { val = val2; break; } } break; } case SubAssetType.MixerGroup: val = (Object)(object)((AudioMixer)val).FindMatchingGroups(field.SubPath)[0]; break; } if (val == (Object)null) { Log.Info(string.Format("{0}: Restoring reference to vanilla asset failed, sub-asset not found: {1}.{2} = LoadAssetFromBundle(\"{3}\", \"{4}\"); SubAssetType={5}; SubPath={6}", "VanillaAssetReferenceV2", ((object)component).GetType().Name, field.Name, field.BundleName, field.Path, field.SubAssetType.ToString(), field.SubPath)); continue; } string message = ""; try { if (component is Animation && field.Name == "AddClip") { AddAnimationClip(val, component, field, out message); continue; } AssignMember(val, component, field, out message); Animation val3 = (Animation)(object)((component is Animation) ? component : null); if ((Object)(object)val3 != (Object)null && field.Name == "clip" && val3.playAutomatically) { ((MonoBehaviour)this).StartCoroutine(PlayAnimationAutomaticallyCoroutine(val3)); } } catch (Exception ex) { Log.Info(message + "\nFailed with error:\n" + ex.Message + "\n" + ex.StackTrace); } } } } private IEnumerator PlayAnimationAutomaticallyCoroutine(Animation animationComponent) { yield return (object)new WaitForEndOfFrame(); animationComponent.Play(); } public static void AssignMember(Object asset, Component component, FieldEntry f, out string message) { Type type = ((object)component).GetType(); MemberInfo memberInfo = type.GetMember(f.Name, BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.FlattenHierarchy)[0]; message = string.Format("{0}: Assigning {1}.{2} = asset {3}:{4} (asset found={5}, field found={6}, asset type={7})", "VanillaAssetReferenceV2", type.Name, f.PropertyPath, f.BundleName, f.Path, asset != (Object)null, memberInfo != null, (asset != (Object)null) ? ((object)asset).GetType().Name : "<not found>"); if (f.Index >= 0) { IList list = (IList)((memberInfo is PropertyInfo propertyInfo) ? propertyInfo.GetValue(component) : ((FieldInfo)memberInfo).GetValue(component)); list[f.Index] = asset; if (memberInfo is PropertyInfo) { ((PropertyInfo)memberInfo).SetValue(component, list); } else { ((FieldInfo)memberInfo).SetValue(component, list); } } else if (memberInfo is PropertyInfo propertyInfo2) { Object value = GetComponentFromPrefab(propertyInfo2.PropertyType, asset); propertyInfo2.SetValue(component, value); } else if (memberInfo is FieldInfo fieldInfo) { Object value2 = GetComponentFromPrefab(fieldInfo.FieldType, asset); fieldInfo.SetValue(component, value2); } else { Log.Info($"Unexpected member type: {memberInfo.MemberType}"); } static Object GetComponentFromPrefab(Type FieldOrPropertyType, Object asset) { GameObject val = (GameObject)(object)((asset is GameObject) ? asset : null); if (val != null && FieldOrPropertyType.IsSubclassOf(typeof(Component))) { return (Object)(object)val.GetComponent(FieldOrPropertyType); } return asset; } } public static void AddAnimationClip(Object asset, Component component, FieldEntry f, out string message) { message = "VanillaAssetReferenceV2: Animation.AddClip(asset, " + asset.name + ") where asset is " + f.BundleName + ":" + f.Path + ((f.SubPath != null) ? (":" + f.SubPath) : "") + " (asset type=" + ((asset != (Object)null) ? ((object)asset).GetType().Name : "<not found>") + ")"; ((Animation)((component is Animation) ? component : null)).AddClip((AnimationClip)(object)((asset is AnimationClip) ? asset : null), asset.name); } } [Serializable] public class ComponentEntry { private class SList_FieldEntry : SList<FieldEntry> { } [SerializeField] public Component Component; [SerializeReference] private SList_FieldEntry fields = new SList_FieldEntry(); public List<FieldEntry> Fields => fields.items; } [Serializable] public class FieldEntry { [HideInInspector] [SerializeField] public bool Enabled = true; [HideInInspector] [SerializeField] public bool AutoSync = true; [SerializeField] public string Name; [SerializeField] public int Index = -1; [SerializeField] public string BundleName; [SerializeField] public string Path; [SerializeField] public SubAssetType SubAssetType; [SerializeField] public string SubPath = ""; public string PropertyPath { get { if (Index < 0) { return Name; } return $"{Name}[{Index}]"; } } } public enum SubAssetType { None, MixerGroup, FbxChild } } namespace MapStation.Common.Dependencies { public class AssemblyDependencies { } } namespace MapStation.Common.Runtime { public class ActiveOnMapOption : MonoBehaviour { public enum Errors { InvalidOptionName, InvalidOptionValue, NoOptionValues, NoMapOptions, NoError } public enum FilterModes { OptionMatchesAnyValue, OptionDoesntMatchAnyValue } public FilterModes FilterMode; public string OptionName; public string[] OptionValues; public static string GetErrorDetails(Errors error) { return error switch { Errors.InvalidOptionName => "Choose a valid Map Option.", Errors.InvalidOptionValue => "Fix the invalid Map Option values by choosing valid options.", Errors.NoMapOptions => "Create a Map Options object for your map via the GameObject -> BRC MapStation menu.", Errors.NoOptionValues => "Define conditional Map Option values for this component to work.", _ => null, }; } public static string GetErrorString(Errors error) { return error switch { Errors.InvalidOptionName => "Invalid Option.", Errors.InvalidOptionValue => "One or more option values are invalid.", Errors.NoMapOptions => "There are no Map Options present in the map.", Errors.NoOptionValues => "No option values were defined.", _ => error.ToString(), }; } public Errors GetError() { MapOptions instance = MapOptions.Instance; if ((Object)(object)instance == (Object)null) { return Errors.NoMapOptions; } if (instance.Options == null) { return Errors.InvalidOptionName; } MapOptions.MapOption mapOption = null; MapOptions.MapOption[] options = instance.Options; foreach (MapOptions.MapOption mapOption2 in options) { if (mapOption2.Name == OptionName) { mapOption = mapOption2; break; } } if (mapOption == null) { return Errors.InvalidOptionName; } if (OptionValues == null || OptionValues.Length == 0) { return Errors.NoOptionValues; } string[] optionValues = OptionValues; foreach (string value in optionValues) { if (!mapOption.PossibleValues.Contains(value)) { return Errors.InvalidOptionValue; } } return Errors.NoError; } public void UpdateActivation() { LoadedMapOptions loadedMapOptions = LoadedMapOptions.GetCurrentMapOptions?.Invoke(); if (loadedMapOptions != null) { if (ShouldActivate(loadedMapOptions)) { ((Component)this).gameObject.SetActive(true); } else { ((Component)this).gameObject.SetActive(false); } } } private bool ShouldActivate(LoadedMapOptions mapOptions) { if (MatchesMapOptions(mapOptions)) { return FilterMode == FilterModes.OptionMatchesAnyValue; } return FilterMode == FilterModes.OptionDoesntMatchAnyValue; } private bool MatchesMapOptions(LoadedMapOptions mapOptions) { if (mapOptions.OptionMatches(OptionName, OptionValues)) { return true; } return false; } } public class FogChanger : MonoBehaviour { [Header("Changes fog settings when enabled.")] public bool FogEnabled; public Color Color = Color.grey; [Header("Linear Fog Settings")] public float Start; public float End = 300f; [Header("Exponential Fog Settings")] public float Density = 0.01f; private static bool OldFogEnabled = false; private static Color OldFogColor = Color.grey; private static float OldFogStart = 0f; private static float OldFogEnd = 300f; private static float OldFogDensity = 0.01f; private static FogChanger CurrentFogChanger = null; private void Awake() { //IL_0007: Unknown result type (might be due to invalid IL or missing references) //IL_0011: Expected O, but got Unknown StageManager.OnStageInitialized += new OnStageInitializedDelegate(StageInitialized); } private void OnDestroy() { //IL_0007: Unknown result type (might be due to invalid IL or missing references) //IL_0011: Expected O, but got Unknown StageManager.OnStageInitialized -= new OnStageInitializedDelegate(StageInitialized); } private void StageInitialized() { if (((Behaviour)this).isActiveAndEnabled) { OnEnable(); } } private void OnEnable() { //IL_0051: Unknown result type (might be due to invalid IL or missing references) //IL_0017: Unknown result type (might be due to invalid IL or missing references) //IL_001c: Unknown result type (might be due to invalid IL or missing references) if ((Object)(object)CurrentFogChanger == (Object)null) { OldFogEnabled = RenderSettings.fog; OldFogColor = RenderSettings.fogColor; OldFogStart = RenderSettings.fogStartDistance; OldFogEnd = RenderSettings.fogEndDistance; OldFogDensity = RenderSettings.fogDensity; } CurrentFogChanger = this; RenderSettings.fog = FogEnabled; RenderSettings.fogColor = Color; RenderSettings.fogDensity = Density; RenderSettings.fogStartDistance = Start; RenderSettings.fogEndDistance = End; } private void OnDisable() { //IL_001e: Unknown result type (might be due to invalid IL or missing references) if (!((Object)(object)CurrentFogChanger != (Object)(object)this)) { CurrentFogChanger = null; RenderSettings.fog = OldFogEnabled; RenderSettings.fogColor = OldFogColor; RenderSettings.fogDensity = OldFogDensity; RenderSettings.fogStartDistance = OldFogStart; RenderSettings.fogEndDistance = OldFogEnd; } } } [RequireComponent(typeof(AudioSource))] public class GameAudio : MonoBehaviour { public enum AudioTypes { Master = 0, Music = 4, SFX = 1, UI = 2, Gameplay = 3, Voices = 5, Ambience = 6 } public AudioTypes AudioType = AudioTypes.Gameplay; private void Awake() { ((Component)this).GetComponent<AudioSource>().outputAudioMixerGroup = Core.Instance.AudioManager.mixerGroups[(int)AudioType]; } } public static class GamePluginManager { private static ManualLogSource LogSource = Logger.CreateLogSource("MapStation Plugin Manager"); private static List<AGameMapStationPlugin> GetPlugins() { List<AGameMapStationPlugin> list = new List<AGameMapStationPlugin>(); Assembly[] assemblies = AppDomain.CurrentDomain.GetAssemblies(); foreach (Assembly assembly in assemblies) { try { Type[] types = assembly.GetTypes(); foreach (Type type in types) { try { if (typeof(AGameMapStationPlugin).IsAssignableFrom(type) && !type.IsAbstract) { AGameMapStationPlugin item = Activator.CreateInstance(type) as AGameMapStationPlugin; list.Add(item); } } catch (Exception arg) { LogSource.LogWarning((object)$"Problem loading Type, silently handled.{Environment.NewLine}{arg}"); } } } catch (Exception arg2) { LogSource.LogWarning((object)$"Problem loading Assembly, silently handled.{Environment.NewLine}{arg2}"); } } return list; } public static void OnAddMapToDatabase(ZipArchive archive, string path, string mapName) { foreach (AGameMapStationPlugin plugin in GetPlugins()) { plugin.OnAddMapToDatabase(archive, path, mapName); } } public static void OnReload() { foreach (AGameMapStationPlugin plugin in GetPlugins()) { plugin.OnReload(); } } } public class LightingChanger : MonoBehaviour { [Header("Changes the sun lighting when enabled.")] [Header("This GameObject's Transform will be applied to the Sun.")] [Header("Light Settings")] public Color LightColor = Color.white; [Header("BRC Shading Settings")] public Color EnvLightColor = Color.white; public Color EnvShadowColor = Color.black; private static Quaternion OldRotation = Quaternion.identity; private static Color OldLightColor = Color.white; private static Color OldEnvLightColor = Color.white; private static Color OldEnvShadowColor = Color.black; private static LightingChanger CurrentLightingChanger = null; private void Awake() { //IL_0007: Unknown result type (might be due to invalid IL or missing references) //IL_0011: Expected O, but got Unknown StageManager.OnStageInitialized += new OnStageInitializedDelegate(StageInitialized); } private void OnDestroy() { //IL_0007: Unknown result type (might be due to invalid IL or missing references) //IL_0011: Expected O, but got Unknown StageManager.OnStageInitialized -= new OnStageInitializedDelegate(StageInitialized); } private void StageInitialized() { if (((Behaviour)this).isActiveAndEnabled) { OnEnable(); } } private AmbientManager GetAmbientManager() { //IL_0016: Unknown result type (might be due to invalid IL or missing references) //IL_0021: Unknown result type (might be due to invalid IL or missing references) AmbientManager result = null; AmbientManager[] array = Object.FindObjectsOfType<AmbientManager>(); foreach (AmbientManager val in array) { if (((Component)val).gameObject.scene == ((Component)this).gameObject.scene) { result = val; break; } } return result; } private void OnEnable() { //IL_0057: Unknown result type (might be due to invalid IL or missing references) //IL_006d: Unknown result type (might be due to invalid IL or missing references) //IL_0079: Unknown result type (might be due to invalid IL or missing references) //IL_007e: Unknown result type (might be due to invalid IL or missing references) //IL_0085: Unknown result type (might be due to invalid IL or missing references) //IL_008a: Unknown result type (might be due to invalid IL or missing references) //IL_001a: Unknown result type (might be due to invalid IL or missing references) //IL_001f: Unknown result type (might be due to invalid IL or missing references) //IL_002a: Unknown result type (might be due to invalid IL or missing references) //IL_002f: Unknown result type (might be due to invalid IL or missing references) //IL_0035: Unknown result type (might be due to invalid IL or missing references) //IL_003a: Unknown result type (might be due to invalid IL or missing references) //IL_0040: Unknown result type (might be due to invalid IL or missing references) //IL_0045: Unknown result type (might be due to invalid IL or missing references) //IL_009f: Unknown result type (might be due to invalid IL or missing references) //IL_00a4: Unknown result type (might be due to invalid IL or missing references) //IL_00ab: Unknown result type (might be due to invalid IL or missing references) //IL_00b0: Unknown result type (might be due to invalid IL or missing references) //IL_00b7: Unknown result type (might be due to invalid IL or missing references) //IL_00bc: Unknown result type (might be due to invalid IL or missing references) //IL_00c3: Unknown result type (might be due to invalid IL or missing references) //IL_00c8: Unknown result type (might be due to invalid IL or missing references) AmbientManager ambientManager = GetAmbientManager(); if ((Object)(object)CurrentLightingChanger == (Object)null) { OldRotation = ((Component)ambientManager).transform.rotation; OldLightColor = ((Component)ambientManager).GetComponent<Light>().color; OldEnvLightColor = ambientManager.AmbientEnvLight; OldEnvShadowColor = ambientManager.AmbientEnvShadow; } CurrentLightingChanger = this; ((Component)ambientManager).GetComponent<Light>().color = LightColor; ((Component)ambientManager).transform.rotation = ((Component)this).transform.rotation; ambientManager.AmbientEnvLight = EnvLightColor; ambientManager.AmbientEnvShadow = EnvShadowColor; if ((Object)(object)ambientManager.curAmbientTrigger == (Object)null) { ambientManager.currentDefaultAmbientEnvLight = EnvLightColor; ambientManager.currentDefaultAmbientEnvShadow = EnvShadowColor; ambientManager.curLight = EnvLightColor; ambientManager.curShadow = EnvShadowColor; ambientManager.RevertAmbient(0f); } } private void OnDisable() { //IL_0021: Unknown result type (might be due to invalid IL or missing references) //IL_0031: Unknown result type (might be due to invalid IL or missing references) //IL_003c: Unknown result type (might be due to invalid IL or missing references) //IL_0041: Unknown result type (might be due to invalid IL or missing references) //IL_0047: Unknown result type (might be due to invalid IL or missing references) //IL_004c: Unknown result type (might be due to invalid IL or missing references) //IL_0060: Unknown result type (might be due to invalid IL or missing references) //IL_0065: Unknown result type (might be due to invalid IL or missing references) //IL_006b: Unknown result type (might be due to invalid IL or missing references) //IL_0070: Unknown result type (might be due to invalid IL or missing references) //IL_0076: Unknown result type (might be due to invalid IL or missing references) //IL_007b: Unknown result type (might be due to invalid IL or missing references) //IL_0081: Unknown result type (might be due to invalid IL or missing references) //IL_0086: Unknown result type (might be due to invalid IL or missing references) if (!((Object)(object)CurrentLightingChanger != (Object)(object)this)) { CurrentLightingChanger = null; AmbientManager ambientManager = GetAmbientManager(); ((Component)ambientManager).GetComponent<Light>().color = OldLightColor; ((Component)ambientManager).transform.rotation = OldRotation; ambientManager.AmbientEnvLight = OldEnvLightColor; ambientManager.AmbientEnvShadow = OldEnvShadowColor; if ((Object)(object)ambientManager.curAmbientTrigger == (Object)null) { ambientManager.currentDefaultAmbientEnvLight = OldEnvLightColor; ambientManager.currentDefaultAmbientEnvShadow = OldEnvShadowColor; ambientManager.curLight = OldEnvLightColor; ambientManager.curShadow = OldEnvShadowColor; ambientManager.RevertAmbient(0f); } } } } public class LoadedMapOptions { public Dictionary<string, string> Options = new Dictionary<string, string>(); public static Func<LoadedMapOptions> GetCurrentMapOptions; public void MakeDefault() { Options.Clear(); MapOptions instance = MapOptions.Instance; if (!((Object)(object)instance == (Object)null)) { MapOptions.MapOption[] options = instance.Options; foreach (MapOptions.MapOption mapOption in options) { Options[mapOption.Name] = mapOption.DefaultValue; } } } public void Sanitize() { MapOptions instance = MapOptions.Instance; if ((Object)(object)instance == (Object)null) { return; } foreach (KeyValuePair<string, string> option in Options) { MapOptions.MapOption[] options = instance.Options; foreach (MapOptions.MapOption mapOption in options) { if (mapOption.Name == option.Key && !mapOption.PossibleValues.Contains(option.Value)) { Options[option.Key] = mapOption.DefaultValue; } } } } public string GetOption(string optionName) { if (Options.TryGetValue(optionName, out var value)) { return value; } if ((Object)(object)MapOptions.Instance != (Object)null) { return MapOptions.Instance.GetDefaultOption(optionName); } return string.Empty; } public bool OptionMatches(string optionName, string[] optionValues) { return optionValues.Contains(GetOption(optionName)); } } public class MapOptions : MonoBehaviour { [Serializable] public class MapOption { public string Name; [TextArea(5, 5)] public string Description; public string DefaultValue; public string[] PossibleValues; [Tooltip("Camera shown when previewing the map option in-game.")] public Camera PreviewCamera; } private static MapOptions _instance; public static Action OnMapOptionsChanged; public MapOption[] Options; private static ActiveOnMapOption[] ActiveOnMapOptions = new ActiveOnMapOption[0]; public static MapOptions Instance { get { if ((Object)(object)_instance != (Object)null) { return _instance; } _instance = Object.FindObjectOfType<MapOptions>(); return _instance; } } private void Awake() { _instance = this; } public string GetError() { if (Options == null || Options.Length == 0) { return "No Map Options were defined."; } MapOption[] options = Options; foreach (MapOption mapOption in options) { if (mapOption.PossibleValues == null || mapOption.PossibleValues.Length == 0) { return "One or more Options don't have any possible values."; } if (!mapOption.PossibleValues.Contains(mapOption.DefaultValue)) { return "One or more Options don't have a valid default value."; } } return null; } public string GetDefaultOption(string optionName) { MapOption[] options = Options; foreach (MapOption mapOption in options) { if (mapOption.Name == optionName) { return mapOption.DefaultValue; } } return string.Empty; } public static void UpdateActiveOnMapOptions() { ActiveOnMapOption[] activeOnMapOptions = ActiveOnMapOptions; foreach (ActiveOnMapOption activeOnMapOption in activeOnMapOptions) { if (!((Object)(object)activeOnMapOption == (Object)null)) { activeOnMapOption.UpdateActivation(); } } } public static void OnStageInitialized() { ActiveOnMapOptions = Object.FindObjectsOfType<ActiveOnMapOption>(true); UpdateActiveOnMapOptions(); } } [RequireComponent(typeof(Camera))] public class MapStationCameraOverride : MonoBehaviour { public bool AlsoAffectPhoneCamera = true; private PostProcessLayer _layer; public static MapStationCameraOverride Instance { get; private set; } private void Awake() { Instance = this; Camera component = ((Component)this).GetComponent<Camera>(); if ((Object)(object)component != (Object)null) { ((Behaviour)component).enabled = false; } _layer = ((Component)this).GetComponent<PostProcessLayer>(); if ((Object)(object)_layer != (Object)null) { ((Behaviour)_layer).enabled = false; } AudioListener component2 = ((Component)this).GetComponent<AudioListener>(); if ((Object)(object)component2 != (Object)null) { ((Behaviour)component2).enabled = false; } } private void OnDestroy() { Instance = null; } public void ApplyToCamera(Camera camera) { //IL_0071: Unknown result type (might be due to invalid IL or missing references) //IL_0076: Unknown result type (might be due to invalid IL or missing references) //IL_0082: Unknown result type (might be due to invalid IL or missing references) //IL_0087: Unknown result type (might be due to invalid IL or missing references) if (!((Object)(object)camera == (Object)null) && (Object)(object)_layer != (Object)null) { PostProcessLayer val = ((Component)camera).gameObject.GetComponent<PostProcessLayer>(); if ((Object)(object)val == (Object)null) { val = ((Component)camera).gameObject.AddComponent<PostProcessLayer>(); } val.finalBlitToCameraTarget = _layer.finalBlitToCameraTarget; val.stopNaNPropagation = _layer.stopNaNPropagation; val.volumeTrigger = ((Component)camera).transform; val.volumeLayer = _layer.volumeLayer; val.antialiasingMode = _layer.antialiasingMode; val.fastApproximateAntialiasing = _layer.fastApproximateAntialiasing; val.subpixelMorphologicalAntialiasing = _layer.subpixelMorphologicalAntialiasing; val.temporalAntialiasing = _layer.temporalAntialiasing; FieldInfo field = typeof(PostProcessLayer).GetField("m_Resources", BindingFlags.Instance | BindingFlags.NonPublic); field.SetValue(val, field.GetValue(_layer)); } } } public class SkyboxSwitcher : MonoBehaviour { [Header("Changes the skybox when enabled.")] public Material Skybox; private Material _oldSkybox; private void Awake() { //IL_0007: Unknown result type (might be due to invalid IL or missing references) //IL_0011: Expected O, but got Unknown StageManager.OnStageInitialized += new OnStageInitializedDelegate(StageInitialized); } private void OnDestroy() { //IL_0007: Unknown result type (might be due to invalid IL or missing references) //IL_0011: Expected O, but got Unknown StageManager.OnStageInitialized -= new OnStageInitializedDelegate(StageInitialized); } private void StageInitialized() { if (((Behaviour)this).isActiveAndEnabled) { OnEnable(); } } private void OnEnable() { _oldSkybox = RenderSettings.skybox; RenderSettings.skybox = Skybox; } private void OnDisable() { if ((Object)(object)RenderSettings.skybox == (Object)(object)Skybox) { RenderSettings.skybox = _oldSkybox; } } } } namespace MapStation.Common.Runtime.Gameplay { public class MapStationPublicToilet : MonoBehaviour { public Transform Exit; public Animator DoorAnimator; public GameObject GreenLight; public GameObject RedLight; private void Awake() { //IL_00e4: Unknown result type (might be due to invalid IL or missing references) //IL_00e9: Unknown result type (might be due to invalid IL or missing references) //IL_0144: Unknown result type (might be due to invalid IL or missing references) //IL_0149: Unknown result type (might be due to invalid IL or missing references) Transform val = ((Component)this).transform.Find("Trigger"); GameObject toilet = StagePrefabHijacker.Prefabs.GetToilet(); PublicToilet component = toilet.GetComponent<PublicToilet>(); component.Awake(); Object.Destroy((Object)(object)((Component)((Component)component).transform.Find("OutHouse").Find("Cube.007")).gameObject); Object.Destroy((Object)(object)((Component)((Component)component).transform.Find("OutHouse").Find("Cube.001")).gameObject); Object.Destroy((Object)(object)((Component)((Component)component).transform.Find("Trigger")).gameObject); Object.Destroy((Object)(object)((Component)component.doorAnimator).gameObject); component.exit = Exit; component.doorAnimator = DoorAnimator; component.greenLight = GreenLight; component.redLight = RedLight; foreach (PlayableBinding output in component.sequence.playableAsset.outputs) { PlayableBinding current = output; if (((PlayableBinding)(ref current)).streamName == "Animation Track (3)") { component.sequence.SetGenericBinding(((PlayableBinding)(ref current)).sourceObject, (Object)(object)DoorAnimator); break; } } toilet.transform.SetParent(((Component)this).transform, false); toilet.transform.SetLocalPositionAndRotation(Vector3.zero, Quaternion.identity); ((Component)val).transform.SetParent(toilet.transform, true); } } } namespace System.Runtime.CompilerServices { [AttributeUsage(AttributeTargets.Assembly, AllowMultiple = true)] internal sealed class IgnoresAccessChecksToAttribute : Attribute { public IgnoresAccessChecksToAttribute(string assemblyName) { } } }
MapStation.Plugin.dll
Decompiled a week ago
The result has been truncated due to the large size, download it to view full contents!
using System; using System.Collections; using System.Collections.Generic; using System.Collections.ObjectModel; using System.Diagnostics; using System.IO; using System.Linq; using System.Reflection; using System.Runtime.CompilerServices; using System.Runtime.Versioning; using System.Security; using System.Security.Cryptography; using System.Security.Permissions; using System.Text; using System.Text.RegularExpressions; using System.Threading; using BepInEx; using BepInEx.Configuration; using BepInEx.Logging; using CommonAPI; using CommonAPI.Phone; using HarmonyLib; using MapStation.API; using MapStation.Common; using MapStation.Common.Dependencies; using MapStation.Common.Doctor; using MapStation.Common.Gameplay; using MapStation.Common.Runtime; using MapStation.Plugin; using MapStation.Plugin.API; using MapStation.Plugin.Dependencies; using MapStation.Plugin.Gameplay; using MapStation.Plugin.Phone; using MapStation.Plugin.Tools; using MapStation.TypeForwarder.Dependencies; using Microsoft.CodeAnalysis; using ProtoBuf; using Reptile; using Reptile.Phone; using Rewired; using TMPro; using Unity.AI.Navigation; using UnityEngine; using UnityEngine.Rendering.PostProcessing; using UnityEngine.SceneManagement; using cspotcode.SlopCrewClient; using cspotcode.SlopCrewClient.SlopCrewAPI; using cspotcode.UnityGUI; [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: TargetFramework(".NETFramework,Version=v4.7.1", FrameworkDisplayName = ".NET Framework 4.7.1")] [assembly: IgnoresAccessChecksTo("Assembly-CSharp")] [assembly: AssemblyCompany("MapStation.Plugin")] [assembly: AssemblyConfiguration("Release")] [assembly: AssemblyDescription("BepInEx Plugin Assembly for MapStation.")] [assembly: AssemblyFileVersion("0.19.1.0")] [assembly: AssemblyInformationalVersion("0.19.1+b563dbbebaa7f606b3f17d667187816fc03f215e")] [assembly: AssemblyProduct("MapStation.Plugin")] [assembly: AssemblyTitle("MapStation.Plugin")] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("0.19.1.0")] [module: UnverifiableCode] [module: RefSafetyRules(11)] namespace Microsoft.CodeAnalysis { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] internal sealed class EmbeddedAttribute : Attribute { } } namespace System.Runtime.CompilerServices { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Module, AllowMultiple = false, Inherited = false)] internal sealed class RefSafetyRulesAttribute : Attribute { public readonly int Version; public RefSafetyRulesAttribute(int P_0) { Version = P_0; } } } [HarmonyPatch(typeof(SceneManager))] internal static class SceneManagerPatch { [HarmonyPrefix] [HarmonyPatch("LoadSceneAsync")] [HarmonyPatch(new Type[] { typeof(string), typeof(LoadSceneMode) })] private static void LoadSceneAsync_Prefix(ref string sceneName, LoadSceneMode __1) { if (SceneNameMapper.Instance.Paths.TryGetValue(sceneName, out var value)) { Log.Info("SceneManager.LoadSceneAsync redirected from " + sceneName + " to " + value); sceneName = value; } } [HarmonyPrefix] [HarmonyPatch("UnloadSceneAsync")] [HarmonyPatch(new Type[] { typeof(string) })] private static void UnloadSceneAsync_Prefix(ref string sceneName) { if (SceneNameMapper.Instance.Names.TryGetValue(sceneName, out var value)) { Log.Info("SceneManager.UnloadSceneAsync redirected from " + sceneName + " to " + value); sceneName = value; } } } [HarmonyPatch(typeof(UnityLogSource))] internal class Patch { [HarmonyPrefix] [HarmonyPatch("OnUnityLogMessageReceived")] private static bool OnUnityLogMessageReceived_Prefix(string message, string stackTrace, LogType type) { //IL_0000: Unknown result type (might be due to invalid IL or missing references) //IL_0002: Invalid comparison between Unknown and I4 if ((int)type == 2 && message.Contains("does not support negative scale or size")) { return false; } return true; } } namespace MapStation.Common.Doctor { public static class Doctor { public const string AboutMe = "The Doctor will analyze your map and list any problems, offering suggestions to fix them."; private static readonly string[] VendingMachineAnimations = new string[5] { "none", "shake", "emptyShake", "close", "drop" }; public static Analysis Analyze(MapProperties mapProperties) { //IL_0000: Unknown result type (might be due to invalid IL or missing references) //IL_0005: Unknown result type (might be due to invalid IL or missing references) Scene activeScene = SceneManager.GetActiveScene(); return Analyze(((Scene)(ref activeScene)).GetRootGameObjects(), mapProperties); } public static Analysis Analyze(GameObject root, MapProperties mapProperties) { return Analyze((GameObject[])(object)new GameObject[1] { root }, mapProperties); } private static List<T> GetComponentsInChildren<T>(this GameObject[] roots) { List<T> list = new List<T>(); foreach (GameObject val in roots) { list.AddRange(val.GetComponentsInChildren<T>(true)); } return list; } private static void CheckMapOptions(Analysis a, GameObject[] roots) { //IL_007a: Unknown result type (might be due to invalid IL or missing references) //IL_007f: Unknown result type (might be due to invalid IL or missing references) //IL_0081: Unknown result type (might be due to invalid IL or missing references) //IL_0084: Invalid comparison between Unknown and I4 //IL_008a: Unknown result type (might be due to invalid IL or missing references) //IL_0091: Unknown result type (might be due to invalid IL or missing references) List<ActiveOnMapOption> componentsInChildren = roots.GetComponentsInChildren<ActiveOnMapOption>(); List<MapOptions> componentsInChildren2 = roots.GetComponentsInChildren<MapOptions>(); if (componentsInChildren2.Count > 1) { a.Add(Severity.Warning, null, "Multiple Map Options", "Multiple Map Options components are in the map. Only 1 is allowed."); } foreach (MapOptions item in componentsInChildren2) { string error = item.GetError(); if (error != null) { a.Add(Severity.Warning, (Object)(object)item, error); } } foreach (ActiveOnMapOption item2 in componentsInChildren) { Errors error2 = item2.GetError(); if ((int)error2 != 4) { a.Add(Severity.Warning, (Object)(object)item2, ActiveOnMapOption.GetErrorString(error2), ActiveOnMapOption.GetErrorDetails(error2)); } } } private static void CheckChunkStuff(Analysis a, GameObject[] roots) { List<MonoBehaviour> list = new List<MonoBehaviour>(); list.AddRange((IEnumerable<MonoBehaviour>)roots.GetComponentsInChildren<Junk>()); list.AddRange((IEnumerable<MonoBehaviour>)roots.GetComponentsInChildren<StreetLifeCluster>()); foreach (MonoBehaviour item in list) { if ((Object)(object)((Component)item).GetComponentInParent<StageChunk>() == (Object)null) { a.Add(Severity.Warning, (Object)(object)item, "Component not in Chunk", "This component is not inside of a Stage Chunk. It might not work fully."); } } } private static void CheckStreetLife(Analysis a, GameObject[] roots) { foreach (Pedestrian componentsInChild in roots.GetComponentsInChildren<Pedestrian>()) { if ((Object)(object)((Component)componentsInChild).GetComponentInParent<StreetLifeCluster>(true) == (Object)null) { a.Add(Severity.Warning, (Object)(object)componentsInChild, "Pedestrian not in StreetLifeCluster", "Pedestrian is not in a StreetLifeCluster, may not function properly."); } } } public static Analysis Analyze(GameObject[] roots, MapProperties mapProperties) { Analysis analysis = new Analysis(); if (roots.GetComponentsInChildren<MapStationCameraOverride>().Count > 1) { analysis.Add(Severity.Warning, null, "Multiple Camera Overrides", "There are multiple Camera Overrides. Only one is supported."); } List<PlayerSpawner> componentsInChildren = roots.GetComponentsInChildren<PlayerSpawner>(); bool flag = false; foreach (PlayerSpawner item in componentsInChildren) { if (item.isDefaultSpawnPoint) { flag = true; break; } } if (!flag) { analysis.Add(Severity.Warning, null, "Missing Default Player Spawn Point", "Map is missing a default player spawn point. Player will spawn at 0,0,0."); } CheckChunkStuff(analysis, roots); CheckStreetLife(analysis, roots); CheckMapOptions(analysis, roots); List<BasicEnemySpawner> componentsInChildren2 = roots.GetComponentsInChildren<BasicEnemySpawner>(); bool flag2 = false; bool flag3 = false; bool flag4 = false; foreach (BasicEnemySpawner item2 in componentsInChildren2) { if (item2.spawnableEnemies == null) { continue; } GameObject[] spawnableEnemies = item2.spawnableEnemies; for (int i = 0; i < spawnableEnemies.Length; i++) { switch (((Object)spawnableEnemies[i]).name) { case "ShieldCop": case "SniperCop": case "BasicCop": flag2 = true; break; case "CopterCop": flag3 = true; break; case "tankWalker": flag4 = true; break; } } } List<NavMeshSurface> componentsInChildren3 = roots.GetComponentsInChildren<NavMeshSurface>(); bool flag5 = false; bool flag6 = false; bool flag7 = false; foreach (NavMeshSurface item3 in componentsInChildren3) { if (!((Object)(object)item3.navMeshData == (Object)null)) { switch (item3.agentTypeID) { case 0: flag5 = true; break; case -1372625422: flag7 = true; break; case -334000983: flag6 = true; break; } } } if (componentsInChildren2.Count == 0 && !mapProperties.disableCops) { analysis.Add(Severity.Warning, null, "Missing Cop Spawners", "Map has cops enabled, but there are no spawners for them."); } if (flag2 && !flag5) { analysis.Add(Severity.Warning, null, "Missing NavMeshSurface for Cops", "Map has cops but no NavMeshSurface for them. They will not be able to navigate."); } if (flag3 && !flag6) { analysis.Add(Severity.Warning, null, "Missing NavMeshSurface for Cop Helicopters", "Map has helicopters but no NavMeshSurface for them. They will not be able to navigate."); } if (flag4 && !flag7) { analysis.Add(Severity.Warning, null, "Missing NavMeshSurface for Tankwalkers", "Map has tankwalkers but no NavMeshSurface for them. They will not be able to navigate."); } foreach (GraffitiSpot componentsInChild in roots.GetComponentsInChildren<GraffitiSpot>()) { if ((Object)(object)componentsInChild.dynamicRepPickup == (Object)null) { analysis.Add(Severity.Error, (Object)(object)componentsInChild, "Graffiti missing dynamicRepPickup", "Found GraffitiSpot.dynamicRepPickup == null. This will soft-lock when tagged."); } if (((Component)componentsInChild).tag != "GraffitiSpot") { analysis.Add(Severity.Warning, (Object)(object)componentsInChild, "GraffitiSpot has wrong tag", "Found GraffitiSpot not tagged as 'GraffitiSpot'"); } if (((Component)componentsInChild).gameObject.layer != 19) { analysis.Add(Severity.Warning, (Object)(object)componentsInChild, "GraffitiSpot has wrong layer", "Found GraffitiSpot not on the 'TriggerDetectPlayer' layer."); } } List<AProgressable> componentsInChildren4 = roots.GetComponentsInChildren<AProgressable>(); foreach (AProgressable item4 in componentsInChildren4) { if ((!(((Object)((Component)item4).gameObject).name == "DummyNPC") || !(item4 is NPC)) && !Regex.Match(item4.uid, "^[a-f0-9]{8}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{12}$", RegexOptions.None).Success) { analysis.Add(Severity.Warning, (Object)(object)item4, "Bad Uid", "Found " + ((object)item4).GetType().Name + ".uid which is not in expected UID format (all lowercase, numbers and letters a-f, correct length, correct hyphens) UID=" + item4.uid); } } foreach (IGrouping<string, AProgressable> item5 in from p in componentsInChildren4 group p by p.uid) { if (item5.Count() <= 1) { continue; } foreach (AProgressable item6 in item5) { analysis.Add(Severity.Error, (Object)(object)item6, "Duplicate Uid", "Found " + ((object)item6).GetType().Name + ".uid which is identical to one or more other progressables in this map. This may crash the game when the map loads. Ensure all UIDs are unique. UID=" + item6.uid); } } foreach (VendingMachine componentsInChild2 in roots.GetComponentsInChildren<VendingMachine>()) { if (((Component)componentsInChild2).gameObject.layer != 17) { analysis.Add(Severity.Warning, (Object)(object)componentsInChild2, "VendingMachine has wrong layer", "Found VendingMachine that is not on the Enemies layer, this means it cannot be kicked."); } Animation component = ((Component)componentsInChild2).GetComponent<Animation>(); if ((Object)(object)component == (Object)null) { analysis.Add(Severity.Warning, (Object)(object)componentsInChild2, "VendingMachine missing Animation component", "Found VendingMachine without an Animation component."); } string[] vendingMachineAnimations = VendingMachineAnimations; foreach (string text in vendingMachineAnimations) { if ((TrackedReference)(object)component.GetState(text) == (TrackedReference)null) { analysis.Add(Severity.Warning, (Object)(object)componentsInChild2, "VendingMachine missing animations", "Found VendingMachine with Animation component missing animation: " + text + ". This will fail with errors when kicked."); } } } foreach (Teleport componentsInChild3 in roots.GetComponentsInChildren<Teleport>()) { if ((Object)(object)componentsInChild3.teleportTo == (Object)null && !componentsInChild3.automaticallyReturnPlayerToLastSafeLocation) { analysis.Add(Severity.Warning, (Object)(object)componentsInChild3, "Found Teleport missing a `teleportTo` destination."); } BoxCollider componentInChildren = ((Component)componentsInChild3).GetComponentInChildren<BoxCollider>(); if ((Object)(object)componentInChildren == (Object)null) { analysis.Add(Severity.Warning, (Object)(object)componentsInChild3, "Found Teleport without a Box Collider on a child GameObject."); continue; } if (((Component)componentInChildren).tag != "Teleport") { analysis.Add(Severity.Warning, (Object)(object)componentsInChild3, "Found Teleporter's child collider not tagged as 'Teleport'"); } if (((Component)componentInChildren).gameObject.layer != 19) { analysis.Add(Severity.Warning, (Object)(object)componentsInChild3, "Found Teleport's child collider not on the 'TriggerDetectPlayer' layer."); } } List<SunFlareGPU> componentsInChildren5 = roots.GetComponentsInChildren<SunFlareGPU>(); if (componentsInChildren5.Count == 0) { analysis.Add(Severity.Error, null, "Missing Sun", "Map is missing a sun, will crash on startup. Try adding Sun prefab from the right-click menu."); } if (componentsInChildren5.Count > 1) { foreach (SunFlareGPU item7 in componentsInChildren5) { analysis.Add(Severity.Warning, (Object)(object)item7, "Multiple Suns", "Map has multiple suns, lighting will be too bright. Try deleting all but one."); } } foreach (GrindNode componentsInChild4 in roots.GetComponentsInChildren<GrindNode>()) { if ((Object)(object)componentsInChild4.grindLines.Find((GrindLine l) => (Object)(object)l != (Object)null) == (Object)null) { analysis.Add(Severity.Warning, (Object)(object)componentsInChild4, "Unattached Grind Node", "Grind Node is not attached to any grind lines, should probably be deleted."); } } foreach (GrindLine componentsInChild5 in roots.GetComponentsInChildren<GrindLine>()) { if ((Object)(object)componentsInChild5.n0 == (Object)null || (Object)(object)componentsInChild5.n1 == (Object)null) { analysis.Add(Severity.Warning, (Object)(object)componentsInChild5, "Unattached Grind Line", "Grind Line is not attached to two Grind Nodes, should probably be deleted."); } } return analysis; } public static string GetGameObjectPath(GameObject obj) { string text = "/" + ((Object)obj).name; while ((Object)(object)obj.transform.parent != (Object)null) { obj = ((Component)obj.transform.parent).gameObject; text = "/" + ((Object)obj).name + text; } return text; } } public class Analysis { public readonly Dictionary<GameObject, List<Diagnostic>> gameObjects = new Dictionary<GameObject, List<Diagnostic>>(); public readonly List<Diagnostic> diagnostics = new List<Diagnostic>(); public readonly List<Diagnostic> diagnosticsWithoutTarget = new List<Diagnostic>(); public readonly Dictionary<Severity, int> countBySeverity = new Dictionary<Severity, int>(); public Analysis() { foreach (object value in Enum.GetValues(typeof(Severity))) { countBySeverity.Add((Severity)value, 0); } } public void Add(Severity severity, Object target, string message, string details = null) { Diagnostic diagnostic = new Diagnostic(severity, target, message, details); diagnostics.Add(diagnostic); countBySeverity[diagnostic.Severity]++; if ((Object)(object)diagnostic.GameObject != (Object)null) { gameObjects.TryGetValue(diagnostic.GameObject, out var value); if (value == null) { value = new List<Diagnostic>(); gameObjects.Add(diagnostic.GameObject, value); } value.Add(diagnostic); } else { diagnosticsWithoutTarget.Add(diagnostic); } } public void Log() { Debug.Log((object)$"MapStation: Analysis found {diagnostics.Count} problems."); foreach (Diagnostic diagnostic in diagnostics) { string targetPath = diagnostic.TargetPath; string text = ""; if (targetPath != null) { text = " (at " + targetPath + ")"; } Debug.Log((object)(diagnostic.Message + text)); } } } public class Diagnostic { public readonly string Message; public readonly string Details; public readonly Object Target; public readonly Component Component; public readonly GameObject GameObject; public readonly Severity Severity; public string TargetPath; public Diagnostic(Severity severity, Object target, string message, string details = null) { GameObject gameObject = (GameObject)(object)((target is GameObject) ? target : null); Component val = (Component)(object)((target is Component) ? target : null); if ((Object)(object)val != (Object)null) { gameObject = val.gameObject; } Message = message; Details = details; Target = target; GameObject = gameObject; Severity = severity; Component = val; TargetPath = (((Object)(object)GameObject == (Object)null) ? null : Doctor.GetGameObjectPath(GameObject)); } } public enum Severity { Error, Warning } } namespace MapStation.Plugin { public class CrashDetector { [CompilerGenerated] private static class <>O { public static OnStageInitializedDelegate <0>__AfterLoadStage; } private const string PlayerPrefName = "MapStation.CrashDetector.IsLoadingStage"; public static bool ShouldAvoidReCrashing { get; private set; } public static void InitOnGameStart() { //IL_0022: Unknown result type (might be due to invalid IL or missing references) //IL_0027: Unknown result type (might be due to invalid IL or missing references) //IL_002d: Expected O, but got Unknown ShouldAvoidReCrashing = PlayerPrefs.GetInt("MapStation.CrashDetector.IsLoadingStage") > 0; object obj = <>O.<0>__AfterLoadStage; if (obj == null) { OnStageInitializedDelegate val = AfterLoadStage; <>O.<0>__AfterLoadStage = val; obj = (object)val; } StageManager.OnStagePostInitialization += (OnStageInitializedDelegate)obj; } public static void BeforeLoadStage() { PlayerPrefs.SetInt("MapStation.CrashDetector.IsLoadingStage", 1); } public static void AfterLoadStage() { PlayerPrefs.SetInt("MapStation.CrashDetector.IsLoadingStage", 0); ShouldAvoidReCrashing = false; } } internal class KBMInputDisabler { private static bool KbmDisabled; private static KeyCode ToggleKey; public static void Init(bool kbmDisabled, KeyCode toggleKey, ref Plugin.UpdateDelegate updateEvent, ref Plugin.UpdateDelegate lateUpdateEvent) { //IL_0006: Unknown result type (might be due to invalid IL or missing references) //IL_0007: Unknown result type (might be due to invalid IL or missing references) KbmDisabled = kbmDisabled; ToggleKey = toggleKey; updateEvent = (Plugin.UpdateDelegate)Delegate.Combine(updateEvent, new Plugin.UpdateDelegate(Update)); lateUpdateEvent = (Plugin.UpdateDelegate)Delegate.Combine(lateUpdateEvent, new Plugin.UpdateDelegate(LateUpdate)); } private static void Update() { //IL_0000: Unknown result type (might be due to invalid IL or missing references) if (Input.GetKeyDown(ToggleKey)) { KbmDisabled = !KbmDisabled; Apply(); } } private static void LateUpdate() { if (KbmDisabled) { Cursor.visible = true; Cursor.lockState = (CursorLockMode)0; } } private static Player TryGetRewiredPlayer() { Core instance = Core.Instance; if ((Object)(object)instance == (Object)null) { return null; } GameInput gameInput = instance.GameInput; if (gameInput == null) { return null; } RewiredMappingHandler rewiredMappingHandler = gameInput.rewiredMappingHandler; if (rewiredMappingHandler == null) { return null; } return rewiredMappingHandler.GetRewiredPlayer(0); } public static void Apply() { Player val = TryGetRewiredPlayer(); if (val != null) { if (KbmDisabled) { DisableKbm(val); } else { EnableKbm(val); } } } private static void DisableKbm(Player player) { ((Controller)player.controllers.Mouse).enabled = false; ((Controller)player.controllers.Keyboard).enabled = false; Cursor.visible = true; Cursor.lockState = (CursorLockMode)0; } private static void EnableKbm(Player player) { ((Controller)player.controllers.Mouse).enabled = true; ((Controller)player.controllers.Keyboard).enabled = true; Cursor.visible = false; Cursor.lockState = (CursorLockMode)1; } } public enum MapSource { Normal, TestMaps } public class MapDatabase { public static MapDatabase Instance; public Assets Assets; public Dictionary<Stage, PluginMapDatabaseEntry> maps = new Dictionary<Stage, PluginMapDatabaseEntry>(); private ManualLogSource logger; public MapDatabase(Assets assets) { //IL_001e: Unknown result type (might be due to invalid IL or missing references) //IL_0028: Expected O, but got Unknown Assets = assets; logger = new ManualLogSource("MapStation Map Database"); } public void AddFromDirectory(string path, MapSource source = MapSource.Normal) { //IL_0020: Unknown result type (might be due to invalid IL or missing references) //IL_0025: Unknown result type (might be due to invalid IL or missing references) //IL_002d: Unknown result type (might be due to invalid IL or missing references) //IL_0074: Unknown result type (might be due to invalid IL or missing references) //IL_007b: Expected O, but got Unknown //IL_007c: Unknown result type (might be due to invalid IL or missing references) //IL_0083: Expected O, but got Unknown //IL_0042: Unknown result type (might be due to invalid IL or missing references) //IL_0049: Expected I4, but got Unknown //IL_00d6: Unknown result type (might be due to invalid IL or missing references) //IL_00d8: Unknown result type (might be due to invalid IL or missing references) string[] files = Directory.GetFiles(path, "*.brcmap", SearchOption.AllDirectories); foreach (string text in files) { string fileNameWithoutExtension = Path.GetFileNameWithoutExtension(text); Stage val = StageEnum.HashMapName(fileNameWithoutExtension); if (maps.ContainsKey(val)) { logger.LogWarning((object)$"Won't add custom stage {fileNameWithoutExtension} to the database as there's already a stage with the same ID ({(int)val})"); continue; } logger.LogInfo((object)("Found map " + fileNameWithoutExtension + " at " + text)); MapProperties val2 = new MapProperties(); MapZip val3 = new MapZip(text); try { JsonUtility.FromJsonOverwrite(val3.GetPropertiesText(), (object)val2); val3.DoPluginOnAddMapToDatabase(fileNameWithoutExtension); } finally { ((IDisposable)val3)?.Dispose(); } PluginMapDatabaseEntry map = new PluginMapDatabaseEntry { Name = fileNameWithoutExtension, internalName = fileNameWithoutExtension, Properties = val2, ScenePath = AssetNames.GetScenePathForMap(fileNameWithoutExtension), zipPath = text, stageId = val, source = source }; Add(map); } } public void Add(PluginMapDatabaseEntry map) { //IL_0007: Unknown result type (might be due to invalid IL or missing references) //IL_0013: Unknown result type (might be due to invalid IL or missing references) //IL_014c: Unknown result type (might be due to invalid IL or missing references) //IL_0151: Unknown result type (might be due to invalid IL or missing references) //IL_015e: Expected O, but got Unknown maps.Add(map.stageId, map); StageEnum.AddMapName(map.stageId, map.internalName); List<AssetBundleCollection> list = Assets.assetBundleLibrary.collections.ToList(); AssetBundleCollection val = ScriptableObject.CreateInstance<AssetBundleCollection>(); val.assetBundleCollectionName = ((object)(Stage)(ref map.stageId)).ToString(); val.assetBundleNames = new string[18] { "characters", "graffiti", "common_assets", "enemies", "enemy_animation", "character_animation", "in_game_assets", "mocap_animation_two", "mocap_animation", "finalboss_assets", "playeranimation", "finalboss_animation", "storyanimation", "minimap", "common_game_shaders", "city_assets", ((BaseMapDatabaseEntry)map).AssetsBundleName, ((BaseMapDatabaseEntry)map).SceneBundleName }; list.Add(val); Assets.assetBundleLibrary.collections = list.ToArray(); string[] array = new string[2] { ((BaseMapDatabaseEntry)map).AssetsBundleName, ((BaseMapDatabaseEntry)map).SceneBundleName }; foreach (string text in array) { Assets.availableBundles.Add(text, new Bundle(text) { name = text }); } ZipAssetBundles.Instance.Bundles.Add(((BaseMapDatabaseEntry)map).AssetsBundleName, new ZipAssetBundle { zipPath = map.zipPath, bundleType = ZipBundleType.ASSETS }); ZipAssetBundles.Instance.Bundles.Add(((BaseMapDatabaseEntry)map).SceneBundleName, new ZipAssetBundle { zipPath = map.zipPath, bundleType = ZipBundleType.SCENE }); SceneNameMapper.Instance.Names.Add(((object)(Stage)(ref map.stageId)).ToString(), "Scene." + map.internalName); SceneNameMapper.Instance.Paths.Add(((object)(Stage)(ref map.stageId)).ToString(), "Assets/Maps/" + map.internalName + "/Scene." + map.internalName + ".unity"); } } public class PluginMapDatabaseEntry : BaseMapDatabaseEntry { public Stage stageId; public string internalName; public string zipPath; public MapProperties Properties; public MapSource source; } internal class SceneNameMapper { public static SceneNameMapper Instance; public Dictionary<string, string> Names = new Dictionary<string, string>(); public Dictionary<string, string> Paths = new Dictionary<string, string>(); } public static class StageEnum { public const Stage FirstMapId = 15; public const string MapNamePrefix = "mapstation/"; public const int MapNamePrefixLength = 11; public const string MapNameUnknownInfix = "unknown/"; public const Stage FirstVanillaStage = -1; public static readonly Dictionary<string, Stage> MapIds; public static readonly Dictionary<Stage, string> MapNames; static StageEnum() { MapIds = new Dictionary<string, Stage>(); MapNames = new Dictionary<Stage, string>(); if ("mapstation/".Length != 11) { throw new Exception("StageEnumMapNamePrefixLength is wrong."); } } public static string GetMapName(Stage id) { //IL_0005: Unknown result type (might be due to invalid IL or missing references) return MapNames[id]; } public static Stage GetMapId(string internalName) { //IL_0006: Unknown result type (might be due to invalid IL or missing references) return MapIds[internalName]; } public static string RemovePrefixFromInternalName(string prefixedInternalName) { int num = prefixedInternalName.IndexOf("/"); if (num < 0) { return prefixedInternalName; } return prefixedInternalName.Substring(num + 1); } public static Stage HashMapName(string internalName) { uint num = BitConverter.ToUInt32(new SHA512Managed().ComputeHash(Encoding.UTF8.GetBytes(internalName)), 0); num &= 0xFFFFFFF0u; num >>= 4; return (Stage)(15 + num); } public static Stage AddMapName(string internalName) { //IL_0001: Unknown result type (might be due to invalid IL or missing references) //IL_0006: Unknown result type (might be due to invalid IL or missing references) Stage val = HashMapName(internalName); AddMapName(val, internalName); return val; } public static void AddMapName(Stage id, string internalName) { //IL_0005: Unknown result type (might be due to invalid IL or missing references) //IL_0012: Unknown result type (might be due to invalid IL or missing references) MapNames.Add(id, internalName); MapIds.Add(internalName, id); } public static void RemoveMapName(string internalName) { //IL_000b: Unknown result type (might be due to invalid IL or missing references) MapNames.Remove(MapIds[internalName]); MapIds.Remove(internalName); } public static bool IsValidMapId(Stage id) { //IL_0000: Unknown result type (might be due to invalid IL or missing references) //IL_0003: Invalid comparison between Unknown and I4 //IL_0005: Unknown result type (might be due to invalid IL or missing references) //IL_0007: Invalid comparison between Unknown and I4 if ((int)id < 15) { return (int)id < -1; } return true; } public static bool IsKnownMapId(Stage id) { //IL_0005: Unknown result type (might be due to invalid IL or missing references) return MapNames.ContainsKey(id); } } public class StageProgresses : CustomSaveData { public static StageProgresses Instance; public Dictionary<string, StageProgress> stageProgresses = new Dictionary<string, StageProgress>(); private const byte Version = 1; public StageProgresses() : base("MapStation.Plugin", "{0}.msp") { } public override void Write(BinaryWriter writer) { writer.Write((byte)1); writer.Write(stageProgresses.Count); foreach (KeyValuePair<string, StageProgress> stageProgress in stageProgresses) { StageProgress value = stageProgress.Value; string key = stageProgress.Key; writer.Write(key); value.Write(writer); value.WriteVersionTwo(writer); value.WriteVersionThree(writer); } } public override void Read(BinaryReader reader) { //IL_0020: Unknown result type (might be due to invalid IL or missing references) //IL_0027: Expected O, but got Unknown //IL_0042: Unknown result type (might be due to invalid IL or missing references) //IL_0047: Unknown result type (might be due to invalid IL or missing references) reader.ReadByte(); int num = reader.ReadInt32(); for (int i = 0; i < num; i++) { string text = reader.ReadString(); string internalName = StageEnum.RemovePrefixFromInternalName(text); StageProgress val = new StageProgress(); val.Read(reader); val.ReadVersionTwo(reader); val.ReadVersionThree(reader); val.stageID = StageEnum.HashMapName(internalName); stageProgresses[text] = val; } } public override void Initialize() { stageProgresses.Clear(); } public StageProgress GetOrCreateForStage(Stage stageId) { //IL_0000: Unknown result type (might be due to invalid IL or missing references) //IL_0028: Unknown result type (might be due to invalid IL or missing references) //IL_002d: Unknown result type (might be due to invalid IL or missing references) //IL_0034: Unknown result type (might be due to invalid IL or missing references) //IL_0035: Unknown result type (might be due to invalid IL or missing references) //IL_0036: Unknown result type (might be due to invalid IL or missing references) //IL_003b: Unknown result type (might be due to invalid IL or missing references) //IL_0042: Unknown result type (might be due to invalid IL or missing references) //IL_0049: Unknown result type (might be due to invalid IL or missing references) //IL_0051: Expected O, but got Unknown if (StageEnum.IsValidMapId(stageId)) { string key = ((object)(Stage)(ref stageId)).ToString(); if (stageProgresses.TryGetValue(key, out var value)) { return value; } value = new StageProgress { version = 3, stageID = stageId, policeAllowed = true, mapFound = true, taxiFound = true }; stageProgresses.Add(key, value); return value; } return null; } } public class ZipAssetBundles { public static ZipAssetBundles Instance; public Dictionary<string, ZipAssetBundle> Bundles = new Dictionary<string, ZipAssetBundle>(); } public class ZipAssetBundle { public string zipPath; public ZipBundleType bundleType; } public enum ZipBundleType { ASSETS, SCENE } public class MapOptionDescriptionUI : MonoBehaviour { private TextMeshProUGUI _descLabel; public static MapOptionDescriptionUI Instance { get; private set; } private void Awake() { Instance = this; Init(); } private static TextMeshProUGUI MakeLabel(TextMeshProUGUI reference, string name) { //IL_0016: Unknown result type (might be due to invalid IL or missing references) TMP_FontAsset font = ((TMP_Text)reference).font; float fontSize = ((TMP_Text)reference).fontSize; Material fontMaterial = ((TMP_Text)reference).fontMaterial; TextMeshProUGUI obj = new GameObject(name).AddComponent<TextMeshProUGUI>(); ((TMP_Text)obj).font = font; ((TMP_Text)obj).fontSize = fontSize; ((TMP_Text)obj).fontMaterial = fontMaterial; ((TMP_Text)obj).alignment = (TextAlignmentOptions)4097; ((TMP_Text)obj).fontStyle = (FontStyles)1; ((TMP_Text)obj).outlineWidth = 0.2f; return obj; } private void Init() { //IL_0011: Unknown result type (might be due to invalid IL or missing references) //IL_001c: Unknown result type (might be due to invalid IL or missing references) //IL_00b1: Unknown result type (might be due to invalid IL or missing references) //IL_00d0: Unknown result type (might be due to invalid IL or missing references) //IL_00ef: Unknown result type (might be due to invalid IL or missing references) //IL_010e: Unknown result type (might be due to invalid IL or missing references) //IL_012d: Unknown result type (might be due to invalid IL or missing references) RectTransform val = ((Component)Instance).gameObject.AddComponent<RectTransform>(); val.anchorMin = Vector2.zero; val.anchorMax = Vector2.one; TextMeshProUGUI[] componentsInChildren = ((Component)Core.Instance.UIManager.danceAbilityUI).GetComponentsInChildren<TextMeshProUGUI>(true); TextMeshProUGUI val2 = null; TextMeshProUGUI[] array = componentsInChildren; foreach (TextMeshProUGUI val3 in array) { if (((Object)((Component)((TMP_Text)val3).transform).gameObject).name == "DanceSelectConfirmText") { val2 = val3; } } if (!((Object)(object)val2 == (Object)null)) { _descLabel = MakeLabel(val2, "DescLabel"); ((TMP_Text)_descLabel).text = ""; ((TMP_Text)_descLabel).rectTransform.anchorMin = new Vector2(0.5f, 1f); ((TMP_Text)_descLabel).rectTransform.anchorMax = new Vector2(0.5f, 1f); ((TMP_Text)_descLabel).rectTransform.pivot = new Vector2(0f, 1f); ((TMP_Text)_descLabel).rectTransform.anchoredPosition = new Vector2(-100f, -100f); ((TMP_Text)_descLabel).rectTransform.sizeDelta = new Vector2(500f, 500f); ((TMP_Text)_descLabel).horizontalAlignment = (HorizontalAlignmentOptions)2; ((TMP_Text)_descLabel).verticalAlignment = (VerticalAlignmentOptions)256; ((Transform)((TMP_Text)_descLabel).rectTransform).SetParent((Transform)(object)val, false); } } public void SetText(string text) { ((TMP_Text)_descLabel).text = text; } public static void Create() { //IL_0021: Unknown result type (might be due to invalid IL or missing references) //IL_0026: Unknown result type (might be due to invalid IL or missing references) //IL_0050: Unknown result type (might be due to invalid IL or missing references) if ((Object)(object)Instance != (Object)null) { Object.Destroy((Object)(object)((Component)Instance).gameObject); } GameObject val = new GameObject("Map Option Description"); val.transform.SetParent((Transform)(object)((Component)((Component)Core.Instance.UIManager.gameplay).transform.parent).GetComponent<RectTransform>(), false); val.AddComponent<MapOptionDescriptionUI>(); val.SetActive(false); } } public static class MapOverrides { public static void OnStagePreInitialization(Stage newStage, Stage previousStage) { //IL_0000: Unknown result type (might be due to invalid IL or missing references) OverrideQualitySettings(newStage, Core.Instance.BaseModule.user.VideoSettingsManager.cachedVideoSettings); } public static void OverrideQualitySettings(Stage stage, VideoSettings videoSettings) { //IL_000a: Unknown result type (might be due to invalid IL or missing references) if (MapDatabase.Instance.maps.TryGetValue(stage, out var value) && value.Properties.overrideShadowDistance) { QualitySettings.shadowDistance = value.Properties.shadowDistance; } else { QualitySettings.shadowDistance = videoSettings.shadowDistance; } } } public class MapRepair { public static void OnStagePreInitialization(Stage newStage, Stage previousStage) { //IL_0000: Unknown result type (might be due to invalid IL or missing references) if (StageEnum.IsKnownMapId(newStage)) { Repair(); } } public static void Repair() { //IL_000d: Unknown result type (might be due to invalid IL or missing references) //IL_0071: Unknown result type (might be due to invalid IL or missing references) //IL_0076: Unknown result type (might be due to invalid IL or missing references) //IL_003f: Unknown result type (might be due to invalid IL or missing references) //IL_0044: Unknown result type (might be due to invalid IL or missing references) //IL_0055: Unknown result type (might be due to invalid IL or missing references) if ((Object)(object)Object.FindObjectOfType<PlayerSpawner>() == (Object)null) { new GameObject().AddComponent<PlayerSpawner>().isDefaultSpawnPoint = true; } CharacterSelectSpot[] array = Object.FindObjectsOfType<CharacterSelectSpot>(); foreach (CharacterSelectSpot val in array) { if ((Object)(object)((Component)val).GetComponentInChildren<NPC>(true) == (Object)null) { GameObject val2 = new GameObject("DummyNPC"); val2.transform.parent = ((Component)val).transform; val2.SetActive(false); val2.AddComponent<NPC>(); } } GameObject val3 = new GameObject("DummyNPC"); val3.SetActive(false); val3.AddComponent<NPC>(); } } public class MapSaveData : CustomSaveData { public static MapSaveData Instance; private const byte Version = 1; public Dictionary<string, LoadedMapOptions> Options = new Dictionary<string, LoadedMapOptions>(); public MapSaveData() : base("MapStation.Plugin", "{0}.cmsp") { } public override void Write(BinaryWriter writer) { writer.Write((byte)1); writer.Write(Options.Count); foreach (KeyValuePair<string, LoadedMapOptions> option in Options) { writer.Write(option.Key); writer.Write(option.Value.Options.Count); foreach (KeyValuePair<string, string> option2 in option.Value.Options) { writer.Write(option2.Key); writer.Write(option2.Value); } } } public override void Read(BinaryReader reader) { //IL_0012: Unknown result type (might be due to invalid IL or missing references) //IL_0018: Expected O, but got Unknown reader.ReadByte(); int num = reader.ReadInt32(); for (int i = 0; i < num; i++) { LoadedMapOptions val = new LoadedMapOptions(); string key = reader.ReadString(); Options[key] = val; int num2 = reader.ReadInt32(); for (int j = 0; j < num2; j++) { string key2 = reader.ReadString(); string value = reader.ReadString(); val.Options[key2] = value; } val.Sanitize(); } } public override void Initialize() { Options.Clear(); } public LoadedMapOptions GetCurrentMapOptions() { //IL_0000: Unknown result type (might be due to invalid IL or missing references) //IL_0005: Unknown result type (might be due to invalid IL or missing references) //IL_002a: Unknown result type (might be due to invalid IL or missing references) //IL_002f: Unknown result type (might be due to invalid IL or missing references) //IL_0038: Unknown result type (might be due to invalid IL or missing references) //IL_003d: Unknown result type (might be due to invalid IL or missing references) //IL_005f: Unknown result type (might be due to invalid IL or missing references) //IL_0065: Expected O, but got Unknown Stage val = Utility.GetCurrentStage(); string key = ((object)(Stage)(ref val)).ToString(); MapOptions instance = MapOptions.Instance; if ((Object)(object)instance != (Object)null) { Scene scene = ((Component)instance).gameObject.scene; val = Utility.SceneNameToStage(((Scene)(ref scene)).name); key = ((object)(Stage)(ref val)).ToString(); } if (Options.TryGetValue(key, out var value)) { return value; } LoadedMapOptions val2 = new LoadedMapOptions(); val2.MakeDefault(); Options[key] = val2; return val2; } } public class MapStationConfig { public ConfigEntry<string> QuickLaunch; public ConfigEntry<bool> QuickReload; public ConfigEntry<bool> DisableKBMInput; public ConfigEntry<bool> DebugUI; public ConfigEntry<bool> ShowDebugShapes; public ConfigEntry<KeyCode> QuickReloadKey; public ConfigEntry<KeyCode> DisableKBMInputKey; public static MapStationConfig Instance { get; private set; } public string QuickLaunchValue => QuickLaunch.Value; public bool QuickReloadValue => QuickReload.Value; public bool DisableKBMInputValue => DisableKBMInput.Value; public bool DebugUIValue => DebugUI.Value; public bool ShowDebugShapesValue => ShowDebugShapes.Value; public KeyCode QuickReloadKeyValue => QuickReloadKey.Value; public KeyCode DisableKBMInputKeyValue => DisableKBMInputKey.Value; public MapStationConfig() { Instance = this; } public MapStationConfig(ConfigFile file) : this() { string text = "Mapping"; QuickLaunch = file.Bind<string>(text, "QuickLaunch", "", "Skip game intros and menu and launch directly into this map."); string text2 = "Enable to reload *any* map with a hotkey (F5 by default), including vanilla and downloaded maps. By default, only locally-built maps can be reloaded."; string text3 = "Reloads the map."; QuickReload = file.Bind<bool>(text, "QuickReload", false, text2); string text4 = "Disable keyboard and mouse input, making it easier to use MapStation's DebugUI, Unity Explorer, or tab between windows. When this is enabled, you MUST use a game controller. Note: there is also a hotkey for this."; string text5 = "Enables/disables keyboard and mouse input."; DisableKBMInput = file.Bind<bool>(text, "DisableKBMInput", false, text4); DebugUI = file.Bind<bool>(text, "DebugUI", false, "Show Debug UI in the corner for *all* maps. By default this is enabled only for locally-built maps."); ShowDebugShapes = file.Bind<bool>(text, "ShowDebugShapes", false, "Show debug meshes along grind lines, spawners, teleporters, etc."); string text6 = "Input"; QuickReloadKey = file.Bind<KeyCode>(text6, "QuickReloadKey", (KeyCode)286, text3); DisableKBMInputKey = file.Bind<KeyCode>(text6, "DisableKBMInputKey", (KeyCode)287, text5); } } public static class MiniMapManager { public static bool TryCreateMapForCustomStage(BaseMapDatabaseEntry mapEntry, out Map map) { //IL_0059: Unknown result type (might be due to invalid IL or missing references) //IL_005e: Unknown result type (might be due to invalid IL or missing references) //IL_0064: Unknown result type (might be due to invalid IL or missing references) //IL_0069: Unknown result type (might be due to invalid IL or missing references) GameObject val = Core.Instance.Assets.LoadAssetFromBundle<GameObject>(mapEntry.AssetsBundleName, "MiniMap.prefab"); if ((Object)(object)val == (Object)null) { map = null; return false; } MiniMapProperties val2 = val.GetComponent<MiniMapProperties>(); if ((Object)(object)val2 == (Object)null) { val2 = val.AddComponent<MiniMapProperties>(); } Map val3 = ScriptableObject.CreateInstance<Map>(); val3.m_MapObject = val; val3.m_ScaleFactor = 1f; val3.m_PositionOffset = Vector3.zero; val3.m_EulerOffset = Vector3.zero; val3.mapMaterial = Mapcontroller.Instance.pyramidMap.mapMaterial; map = val3; ProcessCustomMiniMapPrefab(map, val2); if ((Object)(object)val2.MapMaterial != (Object)null) { val3.mapMaterial = val2.MapMaterial; } val3.mapMaterial.SetFloat("_AnchorOffset", -5000f); val3.mapMaterial.SetFloat("_AnchorScale", 0.035f); return true; } private static void ProcessCustomMiniMapPrefab(Map map, MiniMapProperties properties) { Renderer[] componentsInChildren = map.m_MapObject.GetComponentsInChildren<Renderer>(); for (int i = 0; i < componentsInChildren.Length; i++) { ((Component)componentsInChildren[i]).gameObject.layer = 27; } } } [BepInPlugin("MapStation.Plugin", "MapStation.Plugin", "0.19.1")] public class Plugin : BaseUnityPlugin { public delegate void UpdateDelegate(); [CompilerGenerated] private static class <>O { public static StageInitializationDelegate <0>__OnStagePreInitialization; public static StageInitializationDelegate <1>__OnStagePreInitialization; public static OnStageInitializedDelegate <2>__OnStageInitialized; public static Action <3>__UpdateActiveOnMapOptions; public static UpdateDelegate <4>__QuickReloadUpdate; } public static Plugin Instance; internal string MapStationMapsAbsoluteDirectory; internal string TestMapsAbsoluteDirectory; internal string UserMapsAbsoluteDirectory; private static Type ForceLoadMapStationCommonAssembly = typeof(AssemblyDependencies); private static Type ForceLoadMapStationPluginAssembly = typeof(AssemblyDependencies); private static Type ForceLoadMapStationTypeForwarderAssembly = typeof(AssemblyDependencies); public static UpdateDelegate UpdateEvent; public static UpdateDelegate LateUpdateEvent; public Plugin() { Log.Logger = ((BaseUnityPlugin)this).Logger; } private void Awake() { Instance = this; try { Initialize(); ((BaseUnityPlugin)this).Logger.LogInfo((object)"Plugin MapStation.Plugin 0.19.1 is loaded!"); } catch (Exception ex) { ((BaseUnityPlugin)this).Logger.LogError((object)string.Format("Plugin {0} {1} failed to load!{2}{3}", "MapStation.Plugin", "0.19.1", Environment.NewLine, ex)); } } private void Initialize() { //IL_0105: Unknown result type (might be due to invalid IL or missing references) //IL_014d: Unknown result type (might be due to invalid IL or missing references) //IL_0157: Expected O, but got Unknown //IL_013d: Unknown result type (might be due to invalid IL or missing references) //IL_0142: Unknown result type (might be due to invalid IL or missing references) //IL_0148: Expected O, but got Unknown //IL_017c: Unknown result type (might be due to invalid IL or missing references) //IL_0186: Expected O, but got Unknown //IL_0192: Unknown result type (might be due to invalid IL or missing references) //IL_019c: Expected O, but got Unknown //IL_019c: Unknown result type (might be due to invalid IL or missing references) //IL_01a6: Expected O, but got Unknown //IL_01b2: Unknown result type (might be due to invalid IL or missing references) //IL_01bc: Expected O, but got Unknown //IL_01bc: Unknown result type (might be due to invalid IL or missing references) //IL_01c6: Expected O, but got Unknown //IL_016c: Unknown result type (might be due to invalid IL or missing references) //IL_0171: Unknown result type (might be due to invalid IL or missing references) //IL_0177: Expected O, but got Unknown //IL_01d6: Unknown result type (might be due to invalid IL or missing references) //IL_01db: Unknown result type (might be due to invalid IL or missing references) //IL_01e1: Expected O, but got Unknown //IL_0224: Unknown result type (might be due to invalid IL or missing references) new MapStationConfig(((BaseUnityPlugin)this).Config); SceneNameMapper.Instance = new SceneNameMapper(); ZipAssetBundles.Instance = new ZipAssetBundles(); StageProgresses.Instance = new StageProgresses(); MapSaveData.Instance = new MapSaveData(); LoadedMapOptions.GetCurrentMapOptions = MapSaveData.Instance.GetCurrentMapOptions; DebugUI.Create(MapStationConfig.Instance.DebugUI.Value); DebugUI.Instance.RegisterMenu((DebugMenu)(object)new BackToHideoutDebugUI()); DebugUI.Instance.RegisterMenu((DebugMenu)(object)new DoctorDebugUI()); DebugUI.Instance.RegisterMenu((DebugMenu)(object)new HiddenShapesDebugUI()); MapStationMapsAbsoluteDirectory = Path.GetDirectoryName(((BaseUnityPlugin)this).Info.Location); TestMapsAbsoluteDirectory = Path.Combine(Paths.ConfigPath, "MapStation", "TestMaps"); UserMapsAbsoluteDirectory = Paths.PluginPath; ThreadedLogFix.Install(); Sprite val = TextureUtility.LoadSprite(Path.Combine(Path.GetDirectoryName(((BaseUnityPlugin)this).Info.Location), "MapStation-AppIcon.png")); PhoneAPI.RegisterApp<AppMapStation>("mapstation", val); PhoneAPI.RegisterApp<AppMapOptions>("map options", val); new Harmony("MapStation.Plugin").PatchAll(); PathDetection.SetBepInExProfileInRegistry(Paths.BepInExRootPath); PathDetection.SetBRCPathInRegistry(Path.GetDirectoryName(Application.dataPath)); StageInitializationDelegate onStagePreInitialization = StageAPI.OnStagePreInitialization; object obj = <>O.<0>__OnStagePreInitialization; if (obj == null) { StageInitializationDelegate val2 = MapRepair.OnStagePreInitialization; <>O.<0>__OnStagePreInitialization = val2; obj = (object)val2; } StageAPI.OnStagePreInitialization = (StageInitializationDelegate)Delegate.Combine((Delegate?)(object)onStagePreInitialization, (Delegate?)obj); StageInitializationDelegate onStagePreInitialization2 = StageAPI.OnStagePreInitialization; object obj2 = <>O.<1>__OnStagePreInitialization; if (obj2 == null) { StageInitializationDelegate val3 = MapOverrides.OnStagePreInitialization; <>O.<1>__OnStagePreInitialization = val3; obj2 = (object)val3; } StageAPI.OnStagePreInitialization = (StageInitializationDelegate)Delegate.Combine((Delegate?)(object)onStagePreInitialization2, (Delegate?)obj2); StageAPI.OnStagePreInitialization = (StageInitializationDelegate)Delegate.Combine((Delegate?)(object)StageAPI.OnStagePreInitialization, (Delegate?)new StageInitializationDelegate(EnableDebugFeaturesOnStageInit)); StageAPI.OnStagePreInitialization = (StageInitializationDelegate)Delegate.Combine((Delegate?)(object)StageAPI.OnStagePreInitialization, (Delegate?)new StageInitializationDelegate(CreateMapOptionDescription)); object obj3 = <>O.<2>__OnStageInitialized; if (obj3 == null) { OnStageInitializedDelegate val4 = MapOptions.OnStageInitialized; <>O.<2>__OnStageInitialized = val4; obj3 = (object)val4; } StageManager.OnStageInitialized += (OnStageInitializedDelegate)obj3; MapOptions.OnMapOptionsChanged = (Action)Delegate.Combine(MapOptions.OnMapOptionsChanged, new Action(MapOptions.UpdateActiveOnMapOptions)); KBMInputDisabler.Init(MapStationConfig.Instance.DisableKBMInputValue, MapStationConfig.Instance.DisableKBMInputKeyValue, ref UpdateEvent, ref LateUpdateEvent); CrashDetector.InitOnGameStart(); HiddenShapes.Visible = MapStationConfig.Instance.ShowDebugShapesValue; } public void InitializeMapDatabase(Assets assets) { MapDatabase.Instance = new MapDatabase(assets); if (!Directory.Exists(TestMapsAbsoluteDirectory)) { Directory.CreateDirectory(TestMapsAbsoluteDirectory); } MapDatabase.Instance.AddFromDirectory(MapStationMapsAbsoluteDirectory); MapDatabase.Instance.AddFromDirectory(TestMapsAbsoluteDirectory, MapSource.TestMaps); MapDatabase.Instance.AddFromDirectory(UserMapsAbsoluteDirectory); APIManager.Initialize((IMapStationAPI)(object)new MapStationAPI(MapDatabase.Instance)); } private void Update() { UpdateEvent?.Invoke(); } private void LateUpdate() { LateUpdateEvent?.Invoke(); } private static IEnumerator BackToHideout() { yield return null; Core.Instance.BaseModule.SwitchStage((Stage)5); } public static bool CanSwitchStagesWithoutCrashing() { if ((Object)(object)Core.Instance != (Object)null && Core.Instance.BaseModule.IsPlayingInStage && !Core.Instance.BaseModule.IsLoading) { return !Core.Instance.BaseModule.IsInGamePaused; } return false; } private static void QuickReloadUpdate() { //IL_000c: Unknown result type (might be due to invalid IL or missing references) //IL_0040: Unknown result type (might be due to invalid IL or missing references) if (CanSwitchStagesWithoutCrashing() && Input.GetKeyDown(MapStationConfig.Instance.QuickReloadKeyValue)) { GamePluginManager.OnReload(); Core.Instance.BaseModule.StageManager.ExitCurrentStage(Core.Instance.SaveManager.CurrentSaveSlot.currentStageProgress.stageID, (Stage)(-1)); } } private void CreateMapOptionDescription(Stage newStage, Stage previousStage) { MapOptionDescriptionUI.Create(); } private void EnableDebugFeaturesOnStageInit(Stage newStage, Stage previousStage) { //IL_000a: Unknown result type (might be due to invalid IL or missing references) PluginMapDatabaseEntry value; bool flag = MapDatabase.Instance.maps.TryGetValue(newStage, out value) && value.source == MapSource.TestMaps; DebugUI.Instance.UiEnabled = MapStationConfig.Instance.DebugUIValue || flag; UpdateEvent = (UpdateDelegate)Delegate.Remove(UpdateEvent, new UpdateDelegate(QuickReloadUpdate)); if (MapStationConfig.Instance.QuickReloadValue || flag) { UpdateEvent = (UpdateDelegate)Delegate.Combine(UpdateEvent, new UpdateDelegate(QuickReloadUpdate)); } } } internal class ThreadedLogFix { private delegate void UnityLogSource_OnUnityLogMessageReceived(string message, string stackTrace, LogType type); [CompilerGenerated] private static class <>O { public static LogCallback <0>__onLogMessageReceivedThreaded; } private static int MainThreadId; private static UnityLogSource_OnUnityLogMessageReceived UnityLogSource_OnUnityLogMessageReceived_Handler; public static void Install() { //IL_004e: Unknown result type (might be due to invalid IL or missing references) //IL_0053: Unknown result type (might be due to invalid IL or missing references) //IL_0059: Expected O, but got Unknown MainThreadId = Thread.CurrentThread.ManagedThreadId; UnityLogSource_OnUnityLogMessageReceived_Handler = (UnityLogSource_OnUnityLogMessageReceived)typeof(UnityLogSource).GetMethod("OnUnityLogMessageReceived", BindingFlags.Static | BindingFlags.NonPublic).CreateDelegate(typeof(UnityLogSource_OnUnityLogMessageReceived)); object obj = <>O.<0>__onLogMessageReceivedThreaded; if (obj == null) { LogCallback val = onLogMessageReceivedThreaded; <>O.<0>__onLogMessageReceivedThreaded = val; obj = (object)val; } Application.logMessageReceivedThreaded += (LogCallback)obj; } private static void onLogMessageReceivedThreaded(string condition, string stackTrace, LogType type) { //IL_0018: Unknown result type (might be due to invalid IL or missing references) if (Thread.CurrentThread.ManagedThreadId != MainThreadId) { UnityLogSource_OnUnityLogMessageReceived_Handler(condition, stackTrace, type); } } } public static class PluginInfo { public const string PLUGIN_GUID = "MapStation.Plugin"; public const string PLUGIN_NAME = "MapStation.Plugin"; public const string PLUGIN_VERSION = "0.19.1"; } } namespace MapStation.Plugin.Tools { internal class BackToHideoutDebugUI : DebugMenu { public override string Name => "Hideout Escape"; public override void OnGUI() { if (Plugin.CanSwitchStagesWithoutCrashing()) { GUILayout.Label("This button takes you back to the hideout, if you get trapped in a custom map.", Array.Empty<GUILayoutOption>()); if (GUILayout.Button("Go to Hideout", Array.Empty<GUILayoutOption>())) { Core.Instance.BaseModule.SwitchStage((Stage)5); } } } } public class DoctorDebugUI : DebugMenu { private int widthIndex; private int[] widths = new int[3] { 400, 700, 1000 }; private Analysis analysis; private bool[] showDiag; private bool[] showGo; private Vector2 scrollPosition = Vector2.zero; private bool HasUnityExplorer; private Assembly unityExplorerAssembly; private Type unityExplorerInspectorManagerType; private Type unityExplorerUIManagerType; private Type unityExplorerCacheObjectBase; public override string Name => "Map Doctor"; public override int? Width => widths[widthIndex]; public DoctorDebugUI() { //IL_0018: Unknown result type (might be due to invalid IL or missing references) //IL_001d: Unknown result type (might be due to invalid IL or missing references) //IL_0034: Unknown result type (might be due to invalid IL or missing references) //IL_003e: Expected O, but got Unknown //IL_003e: Unknown result type (might be due to invalid IL or missing references) //IL_0048: Expected O, but got Unknown StageAPI.OnStagePreInitialization = (StageInitializationDelegate)Delegate.Combine((Delegate?)(object)StageAPI.OnStagePreInitialization, (Delegate?)new StageInitializationDelegate(OnStagePreInitialization)); HasUnityExplorer = false; unityExplorerAssembly = AppDomain.CurrentDomain.GetAssemblies().SingleOrDefault((Assembly assembly) => assembly.GetName().Name == "UnityExplorer.BIE5.Mono"); if (unityExplorerAssembly != null) { unityExplorerInspectorManagerType = unityExplorerAssembly.GetExportedTypes().SingleOrDefault((Type type) => type.FullName == "UnityExplorer.InspectorManager"); unityExplorerUIManagerType = unityExplorerAssembly.GetExportedTypes().SingleOrDefault((Type type) => type.FullName == "UnityExplorer.UI.UIManager"); unityExplorerCacheObjectBase = unityExplorerAssembly.GetExportedTypes().SingleOrDefault((Type t) => t.Name == "CacheObjectBase"); HasUnityExplorer = unityExplorerInspectorManagerType != null; } } public override void OnGUI() { //IL_0014: Unknown result type (might be due to invalid IL or missing references) //IL_0019: Unknown result type (might be due to invalid IL or missing references) //IL_0025: Expected O, but got Unknown //IL_002f: Unknown result type (might be due to invalid IL or missing references) //IL_0034: Unknown result type (might be due to invalid IL or missing references) //IL_003c: Expected O, but got Unknown //IL_0098: Unknown result type (might be due to invalid IL or missing references) GUIStyle wrappedLabel = new GUIStyle(GUI.skin.label) { wordWrap = true }; GUIStyle val = new GUIStyle(GUI.skin.label) { fontStyle = (FontStyle)1 }; GUILayout.Label("The Doctor will analyze your map and list any problems, offering suggestions to fix them.", Array.Empty<GUILayoutOption>()); if (GUILayout.Button("Expand", Array.Empty<GUILayoutOption>())) { widthIndex = (widthIndex + 1) % widths.Length; } if (GUILayout.Button("Analyze", Array.Empty<GUILayoutOption>()) && MapDatabase.Instance.maps.TryGetValue(Core.Instance.BaseModule.CurrentStage, out var value)) { analysis = Doctor.Analyze(value.Properties); showDiag = new bool[analysis.diagnostics.Count]; showGo = new bool[analysis.gameObjects.Count + 1]; } if (analysis == null) { return; } GUILayout.Label($"Analysis found {analysis.diagnostics.Count} problems.", val, Array.Empty<GUILayoutOption>()); using (GUIUtil.ScrollView(ref scrollPosition)) { int di = -1; int num = 0; if (analysis.diagnosticsWithoutTarget.Count > 0) { GUILayout.Label("Misc", Array.Empty<GUILayoutOption>()); using (GUIUtil.Indent(2, true, true)) { foreach (Diagnostic item in analysis.diagnosticsWithoutTarget) { DrawDiagnostic(item); } } } foreach (KeyValuePair<GameObject, List<Diagnostic>> gameObject in analysis.gameObjects) { num++; GameObject key = gameObject.Key; List<Diagnostic> value2 = gameObject.Value; showGo[num] = GUILayout.Toggle(showGo[num], $"{expandCollapseIcon(showGo[num])} GameObject: {value2[0].TargetPath}", GUI.skin.label, Array.Empty<GUILayoutOption>()); if (!showGo[num]) { continue; } using (GUIUtil.Indent(1, true, true)) { if (HasUnityExplorer && GUILayout.Button("UnityExplorer", Array.Empty<GUILayoutOption>())) { OpenInUnityExplorer((Object)(object)key); } foreach (Diagnostic item2 in value2) { DrawDiagnostic(item2); } } } void DrawDiagnostic(Diagnostic diagnostic) { di++; showDiag[di] = GUILayout.Toggle(showDiag[di], $"{expandCollapseIcon(showDiag[di])} {diagnostic.Message}", wrappedLabel, Array.Empty<GUILayoutOption>()); if (showDiag[di]) { using (GUIUtil.Indent(1, true, true)) { GUILayout.Label((diagnostic.Details == null) ? "<no details>" : diagnostic.Details, Array.Empty<GUILayoutOption>()); } } } } } private char expandCollapseIcon(bool expanded) { if (!expanded) { return '▶'; } return '▼'; } private void OpenInUnityExplorer(Object obj) { MethodInfo? method = unityExplorerInspectorManagerType.GetMethod("Inspect", new Type[2] { typeof(object), unityExplorerCacheObjectBase }); object[] parameters = (object[])(object)new Object[2] { obj, default(Object) }; method.Invoke(null, parameters); unityExplorerUIManagerType.GetMethod("set_ShowMenu").Invoke(null, new object[1] { true }); } private void OnStagePreInitialization(Stage newStage, Stage previousStage) { analysis = null; } } public static class HiddenShapes { private static readonly int[] DebugLayers = new int[2] { 12, 19 }; private static bool visible; private static GameplayCamera camera; public static bool Visible { get { return visible; } set { visible = value; Apply(); } } public static GameplayCamera Camera { get { return camera; } set { camera = value; Apply(); } } private static void Apply() { if ((Object)(object)camera == (Object)null) { return; } int[] debugLayers = DebugLayers; foreach (int num in debugLayers) { if (visible) { Camera cam = camera.cam; cam.cullingMask |= 1 << num; } else { Camera cam2 = camera.cam; cam2.cullingMask &= ~(1 << num); } } } } internal class HiddenShapesDebugUI : DebugMenu { public override string Name => "Show/Hide Hidden Shapes"; public override void OnGUI() { GUILayout.Label("Toggle visibility of hidden shapes: spawn points, grind lines, etc.", Array.Empty<GUILayoutOption>()); if (GUILayout.Button(HiddenShapes.Visible ? "Hide" : "Show", Array.Empty<GUILayoutOption>())) { HiddenShapes.Visible = !HiddenShapes.Visible; } } } [ProtoContract] [ProtoInclude(1, typeof(PlayAnimation))] internal class BasePacket { } [ProtoContract] internal class PlayAnimation : BasePacket { [ProtoMember(1)] public string directorId; [ProtoMember(2)] public Vector3 position; } internal class SlopCrewClientUI : DebugMenu { private Client<BasePacket> client; public override string Name => "SlopCrewClient"; public SlopCrewClientUI() { client = new Client<BasePacket>("MapStation.Common"); client.Enable(); client.OnPacketReceived += delegate(uint player, BasePacket packet, bool isLocal) { //IL_002c: Unknown result type (might be due to invalid IL or missing references) Debug.Log((object)$"{player} sent us: {packet}"); if (packet is PlayAnimation playAnimation) { Debug.Log((object)playAnimation.directorId); Debug.Log((object)playAnimation.position); } }; } public override void OnGUI() { //IL_02a8: Unknown result type (might be due to invalid IL or missing references) //IL_02ad: Unknown result type (might be due to invalid IL or missing references) GUILayout.Label($"IsSlopCrewInstalled {APIManager.IsSlopCrewInstalled}", Array.Empty<GUILayoutOption>()); GUILayout.Label($"API available? {client.ApiAvailable}", Array.Empty<GUILayoutOption>()); if (client.ApiAvailable) { GUILayout.Label($"Connected {client.SlopCrewAPI.Connected}", Array.Empty<GUILayoutOption>()); GUILayout.Label($"TickRate {client.SlopCrewAPI.TickRate}", Array.Empty<GUILayoutOption>()); GUILayout.Label("ServerAddress " + client.SlopCrewAPI.ServerAddress, Array.Empty<GUILayoutOption>()); GUILayout.Label($"Latency {client.SlopCrewAPI.Latency}", Array.Empty<GUILayoutOption>()); GUILayout.Label($"PlayerCount {client.SlopCrewAPI.PlayerCount}", Array.Empty<GUILayoutOption>()); foreach (uint player in client.SlopCrewAPI.Players) { GUILayout.Label($"Player#{player}: {client.SlopCrewAPI.GetPlayerName(player)}", Array.Empty<GUILayoutOption>()); } } GUILayout.Label($"CurrentTick {client.CurrentTick}", Array.Empty<GUILayoutOption>()); GUILayout.Label($"CurrentTickSmoothed {client.CurrentTickSmoothed}", Array.Empty<GUILayoutOption>()); GUILayout.Label($"TickDuration {client.TickDuration}", Array.Empty<GUILayoutOption>()); bool flag = client.CurrentTickSmoothed > client.CurrentTick; bool flag2 = client.CurrentTickSmoothed < client.CurrentTick; ulong num = (flag ? (client.CurrentTickSmoothed - client.CurrentTick) : (client.CurrentTick - client.CurrentTickSmoothed)); GUILayout.Label(string.Format("Tick difference {0} {1}", num, flag ? "Local is ahead" : (flag2 ? "Server is ahead" : "")), Array.Empty<GUILayoutOption>()); if (GUILayout.Button("Send Packet", Array.Empty<GUILayoutOption>())) { client.Send((BasePacket)new PlayAnimation { directorId = "foobar", position = Vector3.down }, true); } } } } namespace MapStation.Plugin.Phone { public class AppMapOptions : CustomApp { private LoadedMapOptions _loadedMapOptions = LoadedMapOptions.GetCurrentMapOptions(); private MapOptions _mapOptions = MapOptions.Instance; private Dictionary<string, SimplePhoneButton> _buttonByOptionName = new Dictionary<string, SimplePhoneButton>(); private Camera _currentCamera; private bool _onMapOptionSetting; private Vector3 _fixedPosition; private Quaternion _fixedRotation; public override bool Available { get { if ((Object)(object)MapOptions.Instance != (Object)null) { return MapOptions.Instance.Options.Count() > 0; } return false; } } public override void OnAppInit() { ((CustomApp)this).OnAppInit(); ((CustomApp)this).CreateIconlessTitleBar("Map Options", 70f); base.ScrollView = PhoneScrollView.Create((CustomApp)(object)this, 275f, 1600f); if ((Object)(object)_mapOptions == (Object)null) { return; } SimplePhoneButton val = PhoneUIUtility.CreateSimpleButton("Reset"); ((PhoneButton)val).OnConfirm = (Action)Delegate.Combine(((PhoneButton)val).OnConfirm, (Action)delegate { ResetOptions(); }); base.ScrollView.AddButton((PhoneButton)(object)val); MapOption[] options = _mapOptions.Options; foreach (MapOption option in options) { if (option != null) { SimplePhoneButton val2 = PhoneUIUtility.CreateSimpleButton(GetOptionString(option.Name)); ((PhoneButton)val2).OnConfirm = (Action)Delegate.Combine(((PhoneButton)val2).OnConfirm, (Action)delegate { ChangeOption(option.Name); }); _buttonByOptionName[option.Name] = val2; base.ScrollView.AddButton((PhoneButton)(object)val2); } } MapOptions.OnMapOptionsChanged = (Action)Delegate.Remove(MapOptions.OnMapOptionsChanged, new Action(RefreshButtonNames)); MapOptions.OnMapOptionsChanged = (Action)Delegate.Combine(MapOptions.OnMapOptionsChanged, new Action(RefreshButtonNames)); } public override void OnAppUpdate() { ((App)this).OnAppUpdate(); UpdateCamera(); UpdateDesc(); UpdatePlayerFreeze(); } public override void OnAppDisable() { ((App)this).OnAppDisable(); _onMapOptionSetting = false; DisableCamera(); ((Component)MapOptionDescriptionUI.Instance).gameObject.SetActive(false); } public override void OnAppTerminate() { ((App)this).OnAppTerminate(); _onMapOptionSetting = false; DisableCamera(); ((Component)MapOptionDescriptionUI.Instance).gameObject.SetActive(false); } private void UpdatePlayerFreeze() { //IL_0045: Unknown result type (might be due to invalid IL or missing references) //IL_004b: Unknown result type (might be due to invalid IL or missing references) //IL_0028: Unknown result type (might be due to invalid IL or missing references) //IL_002d: Unknown result type (might be due to invalid IL or missing references) //IL_0039: Unknown result type (might be due to invalid IL or missing references) //IL_003e: Unknown result type (might be due to invalid IL or missing references) if ((Object)(object)_currentCamera != (Object)null) { Player currentPlayer = WorldHandler.instance.currentPlayer; if (!_onMapOptionSetting) { _fixedPosition = ((Component)currentPlayer).transform.position; _fixedRotation = ((Component)currentPlayer).transform.rotation; } currentPlayer.SetPosAndRotHard(_fixedPosition, _fixedRotation); _onMapOptionSetting = true; } else { _onMapOptionSetting = false; } } private void UpdateDesc() { MapOptionDescriptionUI instance = MapOptionDescriptionUI.Instance; PhoneButton val = base.ScrollView.Buttons[base.ScrollView.SelectedIndex]; foreach (KeyValuePair<string, SimplePhoneButton> item in _buttonByOptionName) { if (!((Object)(object)item.Value == (Object)(object)val)) { continue; } MapOption[] options = MapOptions.Instance.Options; foreach (MapOption val2 in options) { if (val2.Name == item.Key) { ((Component)instance).gameObject.SetActive(true); instance.SetText(val2.Description); return; } } ((Component)instance).gameObject.SetActive(false); return; } ((Component)instance).gameObject.SetActive(false); } private void UpdateCamera() { PhoneButton val = base.ScrollView.Buttons[base.ScrollView.SelectedIndex]; if ((Object)(object)val == (Object)null) { DisableCamera(); return; } foreach (KeyValuePair<string, SimplePhoneButton> item in _buttonByOptionName) { if (!((Object)(object)item.Value == (Object)(object)val)) { continue; } MapOption[] options = MapOptions.Instance.Options; foreach (MapOption val2 in options) { if (val2.Name == item.Key) { if ((Object)(object)val2.PreviewCamera == (Object)null) { DisableCamera(); } else { EnableCamera(val2.PreviewCamera); } return; } } DisableCamera(); return; } DisableCamera(); } private void DisableCamera() { if ((Object)(object)_currentCamera != (Object)null) { ((Component)_currentCamera).gameObject.SetActive(false); } _currentCamera = null; } private void EnableCamera(Camera camera) { if ((Object)(object)_currentCamera != (Object)null) { DisableCamera(); } ((Component)camera).gameObject.SetActive(true); _currentCamera = camera; } private void OnDestroy() { MapOptions.OnMapOptionsChanged = (Action)Delegate.Remove(MapOptions.OnMapOptionsChanged, new Action(RefreshButtonNames)); } private void ResetOptions() { _loadedMapOptions.MakeDefault(); MapOptions.OnMapOptionsChanged?.Invoke(); } private void ChangeOption(string optionName) { string option = _loadedMapOptions.GetOption(optionName); MapOption[] options = _mapOptions.Options; foreach (MapOption val in options) { if (val.Name == optionName) { int num = Array.IndexOf(val.PossibleValues, option); if (num < 0) { num = Array.IndexOf(val.PossibleValues, val.DefaultValue); } if (num < 0) { num = 0; } num++; if (num >= val.PossibleValues.Length) { num = 0; } _loadedMapOptions.Options[optionName] = val.PossibleValues[num]; break; } } Core.Instance.SaveManager.SaveCurrentSaveSlot(); MapOptions.OnMapOptionsChanged?.Invoke(); } private void RefreshButtonNames() { foreach (KeyValuePair<string, SimplePhoneButton> item in _buttonByOptionName) { ((TMP_Text)item.Value.Label).text = GetOptionString(item.Key); } } private string GetOptionString(string optionName) { string option = _loadedMapOptions.GetOption(optionName); return optionName + " = " + option; } } public class AppMapStation : CustomApp { public override void OnAppInit() { ((CustomApp)this).OnAppInit(); ((CustomApp)this).CreateIconlessTitleBar("MapStation", 70f); base.ScrollView = PhoneScrollView.Create((CustomApp)(object)this, 275f, 1600f); } public override void OnAppEnable() { //IL_00c0: Unknown result type (might be due to invalid IL or missing references) ((App)this).OnAppEnable(); base.ScrollView.RemoveAllButtons(); base.ScrollView.ResetScroll(); base.ScrollView.CancelAnimation(); IEnumerable<PluginMapDatabaseEntry> enumerable = from map in MapDatabase.Instance.maps.Values orderby map.source descending, map.Properties.displayName where map.Properties.showInFastTravelMenus select map; addButton((Stage)5, "Hideout"); foreach (PluginMapDatabaseEntry item in enumerable) { addButton(item.stageId, item.Properties.displayName, item.source == MapSource.TestMaps); } void addButton(Stage stageId, string displayName, bool localBuild = false) { //IL_0007: Unknown result type (might be due to invalid IL or missing references) //IL_0008: Unknown result type (might be due to invalid IL or missing references) //IL_0048: Unknown result type (might be due to invalid IL or missing references) //IL_004d: Unknown result type (might be due to invalid IL or missing references) //IL_0057: Unknown result type (might be due to invalid IL or missing references) //IL_005c: Unknown result type (might be due to invalid IL or missing references) //IL_0066: Unknown result type (might be due to invalid IL or missing references) //IL_006b: Unknown result type (might be due to invalid IL or missing references) //IL_0070: Unknown result type (might be due to invalid IL or missing references) SimplePhoneButton val = PhoneUIUtility.CreateSimpleButton(displayName); if (localBuild) { GameObject obj = Object.Instantiate<GameObject>(((Component)((TMP_Text)val.Label).transform).gameObject, val.AnimationParent); ((TMP_Text)obj.GetComponent<TextMeshProUGUI>()).text = "L"; RectTransform obj2 = GameObjectExtensions.RectTransform(obj); ((Transform)obj2).localPosition = ((Transform)obj2).localPosition + (Vector3.up * 65f + Vector3.left * 65f); } ((PhoneButton)val).OnConfirm = (Action)Delegate.Combine(((PhoneButton)val).OnConfirm, (Action)delegate { //IL_0010: Unknown result type (might be due to invalid IL or missing references) Core.Instance.BaseModule.StageManager.ExitCurrentStage(stageId, (Stage)(-1)); }); base.ScrollView.AddButton((PhoneButton)(object)val); } } } } namespace MapStation.Plugin.Patches { [HarmonyPatch(typeof(AirDashAbility))] internal static class AirDashAbilityPatch { [HarmonyPrefix] [HarmonyPatch("OnStartAbility")] private static void OnStartAbility_Prefix(AirDashAbility __instance) { MapStationPlayer mapStationPlayer = MapStationPlayer.Get(((Ability)__instance).p); if (mapStationPlayer.OnVertAir) { mapStationPlayer.AirVertEnd(); } } } [HarmonyPatch(typeof(AirTrickAbility))] internal static class AirTrickAbilityPatch { [HarmonyPrefix] [HarmonyPatch("SetupBoostTrick")] private static bool SetupBoostTrick_Prefix(AirTrickAbility __instance) { //IL_0049: Unknown result type (might be due to invalid IL or missing references) Player p = ((Ability)__instance).p; if (MapStationPlayer.Get(p).OnVertAir) { p.PlayAnim(__instance.airBoostTrickHashes[__instance.curTrick], true, false, 0f); p.PlayVoice((AudioClipID)498, (VoicePriority)2, true); p.ringParticles.Emit(1); __instance.trickType = (TrickType)2; __instance.duration *= 1.5f; p.AddBoostCharge(0f - p.boostTrickCost); return false; } return true; } } [HarmonyPatch(typeof(AProgressable))] internal static class AProgressablePatch { [HarmonyPrefix] [HarmonyPatch("InitProgressable")] private static bool InitProgressable_Prefix(AProgressable __instance, StageProgress stageProgress) { //IL_0047: Unknown result type (might be due to invalid IL or missing references) //IL_004c: Unknown result type (might be due to invalid IL or missing references) __instance.hasSaveData = stageProgress.HasProgressableData(__instance.uid); if (__instance.hasSaveData) { __instance.progressableData = stageProgress.GetProgressableData(__instance.uid); try { __instance.ReadFromData(); } catch (InvalidCastException) { string uid = __instance.uid; Type type = ((object)__instance).GetType(); Stage stageID = stageProgress.stageID; Debug.LogWarning((object)$"Invalid data for progressable with UID {uid}, type {type} in Stage {((object)(Stage)(ref stageID)).ToString()}. Setting default data."); __instance.SetDefaultData(stageProgress); return false; } return false; } __instance.SetDefaultData(stageProgress); return false; } } [HarmonyPatch(typeof(ASceneSetupInstruction))] public class ASceneSetupInstructionPatch { [HarmonyPrefix] [HarmonyPatch("SetSceneActive")] protected static void SetSceneActive_Prefix(ref string sceneToSetActive) { if (SceneNameMapper.Instance.Names.TryGetValue(sceneToSetActive, out var value)) { Log.Info("ASceneSetupInstruction.SetSceneActive redirected from " + sceneToSetActive + " to " + value); sceneToSetActive = value; } } } [HarmonyPatch(typeof(Assets))] internal static class AssetsPatch { [HarmonyPostfix] [HarmonyPatch("Init")] private static void Init_Postfix(Assets __instance) { Plugin.Instance.InitializeMapDatabase(__instance); } [HarmonyPostfix] [HarmonyPatch("GetAssetsToLoadDataForScene")] private static void GetAssetsToLoadDataForScene_Postfix(Assets __instance, string sceneName, ref AssetsToLoadData __result) { if ((Object)(object)__result == (Object)null) { Log.Info("Assets.GetAssetsToLoadDataForScene does not know about scene " + sceneName + "; assuming it's a custom map, creating default struct instead."); __result = ScriptableObject.CreateInstance<AssetsToLoadData>(); __result.loadCharacters = true; __result.loadGameplayPrefabs = true; __result.loadGraffiti = true; __result.sfxCollectionsToLoad = (SfxCollection[])(object)new SfxCollection[0]; } } [HarmonyPrefix] [HarmonyPatch("UnloadAssetBundleByName")] private static bool UnloadAssetBundleByName_Prefix(string assetBundleName) { if (StagePrefabHijacker.Loaded && StagePrefabHijacker.ProtectedAssetBundles.Contains(assetBundleName)) { return false; } return true; } [HarmonyPrefix] [HarmonyPatch("LoadBundleASync")] private static bool LoadBundleASync_Prefix(ref IEnumerator __result, Assets __instance, Bundle bundleToLoad) { if (ZipAssetBundles.Instance.Bundles.TryGetValue(bundleToLoad.name, out var value)) { __result = LoadMapBundleASync(__instance, bundleToLoad, value); return false; } if (bundleToLoad.IsLoaded) { return false; } return true; } private static IEnumerator LoadMapBundleASync(Assets __instance, Bundle bundleToLoad, ZipAssetBundle zipAssetBundle) { bundleToLoad.InitializeLoad(); Log.Info("Assets.LoadBundleASync loading " + bundleToLoad.Name + " from zip " + zipAssetBundle.zipPath); MapZip val = new MapZip(zipAssetBundle.zipPath); byte[] array; try { Stream stream = zipAssetBundle.bundleType switch { ZipBundleType.SCENE => val.GetSceneBundleStream(), ZipBundleType.ASSETS => val.GetAssetsBundleStream(), _ => throw new Exception("Unexpected ZipBundleType " + zipAssetBundle.bundleType), }; using (stream) { using MemoryStream memoryStream = new MemoryStream(); stream.CopyTo(memoryStream); array = memoryStream.ToArray(); } } finally { ((IDisposable)val)?.Dispose(); } __instance.currentAssetBundleCreateRequest = AssetBundle.LoadFromMemoryAsync(array); yield return __instance.currentAssetBundleCreateRequest; if ((Object)(object)__instance.currentAssetBundleCreateRequest.assetBundle == (Object)null) { bundleToLoad.ResetLoadState(); } else { bundleToLoad.SetAssetBundle(__instance.currentAssetBundleCreateRequest.assetBundle); } } } [HarmonyPatch(typeof(BaseModule))] internal static class BaseModulePatch { [HarmonyPrefix] [HarmonyPatch("SetupNewStage")] private static bool SetupNewStage_Prefix(Stage newStage) { //IL_0050: Unknown result type (might be due to invalid IL or missing references) //IL_0033: Unknown result type (might be due to invalid IL or missing references) if (!StagePrefabHijacker.Loaded && StagePrefabHijacker.Active) { StagePrefabHijacker.RunOnHijackStage(); StagePrefabHijacker.Log("Hideout resources loaded - switching to intended stage now."); StagePrefabHijacker.Loaded = true; StagePrefabHijacker.Active = false; Core.Instance.BaseModule.SwitchStage(StagePrefabHijacker.ActualTargetStage); return false; } if (StagePrefabHijacker.Loaded && MapDatabase.Instance.maps.ContainsKey(newStage)) { StagePrefabHijacker.RunOnCustomStage(); } StagePrefabHijacker.Loaded = false; return true; } } [HarmonyPatch(typeof(BoostAbility))] internal static class BoostAbilityPatch { [HarmonyPrefix] [HarmonyPatch("CheckActivation")] private static bool CheckActivation_Prefix(BoostAbility __instance, ref bool __result) { MapStationPlayer mapStationPlayer = MapStationPlayer.Get(((Ability)__instance).p); if (mapStationPlayer.VertBoostCooldown > 0f && mapStationPlayer.OnVertAir) { __result = false; return false; } return true; } [HarmonyPrefix] [HarmonyPatch("SetState")] private static void SetState_Prefix(BoostAbility __instance, State setState) { //IL_0014: Unknown result type (might be due to invalid IL or missing references) //IL_0016: Invalid comparison between Unknown and I4 MapStationPlayer mapStationPlayer = MapStationPlayer.Get(((Ability)__instance).p); if (mapStationPlayer.OnVertAir && (int)setState == 1) { mapStationPlayer.AirVertEnd(); } } } [HarmonyPatch(typeof(Bootstrap))] internal static class BootstrapPatch { [HarmonyPrefix] [HarmonyPatch("LaunchGame")] private static bool LaunchGame_Prefix(Bootstrap __instance) { //IL_0022: Unknown result type (might be due to invalid IL or missing references) if (MapStationConfig.Instance.QuickLaunchValue != "") { ((MonoBehaviour)__instance).StartCoroutine(__instance.SetupGameToStage(StageEnum.GetMapId(MapStationConfig.Instance.QuickLaunchValue))); return false; } return true; } } [HarmonyPatch(typeof(CharacterVisual))] internal static class CharacterVisualPatch { [HarmonyPostfix] [HarmonyPatch("InitVFX")] private static void InitVFX_Postfix(CharacterVisual __instance) { if (__instance.VFX != null) { Assets assets = Core.Instance.Assets; Texture2D mainTexture = assets.LoadAssetFromBundle<Texture2D>("common_assets", "spraycanTex"); if ((Object)(object)__instance.VFX.spraycan != (Object)null) { __instance.VFX.spraycan.GetComponent<Renderer>().sharedMaterial.mainTexture = (Texture)(object)mainTexture; } Texture2D mainTexture2 = assets.LoadAssetFromBundle<Texture2D>("common_assets", "flipPhoneTex"); if ((Object)(object)__instance.VFX.phone != (Object)null) { __instance.VFX.phone.GetComponent<Renderer>().sharedMaterial.mainTexture = (Texture)(object)mainTexture2; } } } } [HarmonyPatch(typeof(GameplayCamera))] internal static class GameplayCameraPatch { [HarmonyPostfix] [HarmonyPatch("Awake")] private static void Awake_Postfix(GameplayCamera __instance) { HiddenShapes.Camera = __instance; } [HarmonyPostfix] [HarmonyPatch("UpdateCamera")] private static void UpdateCamera_Postfix(GameplayCamera __instance) { //IL_0029: Unknown result type (might be due to invalid IL or missing references) //IL_002e: Unknown result type (might be due to invalid IL or missing references) if (Object.op_Implicit((Object)(object)__instance.player) && ((Behaviour)__instance).isActiveAndEnabled && (!(__instance.hitpause > 0f) || !(__instance.player.GetVelocity() == Vector3.zero))) { MapStationPlayer mapStationPlayer = MapStationPlayer.Get(__instance.player); if (__instance.cameraMode == __instance.cameraModeDrag && mapStationPlayer.OnVertAir) { __instance.SetCameraMode(mapStationPlayer.VertCameraMode, false); } } } [HarmonyPrefix] [HarmonyPatch("SetCameraMode")] [HarmonyPatch(new Type[] { typeof(CameraMode), typeof(bool) })] private static bool SetCameraMode_Prefix(GameplayCamera __instance, ref CameraMode mode) { MapStationPlayer mapStationPlayer = MapStationPlayer.Get(__instance.player); if (!(mode is CameraModeDrag)) { return true; } if (mapStationPlayer.OnVertAir) { mode = mapStationPlayer.VertCameraMode; if (__instance.cameraMode == mapStationPlayer.VertCameraMode) { return false; } } return true; } } [HarmonyPatch(typeof(GrindAbility))] internal static class GrindAbilityPatch { [HarmonyPrefix] [HarmonyPatch("SetToLine")] private static void SetToLine_Prefix(GrindAbility __instance) { Player p = ((Ability)__instance).p; MapStationPlayer mapStationPlayer = MapStationPlayer.Get(p); if (mapStationPlayer.OnVertGround || mapStationPlayer.OnVertAir || mapStationPlayer.HasVertBelow) { mapStationPlayer.AirVertEnd(); p.OrientVisualInstantReset(); } } [HarmonyPrefix] [HarmonyPatch("JumpOut")] private static void JumpOut_Prefix(GrindAbility __instance) { if ((Object)(object)((Component)__instance.lastPath).GetComponent<GrindPath_FixComboBreakingProperty>() != (Object)null) { MapStationPlayer.Get(((Ability)__instance).p).GroundCooldown = 0.1f; } } } [HarmonyPatch(typeof(GroundDetection))] internal static class GroundDetectionPatch { private static void ComputeVert(GroundDetection __instance) { //IL_0022: Unknown result type (might be due to invalid IL or missing references) //IL_0027: Unknown result type (might be due to invalid IL or missing references) //IL_0031: Unknown result type (might be due to invalid IL or missing references) //IL_0036: Unknown result type (might be due to invalid IL or missing references) //IL_003b: Unknown result type (might be due to invalid IL or missing references) //IL_0046: Unknown result type (might be due to invalid IL or missing references) //IL_004b: Unknown result type (might be due to invalid IL or missing references) //IL_004c: Unknown result type (might be due to invalid IL or missing references) //IL_0055: Unknown result type (might be due to invalid IL or missing references) //IL_0061: Unknown result type (might be due to invalid IL or missing references) //IL_00c6: Unknown result type (might be due to invalid IL or missing references) //IL_00cc: Unknown result type (might be due to invalid IL or missing references) //IL_00d6: Unknown result type (might be due to invalid IL or missing references) //IL_00db: Unknown result type (might be due to invalid IL or missing references) //IL_00e0: Unknown result type (might be due to invalid IL or missing references) //IL_00ea: Unknown result type (might be due to invalid IL or missing references) //IL_00ef: Unknown result type (might be due to invalid IL or missing references) //IL_00f4: Unknown result type (might be due to invalid IL or missing references) //IL_00ff: Unknown result type (might be due to invalid IL or missing references) //IL_0104: Unknown result type (might be due to invalid IL or missing references) //IL_0106: Unknown result type (might be due to invalid IL or missing references) //IL_00a7: Unknown result type (might be due to invalid IL or missing references) //IL_00ac: Unknown result type (might be due to invalid IL or missing references) //IL_00b1: Unknown result type (might be due to invalid IL or missing references) //IL_0172: Unknown result type (might be due to invalid IL or missing references) //IL_0178: Unknown result type (might be due to invalid IL or missing references) //IL_0182: Unknown result type (might be due to invalid IL or missing references) //IL_0187: Unknown result type (might be due to invalid IL or missing references) //IL_018c: Unknown result type (might be due to invalid IL or missing references) //IL_0196: Unknown result type (might be due to invalid IL or missing references) //IL_019b: Unknown result type (might be due to invalid IL or missing references) //IL_01a0: Unknown result type (might be due to invalid IL or missing references) //IL_01ab: Unknown result type (might be due to invalid IL or missing references) //IL_01b0: Unknown result type (might be due to invalid IL or missing references) //IL_01b2: Unknown result type (might be due to invalid IL or missing references) //IL_014c: Unknown result type (might be due to invalid IL or missing references) //IL_0152: Unknown result type (might be due to invalid IL or missing references) //IL_015c: Unknown result type (might be due to invalid IL or missing references) //IL_0161: Unknown result type (might be due to invalid IL or missing references) //IL_012f: Unknown result type (might be due to invalid IL or missing references) //IL_0134: Unknown result type (might be due to invalid IL or missing references) //IL_0228: Unknown result type (might be due to invalid IL or missing references) //IL_022d: Unknown result type (might be due to invalid IL or missing references) //IL_0232: Unknown result type (might be due to invalid IL or missing references) //IL_0234: Unknown result type (might be due to invalid IL or missing references) //IL_0237: Unknown result type (might be due to invalid IL or missing references) //IL_01f8: Unknown result type (might be due to invalid IL or missing references) //IL_01fe: Unknown result type (might be due to invalid IL or missing references) //IL_0208: Unknown result type (might be due to invalid IL or missing references) //IL_020d: Unknown result type (might be due to invalid IL or missing references) //IL_01db: Unknown result type (might be due to invalid IL or missing references) //IL_01e0: Unknown result type (might be due to invalid IL or missing references) //IL_0245: Unknown result type (might be due to invalid IL or missing references) Player player = ((BaseGroundDetection)__instance).player; MapStationPlayer mapStationPlayer = MapStationPlayer.Get(player); mapStationPlayer.HasVertBelow = false; float num = 500f; RaycastInfo raycastInfo = __instance.GetRaycastInfo(((Component)player).transform.position + Vector3.up * 1f, Vector3.down, num, 1f); if (!raycastInfo.hit) { return; } float num2 = Vector3.Angle(Vector3.up, ((RaycastHit)(ref raycastInfo.hitInfo)).normal); if ((Object)(object)((Component)((RaycastHit)(ref raycastInfo.hitInfo)).collider).GetComponent<MapStationVert>() == (Object)null) { return; } if (num2 >= 45f) { mapStationPlayer.HasVertBelow = true; if (!mapStationPlayer.OnVertGround) { mapStationPlayer.GroundVertVector = -((RaycastHit)(ref raycastInfo.hitInfo)).normal; } } if (!mapStationPlayer.OnVertAir) { return; } RaycastInfo raycastInfo2 = __instance.GetRaycastInfo(((Component)player).transform.position - mapStationPlayer.AirVertVector * 0.35f + Vector3.up * 1f, Vector3.down, num, 1f); if (raycastInfo2.hit && ((Object)(object)((Component)((RaycastHit)(ref raycastInfo2.hitInfo)).collider).GetComponent<MapStationVert>() == (Object)null || Vector3.Angle(((RaycastHit)(ref raycastInfo2.hitInfo)).normal, Vector3.up) < 45f)) { Transform transform = ((Component)player).transform; transform.position += mapStationPlayer.AirVertVector * 0.35f; } raycastInfo2 = __instance.GetRaycastInfo(((Component)player).transform.position + mapStationPlayer.AirVertVector * 0.35f + Vector3.up * 1f, Vector3.down, num, 1f); if (raycastInfo2.hit && ((Object)(object)((Component)((RaycastHit)(ref raycastInfo2.hitInfo)).collider).GetComponent<MapStationVert>() == (Object)null || Vector3.Angle(((RaycastHit)(ref raycastInfo2.hitInfo)).normal, Vector3.up) < 45f)) { Transform transform2 = ((Component)player).transform; transform2.position -= mapStationPlayer.AirVertVector * 0.35f; } if (!(num2 < 45f)) { Vector3 vertVectorFromGroundNormal = MapStationPlayer.GetVertVectorFromGroundNormal(((RaycastHit)(ref raycastInfo.hitInfo)).normal); if (!(vertVectorFromGroundNormal == mapStationPlayer.AirVertVector)) { mapStationPlayer.TransferVert(vertVectorFromGroundNormal); } } } [HarmonyPrefix] [HarmonyPatch("ComputeGroundHit")] private static bool ComputeGroundHit_Prefix(GroundDetection __instance, ref bool __result, Vector3 position, Quaternion rotation, ref GroundHit groundHitInfo, float distance) { //IL_0091: Unknown result type (might be due to invalid IL or missing references) //IL_0096: Unknown result type (might be due to invalid IL or missing references) //IL_007a: Unknown result type (might be due to invalid IL or missing references) //IL_00db: Unknown result type (might be due to invalid IL or missing references) //IL_00dc: Unknown result type (might be due to invalid IL or missing references) //IL_00e3: Unknown result type (might be due to invalid IL or missing references) //IL_00e8: Unknown result type (might be due to invalid IL or missing references) //IL_00e9: Unknown result type (might be due to invalid IL or missing references) //IL_00cf: Unknown result type (might be due to invalid IL or missing references) //IL_00d4: Unknown result type (might be due to invalid IL or missing references) //IL_00d9: Unknown result type (might be due to invalid IL or missing references) //IL_00f2: Unknown result type (might be due to invalid IL or missing references) //IL_00f3: Unknown result type (might be due to invalid IL or missing references) //IL_0134: Unknown result type (might be due to invalid IL or missing references) //IL_0135: Unknown result type (might be due to invalid IL or missing references) //IL_015f: Unknown result type (might be due to invalid IL or missing references) //IL_0164: Unknown result type (might be due to invalid IL or missing references) //IL_0168: Unknown result type (might be due to invalid IL or missing references) //IL_0176: Unknown result type (might be due to invalid IL or missing references) //IL_0110: Unknown result type (might be due to invalid IL or missing references) //IL_0112: Unknown result type (might be due to invalid IL or missing references) MapStationPlayer mapStationPlayer = MapStationPlayer.Get(((BaseGroundDetection)__instance).player); if (mapStationPlayer.GroundCooldown > 0f || mapStationPlayer.OnPreventComboBreakingGrindPath()) { mapStationPlayer.OnVertGround = false; mapStationPlayer.WasOnVertGround = false; mapStationPlayer.HasVertBelow = false; __result = false; return false; } if (!mapStationPlayer.MoveStyleEquipped) { mapStationPlayer.OnVertGround = false; mapStationPlayer.WasOnVertGround = false; mapStationPlayer.HasVertBelow = false; return true; } ComputeVert(__instance); mapStationPlayer.OnVertGround = false; if (mapStationPlayer.OnVertAir && ((BaseGroundDetection)__instance).player.motor.velocity.y > 0f) { __result = false; return false; } Vector3 val = mapStationPlayer.GroundVertVector; float num = distance; if (mapStationPlayer.WasOnVertGround || ((BaseGroundDetection)__instance).player.motor.wasGrounded) { num = distance * 2f; } if (mapStationPlayer.OnVertAir) { num = distance * 1.25f; val = -mapStationPlayer.AirVertVector; } RaycastInfo raycastInfo = __instance.GetRaycastInfo(position, val, num, 1f); if (!raycastInfo.hit) { RaycastHit hitInfo = default(RaycastHit); if (!((BaseGroundDetection)__instance).BottomSphereCast(position, rotation, ref hitInfo, distance, 0.05f)) { return true; } raycastInfo.hit = true; raycastInfo.hitInfo = hitInfo; } if ((Object)(object)((Component)((RaycastHit)(ref raycastInfo.hitInfo)).collider).GetComponent<MapStationVert>() == (Object)null) { return true; } ((GroundHit)(ref groundHitInfo)).SetFrom(raycastInfo.hitInfo); ((GroundHit)(ref groundHitInfo)).groundDistance = 0.001f; ((GroundHit)(ref groundHitInfo)).isOnGround = true; ((GroundHit)(ref groundHitInfo)).isValidGround = true; Vector3 groundNormal = ((GroundHit)(ref groundHitInfo)).groundNormal; ((GroundHit)(ref groundHitInfo)).groundNormal = ((Vector3)(ref groundNormal)).normalized; ((GroundHit)(ref groundHitInfo)).groundNormalVisual = ((GroundHit)(ref groundHitInfo)).groundNormal; ((GroundHit)(ref groundHitInfo)).isOnStep = false; mapStationPlayer.VertCollider = ((GroundHit)(ref groundHitInfo)).groundCollider; mapStationPlayer.OnVertGround = true; __result = true; return false; } [HarmonyPostfix] [HarmonyPatch("ComputeGroundHit")] private static void ComputeGroundHit_Postfix(GroundDetection __instance, ref bool __result, Vector3 position, Quaternion rotation, ref GroundHit groundHitInfo, float distance) { //IL_0029: Unknown result type (might be due to invalid IL or missing references) //IL_002e: Unknown result type (might be due to invalid IL or missing references) //IL_009c: Unknown result type (might be due to invalid IL or missing references) //IL_00a1: Unknown result type (might be due to invalid IL or missing references) //IL_00a6: Unknown result type (might be due to invalid IL or missing references) //IL_0039: Unknown result type (might be due to invalid IL or missing references) //IL_003e: Unknown result type (might be due to invalid IL or missing references) //IL_0043: Unknown result type (might be due to invalid IL or missing references) //IL_005f: Unknown result type (might be due to invalid IL or missing references) //IL_0103: Unknown result type (might be due to invalid IL or missing references) //IL_0108: Unknown result type (might be due to invalid IL or missing references) //IL_00ce: Unknown result type (might be due to invalid IL or missing references) //IL_00d3: Unknown result type (might be due to invalid IL or missing references) MapStationPlayer mapStationPlayer = MapStationPlayer.Get(((BaseGroundDetection)__instance).player); if (!__result && (mapStationPlayer.WasOnVertGround || mapStationPlayer.OnVertGround || mapStationPlayer.HasVertBelow)) { GroundHit prevGroundHit = ((BaseGroundDetection)__instance).prevGroundHit; if (((GroundHit)(ref prevGroundHit)).isValidGround && Vector3.Angle(-mapStationPlayer.GroundVertVector, Vector3.up) >= 45f && ((BaseGroundDetection)__instance).player.motor.velocity.y > 0f) { mapStationPlayer.AirVertBegin(); } } if (__result && mapStationPlayer.OnVertAir && ((GroundHit)(ref groundHitInfo)).isValidGround) { mapStationPlayer.AirVertEnd(); } if (mapStationPlayer.OnVertGround) { mapStationPlayer.GroundVertVector = -((GroundHit)(ref
MapStation.Tools.dll
Decompiled a week agousing System; using System.Diagnostics; using System.Reflection; using System.Runtime.CompilerServices; using System.Runtime.Versioning; using System.Security; using System.Security.Permissions; using Microsoft.CodeAnalysis; using Reptile; [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: TargetFramework(".NETFramework,Version=v4.7.1", FrameworkDisplayName = ".NET Framework 4.7.1")] [assembly: IgnoresAccessChecksTo("Assembly-CSharp")] [assembly: AssemblyCompany("MapStation.Tools")] [assembly: AssemblyConfiguration("Release")] [assembly: AssemblyFileVersion("1.0.0.0")] [assembly: AssemblyInformationalVersion("1.0.0+b563dbbebaa7f606b3f17d667187816fc03f215e")] [assembly: AssemblyProduct("MapStation.Tools")] [assembly: AssemblyTitle("MapStation.Tools")] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("1.0.0.0")] [assembly: TypeForwardedTo(typeof(ABaseError))] [assembly: TypeForwardedTo(typeof(Ability))] [assembly: TypeForwardedTo(typeof(Achievement))] [assembly: TypeForwardedTo(typeof(AchievementLibrary))] [assembly: TypeForwardedTo(typeof(AchievementPhotoObjective))] [assembly: TypeForwardedTo(typeof(Achievements))] [assembly: TypeForwardedTo(typeof(AchievementsCache))] [assembly: TypeForwardedTo(typeof(AchievementsLocal))] [assembly: TypeForwardedTo(typeof(AchievementsSteam))] [assembly: TypeForwardedTo(typeof(AchievementsTracker))] [assembly: TypeForwardedTo(typeof(AchievementsTracking))] [assembly: TypeForwardedTo(typeof(AchievementType))] [assembly: TypeForwardedTo(typeof(ActiveOnChapter))] [assembly: TypeForwardedTo(typeof(ADataSerializer))] [assembly: TypeForwardedTo(typeof(ADownloadableContent))] [assembly: TypeForwardedTo(typeof(AErrorHandler))] [assembly: TypeForwardedTo(typeof(AFileTransaction))] [assembly: TypeForwardedTo(typeof(AFodsLocalizationFileParser))] [assembly: TypeForwardedTo(typeof(AGameDebug))] [assembly: TypeForwardedTo(typeof(AGameTextFormatter))] [assembly: TypeForwardedTo(typeof(AIndexQueue))] [assembly: TypeForwardedTo(typeof(AirDashAbility))] [assembly: TypeForwardedTo(typeof(AirTrickAbility))] [assembly: TypeForwardedTo(typeof(AlignWithRayAttribute))] [assembly: TypeForwardedTo(typeof(AmbientManager))] [assembly: TypeForwardedTo(typeof(AmbientTrigger))] [assembly: TypeForwardedTo(typeof(AMenuController))] [assembly: TypeForwardedTo(typeof(AnimatedStripe))] [assembly: TypeForwardedTo(typeof(AnimationAssetManager))] [assembly: TypeForwardedTo(typeof(AnimationEventRelay))] [assembly: TypeForwardedTo(typeof(AnimationInstanceEvent))] [assembly: TypeForwardedTo(typeof(AnimationInstanceInfo))] [assembly: TypeForwardedTo(typeof(AnimationInstanceType))] [assembly: TypeForwardedTo(typeof(AnimationInstancing))] [assembly: TypeForwardedTo(typeof(AnimationInstancingManager))] [assembly: TypeForwardedTo(typeof(AnimationTexture))] [assembly: TypeForwardedTo(typeof(AnimInfo))] [assembly: TypeForwardedTo(typeof(AOptionsMenuTab))] [assembly: TypeForwardedTo(typeof(APlatform))] [assembly: TypeForwardedTo(typeof(ApplicationUtility))] [assembly: TypeForwardedTo(typeof(ApplyToChildAttribute))] [assembly: TypeForwardedTo(typeof(AProgressable))] [assembly: TypeForwardedTo(typeof(Arm))] [assembly: TypeForwardedTo(typeof(ASceneAssetLoader))] [assembly: TypeForwardedTo(typeof(ASceneSetupInstruction))] [assembly: TypeForwardedTo(typeof(AssetBundleCollection))] [assembly: TypeForwardedTo(typeof(AssetBundleLibrary))] [assembly: TypeForwardedTo(typeof(Assets))] [assembly: TypeForwardedTo(typeof(AssetsToLoadData))] [assembly: TypeForwardedTo(typeof(AssetsToLoadDataLibrary))] [assembly: TypeForwardedTo(typeof(AStorage))] [assembly: TypeForwardedTo(typeof(AsyncState))] [assembly: TypeForwardedTo(typeof(ATextMeshProFormatter))] [assembly: TypeForwardedTo(typeof(ATransaction))] [assembly: TypeForwardedTo(typeof(AudioAmbienceTrigger))] [assembly: TypeForwardedTo(typeof(AudioAmbienceZone))] [assembly: TypeForwardedTo(typeof(AudioAnalyzer))] [assembly: TypeForwardedTo(typeof(AudioChannelID))] [assembly: TypeForwardedTo(typeof(AudioClipFilterAttribute))] [assembly: TypeForwardedTo(typeof(AudioClipID))] [assembly: TypeForwardedTo(typeof(AudioManager))] [assembly: TypeForwardedTo(typeof(AudioRectangularReverb))] [assembly: TypeForwardedTo(typeof(AudioSettings))] [assembly: TypeForwardedTo(typeof(AudioSourceID))] [assembly: TypeForwardedTo(typeof(AudioSubSystem))] [assembly: TypeForwardedTo(typeof(AUnlockable))] [assembly: TypeForwardedTo(typeof(AUser))] [assembly: TypeForwardedTo(typeof(AUserSaveDataLoader))] [assembly: TypeForwardedTo(typeof(AutoPlayLoop))] [assembly: TypeForwardedTo(typeof(BannerSpin))] [assembly: TypeForwardedTo(typeof(BaseGroundDetection))] [assembly: TypeForwardedTo(typeof(BaseMenuTimelineBehaviour))] [assembly: TypeForwardedTo(typeof(BaseModule))] [assembly: TypeForwardedTo(typeof(BaseMoveHandler))] [assembly: TypeForwardedTo(typeof(BasePhotoObjective))] [assembly: TypeForwardedTo(typeof(BasicCop))] [assembly: TypeForwardedTo(typeof(BasicCopAnimInfo))] [assembly: TypeForwardedTo(typeof(BasicEnemy))] [assembly: TypeForwardedTo(typeof(BasicEnemySpawner))] [assembly: TypeForwardedTo(typeof(BasketballAchievement))] [assembly: TypeForwardedTo(typeof(Battle))] [assembly: TypeForwardedTo(typeof(Bird))] [assembly: TypeForwardedTo(typeof(BirdAchievement))] [assembly: TypeForwardedTo(typeof(BirdBehaviour))] [assembly: TypeForwardedTo(typeof(BlackBarBehaviour))] [assembly: TypeForwardedTo(typeof(BlackBarClip))] [assembly: TypeForwardedTo(typeof(BlackBarTrack))] [assembly: TypeForwardedTo(typeof(BMXOnlyGateway))] [assembly: TypeForwardedTo(typeof(BoostAbility))] [assembly: TypeForwardedTo(typeof(BoosterAchievementsTracker))] [assembly: TypeForwardedTo(typeof(BoosterEvent))] [assembly: TypeForwardedTo(typeof(BoosterStats))] [assembly: TypeForwardedTo(typeof(BoostpackEffectMode))] [assembly: TypeForwardedTo(typeof(Bootstrap))] [assembly: TypeForwardedTo(typeof(BouncingBoxWidget))] [assembly: TypeForwardedTo(typeof(BoxGroundDetection))] [assembly: TypeForwardedTo(typeof(BoxSide))] [assembly: TypeForwardedTo(typeof(BreakableObject))] [assembly: TypeForwardedTo(typeof(Buffer<>))] [assembly: TypeForwardedTo(typeof(Bullet))] [assembly: TypeForwardedTo(typeof(Bundle))] [assembly: TypeForwardedTo(typeof(ButtonSpriteData))] [assembly: TypeForwardedTo(typeof(ButtonSpriteDictionary))] [assembly: TypeForwardedTo(typeof(CameraExtensions))] [assembly: TypeForwardedTo(typeof(CameraMode))] [assembly: TypeForwardedTo(typeof(CameraModeDrag))] [assembly: TypeForwardedTo(typeof(CameraModeGrind))] [assembly: TypeForwardedTo(typeof(CameraModeHandplant))] [assembly: TypeForwardedTo(typeof(CameraModeLock))] [assembly: TypeForwardedTo(typeof(CameraModeVert))] [assembly: TypeForwardedTo(typeof(CameraModeWallrun))] [assembly: TypeForwardedTo(typeof(CameraModeZone))] [assembly: TypeForwardedTo(typeof(CameraRegisterer))] [assembly: TypeForwardedTo(typeof(CameraShakeBehaviour))] [assembly: TypeForwardedTo(typeof(CameraShakeClip))] [assembly: TypeForwardedTo(typeof(CameraShakeComponent))] [assembly: TypeForwardedTo(typeof(CameraShakeTrack))] [assembly: TypeForwardedTo(typeof(CameraUtility))] [assembly: TypeForwardedTo(typeof(CameraZone))] [assembly: TypeForwardedTo(typeof(CameraZoneMode))] [assembly: TypeForwardedTo(typeof(Car))] [assembly: TypeForwardedTo(typeof(CarsMoveHandler))] [assembly: TypeForwardedTo(typeof(CarVisualAudio))] [assembly: TypeForwardedTo(typeof(Category))] [assembly: TypeForwardedTo(typeof(CaughtAbility))] [assembly: TypeForwardedTo(typeof(ChapterMusic))] [assembly: TypeForwardedTo(typeof(CharacterConstructor))] [assembly: TypeForwardedTo(typeof(CharacterLoader))] [assembly: TypeForwardedTo(typeof(CharacterNamePickerAttribute))] [assembly: TypeForwardedTo(typeof(CharacterProgress))] [assembly: TypeForwardedTo(typeof(Characters))] [assembly: TypeForwardedTo(typeof(CharacterSelect))] [assembly: TypeForwardedTo(typeof(CharacterSelectAbility))] [assembly: TypeForwardedTo(typeof(CharacterSelectCharacter))] [assembly: TypeForwardedTo(typeof(CharacterSelectSpot))] [assembly: TypeForwardedTo(typeof(CharacterSelectUI))] [assembly: TypeForwardedTo(typeof(CharacterVisual))] [assembly: TypeForwardedTo(typeof(Collectable))] [assembly: TypeForwardedTo(typeof(CollectableProgress))] [assembly: TypeForwardedTo(typeof(CombatEncounter))] [assembly: TypeForwardedTo(typeof(ComboEncounter))] [assembly: TypeForwardedTo(typeof(ComboMascot))] [assembly: TypeForwardedTo(typeof(ComboMascotSystem))] [assembly: TypeForwardedTo(typeof(ComparerHash))] [assembly: TypeForwardedTo(typeof(ComponentExtensions))] [assembly: TypeForwardedTo(typeof(CompressedGameSaveDataSerializer))] [assembly: TypeForwardedTo(typeof(ContainerExtensions))] [assembly: TypeForwardedTo(typeof(ControllerGuidHandlerFactory))] [assembly: TypeForwardedTo(typeof(CopAnimInfo))] [assembly: TypeForwardedTo(typeof(CopterCop))] [assembly: TypeForwardedTo(typeof(CopterCopAnimInfo))] [assembly: TypeForwardedTo(typeof(CopterCopSpawner))] [assembly: TypeForwardedTo(typeof(Core))] [assembly: TypeForwardedTo(typeof(CorruptedDataLoadError))] [assembly: TypeForwardedTo(typeof(CorruptedDataSaveError))] [assembly: TypeForwardedTo(typeof(CorruptedSaveSlotLoadError))] [assembly: TypeForwardedTo(typeof(CreditsManager))] [assembly: TypeForwardedTo(typeof(Crew))] [assembly: TypeForwardedTo(typeof(CuffMissileEnemy))] [assembly: TypeForwardedTo(typeof(CuffMissileLauncher))] [assembly: TypeForwardedTo(typeof(CutsceneAudioTrack))] [assembly: TypeForwardedTo(typeof(CutsceneCameraFollowTempRacer))] [assembly: TypeForwardedTo(typeof(DanceAbility))] [assembly: TypeForwardedTo(typeof(DanceAbilityUI))] [assembly: TypeForwardedTo(typeof(DanceAbilityUIButton))] [assembly: TypeForwardedTo(typeof(Dances))] [assembly: TypeForwardedTo(typeof(DataSerializerFactory))] [assembly: TypeForwardedTo(typeof(DeactivateOnAwake))] [assembly: TypeForwardedTo(typeof(DebugConsoleTextAreaHandler))] [assembly: TypeForwardedTo(typeof(DebugMenuController))] [assembly: TypeForwardedTo(typeof(DebugUtility))] [assembly: TypeForwardedTo(typeof(DefaultIndexQueue))] [assembly: TypeForwardedTo(typeof(DeleteTransaction))] [assembly: TypeForwardedTo(typeof(DelimiterMatcher))] [assembly: TypeForwardedTo(typeof(DelimiterRegexFormatterData))] [assembly: TypeForwardedTo(typeof(DestroyWhenOutOfView))] [assembly: TypeForwardedTo(typeof(DialogueBehaviour))] [assembly: TypeForwardedTo(typeof(DialogueClip))] [assembly: TypeForwardedTo(typeof(DialogueTrack))] [assembly: TypeForwardedTo(typeof(DialogueUI))] [assembly: TypeForwardedTo(typeof(DieAbility))] [assembly: TypeForwardedTo(typeof(DieMenu))] [assembly: TypeForwardedTo(typeof(DirectoryCreateTransaction))] [assembly: TypeForwardedTo(typeof(DirectoryInfoTransaction))] [assembly: TypeForwardedTo(typeof(DJBoss))] [assembly: TypeForwardedTo(typeof(DJBossAnimInfo))] [assembly: TypeForwardedTo(typeof(DJBossJumper))] [assembly: TypeForwardedTo(typeof(DJCollider))] [assembly: TypeForwardedTo(typeof(DownloadableContentEditor))] [assembly: TypeForwardedTo(typeof(DownloadableContentItem))] [assembly: TypeForwardedTo(typeof(DownloadableContentLibrary))] [assembly: TypeForwardedTo(typeof(DownloadableContentSteam))] [assembly: TypeForwardedTo(typeof(DownloadableContentWindows))] [assembly: TypeForwardedTo(typeof(DreamEncounter))] [assembly: TypeForwardedTo(typeof(DummyAnimationEventRelay))] [assembly: TypeForwardedTo(typeof(DumpFileGenerator))] [assembly: TypeForwardedTo(typeof(DynamicJunk))] [assembly: TypeForwardedTo(typeof(DynamicJunkUpdater))] [assembly: TypeForwardedTo(typeof(DynamicPickup))] [assembly: TypeForwardedTo(typeof(DynamicRepPickup))] [assembly: TypeForwardedTo(typeof(EffectsUI))] [assembly: TypeForwardedTo(typeof(EmptyError))] [assembly: TypeForwardedTo(typeof(Encounter))] [assembly: TypeForwardedTo(typeof(EncounterProgress))] [assembly: TypeForwardedTo(typeof(EnemyAnimationEventRelay))] [assembly: TypeForwardedTo(typeof(EnemyAnimations))] [assembly: TypeForwardedTo(typeof(EnemyAnimInfos))] [assembly: TypeForwardedTo(typeof(EnemyExtension))] [assembly: TypeForwardedTo(typeof(EnemyFirearm))] [assembly: TypeForwardedTo(typeof(EnemyGraffitiSpotDamager))] [assembly: TypeForwardedTo(typeof(EnemyGrindLines))] [assembly: TypeForwardedTo(typeof(EnemyHitResponse))] [assembly: TypeForwardedTo(typeof(EnemyLockOnAiming))] [assembly: TypeForwardedTo(typeof(EnemyMeleeWeapon))] [assembly: TypeForwardedTo(typeof(EnemyNavmeshMovement))] [assembly: TypeForwardedTo(typeof(EnemyPositioningInfo))] [assembly: TypeForwardedTo(typeof(EnemyShield))] [assembly: TypeForwardedTo(typeof(EnemySpawnAdds))] [assembly: TypeForwardedTo(typeof(EnemySpawnReplacement))] [assembly: TypeForwardedTo(typeof(EnemyStopMoveAlongPoints))] [assembly: TypeForwardedTo(typeof(EnemyTargetabilityAiming))] [assembly: TypeForwardedTo(typeof(EnemyTargets))] [assembly: TypeForwardedTo(typeof(EnemyType))] [assembly: TypeForwardedTo(typeof(EnemyVelocityAiming))] [assembly: TypeForwardedTo(typeof(EnemyVoices))] [assembly: TypeForwardedTo(typeof(ErrorHandlerFinishedDelegate))] [assembly: TypeForwardedTo(typeof(ErrorHandlingResult))] [assembly: TypeForwardedTo(typeof(ErrorQueue))] [assembly: TypeForwardedTo(typeof(ErrorYieldInstruction))] [assembly: TypeForwardedTo(typeof(ExplosionMaterialData))] [assembly: TypeForwardedTo(typeof(Explosive))] [assembly: TypeForwardedTo(typeof(ExtraBoneInfo))] [assembly: TypeForwardedTo(typeof(Extrusion))] [assembly: TypeForwardedTo(typeof(FadeBehaviour))] [assembly: TypeForwardedTo(typeof(FadeClip))] [assembly: TypeForwardedTo(typeof(FadeTrack))] [assembly: TypeForwardedTo(typeof(FinalBossAchievement))] [assembly: TypeForwardedTo(typeof(FixedFramerateSequence))] [assembly: TypeForwardedTo(typeof(FlipOutJumpAbility))] [assembly: TypeForwardedTo(typeof(FloorIsLavaEncounter))] [assembly: TypeForwardedTo(typeof(FodsCharacterNamesParser))] [assembly: TypeForwardedTo(typeof(FodsCreditsParser))] [assembly: TypeForwardedTo(typeof(FodsDialogueParser))] [assembly: TypeForwardedTo(typeof(FodsDocumentLoader))] [assembly: TypeForwardedTo(typeof(FodsLocalizationFileReader))] [assembly: TypeForwardedTo(typeof(FodsObjectiveTextParser))] [assembly: TypeForwardedTo(typeof(FodsStageNamesParser))] [assembly: TypeForwardedTo(typeof(FodsTable))] [assembly: TypeForwardedTo(typeof(FodsTextLocalizationParser))] [assembly: TypeForwardedTo(typeof(FodsTextSizeLocalizationParser))] [assembly: TypeForwardedTo(typeof(FormatterData))] [assembly: TypeForwardedTo(typeof(FormattingUtility))] [assembly: TypeForwardedTo(typeof(FortuneCookie))] [assembly: TypeForwardedTo(typeof(FortuneRare))] [assembly: TypeForwardedTo(typeof(FrictionEffectMode))] [assembly: TypeForwardedTo(typeof(GameDebugDummy))] [assembly: TypeForwardedTo(typeof(GameFontType))] [assembly: TypeForwardedTo(typeof(GameInput))] [assembly: TypeForwardedTo(typeof(GameNotificationUI))] [assembly: TypeForwardedTo(typeof(GameParameters))] [assembly: TypeForwardedTo(typeof(GameplayCamera))] [assembly: TypeForwardedTo(typeof(GameplayEvent))] [assembly: TypeForwardedTo(typeof(GameplaySettings))] [assembly: TypeForwardedTo(typeof(GameplayUI))] [assembly: TypeForwardedTo(typeof(GamePrefabLoader))] [assembly: TypeForwardedTo(typeof(GameVersion))] [assembly: TypeForwardedTo(typeof(GassBarrier))] [assembly: TypeForwardedTo(typeof(GenericStats<, >))] [assembly: TypeForwardedTo(typeof(GraffitiAchievementsTracker))] [assembly: TypeForwardedTo(typeof(GraffitiArt))] [assembly: TypeForwardedTo(typeof(GraffitiArtInfo))] [assembly: TypeForwardedTo(typeof(GraffitiCollectableVisual))] [assembly: TypeForwardedTo(typeof(GraffitiEffect))] [assembly: TypeForwardedTo(typeof(GraffitiEvent))] [assembly: TypeForwardedTo(typeof(GraffitiGame))] [assembly: TypeForwardedTo(typeof(GraffitiInfoPanel))] [assembly: TypeForwardedTo(typeof(GraffitiLoader))] [assembly: TypeForwardedTo(typeof(GraffitiSize))] [assembly: TypeForwardedTo(typeof(GraffitiSpot))] [assembly: TypeForwardedTo(typeof(GraffitiSpotFinisher))] [assembly: TypeForwardedTo(typeof(GraffitiSpotProgress))] [assembly: TypeForwardedTo(typeof(GraffitiState))] [assembly: TypeForwardedTo(typeof(GraffitiStats))] [assembly: TypeForwardedTo(typeof(GraphicsStatusHandler))] [assembly: TypeForwardedTo(typeof(GrindAbility))] [assembly: TypeForwardedTo(typeof(GrindLine))] [assembly: TypeForwardedTo(typeof(GrindLineAnimate))] [assembly: TypeForwardedTo(typeof(GrindNode))] [assembly: TypeForwardedTo(typeof(GrindNodeAnimate))] [assembly: TypeForwardedTo(typeof(GrindPath))] [assembly: TypeForwardedTo(typeof(GroundDetection))] [assembly: TypeForwardedTo(typeof(GroundHit))] [assembly: TypeForwardedTo(typeof(GroundTrickAbility))] [assembly: TypeForwardedTo(typeof(GroupOptions))] [assembly: TypeForwardedTo(typeof(HackerText))] [assembly: TypeForwardedTo(typeof(HandplantAbility))] [assembly: TypeForwardedTo(typeof(HeadspinAbility))] [assembly: TypeForwardedTo(typeof(HitBounceAbility))] [assembly: TypeForwardedTo(typeof(HitDir))] [assembly: TypeForwardedTo(typeof(HomeScreenApp))] [assembly: TypeForwardedTo(typeof(IAudioSubSystem))] [assembly: TypeForwardedTo(typeof(ICollectionGenerator))] [assembly: TypeForwardedTo(typeof(IDataSerializer))] [assembly: TypeForwardedTo(typeof(IEditorGameTextLocalizer))] [assembly: TypeForwardedTo(typeof(IError))] [assembly: TypeForwardedTo(typeof(IGameTextFormatter))] [assembly: TypeForwardedTo(typeof(IGameTextLocalizer))] [assembly: TypeForwardedTo(typeof(IInitializableSceneObject))] [assembly: TypeForwardedTo(typeof(IInterruptable))] [assembly: TypeForwardedTo(typeof(ILocalizationFileLoader))] [assembly: TypeForwardedTo(typeof(ILocalizationFileParser))] [assembly: TypeForwardedTo(typeof(ILocalizationFileReader))] [assembly: TypeForwardedTo(typeof(IMenuAnimationTransitionController))] [assembly: TypeForwardedTo(typeof(IMultiTransactionHandler))] [assembly: TypeForwardedTo(typeof(IMusicLibraryPlayer))] [assembly: TypeForwardedTo(typeof(IMusicPlayer))] [assembly: TypeForwardedTo(typeof(IncorrectFormatException))] [assembly: TypeForwardedTo(typeof(InputControllerGuidData))] [assembly: TypeForwardedTo(typeof(InputSelectionRowController))] [assembly: TypeForwardedTo(typeof(InputSettings))] [assembly: TypeForwardedTo(typeof(InstanceAnimationInstanceInfo))] [assembly: TypeForwardedTo(typeof(InstanceData))] [assembly: TypeForwardedTo(typeof(InstancingPackage))] [assembly: TypeForwardedTo(typeof(InverseKinematicsRelay))] [assembly: TypeForwardedTo(typeof(IOUtility))] [assembly: TypeForwardedTo(typeof(IPoolable))] [assembly: TypeForwardedTo(typeof(IRegexPatternCreator))] [assembly: TypeForwardedTo(typeof(IRewiredControllerGuidHandler))] [assembly: TypeForwardedTo(typeof(ISaveable))] [assembly: TypeForwardedTo(typeof(ISceneAssetLoader))] [assembly: TypeForwardedTo(typeof(ISubsystem))] [assembly: TypeForwardedTo(typeof(ITextFormatter))] [assembly: TypeForwardedTo(typeof(ITextMatcher))] [assembly: TypeForwardedTo(typeof(ITextSelectable))] [assembly: TypeForwardedTo(typeof(ITransactionError))] [assembly: TypeForwardedTo(typeof(IUIElement))] [assembly: TypeForwardedTo(typeof(IUIMenuController))] [assembly: TypeForwardedTo(typeof(IUserId))] [assembly: TypeForwardedTo(typeof(IUserSaveDataLoader))] [assembly: TypeForwardedTo(typeof(Junk))] [assembly: TypeForwardedTo(typeof(JunkBehaviour))] [assembly: TypeForwardedTo(typeof(JunkHolder))] [assembly: TypeForwardedTo(typeof(JunkStageHandler))] [assembly: TypeForwardedTo(typeof(KnockbackAbility))] [assembly: TypeForwardedTo(typeof(Layers))] [assembly: TypeForwardedTo(typeof(Layout))] [assembly: TypeForwardedTo(typeof(LayoutManagerRuleSet))] [assembly: TypeForwardedTo(typeof(LedgeClimbAbility))] [assembly: TypeForwardedTo(typeof(LoadingScreenUI))] [assembly: TypeForwardedTo(typeof(LoadSceneASyncInstruction))] [assembly: TypeForwardedTo(typeof(LoadSceneInstruction))] [assembly: TypeForwardedTo(typeof(LoadStageASyncInstruction))] [assembly: TypeForwardedTo(typeof(LoadTransaction<>))] [assembly: TypeForwardedTo(typeof(LocalizationData))] [assembly: TypeForwardedTo(typeof(LocalizationGroup))] [assembly: TypeForwardedTo(typeof(LocalizationKeyValuePair))] [assembly: TypeForwardedTo(typeof(LocalizationLookupTable))] [assembly: TypeForwardedTo(typeof(LocalizationNameFont))] [assembly: TypeForwardedTo(typeof(LocalizationTableGenerator))] [assembly: TypeForwardedTo(typeof(LocalizedTMProText))] [assembly: TypeForwardedTo(typeof(LodInfo))] [assembly: TypeForwardedTo(typeof(LogEntry))] [assembly: TypeForwardedTo(typeof(Logger))] [assembly: TypeForwardedTo(typeof(LookAtIKBehaviour))] [assembly: TypeForwardedTo(typeof(LookAtIKClip))] [assembly: TypeForwardedTo(typeof(LookAtIKComponent))] [assembly: TypeForwardedTo(typeof(LookAtIKMixerBehaviour))] [assembly: TypeForwardedTo(typeof(LookAtIKTrack))] [assembly: TypeForwardedTo(typeof(MainMenuManager))] [assembly: TypeForwardedTo(typeof(Map))] [assembly: TypeForwardedTo(typeof(Mapcontroller))] [assembly: TypeForwardedTo(typeof(MapPin))] [assembly: TypeForwardedTo(typeof(MaterialBlock))] [assembly: TypeForwardedTo(typeof(Menu))] [assembly: TypeForwardedTo(typeof(MenuNavigationController))] [assembly: TypeForwardedTo(typeof(MenuTimelineButton))] [assembly: TypeForwardedTo(typeof(MissileEnemy))] [assembly: TypeForwardedTo(typeof(MissionPhotoObjective))] [assembly: TypeForwardedTo(typeof(MouseLook))] [assembly: TypeForwardedTo(typeof(MoveAlongHandler))] [assembly: TypeForwardedTo(typeof(MoveAlongPoints))] [assembly: TypeForwardedTo(typeof(MoveAlongPoints_Hot))] [assembly: TypeForwardedTo(typeof(MovementMotor))] [assembly: TypeForwardedTo(typeof(MovementStats))] [assembly: TypeForwardedTo(typeof(MoveObject))] [assembly: TypeForwardedTo(typeof(MoverLOD))] [assembly: TypeForwardedTo(typeof(MoveStyle))] [assembly: TypeForwardedTo(typeof(MoveStyleCollectableVisuals))] [assembly: TypeForwardedTo(typeof(MoveStyleLoader))] [assembly: TypeForwardedTo(typeof(MoveStyleSkin))] [assembly: TypeForwardedTo(typeof(MovingPlatform))] [assembly: TypeForwardedTo(typeof(MultiOptionButton))] [assembly: TypeForwardedTo(typeof(MusicAssetsLoader))] [assembly: TypeForwardedTo(typeof(MusicBundle))] [assembly: TypeForwardedTo(typeof(MusicLibrary))] [assembly: TypeForwardedTo(typeof(MusicLibraryPlayer))] [assembly: TypeForwardedTo(typeof(MusicPlayer))] [assembly: TypeForwardedTo(typeof(MusicPlayerBuffer))] [assembly: TypeForwardedTo(typeof(MusicPlayerData))] [assembly: TypeForwardedTo(typeof(MusicTimelineBehaviour))] [assembly: TypeForwardedTo(typeof(MusicTimelineClip))] [assembly: TypeForwardedTo(typeof(MusicTimelineMixer))] [assembly: TypeForwardedTo(typeof(MusicTimelineTrack))] [assembly: TypeForwardedTo(typeof(MusicTrack))] [assembly: TypeForwardedTo(typeof(MusicTrackDictionary))] [assembly: TypeForwardedTo(typeof(MusicTrackID))] [assembly: TypeForwardedTo(typeof(MusicTrackIDComparer))] [assembly: TypeForwardedTo(typeof(MusicTrackQueue))] [assembly: TypeForwardedTo(typeof(NoAccessToDataError))] [assembly: TypeForwardedTo(typeof(NoBundleFoundException))] [assembly: TypeForwardedTo(typeof(NoDiskSpaceSaveError))] [assembly: TypeForwardedTo(typeof(NoModelException))] [assembly: TypeForwardedTo(typeof(NonPlayerAnimationEventRelay))] [assembly: TypeForwardedTo(typeof(NoOutfitException))] [assembly: TypeForwardedTo(typeof(NotificationTextAsset))] [assembly: TypeForwardedTo(typeof(NPC))] [assembly: TypeForwardedTo(typeof(NPCProgress))] [assembly: TypeForwardedTo(typeof(ObjectProgress))] [assembly: TypeForwardedTo(typeof(OneOffVisualEffect))] [assembly: TypeForwardedTo(typeof(OnGSpotStateChanged))] [assembly: TypeForwardedTo(typeof(OnLanguageChangedHandler))] [assembly: TypeForwardedTo(typeof(OnMultiOptionsUIChangedEvent))] [assembly: TypeForwardedTo(typeof(OnSliderValueChangedEvent))] [assembly: TypeForwardedTo(typeof(OptionsMenu))] [assembly: TypeForwardedTo(typeof(OptionsMenuAudioTab))] [assembly: TypeForwardedTo(typeof(OptionsMenuGameTab))] [assembly: TypeForwardedTo(typeof(OptionsMenuInputTab))] [assembly: TypeForwardedTo(typeof(OptionsMenuVideoTab))] [assembly: TypeForwardedTo(typeof(OptionsSliderButton))] [assembly: TypeForwardedTo(typeof(OutfitSwappableCharacter))] [assembly: TypeForwardedTo(typeof(OutfitSwitchBehaviour))] [assembly: TypeForwardedTo(typeof(OutfitSwitchClip))] [assembly: TypeForwardedTo(typeof(OutfitSwitchMenu))] [assembly: TypeForwardedTo(typeof(OutfitSwitchTrack))] [assembly: TypeForwardedTo(typeof(OutfitUnlockable))] [assembly: TypeForwardedTo(typeof(Overlay))] [assembly: TypeForwardedTo(typeof(PauseMenu))] [assembly: TypeForwardedTo(typeof(PauseType))] [assembly: TypeForwardedTo(typeof(Pedestrian))] [assembly: TypeForwardedTo(typeof(PhonePictureData))] [assembly: TypeForwardedTo(typeof(PhotoAchievementTracker))] [assembly: TypeForwardedTo(typeof(PhotoButton))] [assembly: TypeForwardedTo(typeof(PhotoEvent))] [assembly: TypeForwardedTo(typeof(PhotoObjectiveProgressable))] [assembly: TypeForwardedTo(typeof(PhotoObjectProgress))] [assembly: TypeForwardedTo(typeof(PhotosAlbumMenu))] [assembly: TypeForwardedTo(typeof(PhotosManager))] [assembly: TypeForwardedTo(typeof(PhotoStats))] [assembly: TypeForwardedTo(typeof(PhotoViewScrollArea))] [assembly: TypeForwardedTo(typeof(Pickup))] [assembly: TypeForwardedTo(typeof(PlatformData))] [assembly: TypeForwardedTo(typeof(PlatformLanguages))] [assembly: TypeForwardedTo(typeof(PlatformSteam))] [assembly: TypeForwardedTo(typeof(PlayAudioOnEnable))] [assembly: TypeForwardedTo(typeof(Player))] [assembly: TypeForwardedTo(typeof(PlayerAchievements))] [assembly: TypeForwardedTo(typeof(PlayerAI))] [assembly: TypeForwardedTo(typeof(PlayerAIPath))] [assembly: TypeForwardedTo(typeof(PlayerAIWaypoint))] [assembly: TypeForwardedTo(typeof(PlayerCuff))] [assembly: TypeForwardedTo(typeof(PlayerIK))] [assembly: TypeForwardedTo(typeof(PlayerLogInputThing))] [assembly: TypeForwardedTo(typeof(PlayerMoveStyleProps))] [assembly: TypeForwardedTo(typeof(PlayerPhoneCameras))] [assembly: TypeForwardedTo(typeof(PlayerSpawner))] [assembly: TypeForwardedTo(typeof(PlayerStats))] [assembly: TypeForwardedTo(typeof(PlayerType))] [assembly: TypeForwardedTo(typeof(PlayerVisualEffects))] [assembly: TypeForwardedTo(typeof(Playlist))] [assembly: TypeForwardedTo(typeof(PlayListDictionary))] [assembly: TypeForwardedTo(typeof(PlaylistID))] [assembly: TypeForwardedTo(typeof(PlaylistIDComparer))] [assembly: TypeForwardedTo(typeof(PlaystationFiveBootstrap))] [assembly: TypeForwardedTo(typeof(PoliceCaptainIrene))] [assembly: TypeForwardedTo(typeof(PoliceCaptainIreneAnimInfo))] [assembly: TypeForwardedTo(typeof(PoliceCaptainSniper))] [assembly: TypeForwardedTo(typeof(PoliceCutscenes))] [assembly: TypeForwardedTo(typeof(PoliceTubeSpawner))] [assembly: TypeForwardedTo(typeof(PoliceWall))] [assembly: TypeForwardedTo(typeof(PoolableInstantiator))] [assembly: TypeForwardedTo(typeof(PoolableObjectToName))] [assembly: TypeForwardedTo(typeof(PoolableParticleEffects))] [assembly: TypeForwardedTo(typeof(PoolableState))] [assembly: TypeForwardedTo(typeof(PostProssesing))] [assembly: TypeForwardedTo(typeof(PreludeMusicStopper))] [assembly: TypeForwardedTo(typeof(ProgressableData))] [assembly: TypeForwardedTo(typeof(ProgressableDataFactory))] [assembly: TypeForwardedTo(typeof(ProgressableType))] [assembly: TypeForwardedTo(typeof(ProgressObject))] [assembly: TypeForwardedTo(typeof(Projectile))] [assembly: TypeForwardedTo(typeof(PromptButton))] [assembly: TypeForwardedTo(typeof(ProximityMine))] [assembly: TypeForwardedTo(typeof(PseudoGraffitiAbility))] [assembly: TypeForwardedTo(typeof(PublicToilet))] [assembly: TypeForwardedTo(typeof(QuickTurnAbility))] [assembly: TypeForwardedTo(typeof(RaceEncounter))] [assembly: TypeForwardedTo(typeof(RailRider))] [assembly: TypeForwardedTo(typeof(RailRiderLauncher))] [assembly: TypeForwardedTo(typeof(RateLimitWatcher))] [assembly: TypeForwardedTo(typeof(RawDataSerializer))] [assembly: TypeForwardedTo(typeof(RaycastGroundDetection))] [assembly: TypeForwardedTo(typeof(RecoverAbility))] [assembly: TypeForwardedTo(typeof(RegexGameTextFormatter))] [assembly: TypeForwardedTo(typeof(RegularErrorHandler))] [assembly: TypeForwardedTo(typeof(RenameFileTransaction))] [assembly: TypeForwardedTo(typeof(RestrictedArea))] [assembly: TypeForwardedTo(typeof(RewiredControllerGuidHandler))] [assembly: TypeForwardedTo(typeof(RewiredControllerHandler))] [assembly: TypeForwardedTo(typeof(RewiredInputUIActionBinder))] [assembly: TypeForwardedTo(typeof(RewiredMappingHandler))] [assembly: TypeForwardedTo(typeof(RewiredPlayerId))] [assembly: TypeForwardedTo(typeof(RewiredRemappingHandler))] [assembly: TypeForwardedTo(typeof(RewiredStructUtility))] [assembly: TypeForwardedTo(typeof(RewiredUtility))] [assembly: TypeForwardedTo(typeof(RigidbodyMoveAlongHandler))] [assembly: TypeForwardedTo(typeof(RotateObject))] [assembly: TypeForwardedTo(typeof(RuntimeHelper))] [assembly: TypeForwardedTo(typeof(SafeLocation))] [assembly: TypeForwardedTo(typeof(SaveDataUtility))] [assembly: TypeForwardedTo(typeof(SaveManager))] [assembly: TypeForwardedTo(typeof(SaveSettingsData))] [assembly: TypeForwardedTo(typeof(SaveSlotData))] [assembly: TypeForwardedTo(typeof(SaveSlotHandler))] [assembly: TypeForwardedTo(typeof(SaveSlotMenu))] [assembly: TypeForwardedTo(typeof(SaveTransaction<>))] [assembly: TypeForwardedTo(typeof(SceneExtensions))] [assembly: TypeForwardedTo(typeof(SceneInspector))] [assembly: TypeForwardedTo(typeof(SceneLibrary))] [assembly: TypeForwardedTo(typeof(SceneLoader))] [assembly: TypeForwardedTo(typeof(SceneObjectsRegister))] [assembly: TypeForwardedTo(typeof(ScoreEncounter))] [assembly: TypeForwardedTo(typeof(ScreenShakeType))] [assembly: TypeForwardedTo(typeof(SelectEnlargeButton))] [assembly: TypeForwardedTo(typeof(SequenceHandler))] [assembly: TypeForwardedTo(typeof(SequenceState))] [assembly: TypeForwardedTo(typeof(SerializableDictionary<, >))] [assembly: TypeForwardedTo(typeof(SerializedLibraryUtility))] [assembly: TypeForwardedTo(typeof(setclearflag))] [assembly: TypeForwardedTo(typeof(SettingsData))] [assembly: TypeForwardedTo(typeof(SettingsMultiOptionsUI))] [assembly: TypeForwardedTo(typeof(SettingsSliderUI))] [assembly: TypeForwardedTo(typeof(SfxApplyAttribute))] [assembly: TypeForwardedTo(typeof(SfxClip))] [assembly: TypeForwardedTo(typeof(SfxCollection))] [assembly: TypeForwardedTo(typeof(SfxCollectionDictionary))] [assembly: TypeForwardedTo(typeof(SfxCollectionID))] [assembly: TypeForwardedTo(typeof(SfxCollectionLoader))] [assembly: TypeForwardedTo(typeof(SfxCollectionPickerAttribute))] [assembly: TypeForwardedTo(typeof(SfxLibrary))] [assembly: TypeForwardedTo(typeof(SfxTimelineClip))] [assembly: TypeForwardedTo(typeof(ShieldCop))] [assembly: TypeForwardedTo(typeof(ShieldCopAnimInfo))] [assembly: TypeForwardedTo(typeof(ShuffleIndexQueue))] [assembly: TypeForwardedTo(typeof(Side))] [assembly: TypeForwardedTo(typeof(SinglePathMoveAlongHandler))] [assembly: TypeForwardedTo(typeof(SitAbility))] [assembly: TypeForwardedTo(typeof(SkateboardScrewPole))] [assembly: TypeForwardedTo(typeof(SkyboxRotate))] [assembly: TypeForwardedTo(typeof(SlideAbility))] [assembly: TypeForwardedTo(typeof(SlideButton))] [assembly: TypeForwardedTo(typeof(SnakeBossAnimationEventRelay))] [assembly: TypeForwardedTo(typeof(SnakeBossAnimInfo))] [assembly: TypeForwardedTo(typeof(SnakeBossChestImpactReceiver))] [assembly: TypeForwardedTo(typeof(SnakeBossNEW))] [assembly: TypeForwardedTo(typeof(SniperCop))] [assembly: TypeForwardedTo(typeof(SniperCopAnimInfo))] [assembly: TypeForwardedTo(typeof(SoloMoveAlongUpdater))] [assembly: TypeForwardedTo(typeof(SpecialAirAbility))] [assembly: TypeForwardedTo(typeof(SphereGroundDetection))] [assembly: TypeForwardedTo(typeof(SplashScreen))] [assembly: TypeForwardedTo(typeof(SplineBasedGrindLineGenerator))] [assembly: TypeForwardedTo(typeof(Stage))] [assembly: TypeForwardedTo(typeof(StageAchievements))] [assembly: TypeForwardedTo(typeof(StageAmbience))] [assembly: TypeForwardedTo(typeof(StageChunk))] [assembly: TypeForwardedTo(typeof(StageManager))] [assembly: TypeForwardedTo(typeof(StageProgress))] [assembly: TypeForwardedTo(typeof(StageTransition))] [assembly: TypeForwardedTo(typeof(StageTransitionProgress))] [assembly: TypeForwardedTo(typeof(StandbyAbility))] [assembly: TypeForwardedTo(typeof(StatTracker))] [assembly: TypeForwardedTo(typeof(StatTrackerInfo))] [assembly: TypeForwardedTo(typeof(StatTrackerMAX))] [assembly: TypeForwardedTo(typeof(StatTrackerMIN))] [assembly: TypeForwardedTo(typeof(StatTrackerREPLACE))] [assembly: TypeForwardedTo(typeof(StatTrackerSUM))] [assembly: TypeForwardedTo(typeof(Statusbar))] [assembly: TypeForwardedTo(typeof(SteamControllerGuidHandler))] [assembly: TypeForwardedTo(typeof(StorageSteam))] [assembly: TypeForwardedTo(typeof(Story))] [assembly: TypeForwardedTo(typeof(StoryBlinkAnimation))] [assembly: TypeForwardedTo(typeof(StoryManager))] [assembly: TypeForwardedTo(typeof(StoryObjectivePin))] [assembly: TypeForwardedTo(typeof(StreetLife))] [assembly: TypeForwardedTo(typeof(StreetLifeBehaviour))] [assembly: TypeForwardedTo(typeof(StreetLifeCluster))] [assembly: TypeForwardedTo(typeof(StreetLifeHot))] [assembly: TypeForwardedTo(typeof(StringExtensions))] [assembly: TypeForwardedTo(typeof(StyleSwitchBehaviour))] [assembly: TypeForwardedTo(typeof(StyleSwitchClip))] [assembly: TypeForwardedTo(typeof(StyleSwitchMenu))] [assembly: TypeForwardedTo(typeof(StyleSwitchResetTexture))] [assembly: TypeForwardedTo(typeof(StyleSwitchTrack))] [assembly: TypeForwardedTo(typeof(SunFlareGPU))] [assembly: TypeForwardedTo(typeof(SunGlare))] [assembly: TypeForwardedTo(typeof(SwirlSkyUpdater))] [assembly: TypeForwardedTo(typeof(SwitchCorruptedDataLoadError))] [assembly: TypeForwardedTo(typeof(SwitchCorruptedDataSaveError))] [assembly: TypeForwardedTo(typeof(SwitchCorruptedSaveSlotLoadError))] [assembly: TypeForwardedTo(typeof(SwitchErrorHandler))] [assembly: TypeForwardedTo(typeof(SwitchMoveStyleAbility))] [assembly: TypeForwardedTo(typeof(SwitchStageInstruction))] [assembly: TypeForwardedTo(typeof(SystemLanguageUtility))] [assembly: TypeForwardedTo(typeof(Tags))] [assembly: TypeForwardedTo(typeof(TalkAbility))] [assembly: TypeForwardedTo(typeof(TalkIcon))] [assembly: TypeForwardedTo(typeof(Tankwalker))] [assembly: TypeForwardedTo(typeof(TankwalkerAnimInfo))] [assembly: TypeForwardedTo(typeof(TargetVisual))] [assembly: TypeForwardedTo(typeof(Taxi))] [assembly: TypeForwardedTo(typeof(TaxiBehaviour))] [assembly: TypeForwardedTo(typeof(TaxiClip))] [assembly: TypeForwardedTo(typeof(TaxiTrack))] [assembly: TypeForwardedTo(typeof(TaxiUI))] [assembly: TypeForwardedTo(typeof(Teleport))] [assembly: TypeForwardedTo(typeof(TextMeshProBoldFormatter))] [assembly: TypeForwardedTo(typeof(TextMeshProButtonGlyphFormatter))] [assembly: TypeForwardedTo(typeof(TextMeshProButtonSpriteHandler))] [assembly: TypeForwardedTo(typeof(TextMeshProFont))] [assembly: TypeForwardedTo(typeof(TextMeshProGameTextLocalizer))] [assembly: TypeForwardedTo(typeof(TextMeshProHighlightFormatter))] [assembly: TypeForwardedTo(typeof(TextMeshProMenuButton))] [assembly: TypeForwardedTo(typeof(TextMeshProMenuButtonFont))] [assembly: TypeForwardedTo(typeof(TextMeshProNormalFormatter))] [assembly: TypeForwardedTo(typeof(TextMeshProSlider))] [assembly: TypeForwardedTo(typeof(TMProFontLocalizer))] [assembly: TypeForwardedTo(typeof(TMProLocalizationAddOn))] [assembly: TypeForwardedTo(typeof(TrackerType))] [assembly: TypeForwardedTo(typeof(TransactionsYieldInstruction))] [assembly: TypeForwardedTo(typeof(TransactionYieldInstruction))] [assembly: TypeForwardedTo(typeof(TransformExtentions))] [assembly: TypeForwardedTo(typeof(TransformMoveAlongHandler))] [assembly: TypeForwardedTo(typeof(TRInputId))] [assembly: TypeForwardedTo(typeof(TurretEnemy))] [assembly: TypeForwardedTo(typeof(TurretSpawner))] [assembly: TypeForwardedTo(typeof(UIAnimationController))] [assembly: TypeForwardedTo(typeof(UIButtonGlyphComponent))] [assembly: TypeForwardedTo(typeof(UILocalizationUtility))] [assembly: TypeForwardedTo(typeof(UIManager))] [assembly: TypeForwardedTo(typeof(UIPopup))] [assembly: TypeForwardedTo(typeof(UIPrompt))] [assembly: TypeForwardedTo(typeof(UnloadSceneInstruction))] [assembly: TypeForwardedTo(typeof(UnloadStageASyncInstruction))] [assembly: TypeForwardedTo(typeof(UnlockableSaveData))] [assembly: TypeForwardedTo(typeof(UpdateGraffitiOnOtherJuggledEnemies))] [assembly: TypeForwardedTo(typeof(UserAchievementsCacheLoader))] [assembly: TypeForwardedTo(typeof(UserIdSteam))] [assembly: TypeForwardedTo(typeof(UserInputHandler))] [assembly: TypeForwardedTo(typeof(UserPhotosDataLoader))] [assembly: TypeForwardedTo(typeof(UserPlayerStatsLoader))] [assembly: TypeForwardedTo(typeof(UserSaveSlotSaveDataLoader))] [assembly: TypeForwardedTo(typeof(UserSaveSlotSettingsDataLoader))] [assembly: TypeForwardedTo(typeof(UserSettingsSaveDataLoader))] [assembly: TypeForwardedTo(typeof(UserStatusHandler))] [assembly: TypeForwardedTo(typeof(UserSteam))] [assembly: TypeForwardedTo(typeof(Utility))] [assembly: TypeForwardedTo(typeof(VendingMachine))] [assembly: TypeForwardedTo(typeof(VersionUIHandler))] [assembly: TypeForwardedTo(typeof(VertAbility))] [assembly: TypeForwardedTo(typeof(VertexCache))] [assembly: TypeForwardedTo(typeof(VertShape))] [assembly: TypeForwardedTo(typeof(VideoSettings))] [assembly: TypeForwardedTo(typeof(VideoSettingsManager))] [assembly: TypeForwardedTo(typeof(VoicePriority))] [assembly: TypeForwardedTo(typeof(VoiceSfxTimelineClip))] [assembly: TypeForwardedTo(typeof(WallrunLine))] [assembly: TypeForwardedTo(typeof(WallrunLineAbility))] [assembly: TypeForwardedTo(typeof(WantedManager))] [assembly: TypeForwardedTo(typeof(WatermarkInitializer))] [assembly: TypeForwardedTo(typeof(WorldHandler))] [assembly: TypeForwardedTo(typeof(XmlHelper))] [assembly: TypeForwardedTo(typeof(YesNoButton))] [assembly: TypeForwardedTo(typeof(YesNoPanel))] [module: UnverifiableCode] [module: RefSafetyRules(11)] namespace Microsoft.CodeAnalysis { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] internal sealed class EmbeddedAttribute : Attribute { } } namespace System.Runtime.CompilerServices { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Module, AllowMultiple = false, Inherited = false)] internal sealed class RefSafetyRulesAttribute : Attribute { public readonly int Version; public RefSafetyRulesAttribute(int P_0) { Version = P_0; } } } namespace MapStation.Tools { public static class PluginInfo { public const string PLUGIN_GUID = "MapStation.Tools"; public const string PLUGIN_NAME = "MapStation.Tools"; public const string PLUGIN_VERSION = "1.0.0"; } } namespace MapStation.TypeForwarder.Dependencies { public class AssemblyDependencies { } } namespace System.Runtime.CompilerServices { [AttributeUsage(AttributeTargets.Assembly, AllowMultiple = true)] internal sealed class IgnoresAccessChecksToAttribute : Attribute { public IgnoresAccessChecksToAttribute(string assemblyName) { } } }
System.IO.Compression.dll
Decompiled a week ago
The result has been truncated due to the large size, download it to view full contents!
using System; using System.Buffers; using System.Collections.Generic; using System.Collections.ObjectModel; using System.Diagnostics; using System.Globalization; using System.IO.Compression; using System.Reflection; using System.Runtime.CompilerServices; using System.Runtime.InteropServices; using System.Security; using System.Security.Permissions; using System.Text; using System.Threading; using System.Threading.Tasks; using Microsoft.Win32.SafeHandles; using Unity; [assembly: CLSCompliant(true)] [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: AssemblyTitle("System.IO.Compression.dll")] [assembly: AssemblyDefaultAlias("System.IO.Compression.dll")] [assembly: AssemblyDescription("System.IO.Compression.dll")] [assembly: AssemblyCompany("Mono development team")] [assembly: AssemblyProduct("Mono Common Language Infrastructure")] [assembly: AssemblyCopyright("(c) Various Mono authors")] [assembly: AssemblyInformationalVersion("4.6.57.0")] [assembly: AssemblyFileVersion("4.6.57.0")] [assembly: AssemblyDelaySign(true)] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("4.0.0.0")] [assembly: TypeForwardedTo(typeof(CompressionLevel))] [assembly: TypeForwardedTo(typeof(CompressionMode))] [assembly: TypeForwardedTo(typeof(DeflateStream))] [assembly: TypeForwardedTo(typeof(GZipStream))] [module: UnverifiableCode] internal static class Interop { internal static class Brotli { [DllImport("__Internal")] internal static extern SafeBrotliDecoderHandle BrotliDecoderCreateInstance(IntPtr allocFunc, IntPtr freeFunc, IntPtr opaque); [DllImport("__Internal")] internal unsafe static extern int BrotliDecoderDecompressStream(SafeBrotliDecoderHandle state, ref IntPtr availableIn, byte** nextIn, ref IntPtr availableOut, byte** nextOut, out IntPtr totalOut); [DllImport("__Internal")] internal unsafe static extern bool BrotliDecoderDecompress(IntPtr availableInput, byte* inBytes, ref IntPtr availableOutput, byte* outBytes); [DllImport("__Internal")] internal static extern void BrotliDecoderDestroyInstance(IntPtr state); [DllImport("__Internal")] internal static extern bool BrotliDecoderIsFinished(SafeBrotliDecoderHandle state); [DllImport("__Internal")] internal static extern SafeBrotliEncoderHandle BrotliEncoderCreateInstance(IntPtr allocFunc, IntPtr freeFunc, IntPtr opaque); [DllImport("__Internal")] internal static extern bool BrotliEncoderSetParameter(SafeBrotliEncoderHandle state, BrotliEncoderParameter parameter, uint value); [DllImport("__Internal")] internal unsafe static extern bool BrotliEncoderCompressStream(SafeBrotliEncoderHandle state, BrotliEncoderOperation op, ref IntPtr availableIn, byte** nextIn, ref IntPtr availableOut, byte** nextOut, out IntPtr totalOut); [DllImport("__Internal")] internal static extern bool BrotliEncoderHasMoreOutput(SafeBrotliEncoderHandle state); [DllImport("__Internal")] internal static extern void BrotliEncoderDestroyInstance(IntPtr state); [DllImport("__Internal")] internal unsafe static extern bool BrotliEncoderCompress(int quality, int window, int v, IntPtr availableInput, byte* inBytes, ref IntPtr availableOutput, byte* outBytes); } internal static class Libraries { internal const string CompressionNative = "__Internal"; } } internal static class Consts { public const string MonoCorlibVersion = "1A5E0066-58DC-428A-B21C-0AD6CDAE2789"; public const string MonoVersion = "6.13.0.0"; public const string MonoCompany = "Mono development team"; public const string MonoProduct = "Mono Common Language Infrastructure"; public const string MonoCopyright = "(c) Various Mono authors"; public const string FxVersion = "4.0.0.0"; public const string FxFileVersion = "4.6.57.0"; public const string EnvironmentVersion = "4.0.30319.42000"; public const string VsVersion = "0.0.0.0"; public const string VsFileVersion = "11.0.0.0"; private const string PublicKeyToken = "b77a5c561934e089"; public const string AssemblyI18N = "I18N, Version=4.0.0.0, Culture=neutral, PublicKeyToken=0738eb9f132ed756"; public const string AssemblyMicrosoft_JScript = "Microsoft.JScript, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblyMicrosoft_VisualStudio = "Microsoft.VisualStudio, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblyMicrosoft_VisualStudio_Web = "Microsoft.VisualStudio.Web, Version=0.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblyMicrosoft_VSDesigner = "Microsoft.VSDesigner, Version=0.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblyMono_Http = "Mono.Http, Version=4.0.0.0, Culture=neutral, PublicKeyToken=0738eb9f132ed756"; public const string AssemblyMono_Posix = "Mono.Posix, Version=4.0.0.0, Culture=neutral, PublicKeyToken=0738eb9f132ed756"; public const string AssemblyMono_Security = "Mono.Security, Version=4.0.0.0, Culture=neutral, PublicKeyToken=0738eb9f132ed756"; public const string AssemblyMono_Messaging_RabbitMQ = "Mono.Messaging.RabbitMQ, Version=4.0.0.0, Culture=neutral, PublicKeyToken=0738eb9f132ed756"; public const string AssemblyCorlib = "mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"; public const string AssemblySystem = "System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"; public const string AssemblySystem_Data = "System.Data, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"; public const string AssemblySystem_Design = "System.Design, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblySystem_DirectoryServices = "System.DirectoryServices, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblySystem_Drawing = "System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblySystem_Drawing_Design = "System.Drawing.Design, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblySystem_Messaging = "System.Messaging, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblySystem_Security = "System.Security, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblySystem_ServiceProcess = "System.ServiceProcess, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblySystem_Web = "System.Web, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblySystem_Windows_Forms = "System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"; public const string AssemblySystem_2_0 = "System, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"; public const string AssemblySystemCore_3_5 = "System.Core, Version=3.5.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"; public const string AssemblySystem_Core = "System.Core, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"; public const string WindowsBase_3_0 = "WindowsBase, Version=3.0.0.0, PublicKeyToken=31bf3856ad364e35"; public const string AssemblyWindowsBase = "WindowsBase, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"; public const string AssemblyPresentationCore_3_5 = "PresentationCore, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"; public const string AssemblyPresentationCore_4_0 = "PresentationCore, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"; public const string AssemblyPresentationFramework_3_5 = "PresentationFramework, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"; public const string AssemblySystemServiceModel_3_0 = "System.ServiceModel, Version=3.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"; } internal static class SR { public const string ArgumentOutOfRange_Enum = "Enum value was out of legal range."; public const string ArgumentOutOfRange_NeedPosNum = "Positive number required."; public const string CannotReadFromDeflateStream = "Reading from the compression stream is not supported."; public const string CannotWriteToDeflateStream = "Writing to the compression stream is not supported."; public const string GenericInvalidData = "Found invalid data while decoding."; public const string InvalidArgumentOffsetCount = "Offset plus count is larger than the length of target array."; public const string InvalidBeginCall = "Only one asynchronous reader or writer is allowed time at one time."; public const string InvalidBlockLength = "Block length does not match with its complement."; public const string InvalidHuffmanData = "Failed to construct a huffman tree using the length array. The stream might be corrupted."; public const string NotSupported = "This operation is not supported."; public const string NotSupported_UnreadableStream = "Stream does not support reading."; public const string NotSupported_UnwritableStream = "Stream does not support writing."; public const string ObjectDisposed_StreamClosed = "Can not access a closed Stream."; public const string UnknownBlockType = "Unknown block type. Stream might be corrupted."; public const string UnknownState = "Decoder is in some unknown state. This might be caused by corrupted data."; public const string ZLibErrorDLLLoadError = "The underlying compression routine could not be loaded correctly."; public const string ZLibErrorInconsistentStream = "The stream state of the underlying compression routine is inconsistent."; public const string ZLibErrorIncorrectInitParameters = "The underlying compression routine received incorrect initialization parameters."; public const string ZLibErrorNotEnoughMemory = "The underlying compression routine could not reserve sufficient memory."; public const string ZLibErrorVersionMismatch = "The version of the underlying compression routine does not match expected version."; public const string ZLibErrorUnexpected = "The underlying compression routine returned an unexpected error code."; public const string ArgumentNeedNonNegative = "The argument must be non-negative."; public const string CannotBeEmpty = "String cannot be empty."; public const string CDCorrupt = "Central Directory corrupt."; public const string CentralDirectoryInvalid = "Central Directory is invalid."; public const string CreateInReadMode = "Cannot create entries on an archive opened in read mode."; public const string CreateModeCapabilities = "Cannot use create mode on a non-writable stream."; public const string CreateModeCreateEntryWhileOpen = "Entries cannot be created while previously created entries are still open."; public const string CreateModeWriteOnceAndOneEntryAtATime = "Entries in create mode may only be written to once, and only one entry may be held open at a time."; public const string DateTimeOutOfRange = "The DateTimeOffset specified cannot be converted into a Zip file timestamp."; public const string DeletedEntry = "Cannot modify deleted entry."; public const string DeleteOnlyInUpdate = "Delete can only be used when the archive is in Update mode."; public const string DeleteOpenEntry = "Cannot delete an entry currently open for writing."; public const string EntriesInCreateMode = "Cannot access entries in Create mode."; public const string EntryNameEncodingNotSupported = "The specified entry name encoding is not supported."; public const string EntryNamesTooLong = "Entry names cannot require more than 2^16 bits."; public const string EntryTooLarge = "Entries larger than 4GB are not supported in Update mode."; public const string EOCDNotFound = "End of Central Directory record could not be found."; public const string FieldTooBigCompressedSize = "Compressed Size cannot be held in an Int64."; public const string FieldTooBigLocalHeaderOffset = "Local Header Offset cannot be held in an Int64."; public const string FieldTooBigNumEntries = "Number of Entries cannot be held in an Int64."; public const string FieldTooBigOffsetToCD = "Offset to Central Directory cannot be held in an Int64."; public const string FieldTooBigOffsetToZip64EOCD = "Offset to Zip64 End Of Central Directory record cannot be held in an Int64."; public const string FieldTooBigStartDiskNumber = "Start Disk Number cannot be held in an Int64."; public const string FieldTooBigUncompressedSize = "Uncompressed Size cannot be held in an Int64."; public const string FrozenAfterWrite = "Cannot modify entry in Create mode after entry has been opened for writing."; public const string HiddenStreamName = "A stream from ZipArchiveEntry has been disposed."; public const string LengthAfterWrite = "Length properties are unavailable once an entry has been opened for writing."; public const string LocalFileHeaderCorrupt = "A local file header is corrupt."; public const string NumEntriesWrong = "Number of entries expected in End Of Central Directory does not correspond to number of entries in Central Directory."; public const string OffsetLengthInvalid = "The offset and length parameters are not valid for the array that was given."; public const string ReadingNotSupported = "This stream from ZipArchiveEntry does not support reading."; public const string ReadModeCapabilities = "Cannot use read mode on a non-readable stream."; public const string ReadOnlyArchive = "Cannot modify read-only archive."; public const string SeekingNotSupported = "This stream from ZipArchiveEntry does not support seeking."; public const string SetLengthRequiresSeekingAndWriting = "SetLength requires a stream that supports seeking and writing."; public const string SplitSpanned = "Split or spanned archives are not supported."; public const string UnexpectedEndOfStream = "Zip file corrupt: unexpected end of stream reached."; public const string UnsupportedCompression = "The archive entry was compressed using an unsupported compression method."; public const string UnsupportedCompressionMethod = "The archive entry was compressed using {0} and is not supported."; public const string UpdateModeCapabilities = "Update mode requires a stream with read, write, and seek capabilities."; public const string UpdateModeOneStream = "Entries cannot be opened multiple times in Update mode."; public const string WritingNotSupported = "This stream from ZipArchiveEntry does not support writing."; public const string Zip64EOCDNotWhereExpected = "Zip 64 End of Central Directory Record not where indicated."; public const string Argument_InvalidPathChars = "Illegal characters in path '{0}'."; public const string Stream_FalseCanRead = "Stream does not support reading."; public const string Stream_FalseCanWrite = "Stream does not support writing."; public const string BrotliEncoder_Create = "Failed to create BrotliEncoder instance"; public const string BrotliEncoder_Disposed = "Can not access a closed Encoder."; public const string BrotliEncoder_Quality = "Provided BrotliEncoder Quality of {0} is not between the minimum value of {1} and the maximum value of {2}"; public const string BrotliEncoder_Window = "Provided BrotliEncoder Window of {0} is not between the minimum value of {1} and the maximum value of {2}"; public const string BrotliEncoder_InvalidSetParameter = "The BrotliEncoder {0} can not be changed at current encoder state."; public const string BrotliDecoder_Create = "Failed to create BrotliDecoder instance"; public const string BrotliDecoder_Error = "Decoder threw unexpected error: {0}"; public const string BrotliDecoder_Disposed = "Can not access a closed Decoder."; public const string BrotliStream_Compress_UnsupportedOperation = "Can not perform Read operations on a BrotliStream constructed with CompressionMode.Compress."; public const string BrotliStream_Compress_InvalidData = "Encoder ran into invalid data."; public const string BrotliStream_Decompress_UnsupportedOperation = "Can not perform Write operations on a BrotliStream constructed with CompressionMode.Decompress."; public const string BrotliStream_Decompress_InvalidData = "Decoder ran into invalid data."; public const string BrotliStream_Decompress_InvalidStream = "BrotliStream.BaseStream returned more bytes than requested in Read."; internal static string GetString(string name, params object[] args) { return GetString(CultureInfo.InvariantCulture, name, args); } internal static string GetString(CultureInfo culture, string name, params object[] args) { return string.Format(culture, name, args); } internal static string GetString(string name) { return name; } internal static string GetString(CultureInfo culture, string name) { return name; } internal static string Format(string resourceFormat, params object[] args) { if (args != null) { return string.Format(CultureInfo.InvariantCulture, resourceFormat, args); } return resourceFormat; } internal static string Format(string resourceFormat, object p1) { return string.Format(CultureInfo.InvariantCulture, resourceFormat, p1); } internal static string Format(string resourceFormat, object p1, object p2) { return string.Format(CultureInfo.InvariantCulture, resourceFormat, p1, p2); } internal static string Format(CultureInfo ci, string resourceFormat, object p1, object p2) { return string.Format(ci, resourceFormat, p1, p2); } internal static string Format(string resourceFormat, object p1, object p2, object p3) { return string.Format(CultureInfo.InvariantCulture, resourceFormat, p1, p2, p3); } internal static string GetResourceString(string str) { return str; } } namespace System.Runtime.CompilerServices { internal class FriendAccessAllowedAttribute : Attribute { } } namespace System.IO.Compression { public sealed class BrotliStream : Stream { [StructLayout(LayoutKind.Auto)] [CompilerGenerated] private struct <FinishReadAsyncMemory>d__41 : IAsyncStateMachine { public int <>1__state; public AsyncValueTaskMethodBuilder<int> <>t__builder; public BrotliStream <>4__this; public CancellationToken cancellationToken; public Memory<byte> buffer; private int <totalWritten>5__2; private ConfiguredValueTaskAwaiter<int> <>u__1; private void MoveNext() { //IL_013c: Unknown result type (might be due to invalid IL or missing references) //IL_0141: Unknown result type (might be due to invalid IL or missing references) //IL_0149: Unknown result type (might be due to invalid IL or missing references) //IL_0025: Unknown result type (might be due to invalid IL or missing references) //IL_002c: Unknown result type (might be due to invalid IL or missing references) //IL_0223: Unknown result type (might be due to invalid IL or missing references) //IL_0032: Unknown result type (might be due to invalid IL or missing references) //IL_0034: Invalid comparison between Unknown and I4 //IL_019d: Unknown result type (might be due to invalid IL or missing references) //IL_01a2: Unknown result type (might be due to invalid IL or missing references) //IL_01ad: Unknown result type (might be due to invalid IL or missing references) //IL_01b6: Unknown result type (might be due to invalid IL or missing references) //IL_01bb: Unknown result type (might be due to invalid IL or missing references) //IL_01bc: Unknown result type (might be due to invalid IL or missing references) //IL_01be: Invalid comparison between Unknown and I4 //IL_00e5: Unknown result type (might be due to invalid IL or missing references) //IL_00f4: Unknown result type (might be due to invalid IL or missing references) //IL_00f9: Unknown result type (might be due to invalid IL or missing references) //IL_00fe: Unknown result type (might be due to invalid IL or missing references) //IL_0103: Unknown result type (might be due to invalid IL or missing references) //IL_0107: Unknown result type (might be due to invalid IL or missing references) //IL_010c: Unknown result type (might be due to invalid IL or missing references) //IL_0121: Unknown result type (might be due to invalid IL or missing references) //IL_0123: Unknown result type (might be due to invalid IL or missing references) //IL_005c: Unknown result type (might be due to invalid IL or missing references) //IL_0061: Unknown result type (might be due to invalid IL or missing references) //IL_006b: Unknown result type (might be due to invalid IL or missing references) //IL_020b: Unknown result type (might be due to invalid IL or missing references) //IL_0210: Unknown result type (might be due to invalid IL or missing references) int num = <>1__state; BrotliStream brotliStream = <>4__this; int result; try { if (num != 0) { brotliStream.AsyncOperationStarting(); } try { OperationStatus val; if (num != 0) { <totalWritten>5__2 = 0; _ = Memory<byte>.Empty; val = (OperationStatus)1; goto IL_0215; } ConfiguredValueTaskAwaiter<int> awaiter = <>u__1; <>u__1 = default(ConfiguredValueTaskAwaiter<int>); num = (<>1__state = -1); goto IL_0158; IL_0215: int num2; if (buffer.Length > 0 && (int)val != 0) { if ((int)val == 2) { if (brotliStream._bufferCount > 0 && brotliStream._bufferOffset != 0) { MemoryExtensions.AsSpan<byte>(brotliStream._buffer, brotliStream._bufferOffset, brotliStream._bufferCount).CopyTo(Span<byte>.op_Implicit(brotliStream._buffer)); } brotliStream._bufferOffset = 0; num2 = 0; goto IL_00ab; } goto IL_017a; } goto IL_0229; IL_00ab: bool flag = brotliStream._bufferCount < brotliStream._buffer.Length; if (flag) { awaiter = brotliStream._stream.ReadAsync(new Memory<byte>(brotliStream._buffer, brotliStream._bufferCount, brotliStream._buffer.Length - brotliStream._bufferCount), default(CancellationToken)).ConfigureAwait(false).GetAwaiter(); if (!awaiter.IsCompleted) { num = (<>1__state = 0); <>u__1 = awaiter; <>t__builder.AwaitUnsafeOnCompleted<ConfiguredValueTaskAwaiter<int>, <FinishReadAsyncMemory>d__41>(ref awaiter, ref this); return; } goto IL_0158; } goto IL_0167; IL_0158: flag = (num2 = awaiter.GetResult()) > 0; goto IL_0167; IL_0167: if (flag) { brotliStream._bufferCount += num2; if (brotliStream._bufferCount > brotliStream._buffer.Length) { throw new InvalidDataException("BrotliStream.BaseStream returned more bytes than requested in Read."); } goto IL_00ab; } if (brotliStream._bufferCount > 0) { goto IL_017a; } goto IL_0229; IL_0229: result = <totalWritten>5__2; goto end_IL_0018; IL_017a: cancellationToken.ThrowIfCancellationRequested(); val = brotliStream._decoder.Decompress(Span<byte>.op_Implicit(MemoryExtensions.AsSpan<byte>(brotliStream._buffer, brotliStream._bufferOffset, brotliStream._bufferCount)), buffer.Span, out var bytesConsumed, out var bytesWritten); if ((int)val == 3) { throw new InvalidOperationException("Decoder ran into invalid data."); } if (bytesConsumed > 0) { brotliStream._bufferOffset += bytesConsumed; brotliStream._bufferCount -= bytesConsumed; } if (bytesWritten > 0) { <totalWritten>5__2 += bytesWritten; buffer = buffer.Slice(bytesWritten); } goto IL_0215; end_IL_0018:; } finally { if (num < 0) { brotliStream.AsyncOperationCompleting(); } } } catch (Exception exception) { <>1__state = -2; <>t__builder.SetException(exception); return; } <>1__state = -2; <>t__builder.SetResult(result); } void IAsyncStateMachine.MoveNext() { //ILSpy generated this explicit interface implementation from .override directive in MoveNext this.MoveNext(); } [DebuggerHidden] private void SetStateMachine(IAsyncStateMachine stateMachine) { <>t__builder.SetStateMachine(stateMachine); } void IAsyncStateMachine.SetStateMachine(IAsyncStateMachine stateMachine) { //ILSpy generated this explicit interface implementation from .override directive in SetStateMachine this.SetStateMachine(stateMachine); } } private const int DefaultInternalBufferSize = 65520; private Stream _stream; private readonly byte[] _buffer; private readonly bool _leaveOpen; private readonly CompressionMode _mode; private int _activeAsyncOperation; private BrotliDecoder _decoder; private int _bufferOffset; private int _bufferCount; private BrotliEncoder _encoder; public Stream BaseStream => _stream; public override bool CanRead { get { //IL_0001: Unknown result type (might be due to invalid IL or missing references) if ((int)_mode == 0 && _stream != null) { return _stream.CanRead; } return false; } } public override bool CanWrite { get { //IL_0001: Unknown result type (might be due to invalid IL or missing references) //IL_0007: Invalid comparison between Unknown and I4 if ((int)_mode == 1 && _stream != null) { return _stream.CanWrite; } return false; } } public override bool CanSeek => false; public override long Length { get { throw new NotSupportedException(); } } public override long Position { get { throw new NotSupportedException(); } set { throw new NotSupportedException(); } } private bool AsyncOperationIsActive => _activeAsyncOperation != 0; public BrotliStream(Stream stream, CompressionMode mode) : this(stream, mode, leaveOpen: false) { }//IL_0002: Unknown result type (might be due to invalid IL or missing references) public BrotliStream(Stream stream, CompressionMode mode, bool leaveOpen) { //IL_0014: Unknown result type (might be due to invalid IL or missing references) //IL_0017: Unknown result type (might be due to invalid IL or missing references) //IL_0019: Invalid comparison between Unknown and I4 //IL_005c: Unknown result type (might be due to invalid IL or missing references) //IL_005d: Unknown result type (might be due to invalid IL or missing references) if (stream == null) { throw new ArgumentNullException("stream"); } if ((int)mode != 0) { if ((int)mode != 1) { throw new ArgumentException("Enum value was out of legal range.", "mode"); } if (!stream.CanWrite) { throw new ArgumentException("Stream does not support writing.", "stream"); } } else if (!stream.CanRead) { throw new ArgumentException("Stream does not support reading.", "stream"); } _mode = mode; _stream = stream; _leaveOpen = leaveOpen; _buffer = new byte[65520]; } private void EnsureNotDisposed() { if (_stream == null) { throw new ObjectDisposedException("stream", "Can not access a closed Stream."); } } protected override void Dispose(bool disposing) { //IL_000c: Unknown result type (might be due to invalid IL or missing references) //IL_0012: Invalid comparison between Unknown and I4 //IL_0015: Unknown result type (might be due to invalid IL or missing references) try { if (disposing && _stream != null) { if ((int)_mode == 1) { WriteCore(ReadOnlySpan<byte>.Empty, isFinalBlock: true); } if (!_leaveOpen) { _stream.Dispose(); } } } finally { _stream = null; _encoder.Dispose(); _decoder.Dispose(); base.Dispose(disposing); } } private static void ValidateParameters(byte[] array, int offset, int count) { if (array == null) { throw new ArgumentNullException("array"); } if (offset < 0) { throw new ArgumentOutOfRangeException("offset", "Positive number required."); } if (count < 0) { throw new ArgumentOutOfRangeException("count", "Positive number required."); } if (array.Length - offset < count) { throw new ArgumentException("Offset plus count is larger than the length of target array."); } } public override long Seek(long offset, SeekOrigin origin) { throw new NotSupportedException(); } public override void SetLength(long value) { throw new NotSupportedException(); } private void EnsureNoActiveAsyncOperation() { if (AsyncOperationIsActive) { ThrowInvalidBeginCall(); } } private void AsyncOperationStarting() { if (Interlocked.CompareExchange(ref _activeAsyncOperation, 1, 0) != 0) { ThrowInvalidBeginCall(); } } private void AsyncOperationCompleting() { Interlocked.CompareExchange(ref _activeAsyncOperation, 0, 1); } private static void ThrowInvalidBeginCall() { throw new InvalidOperationException("Only one asynchronous reader or writer is allowed time at one time."); } public override int Read(byte[] buffer, int offset, int count) { //IL_000c: Unknown result type (might be due to invalid IL or missing references) ValidateParameters(buffer, offset, count); return ((Stream)this).Read(new Span<byte>(buffer, offset, count)); } public int Read(Span<byte> buffer) { //IL_0001: Unknown result type (might be due to invalid IL or missing references) //IL_001c: Unknown result type (might be due to invalid IL or missing references) //IL_0158: Unknown result type (might be due to invalid IL or missing references) //IL_0022: Unknown result type (might be due to invalid IL or missing references) //IL_0024: Invalid comparison between Unknown and I4 //IL_00f8: Unknown result type (might be due to invalid IL or missing references) //IL_00fd: Unknown result type (might be due to invalid IL or missing references) //IL_0102: Unknown result type (might be due to invalid IL or missing references) //IL_0107: Unknown result type (might be due to invalid IL or missing references) //IL_010c: Unknown result type (might be due to invalid IL or missing references) //IL_010d: Unknown result type (might be due to invalid IL or missing references) //IL_010f: Invalid comparison between Unknown and I4 //IL_004c: Unknown result type (might be due to invalid IL or missing references) //IL_0051: Unknown result type (might be due to invalid IL or missing references) //IL_005b: Unknown result type (might be due to invalid IL or missing references) //IL_0147: Unknown result type (might be due to invalid IL or missing references) //IL_014c: Unknown result type (might be due to invalid IL or missing references) if ((int)_mode != 0) { throw new InvalidOperationException("Can not perform Read operations on a BrotliStream constructed with CompressionMode.Compress."); } EnsureNotDisposed(); int num = 0; OperationStatus val = (OperationStatus)1; while (buffer.Length > 0 && (int)val != 0) { if ((int)val == 2) { if (_bufferCount > 0 && _bufferOffset != 0) { MemoryExtensions.AsSpan<byte>(_buffer, _bufferOffset, _bufferCount).CopyTo(Span<byte>.op_Implicit(_buffer)); } _bufferOffset = 0; int num2 = 0; while (_bufferCount < _buffer.Length && (num2 = _stream.Read(_buffer, _bufferCount, _buffer.Length - _bufferCount)) > 0) { _bufferCount += num2; if (_bufferCount > _buffer.Length) { throw new InvalidDataException("BrotliStream.BaseStream returned more bytes than requested in Read."); } } if (_bufferCount <= 0) { break; } } val = _decoder.Decompress(Span<byte>.op_Implicit(MemoryExtensions.AsSpan<byte>(_buffer, _bufferOffset, _bufferCount)), buffer, out var bytesConsumed, out var bytesWritten); if ((int)val == 3) { throw new InvalidOperationException("Decoder ran into invalid data."); } if (bytesConsumed > 0) { _bufferOffset += bytesConsumed; _bufferCount -= bytesConsumed; } if (bytesWritten > 0) { num += bytesWritten; buffer = buffer.Slice(bytesWritten); } } return num; } public override IAsyncResult BeginRead(byte[] buffer, int offset, int count, AsyncCallback asyncCallback, object asyncState) { return System.Threading.Tasks.TaskToApm.Begin(ReadAsync(buffer, offset, count, CancellationToken.None), asyncCallback, asyncState); } public override int EndRead(IAsyncResult asyncResult) { return System.Threading.Tasks.TaskToApm.End<int>(asyncResult); } public override Task<int> ReadAsync(byte[] buffer, int offset, int count, CancellationToken cancellationToken) { //IL_000c: Unknown result type (might be due to invalid IL or missing references) //IL_0013: Unknown result type (might be due to invalid IL or missing references) //IL_0018: Unknown result type (might be due to invalid IL or missing references) ValidateParameters(buffer, offset, count); return ((Stream)this).ReadAsync(new Memory<byte>(buffer, offset, count), cancellationToken).AsTask(); } public ValueTask<int> ReadAsync(Memory<byte> buffer, CancellationToken cancellationToken = default(CancellationToken)) { //IL_0001: Unknown result type (might be due to invalid IL or missing references) //IL_0035: Unknown result type (might be due to invalid IL or missing references) //IL_0037: Unknown result type (might be due to invalid IL or missing references) //IL_002e: Unknown result type (might be due to invalid IL or missing references) if ((int)_mode != 0) { throw new InvalidOperationException("Can not perform Read operations on a BrotliStream constructed with CompressionMode.Compress."); } EnsureNoActiveAsyncOperation(); EnsureNotDisposed(); if (cancellationToken.IsCancellationRequested) { return new ValueTask<int>(Task.FromCanceled<int>(cancellationToken)); } return FinishReadAsyncMemory(buffer, cancellationToken); } [AsyncStateMachine(typeof(<FinishReadAsyncMemory>d__41))] private ValueTask<int> FinishReadAsyncMemory(Memory<byte> buffer, CancellationToken cancellationToken) { //IL_000a: Unknown result type (might be due to invalid IL or missing references) //IL_000b: Unknown result type (might be due to invalid IL or missing references) //IL_001a: Unknown result type (might be due to invalid IL or missing references) //IL_001f: Unknown result type (might be due to invalid IL or missing references) //IL_0041: Unknown result type (might be due to invalid IL or missing references) <FinishReadAsyncMemory>d__41 <FinishReadAsyncMemory>d__ = default(<FinishReadAsyncMemory>d__41); <FinishReadAsyncMemory>d__.<>4__this = this; <FinishReadAsyncMemory>d__.buffer = buffer; <FinishReadAsyncMemory>d__.cancellationToken = cancellationToken; <FinishReadAsyncMemory>d__.<>t__builder = AsyncValueTaskMethodBuilder<int>.Create(); <FinishReadAsyncMemory>d__.<>1__state = -1; <FinishReadAsyncMemory>d__.<>t__builder.Start<<FinishReadAsyncMemory>d__41>(ref <FinishReadAsyncMemory>d__); return <FinishReadAsyncMemory>d__.<>t__builder.Task; } public BrotliStream(Stream stream, CompressionLevel compressionLevel) : this(stream, compressionLevel, leaveOpen: false) { }//IL_0002: Unknown result type (might be due to invalid IL or missing references) public BrotliStream(Stream stream, CompressionLevel compressionLevel, bool leaveOpen) : this(stream, (CompressionMode)1, leaveOpen) { //IL_000f: Unknown result type (might be due to invalid IL or missing references) _encoder.SetQuality(BrotliUtils.GetQualityFromCompressionLevel(compressionLevel)); } public override void Write(byte[] buffer, int offset, int count) { //IL_000c: Unknown result type (might be due to invalid IL or missing references) ValidateParameters(buffer, offset, count); WriteCore(new ReadOnlySpan<byte>(buffer, offset, count)); } public void Write(ReadOnlySpan<byte> buffer) { //IL_0001: Unknown result type (might be due to invalid IL or missing references) WriteCore(buffer); } internal void WriteCore(ReadOnlySpan<byte> buffer, bool isFinalBlock = false) { //IL_0001: Unknown result type (might be due to invalid IL or missing references) //IL_0007: Invalid comparison between Unknown and I4 //IL_001b: Unknown result type (might be due to invalid IL or missing references) //IL_007c: Unknown result type (might be due to invalid IL or missing references) //IL_007e: Invalid comparison between Unknown and I4 //IL_0035: Unknown result type (might be due to invalid IL or missing references) //IL_0036: Unknown result type (might be due to invalid IL or missing references) //IL_003c: Unknown result type (might be due to invalid IL or missing references) //IL_0041: Unknown result type (might be due to invalid IL or missing references) //IL_0042: Unknown result type (might be due to invalid IL or missing references) //IL_0044: Invalid comparison between Unknown and I4 //IL_005f: Unknown result type (might be due to invalid IL or missing references) //IL_0064: Unknown result type (might be due to invalid IL or missing references) //IL_0075: Unknown result type (might be due to invalid IL or missing references) //IL_007a: Unknown result type (might be due to invalid IL or missing references) if ((int)_mode != 1) { throw new InvalidOperationException("Can not perform Write operations on a BrotliStream constructed with CompressionMode.Decompress."); } EnsureNotDisposed(); OperationStatus val = (OperationStatus)1; Span<byte> destination = default(Span<byte>); destination..ctor(_buffer); while ((int)val == 1) { int bytesConsumed = 0; int bytesWritten = 0; val = _encoder.Compress(buffer, destination, out bytesConsumed, out bytesWritten, isFinalBlock); if ((int)val == 3) { throw new InvalidOperationException("Encoder ran into invalid data."); } if (bytesWritten > 0) { _stream.Write(Span<byte>.op_Implicit(destination.Slice(0, bytesWritten))); } if (bytesConsumed > 0) { buffer = buffer.Slice(bytesConsumed); } } } public override IAsyncResult BeginWrite(byte[] buffer, int offset, int count, AsyncCallback asyncCallback, object asyncState) { return System.Threading.Tasks.TaskToApm.Begin(WriteAsync(buffer, offset, count, CancellationToken.None), asyncCallback, asyncState); } public override void EndWrite(IAsyncResult asyncResult) { System.Threading.Tasks.TaskToApm.End(asyncResult); } public override Task WriteAsync(byte[] buffer, int offset, int count, CancellationToken cancellationToken) { //IL_000c: Unknown result type (might be due to invalid IL or missing references) //IL_0013: Unknown result type (might be due to invalid IL or missing references) //IL_0018: Unknown result type (might be due to invalid IL or missing references) ValidateParameters(buffer, offset, count); ValueTask val = ((Stream)this).WriteAsync(new ReadOnlyMemory<byte>(buffer, offset, count), cancellationToken); return ((ValueTask)(ref val)).AsTask(); } public ValueTask WriteAsync(ReadOnlyMemory<byte> buffer, CancellationToken cancellationToken = default(CancellationToken)) { //IL_0001: Unknown result type (might be due to invalid IL or missing references) //IL_0007: Invalid comparison between Unknown and I4 //IL_002a: Unknown result type (might be due to invalid IL or missing references) //IL_0039: Unknown result type (might be due to invalid IL or missing references) if ((int)_mode != 1) { throw new InvalidOperationException("Can not perform Write operations on a BrotliStream constructed with CompressionMode.Decompress."); } EnsureNoActiveAsyncOperation(); EnsureNotDisposed(); return new ValueTask(cancellationToken.IsCancellationRequested ? Task.FromCanceled<int>(cancellationToken) : WriteAsyncMemoryCore(buffer, cancellationToken)); } private async Task WriteAsyncMemoryCore(ReadOnlyMemory<byte> buffer, CancellationToken cancellationToken) { //IL_000a: Unknown result type (might be due to invalid IL or missing references) //IL_000b: Unknown result type (might be due to invalid IL or missing references) AsyncOperationStarting(); try { OperationStatus lastResult = (OperationStatus)1; Memory<byte> destination = default(Memory<byte>); while ((int)lastResult == 1) { destination..ctor(_buffer); int bytesConsumed = 0; int bytesWritten = 0; lastResult = _encoder.Compress(buffer, destination, out bytesConsumed, out bytesWritten, isFinalBlock: false); if ((int)lastResult == 3) { throw new InvalidOperationException("Encoder ran into invalid data."); } if (bytesConsumed > 0) { buffer = buffer.Slice(bytesConsumed); } if (bytesWritten > 0) { ValueTask val = _stream.WriteAsync(new ReadOnlyMemory<byte>(_buffer, 0, bytesWritten), cancellationToken); await ((ValueTask)(ref val)).ConfigureAwait(false); } } } finally { AsyncOperationCompleting(); } } public override void Flush() { //IL_0007: Unknown result type (might be due to invalid IL or missing references) //IL_000d: Invalid comparison between Unknown and I4 //IL_0030: Unknown result type (might be due to invalid IL or missing references) //IL_007d: Unknown result type (might be due to invalid IL or missing references) //IL_007f: Invalid comparison between Unknown and I4 //IL_0048: Unknown result type (might be due to invalid IL or missing references) //IL_004b: Unknown result type (might be due to invalid IL or missing references) //IL_0050: Unknown result type (might be due to invalid IL or missing references) //IL_0051: Unknown result type (might be due to invalid IL or missing references) //IL_0053: Invalid comparison between Unknown and I4 //IL_006e: Unknown result type (might be due to invalid IL or missing references) //IL_0073: Unknown result type (might be due to invalid IL or missing references) EnsureNotDisposed(); if ((int)_mode != 1 || _encoder._state == null || _encoder._state.IsClosed) { return; } OperationStatus val = (OperationStatus)1; Span<byte> destination = default(Span<byte>); destination..ctor(_buffer); while ((int)val == 1) { int bytesWritten = 0; val = _encoder.Flush(destination, out bytesWritten); if ((int)val == 3) { throw new InvalidDataException("Encoder ran into invalid data."); } if (bytesWritten > 0) { _stream.Write(Span<byte>.op_Implicit(destination.Slice(0, bytesWritten))); } } } public override Task FlushAsync(CancellationToken cancellationToken) { //IL_001d: Unknown result type (might be due to invalid IL or missing references) //IL_0023: Invalid comparison between Unknown and I4 EnsureNoActiveAsyncOperation(); EnsureNotDisposed(); if (cancellationToken.IsCancellationRequested) { return Task.FromCanceled(cancellationToken); } if ((int)_mode == 1) { return FlushAsyncCore(cancellationToken); } return Task.CompletedTask; } private async Task FlushAsyncCore(CancellationToken cancellationToken) { AsyncOperationStarting(); try { if (_encoder._state == null || _encoder._state.IsClosed) { return; } OperationStatus lastResult = (OperationStatus)1; Memory<byte> destination = default(Memory<byte>); while ((int)lastResult == 1) { destination..ctor(_buffer); int bytesWritten = 0; lastResult = _encoder.Flush(destination, out bytesWritten); if ((int)lastResult == 3) { throw new InvalidDataException("Encoder ran into invalid data."); } if (bytesWritten > 0) { ValueTask val = _stream.WriteAsync(Memory<byte>.op_Implicit(destination.Slice(0, bytesWritten)), cancellationToken); await ((ValueTask)(ref val)).ConfigureAwait(false); } } } finally { AsyncOperationCompleting(); } } } internal static class BrotliUtils { public const int WindowBits_Min = 10; public const int WindowBits_Default = 22; public const int WindowBits_Max = 24; public const int Quality_Min = 0; public const int Quality_Default = 11; public const int Quality_Max = 11; public const int MaxInputSize = 2147483132; internal static int GetQualityFromCompressionLevel(CompressionLevel level) { //IL_0000: Unknown result type (might be due to invalid IL or missing references) //IL_0012: Expected I4, but got Unknown //IL_001b: Unknown result type (might be due to invalid IL or missing references) //IL_001d: Expected I4, but got Unknown return (int)level switch { 0 => 11, 2 => 0, 1 => 1, _ => (int)level, }; } } public struct BrotliDecoder : IDisposable { private SafeBrotliDecoderHandle _state; private bool _disposed; internal void InitializeDecoder() { _state = global::Interop.Brotli.BrotliDecoderCreateInstance(IntPtr.Zero, IntPtr.Zero, IntPtr.Zero); if (_state.IsInvalid) { throw new IOException("Failed to create BrotliDecoder instance"); } } internal void EnsureInitialized() { EnsureNotDisposed(); if (_state == null) { InitializeDecoder(); } } public void Dispose() { _disposed = true; _state?.Dispose(); } private void EnsureNotDisposed() { if (_disposed) { throw new ObjectDisposedException("BrotliDecoder", "Can not access a closed Decoder."); } } public unsafe OperationStatus Decompress(ReadOnlySpan<byte> source, Span<byte> destination, out int bytesConsumed, out int bytesWritten) { //IL_003b: Unknown result type (might be due to invalid IL or missing references) //IL_0045: Unknown result type (might be due to invalid IL or missing references) //IL_00c7: Unknown result type (might be due to invalid IL or missing references) //IL_00cc: Unknown result type (might be due to invalid IL or missing references) //IL_00de: Unknown result type (might be due to invalid IL or missing references) //IL_00e3: Unknown result type (might be due to invalid IL or missing references) EnsureInitialized(); bytesConsumed = 0; bytesWritten = 0; if (!global::Interop.Brotli.BrotliDecoderIsFinished(_state)) { IntPtr availableOut = (IntPtr)destination.Length; IntPtr availableIn = (IntPtr)source.Length; while ((int)availableOut > 0) { fixed (byte* ptr = &MemoryMarshal.GetReference<byte>(source)) { fixed (byte* ptr3 = &MemoryMarshal.GetReference<byte>(destination)) { byte* ptr2 = ptr; byte* ptr4 = ptr3; IntPtr totalOut; int num = global::Interop.Brotli.BrotliDecoderDecompressStream(_state, ref availableIn, &ptr2, ref availableOut, &ptr4, out totalOut); if (num == 0) { return (OperationStatus)3; } bytesConsumed += source.Length - (int)availableIn; bytesWritten += destination.Length - (int)availableOut; switch (num) { case 1: return (OperationStatus)0; case 3: return (OperationStatus)1; } source = source.Slice(source.Length - (int)availableIn); destination = destination.Slice(destination.Length - (int)availableOut); if (num == 2 && source.Length == 0) { return (OperationStatus)2; } } } } return (OperationStatus)1; } return (OperationStatus)0; } public unsafe static bool TryDecompress(ReadOnlySpan<byte> source, Span<byte> destination, out int bytesWritten) { //IL_0000: Unknown result type (might be due to invalid IL or missing references) //IL_000a: Unknown result type (might be due to invalid IL or missing references) fixed (byte* inBytes = &MemoryMarshal.GetReference<byte>(source)) { fixed (byte* outBytes = &MemoryMarshal.GetReference<byte>(destination)) { IntPtr availableOutput = (IntPtr)destination.Length; bool result = global::Interop.Brotli.BrotliDecoderDecompress((IntPtr)source.Length, inBytes, ref availableOutput, outBytes); bytesWritten = (int)availableOutput; return result; } } } } public struct BrotliEncoder : IDisposable { internal SafeBrotliEncoderHandle _state; private bool _disposed; public BrotliEncoder(int quality, int window) { _disposed = false; _state = global::Interop.Brotli.BrotliEncoderCreateInstance(IntPtr.Zero, IntPtr.Zero, IntPtr.Zero); if (_state.IsInvalid) { throw new IOException("Failed to create BrotliEncoder instance"); } SetQuality(quality); SetWindow(window); } internal void InitializeEncoder() { EnsureNotDisposed(); _state = global::Interop.Brotli.BrotliEncoderCreateInstance(IntPtr.Zero, IntPtr.Zero, IntPtr.Zero); if (_state.IsInvalid) { throw new IOException("Failed to create BrotliEncoder instance"); } } internal void EnsureInitialized() { EnsureNotDisposed(); if (_state == null) { InitializeEncoder(); } } public void Dispose() { _disposed = true; _state?.Dispose(); } private void EnsureNotDisposed() { if (_disposed) { throw new ObjectDisposedException("BrotliEncoder", "Can not access a closed Encoder."); } } internal void SetQuality(int quality) { EnsureNotDisposed(); if (_state == null || _state.IsInvalid || _state.IsClosed) { InitializeEncoder(); } if (quality < 0 || quality > 11) { throw new ArgumentOutOfRangeException("quality", SR.Format("Provided BrotliEncoder Quality of {0} is not between the minimum value of {1} and the maximum value of {2}", quality, 0, 11)); } if (!global::Interop.Brotli.BrotliEncoderSetParameter(_state, BrotliEncoderParameter.Quality, (uint)quality)) { throw new InvalidOperationException(SR.Format("The BrotliEncoder {0} can not be changed at current encoder state.", "Quality")); } } internal void SetWindow(int window) { EnsureNotDisposed(); if (_state == null || _state.IsInvalid || _state.IsClosed) { InitializeEncoder(); } if (window < 10 || window > 24) { throw new ArgumentOutOfRangeException("window", SR.Format("Provided BrotliEncoder Window of {0} is not between the minimum value of {1} and the maximum value of {2}", window, 10, 24)); } if (!global::Interop.Brotli.BrotliEncoderSetParameter(_state, BrotliEncoderParameter.LGWin, (uint)window)) { throw new InvalidOperationException(SR.Format("The BrotliEncoder {0} can not be changed at current encoder state.", "Window")); } } public static int GetMaxCompressedLength(int length) { if (length < 0 || length > 2147483132) { throw new ArgumentOutOfRangeException("length"); } if (length == 0) { return 1; } int num = length >> 24; int num2 = (((length & 0xFFFFFF) > 1048576) ? 4 : 3); int num3 = 2 + 4 * num + num2 + 1; return length + num3; } internal OperationStatus Flush(Memory<byte> destination, out int bytesWritten) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0009: Unknown result type (might be due to invalid IL or missing references) return Flush(destination.Span, out bytesWritten); } public OperationStatus Flush(Span<byte> destination, out int bytesWritten) { //IL_0001: Unknown result type (might be due to invalid IL or missing references) //IL_0006: Unknown result type (might be due to invalid IL or missing references) //IL_000b: Unknown result type (might be due to invalid IL or missing references) int bytesConsumed; return Compress(ReadOnlySpan<byte>.Empty, destination, out bytesConsumed, out bytesWritten, BrotliEncoderOperation.Flush); } internal OperationStatus Compress(ReadOnlyMemory<byte> source, Memory<byte> destination, out int bytesConsumed, out int bytesWritten, bool isFinalBlock) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_000a: Unknown result type (might be due to invalid IL or missing references) //IL_0014: Unknown result type (might be due to invalid IL or missing references) return Compress(source.Span, destination.Span, out bytesConsumed, out bytesWritten, isFinalBlock); } public OperationStatus Compress(ReadOnlySpan<byte> source, Span<byte> destination, out int bytesConsumed, out int bytesWritten, bool isFinalBlock) { //IL_0001: Unknown result type (might be due to invalid IL or missing references) //IL_0002: Unknown result type (might be due to invalid IL or missing references) //IL_000e: Unknown result type (might be due to invalid IL or missing references) return Compress(source, destination, out bytesConsumed, out bytesWritten, isFinalBlock ? BrotliEncoderOperation.Finish : BrotliEncoderOperation.Process); } internal unsafe OperationStatus Compress(ReadOnlySpan<byte> source, Span<byte> destination, out int bytesConsumed, out int bytesWritten, BrotliEncoderOperation operation) { //IL_002c: Unknown result type (might be due to invalid IL or missing references) //IL_0036: Unknown result type (might be due to invalid IL or missing references) //IL_00c1: Unknown result type (might be due to invalid IL or missing references) //IL_00c6: Unknown result type (might be due to invalid IL or missing references) //IL_00d8: Unknown result type (might be due to invalid IL or missing references) //IL_00dd: Unknown result type (might be due to invalid IL or missing references) EnsureInitialized(); bytesWritten = 0; bytesConsumed = 0; IntPtr availableOut = (IntPtr)destination.Length; IntPtr availableIn = (IntPtr)source.Length; while ((int)availableOut > 0) { fixed (byte* ptr = &MemoryMarshal.GetReference<byte>(source)) { fixed (byte* ptr3 = &MemoryMarshal.GetReference<byte>(destination)) { byte* ptr2 = ptr; byte* ptr4 = ptr3; if (!global::Interop.Brotli.BrotliEncoderCompressStream(_state, operation, ref availableIn, &ptr2, ref availableOut, &ptr4, out var _)) { return (OperationStatus)3; } bytesConsumed += source.Length - (int)availableIn; bytesWritten += destination.Length - (int)availableOut; if ((int)availableOut == destination.Length && !global::Interop.Brotli.BrotliEncoderHasMoreOutput(_state) && (int)availableIn == 0) { return (OperationStatus)0; } source = source.Slice(source.Length - (int)availableIn); destination = destination.Slice(destination.Length - (int)availableOut); } } } return (OperationStatus)1; } public static bool TryCompress(ReadOnlySpan<byte> source, Span<byte> destination, out int bytesWritten) { //IL_0000: Unknown result type (might be due to invalid IL or missing references) //IL_0001: Unknown result type (might be due to invalid IL or missing references) return TryCompress(source, destination, out bytesWritten, 11, 22); } public unsafe static bool TryCompress(ReadOnlySpan<byte> source, Span<byte> destination, out int bytesWritten, int quality, int window) { //IL_0067: Unknown result type (might be due to invalid IL or missing references) //IL_0071: Unknown result type (might be due to invalid IL or missing references) if (quality < 0 || quality > 11) { throw new ArgumentOutOfRangeException("quality", SR.Format("Provided BrotliEncoder Quality of {0} is not between the minimum value of {1} and the maximum value of {2}", quality, 0, 11)); } if (window < 10 || window > 24) { throw new ArgumentOutOfRangeException("window", SR.Format("Provided BrotliEncoder Window of {0} is not between the minimum value of {1} and the maximum value of {2}", window, 10, 24)); } fixed (byte* inBytes = &MemoryMarshal.GetReference<byte>(source)) { fixed (byte* outBytes = &MemoryMarshal.GetReference<byte>(destination)) { IntPtr availableOutput = (IntPtr)destination.Length; bool result = global::Interop.Brotli.BrotliEncoderCompress(quality, window, 0, (IntPtr)source.Length, inBytes, ref availableOutput, outBytes); bytesWritten = (int)availableOutput; return result; } } } } internal enum BrotliEncoderOperation { Process, Flush, Finish, EmitMetadata } internal enum BrotliEncoderParameter { Mode, Quality, LGWin, LGBlock, LCModeling, SizeHint } internal enum BlockType { Uncompressed, Static, Dynamic } internal sealed class CopyEncoder { private const int PaddingSize = 5; private const int MaxUncompressedBlockSize = 65536; public void GetBlock(DeflateInput input, OutputBuffer output, bool isFinal) { int num = 0; if (input != null) { num = Math.Min(input.Count, output.FreeBytes - 5 - output.BitsInBuffer); if (num > 65531) { num = 65531; } } if (isFinal) { output.WriteBits(3, 1u); } else { output.WriteBits(3, 0u); } output.FlushBits(); WriteLenNLen((ushort)num, output); if (input != null && num > 0) { output.WriteBytes(input.Buffer, input.StartIndex, num); input.ConsumeBytes(num); } } private void WriteLenNLen(ushort len, OutputBuffer output) { output.WriteUInt16(len); ushort value = (ushort)(~len); output.WriteUInt16(value); } } internal sealed class DeflateInput { internal readonly struct InputState { internal readonly int _count; internal readonly int _startIndex; internal InputState(int count, int startIndex) { _count = count; _startIndex = startIndex; } } internal byte[] Buffer { get; set; } internal int Count { get; set; } internal int StartIndex { get; set; } internal void ConsumeBytes(int n) { StartIndex += n; Count -= n; } internal InputState DumpState() { return new InputState(Count, StartIndex); } internal void RestoreState(InputState state) { Count = state._count; StartIndex = state._startIndex; } } internal sealed class DeflateManagedStream : Stream { internal const int DefaultBufferSize = 8192; private Stream _stream; private CompressionMode _mode; private bool _leaveOpen; private System.IO.Compression.InflaterManaged _inflater; private DeflaterManaged _deflater; private byte[] _buffer; private int _asyncOperations; private IFileFormatWriter _formatWriter; private bool _wroteHeader; private bool _wroteBytes; public override bool CanRead { get { //IL_000b: Unknown result type (might be due to invalid IL or missing references) if (_stream == null) { return false; } if ((int)_mode == 0) { return _stream.CanRead; } return false; } } public override bool CanWrite { get { //IL_000b: Unknown result type (might be due to invalid IL or missing references) //IL_0011: Invalid comparison between Unknown and I4 if (_stream == null) { return false; } if ((int)_mode == 1) { return _stream.CanWrite; } return false; } } public override bool CanSeek => false; public override long Length { get { throw new NotSupportedException("This operation is not supported."); } } public override long Position { get { throw new NotSupportedException("This operation is not supported."); } set { throw new NotSupportedException("This operation is not supported."); } } internal DeflateManagedStream(Stream stream, ZipArchiveEntry.CompressionMethodValues method) { if (stream == null) { throw new ArgumentNullException("stream"); } if (!stream.CanRead) { throw new ArgumentException("Stream does not support reading.", "stream"); } InitializeInflater(stream, leaveOpen: false, null, method); } internal void InitializeInflater(Stream stream, bool leaveOpen, IFileFormatReader reader = null, ZipArchiveEntry.CompressionMethodValues method = ZipArchiveEntry.CompressionMethodValues.Deflate) { //IL_0037: Unknown result type (might be due to invalid IL or missing references) if (!stream.CanRead) { throw new ArgumentException("Stream does not support reading.", "stream"); } _inflater = new System.IO.Compression.InflaterManaged(reader, method == ZipArchiveEntry.CompressionMethodValues.Deflate64); _stream = stream; _mode = (CompressionMode)0; _leaveOpen = leaveOpen; _buffer = new byte[8192]; } internal void SetFileFormatWriter(IFileFormatWriter writer) { if (writer != null) { _formatWriter = writer; } } public override void Flush() { EnsureNotDisposed(); } public override Task FlushAsync(CancellationToken cancellationToken) { EnsureNotDisposed(); if (!cancellationToken.IsCancellationRequested) { return Task.CompletedTask; } return Task.FromCanceled(cancellationToken); } public override long Seek(long offset, SeekOrigin origin) { throw new NotSupportedException("This operation is not supported."); } public override void SetLength(long value) { throw new NotSupportedException("This operation is not supported."); } public override int Read(byte[] array, int offset, int count) { EnsureDecompressionMode(); ValidateParameters(array, offset, count); EnsureNotDisposed(); int num = offset; int num2 = count; while (true) { int num3 = _inflater.Inflate(array, num, num2); num += num3; num2 -= num3; if (num2 == 0 || _inflater.Finished()) { break; } int num4 = _stream.Read(_buffer, 0, _buffer.Length); if (num4 <= 0) { break; } if (num4 > _buffer.Length) { throw new InvalidDataException("Found invalid data while decoding."); } _inflater.SetInput(_buffer, 0, num4); } return count - num2; } private void ValidateParameters(byte[] array, int offset, int count) { if (array == null) { throw new ArgumentNullException("array"); } if (offset < 0) { throw new ArgumentOutOfRangeException("offset"); } if (count < 0) { throw new ArgumentOutOfRangeException("count"); } if (array.Length - offset < count) { throw new ArgumentException("Offset plus count is larger than the length of target array."); } } private void EnsureNotDisposed() { if (_stream == null) { ThrowStreamClosedException(); } } [MethodImpl(MethodImplOptions.NoInlining)] private static void ThrowStreamClosedException() { throw new ObjectDisposedException(null, "Can not access a closed Stream."); } private void EnsureDecompressionMode() { //IL_0001: Unknown result type (might be due to invalid IL or missing references) if ((int)_mode != 0) { ThrowCannotReadFromDeflateManagedStreamException(); } } [MethodImpl(MethodImplOptions.NoInlining)] private static void ThrowCannotReadFromDeflateManagedStreamException() { throw new InvalidOperationException("Reading from the compression stream is not supported."); } private void EnsureCompressionMode() { //IL_0001: Unknown result type (might be due to invalid IL or missing references) //IL_0007: Invalid comparison between Unknown and I4 if ((int)_mode != 1) { ThrowCannotWriteToDeflateManagedStreamException(); } } [MethodImpl(MethodImplOptions.NoInlining)] private static void ThrowCannotWriteToDeflateManagedStreamException() { throw new InvalidOperationException("Writing to the compression stream is not supported."); } public override IAsyncResult BeginRead(byte[] buffer, int offset, int count, AsyncCallback asyncCallback, object asyncState) { return System.Threading.Tasks.TaskToApm.Begin(ReadAsync(buffer, offset, count, CancellationToken.None), asyncCallback, asyncState); } public override int EndRead(IAsyncResult asyncResult) { return System.Threading.Tasks.TaskToApm.End<int>(asyncResult); } public override Task<int> ReadAsync(byte[] array, int offset, int count, CancellationToken cancellationToken) { EnsureDecompressionMode(); if (_asyncOperations != 0) { throw new InvalidOperationException("Only one asynchronous reader or writer is allowed time at one time."); } ValidateParameters(array, offset, count); EnsureNotDisposed(); if (cancellationToken.IsCancellationRequested) { return Task.FromCanceled<int>(cancellationToken); } Interlocked.Increment(ref _asyncOperations); Task<int> task = null; try { int num = _inflater.Inflate(array, offset, count); if (num != 0) { return Task.FromResult(num); } if (_inflater.Finished()) { return Task.FromResult(0); } task = _stream.ReadAsync(_buffer, 0, _buffer.Length, cancellationToken); if (task == null) { throw new InvalidOperationException("Stream does not support reading."); } return ReadAsyncCore(task, array, offset, count, cancellationToken); } finally { if (task == null) { Interlocked.Decrement(ref _asyncOperations); } } } private async Task<int> ReadAsyncCore(Task<int> readTask, byte[] array, int offset, int count, CancellationToken cancellationToken) { try { int num; while (true) { num = await readTask.ConfigureAwait(continueOnCapturedContext: false); EnsureNotDisposed(); if (num <= 0) { return 0; } if (num > _buffer.Length) { throw new InvalidDataException("Found invalid data while decoding."); } cancellationToken.ThrowIfCancellationRequested(); _inflater.SetInput(_buffer, 0, num); num = _inflater.Inflate(array, offset, count); if (num != 0 || _inflater.Finished()) { break; } readTask = _stream.ReadAsync(_buffer, 0, _buffer.Length, cancellationToken); if (readTask == null) { throw new InvalidOperationException("Stream does not support reading."); } } return num; } finally { Interlocked.Decrement(ref _asyncOperations); } } public override void Write(byte[] array, int offset, int count) { EnsureCompressionMode(); ValidateParameters(array, offset, count); EnsureNotDisposed(); DoMaintenance(array, offset, count); WriteDeflaterOutput(); _deflater.SetInput(array, offset, count); WriteDeflaterOutput(); } private void WriteDeflaterOutput() { while (!_deflater.NeedsInput()) { int deflateOutput = _deflater.GetDeflateOutput(_buffer); if (deflateOutput > 0) { _stream.Write(_buffer, 0, deflateOutput); } } } private void DoMaintenance(byte[] array, int offset, int count) { if (count <= 0) { return; } _wroteBytes = true; if (_formatWriter != null) { if (!_wroteHeader) { byte[] header = _formatWriter.GetHeader(); _stream.Write(header, 0, header.Length); _wroteHeader = true; } _formatWriter.UpdateWithBytesRead(array, offset, count); } } private void PurgeBuffers(bool disposing) { //IL_0014: Unknown result type (might be due to invalid IL or missing references) //IL_001a: Invalid comparison between Unknown and I4 if (!disposing || _stream == null) { return; } Flush(); if ((int)_mode != 1) { return; } if (_wroteBytes) { WriteDeflaterOutput(); bool flag; do { flag = _deflater.Finish(_buffer, out var bytesRead); if (bytesRead > 0) { _stream.Write(_buffer, 0, bytesRead); } } while (!flag); } else { int bytesRead2; while (!_deflater.Finish(_buffer, out bytesRead2)) { } } if (_formatWriter != null && _wroteHeader) { byte[] footer = _formatWriter.GetFooter(); _stream.Write(footer, 0, footer.Length); } } protected override void Dispose(bool disposing) { try { PurgeBuffers(disposing); } finally { try { if (disposing && !_leaveOpen && _stream != null) { _stream.Dispose(); } } finally { _stream = null; try { _deflater?.Dispose(); _inflater?.Dispose(); } finally { _deflater = null; _inflater = null; base.Dispose(disposing); } } } } public override Task WriteAsync(byte[] array, int offset, int count, CancellationToken cancellationToken) { EnsureCompressionMode(); if (_asyncOperations != 0) { throw new InvalidOperationException("Only one asynchronous reader or writer is allowed time at one time."); } ValidateParameters(array, offset, count); EnsureNotDisposed(); if (cancellationToken.IsCancellationRequested) { return Task.FromCanceled<int>(cancellationToken); } return WriteAsyncCore(array, offset, count, cancellationToken); } private async Task WriteAsyncCore(byte[] array, int offset, int count, CancellationToken cancellationToken) { Interlocked.Increment(ref _asyncOperations); try { await base.WriteAsync(array, offset, count, cancellationToken).ConfigureAwait(continueOnCapturedContext: false); } finally { Interlocked.Decrement(ref _asyncOperations); } } public override IAsyncResult BeginWrite(byte[] buffer, int offset, int count, AsyncCallback asyncCallback, object asyncState) { return System.Threading.Tasks.TaskToApm.Begin(WriteAsync(buffer, offset, count, CancellationToken.None), asyncCallback, asyncState); } public override void EndWrite(IAsyncResult asyncResult) { System.Threading.Tasks.TaskToApm.End(asyncResult); } } internal sealed class DeflaterManaged : IDisposable { private enum DeflaterState { NotStarted, SlowDownForIncompressible1, SlowDownForIncompressible2, StartingSmallData, CompressThenCheck, CheckingForIncompressible, HandlingSmallData } private const int MinBlockSize = 256; private const int MaxHeaderFooterGoo = 120; private const int CleanCopySize = 8072; private const double BadCompressionThreshold = 1.0; private readonly FastEncoder _deflateEncoder; private readonly CopyEncoder _copyEncoder; private readonly DeflateInput _input; private readonly OutputBuffer _output; private DeflaterState _processingState; private DeflateInput _inputFromHistory; internal DeflaterManaged() { _deflateEncoder = new FastEncoder(); _copyEncoder = new CopyEncoder(); _input = new DeflateInput(); _output = new OutputBuffer(); _processingState = DeflaterState.NotStarted; } internal bool NeedsInput() { if (_input.Count == 0) { return _deflateEncoder.BytesInHistory == 0; } return false; } internal void SetInput(byte[] inputBuffer, int startIndex, int count) { _input.Buffer = inputBuffer; _input.Count = count; _input.StartIndex = startIndex; if (count > 0 && count < 256) { switch (_processingState) { case DeflaterState.NotStarted: case DeflaterState.CheckingForIncompressible: _processingState = DeflaterState.StartingSmallData; break; case DeflaterState.CompressThenCheck: _processingState = DeflaterState.HandlingSmallData; break; } } } internal int GetDeflateOutput(byte[] outputBuffer) { _output.UpdateBuffer(outputBuffer); switch (_processingState) { case DeflaterState.NotStarted: { DeflateInput.InputState state3 = _input.DumpState(); OutputBuffer.BufferState state4 = _output.DumpState(); _deflateEncoder.GetBlockHeader(_output); _deflateEncoder.GetCompressedData(_input, _output); if (!UseCompressed(_deflateEncoder.LastCompressionRatio)) { _input.RestoreState(state3); _output.RestoreState(state4); _copyEncoder.GetBlock(_input, _output, isFinal: false); FlushInputWindows(); _processingState = DeflaterState.CheckingForIncompressible; } else { _processingState = DeflaterState.CompressThenCheck; } break; } case DeflaterState.CompressThenCheck: _deflateEncoder.GetCompressedData(_input, _output); if (!UseCompressed(_deflateEncoder.LastCompressionRatio)) { _processingState = DeflaterState.SlowDownForIncompressible1; _inputFromHistory = _deflateEncoder.UnprocessedInput; } break; case DeflaterState.SlowDownForIncompressible1: _deflateEncoder.GetBlockFooter(_output); _processingState = DeflaterState.SlowDownForIncompressible2; goto case DeflaterState.SlowDownForIncompressible2; case DeflaterState.SlowDownForIncompressible2: if (_inputFromHistory.Count > 0) { _copyEncoder.GetBlock(_inputFromHistory, _output, isFinal: false); } if (_inputFromHistory.Count == 0) { _deflateEncoder.FlushInput(); _processingState = DeflaterState.CheckingForIncompressible; } break; case DeflaterState.CheckingForIncompressible: { DeflateInput.InputState state = _input.DumpState(); OutputBuffer.BufferState state2 = _output.DumpState(); _deflateEncoder.GetBlock(_input, _output, 8072); if (!UseCompressed(_deflateEncoder.LastCompressionRatio)) { _input.RestoreState(state); _output.RestoreState(state2); _copyEncoder.GetBlock(_input, _output, isFinal: false); FlushInputWindows(); } break; } case DeflaterState.StartingSmallData: _deflateEncoder.GetBlockHeader(_output); _processingState = DeflaterState.HandlingSmallData; goto case DeflaterState.HandlingSmallData; case DeflaterState.HandlingSmallData: _deflateEncoder.GetCompressedData(_input, _output); break; } return _output.BytesWritten; } internal bool Finish(byte[] outputBuffer, out int bytesRead) { if (_processingState == DeflaterState.NotStarted) { bytesRead = 0; return true; } _output.UpdateBuffer(outputBuffer); if (_processingState == DeflaterState.CompressThenCheck || _processingState == DeflaterState.HandlingSmallData || _processingState == DeflaterState.SlowDownForIncompressible1) { _deflateEncoder.GetBlockFooter(_output); } WriteFinal(); bytesRead = _output.BytesWritten; return true; } private bool UseCompressed(double ratio) { return ratio <= 1.0; } private void FlushInputWindows() { _deflateEncoder.FlushInput(); } private void WriteFinal() { _copyEncoder.GetBlock(null, _output, isFinal: true); } public void Dispose() { } } internal sealed class FastEncoder { private readonly FastEncoderWindow _inputWindow; private readonly Match _currentMatch; private double _lastCompressionRatio; internal int BytesInHistory => _inputWindow.BytesAvailable; internal DeflateInput UnprocessedInput => _inputWindow.UnprocessedInput; internal double LastCompressionRatio => _lastCompressionRatio; public FastEncoder() { _inputWindow = new FastEncoderWindow(); _currentMatch = new Match(); } internal void FlushInput() { _inputWindow.FlushWindow(); } internal void GetBlock(DeflateInput input, OutputBuffer output, int maxBytesToCopy) { WriteDeflatePreamble(output); GetCompressedOutput(input, output, maxBytesToCopy); WriteEndOfBlock(output); } internal void GetCompressedData(DeflateInput input, OutputBuffer output) { GetCompressedOutput(input, output, -1); } internal void GetBlockHeader(OutputBuffer output) { WriteDeflatePreamble(output); } internal void GetBlockFooter(OutputBuffer output) { WriteEndOfBlock(output); } private void GetCompressedOutput(DeflateInput input, OutputBuffer output, int maxBytesToCopy) { int bytesWritten = output.BytesWritten; int num = 0; int num2 = BytesInHistory + input.Count; do { int num3 = ((input.Count < _inputWindow.FreeWindowSpace) ? input.Count : _inputWindow.FreeWindowSpace); if (maxBytesToCopy >= 1) { num3 = Math.Min(num3, maxBytesToCopy - num); } if (num3 > 0) { _inputWindow.CopyBytes(input.Buffer, input.StartIndex, num3); input.ConsumeBytes(num3); num += num3; } GetCompressedOutput(output); } while (SafeToWriteTo(output) && InputAvailable(input) && (maxBytesToCopy < 1 || num < maxBytesToCopy)); int num4 = output.BytesWritten - bytesWritten; int num5 = BytesInHistory + input.Count; int num6 = num2 - num5; if (num4 != 0) { _lastCompressionRatio = (double)num4 / (double)num6; } } private void GetCompressedOutput(OutputBuffer output) { while (_inputWindow.BytesAvailable > 0 && SafeToWriteTo(output)) { _inputWindow.GetNextSymbolOrMatch(_currentMatch); if (_currentMatch.State == MatchState.HasSymbol) { WriteChar(_currentMatch.Symbol, output); continue; } if (_currentMatch.State == MatchState.HasMatch) { WriteMatch(_currentMatch.Length, _currentMatch.Position, output); continue; } WriteChar(_currentMatch.Symbol, output); WriteMatch(_currentMatch.Length, _currentMatch.Position, output); } } private bool InputAvailable(DeflateInput input) { if (input.Count <= 0) { return BytesInHistory > 0; } return true; } private bool SafeToWriteTo(OutputBuffer output) { return output.FreeBytes > 16; } private void WriteEndOfBlock(OutputBuffer output) { uint num = FastEncoderStatics.FastEncoderLiteralCodeInfo[256]; int n = (int)(num & 0x1F); output.WriteBits(n, num >> 5); } internal static void WriteMatch(int matchLen, int matchPos, OutputBuffer output) { uint num = FastEncoderStatics.FastEncoderLiteralCodeInfo[254 + matchLen]; int num2 = (int)(num & 0x1F); if (num2 <= 16) { output.WriteBits(num2, num >> 5); } else { output.WriteBits(16, (num >> 5) & 0xFFFFu); output.WriteBits(num2 - 16, num >> 21); } num = FastEncoderStatics.FastEncoderDistanceCodeInfo[FastEncoderStatics.GetSlot(matchPos)]; output.WriteBits((int)(num & 0xF), num >> 8); int num3 = (int)((num >> 4) & 0xF); if (num3 != 0) { output.WriteBits(num3, (uint)matchPos & FastEncoderStatics.BitMask[num3]); } } internal static void WriteChar(byte b, OutputBuffer output) { uint num = FastEncoderStatics.FastEncoderLiteralCodeInfo[b]; output.WriteBits((int)(num & 0x1F), num >> 5); } internal static void WriteDeflatePreamble(OutputBuffer output) { output.WriteBytes(FastEncoderStatics.FastEncoderTreeStructureData, 0, FastEncoderStatics.FastEncoderTreeStructureData.Length); output.WriteBits(9, 34u); } } internal static class FastEncoderStatics { internal static readonly byte[] FastEncoderTreeStructureData = new byte[98] { 236, 189, 7, 96, 28, 73, 150, 37, 38, 47, 109, 202, 123, 127, 74, 245, 74, 215, 224, 116, 161, 8, 128, 96, 19, 36, 216, 144, 64, 16, 236, 193, 136, 205, 230, 146, 236, 29, 105, 71, 35, 41, 171, 42, 129, 202, 101, 86, 101, 93, 102, 22, 64, 204, 237, 157, 188, 247, 222, 123, 239, 189, 247, 222, 123, 239, 189, 247, 186, 59, 157, 78, 39, 247, 223, 255, 63, 92, 102, 100, 1, 108, 246, 206, 74, 218, 201, 158, 33, 128, 170, 200, 31, 63, 126, 124, 31, 63 }; internal static readonly byte[] BFinalFastEncoderTreeStructureData = new byte[98] { 237, 189, 7, 96, 28, 73, 150, 37, 38, 47, 109, 202, 123, 127, 74, 245, 74, 215, 224, 116, 161, 8, 128, 96, 19, 36, 216, 144, 64, 16, 236, 193, 136, 205, 230, 146, 236, 29, 105, 71, 35, 41, 171, 42, 129, 202, 101, 86, 101, 93, 102, 22, 64, 204, 237, 157, 188, 247, 222, 123, 239, 189, 247, 222, 123, 239, 189, 247, 186, 59, 157, 78, 39, 247, 223, 255, 63, 92, 102, 100, 1, 108, 246, 206, 74, 218, 201, 158, 33, 128, 170, 200, 31, 63, 126, 124, 31, 63 }; internal static readonly uint[] FastEncoderLiteralCodeInfo = new uint[513] { 55278u, 317422u, 186350u, 448494u, 120814u, 382958u, 251886u, 514030u, 14318u, 51180u, 294u, 276462u, 145390u, 407534u, 79854u, 341998u, 210926u, 473070u, 47086u, 309230u, 178158u, 440302u, 112622u, 374766u, 243694u, 505838u, 30702u, 292846u, 161774u, 423918u, 6125u, 96238u, 1318u, 358382u, 9194u, 116716u, 227310u, 489454u, 137197u, 25578u, 2920u, 3817u, 23531u, 5098u, 1127u, 7016u, 3175u, 12009u, 1896u, 5992u, 3944u, 7913u, 8040u, 16105u, 21482u, 489u, 232u, 8681u, 4585u, 4328u, 12777u, 13290u, 2280u, 63470u, 325614u, 6376u, 2537u, 1256u, 10729u, 5352u, 6633u, 29674u, 56299u, 3304u, 15339u, 194542u, 14825u, 3050u, 1513u, 19434u, 9705u, 10220u, 5609u, 13801u, 3561u, 11242u, 75756u, 48107u, 456686u, 129006u, 42988u, 31723u, 391150u, 64491u, 260078u, 522222u, 4078u, 806u, 615u, 2663u, 1639u, 1830u, 7400u, 744u, 3687u, 166u, 108524u, 11753u, 1190u, 359u, 2407u, 678u, 1383u, 71661u, 1702u, 422u, 1446u, 3431u, 4840u, 2792u, 7657u, 6888u, 2027u, 202733u, 26604u, 38893u, 169965u, 266222u, 135150u, 397294u, 69614u, 331758u, 200686u, 462830u, 36846u, 298990u, 167918u, 430062u, 102382u, 364526u, 233454u, 495598u, 20462u, 282606u, 151534u, 413678u, 85998u, 348142u, 217070u, 479214u, 53230u, 315374u, 184302u, 446446u, 118766u, 380910u, 249838u, 511982u, 12270u, 274414u, 143342u, 405486u, 77806u, 339950u, 208878u, 471022u, 45038u, 307182u, 176110u, 438254u, 110574u, 372718u, 241646u, 503790u, 28654u, 290798u, 159726u, 421870u, 94190u, 356334u, 225262u, 487406u, 61422u, 323566u, 192494u, 454638u, 126958u, 389102u, 258030u, 520174u, 8174u, 270318u, 139246u, 401390u, 73710u, 335854u, 204782u, 466926u, 40942u, 303086u, 172014u, 434158u, 106478u, 368622u, 237550u, 499694u, 24558u, 286702u, 155630u, 417774u, 90094u, 352238u, 221166u, 483310u, 57326u, 319470u, 188398u, 450542u, 122862u, 385006u, 253934u, 516078u, 16366u, 278510u, 147438u, 409582u, 81902u, 344046u, 212974u, 475118u, 49134u, 311278u, 180206u, 442350u, 114670u, 376814u, 245742u, 507886u, 32750u, 294894u, 163822u, 425966u, 98286u, 104429u, 235501u, 22509u, 360430u, 153581u, 229358u, 88045u, 491502u, 219117u, 65518u, 327662u, 196590u, 458734u, 131054u, 132u, 3u, 388u, 68u, 324u, 197u, 709u, 453u, 966u, 1990u, 38u, 1062u, 935u, 2983u, 1959u, 4007u, 551u, 1575u, 2599u, 3623u, 104u, 2152u, 4200u, 6248u, 873u, 4969u, 9065u, 13161u, 1770u, 9962u, 18154u, 26346u, 5867u, 14059u, 22251u, 30443u, 38635u, 46827u, 55019u, 63211u, 15852u, 32236u, 48620u, 65004u, 81388u, 97772u, 114156u, 130540u, 27629u, 60397u, 93165u, 125933u, 158701u, 191469u, 224237u, 257005u, 1004u, 17388u, 33772u, 50156u, 66540u, 82924u, 99308u, 115692u, 7150u, 39918u, 72686u, 105454u, 138222u, 170990u, 203758u, 236526u, 269294u, 302062u, 334830u, 367598u, 400366u, 433134u, 465902u, 498670u, 92144u, 223216u, 354288u, 485360u, 616432u, 747504u, 878576u, 1009648u, 1140720u, 1271792u, 1402864u, 1533936u, 1665008u, 1796080u, 1927152u, 2058224u, 34799u, 100335u, 165871u, 231407u, 296943u, 362479u, 428015u, 493551u, 559087u, 624623u, 690159u, 755695u, 821231u, 886767u, 952303u, 1017839u, 59376u, 190448u, 321520u, 452592u, 583664u, 714736u, 845808u, 976880u, 1107952u, 1239024u, 1370096u, 1501168u, 1632240u, 1763312u, 1894384u, 2025456u, 393203u, 917491u, 1441779u, 1966067u, 2490355u, 3014643u, 3538931u, 4063219u, 4587507u, 5111795u, 5636083u, 6160371u, 6684659u, 7208947u, 7733235u, 8257523u, 8781811u, 9306099u, 9830387u, 10354675u, 10878963u, 11403251u, 11927539u, 12451827u, 12976115u, 13500403u, 14024691u, 14548979u, 15073267u, 15597555u, 16121843u, 16646131u, 262131u, 786419u, 1310707u, 1834995u, 2359283u, 2883571u, 3407859u, 3932147u, 4456435u, 4980723u, 5505011u, 6029299u, 6553587u, 7077875u, 7602163u, 8126451u, 8650739u, 9175027u, 9699315u, 10223603u, 10747891u, 11272179u, 11796467u, 12320755u, 12845043u, 13369331u, 13893619u, 14417907u, 14942195u, 15466483u, 15990771u, 16515059u, 524275u, 1048563u, 1572851u, 2097139u, 2621427u, 3145715u, 3670003u, 4194291u, 4718579u, 5242867u, 5767155u, 6291443u, 6815731u, 7340019u, 7864307u, 8388595u, 8912883u, 9437171u, 9961459u, 10485747u, 11010035u, 11534323u, 12058611u, 12582899u, 13107187u, 13631475u, 14155763u, 14680051u, 15204339u, 15728627u, 16252915u, 16777203u, 124913u, 255985u, 387057u, 518129u, 649201u, 780273u, 911345u, 1042417u, 1173489u, 1304561u, 1435633u, 1566705u, 1697777u, 1828849u, 1959921u, 2090993u, 2222065u, 2353137u, 2484209u, 2615281u, 2746353u, 2877425u, 3008497u, 3139569u, 3270641u, 3401713u, 3532785u, 3663857u, 3794929u, 3926001u, 4057073u, 18411u }; internal static readonly uint[] FastEncoderDistanceCodeInfo = new uint[32] { 3846u, 130826u, 261899u, 524043u, 65305u, 16152u, 48936u, 32552u, 7991u, 24375u, 3397u, 12102u, 84u, 7509u, 2148u, 869u, 1140u, 4981u, 3204u, 644u, 2708u, 1684u, 3748u, 420u, 2484u, 2997u, 1476u, 7109u, 2005u, 6101u, 0u, 256u }; internal static readonly uint[] BitMask = new uint[16] { 0u, 1u, 3u, 7u, 15u, 31u, 63u, 127u, 255u, 511u, 1023u, 2047u, 4095u, 8191u, 16383u, 32767u }; internal static readonly byte[] ExtraLengthBits = new byte[29] { 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0 }; internal static readonly byte[] ExtraDistanceBits = new byte[32] { 0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 0, 0 }; internal const int NumChars = 256; internal const int NumLengthBaseCodes = 29; internal const int NumDistBaseCodes = 30; internal const uint FastEncoderPostTreeBitBuf = 34u; internal const int FastEncoderPostTreeBitCount = 9; internal const uint NoCompressionHeader = 0u; internal const int NoCompressionHeaderBitCount = 3; internal const uint BFinalNoCompressionHeader = 1u; internal const int BFinalNoCompressionHeaderBitCount = 3; internal const int MaxCodeLen = 16; private static readonly byte[] s_distLookup = CreateDistanceLookup(); private static byte[] CreateDistanceLookup() { byte[] array = new byte[512]; int num = 0; int i; for (i = 0; i < 16; i++) { for (int j = 0; j < 1 << (int)ExtraDistanceBits[i]; j++) { array[num++] = (byte)i; } } num >>= 7; for (; i < 30; i++) { for (int k = 0; k < 1 << ExtraDistanceBits[i] - 7; k++) { array[256 + num++] = (byte)i; } } return array; } internal static int GetSlot(int pos) { return s_distLookup[(pos < 256) ? pos : (256 + (pos >> 7))]; } public static uint BitReverse(uint code, int length) { uint num = 0u; do { num |= code & 1u; num <<= 1; code >>= 1; } while (--length > 0); return num >> 1; } } internal sealed class FastEncoderWindow { private byte[] _window; private int _bufPos; private int _bufEnd; private const int FastEncoderHashShift = 4; private const int FastEncoderHashtableSize = 2048; private const int FastEncoderHashMask = 2047; private const int FastEncoderWindowSize = 8192; private const int FastEncoderWindowMask = 8191; private const int FastEncoderMatch3DistThreshold = 16384; internal const int MaxMatch = 258; internal const int MinMatch = 3; private const int SearchDepth = 32; private const int GoodLength = 4; private const int NiceLength = 32; private const int LazyMatchThreshold = 6; private ushort[] _prev; private ushort[] _lookup; public int BytesAvailable => _bufEnd - _bufPos; public DeflateInput UnprocessedInput => new DeflateInput { Buffer = _window, StartIndex = _bufPos, Count = _bufEnd - _bufPos }; public int FreeWindowSpace => 16384 - _bufEnd; public FastEncoderWindow() { ResetWindow(); } public void FlushWindow() { ResetWindow(); } private void ResetWindow() { _window = new byte[16646]; _prev = new ushort[8450]; _lookup = new ushort[2048]; _bufPos = 8192; _bufEnd = _bufPos; } public void CopyBytes(byte[] inputBuffer, int startIndex, int count) { Array.Copy(inputBuffer, startIndex, _window, _bufEnd, count); _bufEnd += count; } public void MoveWindows() { Array.Copy(_window, _bufPos - 8192, _window, 0, 8192); for (int i = 0; i < 2048; i++) { int num = _lookup[i] - 8192; if (num <= 0) { _lookup[i] = 0; } else { _lookup[i] = (ushort)num; } } for (int i = 0; i < 8192; i++) { long num2 = (long)_prev[i] - 8192L; if (num2 <= 0) { _prev[i] = 0; } else { _prev[i] = (ushort)num2; } } _bufPos = 8192; _bufEnd = _bufPos; } private uint HashValue(uint hash, byte b) { return (hash << 4) ^ b; } private uint InsertString(ref uint hash) { hash = HashValue(hash, _window[_bufPos + 2]); uint num = _lookup[hash & 0x7FF]; _lookup[hash & 0x7FF] = (ushort)_bufPos; _prev[_bufPos & 0x1FFF] = (ushort)num; return num; } private void InsertStrings(ref uint hash, int matchLen) { if (_bufEnd - _bufPos <= matchLen) { _bufPos += matchLen - 1; return; } while (--matchLen > 0) { InsertString(ref hash); _bufPos++; } } internal bool GetNextSymbolOrMatch(Match match) { uint hash = HashValue(0u, _window[_bufPos]); hash = HashValue(hash, _window[_bufPos + 1]); int matchPos = 0; int num; if (_bufEnd - _bufPos <= 3) { num = 0; } else { int num2 = (int)InsertString(ref hash); if (num2 != 0) { num = FindMatch(num2, out matchPos, 32, 32); if (_bufPos + num > _bufEnd) { num = _bufEnd - _bufPos; } } else { num = 0; } } if (num < 3) { match.State = MatchState.HasSymbol; match.Symbol = _window[_bufPos]; _bufPos++; } else { _bufPos++; if (num <= 6) { int matchPos2 = 0; int num3 = (int)InsertString(ref hash); int num4; if (num3 != 0) { num4 = FindMatch(num3, out matchPos2, (num < 4) ? 32 : 8, 32); if (_bufPos + num4 > _bufEnd) { num4 = _bufEnd - _bufPos; } } else { num4 = 0; } if (num4 > num) { match.State = MatchState.HasSymbolAndMatch; match.Symbol = _window[_bufPos - 1]; match.Position = matchPos2; match.Length = num4; _bufPos++; num = num4; InsertStrings(ref hash, num); } else { match.State = MatchState.HasMatch; match.Position = matchPos; match.Length = num; num--; _bufPos++; InsertStrings(ref hash, num); } } else { match.State = MatchState.HasMatch; match.Position = matchPos; match.Length = num; InsertStrings(ref hash, num); } } if (_bufPos == 16384) { MoveWindows(); } return true; } private int FindMatch(int search, out int matchPos, int searchDepth, int niceLength) { int num = 0; int num2 = 0; int num3 = _bufPos - 8192; byte b = _window[_bufPos]; while (search > num3) { if (_window[search + num] == b) { int i; for (i = 0; i < 258 && _window[_bufPos + i] == _window[search + i]; i++) { } if (i > num) { num = i; num2 = search; if (i > 32) { break; } b = _window[_bufPos + i]; } } if (--searchDepth == 0) { break; } search = _prev[search & 0x1FFF]; } matchPos = _bufPos - num2 - 1; if (num == 3 && matchPos >= 16384) { return 0; } return num; } [Conditional("DEBUG")] private void DebugAssertVerifyHashes() { } [Conditional("DEBUG")] private void DebugAssertRecalculatedHashesAreEqual(int position1, int position2, string message = "") { } } internal interface IFileFormatWriter { byte[] GetHeader(); void UpdateWithBytesRead(byte[] buffer, int offset, int bytesToCopy); byte[] GetFooter(); } internal interface IFileFormatReader { bool ReadHeader(System.IO.Compression.InputBuffer input); bool ReadFooter(System.IO.Compression.InputBuffer input); void UpdateWithBytesRead(byte[] buffer, int offset, int bytesToCopy); void Validate(); } internal sealed class HuffmanTree { internal const int MaxLiteralTreeElements = 288; internal const int MaxDistTreeElements = 32; internal const int EndOfBlockCode = 256; internal const int NumberOfCodeLengthTreeElements = 19; private readonly int _tableBits; private readonly short[] _table; private readonly short[] _left; private readonly short[] _right; private readonly byte[] _codeLengthArray; private readonly int _tableMask; public static System.IO.Compression.HuffmanTree StaticLiteralLengthTree { get; } = new System.IO.Compression.HuffmanTree(GetStaticLiteralTreeLength()); public static System.IO.Compression.HuffmanTree StaticDistanceTree { get; } = new System.IO.Compression.HuffmanTree(GetStaticDistanceTreeLength()); public HuffmanTree(byte[] codeLengths) { _codeLengthArray = codeLengths; if (_codeLengthArray.Length == 288) { _tableBits = 9; } else { _tableBits = 7; } _tableMask = (1 << _tableBits) - 1; _table = new short[1 << _tableBits]; _left = new short[2 * _codeLengthArray.Length]; _right = new short[2 * _codeLengthArray.Length]; CreateTable(); } private static byte[] GetStaticLiteralTreeLength() { byte[] array = new byte[288]; for (int i = 0; i <= 143; i++) { array[i] = 8; } for (int j = 144; j <= 255; j++) { array[j] = 9; } for (int k = 256; k <= 279; k++) { array[k] = 7; } for (int l = 280; l <= 287; l++) { array[l] = 8; } return array; } private static byte[] GetStaticDistanceTreeLength() { byte[] array = new byte[32]; for (int i = 0; i < 32; i++) { array[i] = 5; } return array; } private uint[] CalculateHuffmanCode() { uint[] array = new uint[17]; byte[] codeLengthArray = _codeLengthArray; foreach (int num in codeLengthArray) { array[num]++; } array[0] = 0u; uint[] array2 = new uint[17]; uint num2 = 0u; for (int j = 1; j <= 16; j++) { num2 = (array2[j] = num2 + array[j - 1] << 1); } uint[] array3 = new uint[288]; for (int k = 0; k < _codeLengthArray.Length; k++) { int num3 = _codeLengthArray[k]; if (num3 > 0) { array3[k] = FastEncoderStatics.BitReverse(array2[num3], num3); array2[num3]++; } } return array3; } private void CreateTable() { uint[] array = CalculateHuffmanCode(); short num = (short)_codeLengthArray.Length; for (int i = 0; i < _codeLengthArray.Length; i++) { int num2 = _codeLengthArray[i]; if (num2 <= 0) { continue; } int num3 = (int)array[i]; if (num2 <= _tableBits) { int num4 = 1 << num2; if (num3 >= num4) { throw new InvalidDataException("Failed to construct a huffman tree using the length array. The stream might be corrupted."); } int num5 = 1 << _tableBits - num2; for (int j = 0; j < num5; j++) { _table[num3] = (short)i; num3 += num4; } continue; } int num6 = num2 - _tableBits; int num7 = 1 << _tableBits; int num8 = num3 & ((1 << _tableBits) - 1); short[] array2 = _table; do { short num9 = array2[num8]; if (num9 == 0) { array2[num8] = (short)(-num); num9 = (short)(-num); num++; } if (num9 > 0) { throw new InvalidDataException("Failed to construct a huffman tree using the length array. The stream might be corrupted."); } array2 = (((num3 & num7) != 0) ? _right : _left); num8 = -num9; num7 <<= 1; num6--; } while (num6 != 0); array2[num8] = (short)i; } } public int GetNextSymbol(System.IO.Compression.InputBuffer input) { uint num = input.TryLoad16Bits(); if (input.AvailableBits == 0) { return -1; } int num2 = _table[num & _tableMask]; if (num2 < 0) { uint num3 = (uint)(1 << _tableBits); do { num2 = -num2; num2 = (((num & num3) != 0) ? _right[num2] : _left[num2]); num3 <<= 1; } while (num2 < 0); } int num4 = _codeLengthArray[num2]; if (num4 <= 0) { throw new InvalidDataException("Failed to construct a huffman tree using the length array. The stream might be corrupted."); } if (num4 > input.AvailableBits) { return -1; } input.SkipBits(num4); return num2; } } internal sealed class InflaterManaged { private static readonly byte[] s_extraLengthBits = new byte[29] { 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 16 }; private static readonly int[] s_lengthBase = new int[29] { 3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31, 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 3 }; private static readonly int[] s_distanceBasePosition = new int[32] { 1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193, 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, 8193, 12289, 16385, 24577, 32769, 49153 }; private static readonly byte[] s_codeOrder = new byte[19] { 16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15 }; private static readonly byte[] s_staticDistanceTreeTable = new byte[32] { 0, 16, 8, 24, 4, 20, 12, 28, 2, 18, 10, 26, 6, 22, 14, 30, 1, 17, 9, 25, 5, 21, 13, 29, 3, 19, 11, 27, 7, 23, 15, 31 }; private readonly System.IO.Compression.OutputWindow _output; private readonly System.IO.Compression.InputBuffer _input; private System.IO.Compression.HuffmanTree _literalLengthTree; private System.IO.Compression.HuffmanTree _distanceTree; private System.IO.Compression.InflaterState _state; private bool _hasFormatReader; private int _bfinal; private System.IO.Compression.BlockType _blockType; private readonly byte[] _blockLengthBuffer = new byte[4]; private int _blockLength; private int _length; private int _distanceCode; private int _extraBits; private int _loopCounter; private int _literalLengthCodeCount; private int _distanceCodeCount; private int _codeLengthCodeCount; private int _codeArraySize; private int _lengthCode; private readonly byte[] _codeList; private readonly byte[] _codeLengthTreeCodeLength; private readonly bool _deflate64; private System.IO.Compression.HuffmanTree _codeLengthTree; private IFileFormatReader _formatReader; public int AvailableOutput => _output.AvailableBytes; internal InflaterManaged(IFileFormatReader reader, bool deflate64) { _output = new System.IO.Compression.OutputWindow(); _input = new System.IO.Compression.InputBuffer(); _codeList = new byte[320]; _codeLengthTreeCodeLength = new byte[19]; _deflate64 = deflate64; if (reader != null) { _formatReader = reader; _hasFormatReader = true; } Reset(); } private void Reset() { _state = ((!_hasFormatReader) ? System.IO.Compression.InflaterState.ReadingBFinal : System.IO.Compression.InflaterState.ReadingHeader); } public void SetInput(byte[] inputBytes, int offset, int length) { _input.SetInput(inputBytes, offset, length); } public bool Finished() { if (_state != System.IO.Compression.InflaterState.Done) { return _state == System.IO.Compression.InflaterState.VerifyingFooter; } return true; } public int Inflate(byte[] bytes, int offset, int length) { int num = 0; do { int num2 = _output.CopyTo(bytes, offset, length); if (num2 > 0) { if (_hasFormatReader) { _formatReader.UpdateWithBytesRead(bytes, offset, num2); } offset += num2; num += num2; length -= num2; } } while (length != 0 && !Finished() && Decode()); if (_state == System.IO.Compression.InflaterState.VerifyingFooter && _output.AvailableBytes == 0) { _formatReader.Validate(); } return num; } private bool Decode() { bool end_of_block_code_seen = false; bool flag = false; if (Finished()) { return true; } if (_hasFormatReader) { if (_state == System.IO.Compression.InflaterState.ReadingHeader) { if (!_formatReader.ReadHeader(_input)) { return false; } _state = System.IO.Compression.InflaterState.ReadingBFinal; } else if (_state == System.IO.Compression.InflaterState.StartReadingFooter || _state == System.IO.Compression.InflaterState.ReadingFooter) { if (!_formatReader.ReadFooter(_input)) { return false; } _state = System.IO.Compression.InflaterState.VerifyingFooter; return true; } } if (_state == System.IO.Compression.InflaterState.ReadingBFinal) { if (!_input.EnsureBitsAvailable(1)) { return false; } _bfinal = _input.GetBits(1); _state = System.IO.Compression.InflaterState.ReadingBType; } if (_state == System.IO.Compression.InflaterState.ReadingBType) { if (!_input.EnsureBitsAvailable(2)) { _state = System.IO.Compression.InflaterState.ReadingBType; return false; } _blockType = (System.IO.Compression.BlockType)_input.GetBits(2); if (_blockType == System.IO.Compression.BlockType.Dynamic) { _state = System.IO.Compression.InflaterState.ReadingNumLitCodes; } else if (_blockType == System.IO.Compression.BlockType.Static) { _literalLengthTree = System.IO.Compression.HuffmanTree.StaticLiteralLengthTree; _distanceTree = System.IO.Compression.HuffmanTree.
System.IO.Compression.FileSystem.dll
Decompiled a week agousing System.Buffers; using System.Collections.Generic; using System.ComponentModel; using System.Diagnostics; using System.Reflection; using System.Runtime.CompilerServices; using System.Security; using System.Security.Permissions; using System.Text; [assembly: AssemblyFileVersion("4.6.57.0")] [assembly: AssemblyInformationalVersion("4.6.57.0")] [assembly: AssemblyCopyright("(c) Various Mono authors")] [assembly: AssemblyProduct("Mono Common Language Infrastructure")] [assembly: AssemblyCompany("Mono development team")] [assembly: AssemblyDefaultAlias("System.IO.Compression.FileSystem.dll")] [assembly: AssemblyDescription("System.IO.Compression.FileSystem.dll")] [assembly: AssemblyTitle("System.IO.Compression.FileSystem.dll")] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: CompilationRelaxations(8)] [assembly: AssemblyDelaySign(true)] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("4.0.0.0")] [module: UnverifiableCode] internal static class Consts { public const string MonoCorlibVersion = "1A5E0066-58DC-428A-B21C-0AD6CDAE2789"; public const string MonoVersion = "6.13.0.0"; public const string MonoCompany = "Mono development team"; public const string MonoProduct = "Mono Common Language Infrastructure"; public const string MonoCopyright = "(c) Various Mono authors"; public const string FxVersion = "4.0.0.0"; public const string FxFileVersion = "4.6.57.0"; public const string EnvironmentVersion = "4.0.30319.42000"; public const string VsVersion = "0.0.0.0"; public const string VsFileVersion = "11.0.0.0"; private const string PublicKeyToken = "b77a5c561934e089"; public const string AssemblyI18N = "I18N, Version=4.0.0.0, Culture=neutral, PublicKeyToken=0738eb9f132ed756"; public const string AssemblyMicrosoft_JScript = "Microsoft.JScript, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblyMicrosoft_VisualStudio = "Microsoft.VisualStudio, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblyMicrosoft_VisualStudio_Web = "Microsoft.VisualStudio.Web, Version=0.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblyMicrosoft_VSDesigner = "Microsoft.VSDesigner, Version=0.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblyMono_Http = "Mono.Http, Version=4.0.0.0, Culture=neutral, PublicKeyToken=0738eb9f132ed756"; public const string AssemblyMono_Posix = "Mono.Posix, Version=4.0.0.0, Culture=neutral, PublicKeyToken=0738eb9f132ed756"; public const string AssemblyMono_Security = "Mono.Security, Version=4.0.0.0, Culture=neutral, PublicKeyToken=0738eb9f132ed756"; public const string AssemblyMono_Messaging_RabbitMQ = "Mono.Messaging.RabbitMQ, Version=4.0.0.0, Culture=neutral, PublicKeyToken=0738eb9f132ed756"; public const string AssemblyCorlib = "mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"; public const string AssemblySystem = "System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"; public const string AssemblySystem_Data = "System.Data, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"; public const string AssemblySystem_Design = "System.Design, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblySystem_DirectoryServices = "System.DirectoryServices, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblySystem_Drawing = "System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblySystem_Drawing_Design = "System.Drawing.Design, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblySystem_Messaging = "System.Messaging, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblySystem_Security = "System.Security, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblySystem_ServiceProcess = "System.ServiceProcess, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblySystem_Web = "System.Web, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"; public const string AssemblySystem_Windows_Forms = "System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"; public const string AssemblySystem_2_0 = "System, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"; public const string AssemblySystemCore_3_5 = "System.Core, Version=3.5.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"; public const string AssemblySystem_Core = "System.Core, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"; public const string WindowsBase_3_0 = "WindowsBase, Version=3.0.0.0, PublicKeyToken=31bf3856ad364e35"; public const string AssemblyWindowsBase = "WindowsBase, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"; public const string AssemblyPresentationCore_3_5 = "PresentationCore, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"; public const string AssemblyPresentationCore_4_0 = "PresentationCore, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"; public const string AssemblyPresentationFramework_3_5 = "PresentationFramework, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"; public const string AssemblySystemServiceModel_3_0 = "System.ServiceModel, Version=3.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"; } internal class SR { public const string IO_DirectoryNameWithData = "Zip entry name ends in directory separator character but contains data."; public const string IO_ExtractingResultsInOutside = "Extracting Zip entry would have resulted in a file outside the specified destination directory."; } namespace System.IO { internal static class PathInternal { private static readonly bool s_isCaseSensitive = GetIsCaseSensitive(); internal static StringComparison StringComparison { get { if (!s_isCaseSensitive) { return StringComparison.OrdinalIgnoreCase; } return StringComparison.Ordinal; } } internal static bool IsCaseSensitive => s_isCaseSensitive; private static bool GetIsCaseSensitive() { try { string text = Path.Combine(Path.GetTempPath(), "CASESENSITIVETEST" + Guid.NewGuid().ToString("N")); using (new FileStream(text, FileMode.CreateNew, FileAccess.ReadWrite, FileShare.None, 4096, FileOptions.DeleteOnClose)) { return !File.Exists(text.ToLowerInvariant()); } } catch (Exception) { return false; } } } } namespace System.IO.Compression { public static class ZipFile { private const char PathSeparator = '/'; public static ZipArchive OpenRead(string archiveFileName) { return Open(archiveFileName, ZipArchiveMode.Read); } public static ZipArchive Open(string archiveFileName, ZipArchiveMode mode) { return Open(archiveFileName, mode, null); } public static ZipArchive Open(string archiveFileName, ZipArchiveMode mode, Encoding entryNameEncoding) { FileMode mode2; FileAccess access; FileShare share; switch (mode) { case ZipArchiveMode.Read: mode2 = FileMode.Open; access = FileAccess.Read; share = FileShare.Read; break; case ZipArchiveMode.Create: mode2 = FileMode.CreateNew; access = FileAccess.Write; share = FileShare.None; break; case ZipArchiveMode.Update: mode2 = FileMode.OpenOrCreate; access = FileAccess.ReadWrite; share = FileShare.None; break; default: throw new ArgumentOutOfRangeException("mode"); } FileStream fileStream = new FileStream(archiveFileName, mode2, access, share, 4096, useAsync: false); try { return new ZipArchive(fileStream, mode, leaveOpen: false, entryNameEncoding); } catch { fileStream.Dispose(); throw; } } public static void CreateFromDirectory(string sourceDirectoryName, string destinationArchiveFileName) { DoCreateFromDirectory(sourceDirectoryName, destinationArchiveFileName, null, includeBaseDirectory: false, null); } public static void CreateFromDirectory(string sourceDirectoryName, string destinationArchiveFileName, CompressionLevel compressionLevel, bool includeBaseDirectory) { DoCreateFromDirectory(sourceDirectoryName, destinationArchiveFileName, compressionLevel, includeBaseDirectory, null); } public static void CreateFromDirectory(string sourceDirectoryName, string destinationArchiveFileName, CompressionLevel compressionLevel, bool includeBaseDirectory, Encoding entryNameEncoding) { DoCreateFromDirectory(sourceDirectoryName, destinationArchiveFileName, compressionLevel, includeBaseDirectory, entryNameEncoding); } public static void ExtractToDirectory(string sourceArchiveFileName, string destinationDirectoryName) { ExtractToDirectory(sourceArchiveFileName, destinationDirectoryName, null); } public static void ExtractToDirectory(string sourceArchiveFileName, string destinationDirectoryName, bool overwrite) { ExtractToDirectory(sourceArchiveFileName, destinationDirectoryName, null, overwrite); } public static void ExtractToDirectory(string sourceArchiveFileName, string destinationDirectoryName, Encoding entryNameEncoding) { ExtractToDirectory(sourceArchiveFileName, destinationDirectoryName, entryNameEncoding, overwrite: false); } public static void ExtractToDirectory(string sourceArchiveFileName, string destinationDirectoryName, Encoding entryNameEncoding, bool overwrite) { if (sourceArchiveFileName == null) { throw new ArgumentNullException("sourceArchiveFileName"); } using ZipArchive source = Open(sourceArchiveFileName, ZipArchiveMode.Read, entryNameEncoding); source.ExtractToDirectory(destinationDirectoryName, overwrite); } private static void DoCreateFromDirectory(string sourceDirectoryName, string destinationArchiveFileName, CompressionLevel? compressionLevel, bool includeBaseDirectory, Encoding entryNameEncoding) { sourceDirectoryName = Path.GetFullPath(sourceDirectoryName); destinationArchiveFileName = Path.GetFullPath(destinationArchiveFileName); using ZipArchive zipArchive = Open(destinationArchiveFileName, ZipArchiveMode.Create, entryNameEncoding); bool flag = true; DirectoryInfo directoryInfo = new DirectoryInfo(sourceDirectoryName); string fullName = directoryInfo.FullName; if (includeBaseDirectory && directoryInfo.Parent != null) { fullName = directoryInfo.Parent.FullName; } char[] buffer = ArrayPool<char>.Shared.Rent(260); try { foreach (FileSystemInfo item in directoryInfo.EnumerateFileSystemInfos("*", SearchOption.AllDirectories)) { flag = false; int length = item.FullName.Length - fullName.Length; if (item is FileInfo) { string entryName = EntryFromPath(item.FullName, fullName.Length, length, ref buffer); ZipFileExtensions.DoCreateEntryFromFile(zipArchive, item.FullName, entryName, compressionLevel); } else if (item is DirectoryInfo possiblyEmptyDir && IsDirEmpty(possiblyEmptyDir)) { string entryName2 = EntryFromPath(item.FullName, fullName.Length, length, ref buffer, appendPathSeparator: true); zipArchive.CreateEntry(entryName2); } } if (includeBaseDirectory && flag) { zipArchive.CreateEntry(EntryFromPath(directoryInfo.Name, 0, directoryInfo.Name.Length, ref buffer, appendPathSeparator: true)); } } finally { ArrayPool<char>.Shared.Return(buffer, false); } } private static string EntryFromPath(string entry, int offset, int length, ref char[] buffer, bool appendPathSeparator = false) { while (length > 0 && (entry[offset] == Path.DirectorySeparatorChar || entry[offset] == Path.AltDirectorySeparatorChar)) { offset++; length--; } if (length == 0) { if (!appendPathSeparator) { return string.Empty; } return '/'.ToString(); } int num = (appendPathSeparator ? (length + 1) : length); EnsureCapacity(ref buffer, num); entry.CopyTo(offset, buffer, 0, length); for (int i = 0; i < length; i++) { char c = buffer[i]; if (c == Path.DirectorySeparatorChar || c == Path.AltDirectorySeparatorChar) { buffer[i] = '/'; } } if (appendPathSeparator) { buffer[length] = '/'; } return new string(buffer, 0, num); } private static void EnsureCapacity(ref char[] buffer, int min) { if (buffer.Length < min) { int num = buffer.Length * 2; if (num < min) { num = min; } ArrayPool<char>.Shared.Return(buffer, false); buffer = ArrayPool<char>.Shared.Rent(num); } } private static bool IsDirEmpty(DirectoryInfo possiblyEmptyDir) { using IEnumerator<string> enumerator = Directory.EnumerateFileSystemEntries(possiblyEmptyDir.FullName).GetEnumerator(); return !enumerator.MoveNext(); } } [EditorBrowsable(EditorBrowsableState.Never)] public static class ZipFileExtensions { public static ZipArchiveEntry CreateEntryFromFile(this ZipArchive destination, string sourceFileName, string entryName) { return DoCreateEntryFromFile(destination, sourceFileName, entryName, null); } public static ZipArchiveEntry CreateEntryFromFile(this ZipArchive destination, string sourceFileName, string entryName, CompressionLevel compressionLevel) { return DoCreateEntryFromFile(destination, sourceFileName, entryName, compressionLevel); } public static void ExtractToDirectory(this ZipArchive source, string destinationDirectoryName) { source.ExtractToDirectory(destinationDirectoryName, overwrite: false); } public static void ExtractToDirectory(this ZipArchive source, string destinationDirectoryName, bool overwrite) { if (source == null) { throw new ArgumentNullException("source"); } if (destinationDirectoryName == null) { throw new ArgumentNullException("destinationDirectoryName"); } string text = Directory.CreateDirectory(destinationDirectoryName).FullName; if (!text.EndsWith(Path.DirectorySeparatorChar)) { text += Path.DirectorySeparatorChar; } foreach (ZipArchiveEntry entry in source.Entries) { string fullPath = Path.GetFullPath(Path.Combine(text, entry.FullName)); if (!fullPath.StartsWith(text, System.IO.PathInternal.StringComparison)) { throw new IOException("Extracting Zip entry would have resulted in a file outside the specified destination directory."); } if (Path.GetFileName(fullPath).Length == 0) { if (entry.Length != 0L) { throw new IOException("Zip entry name ends in directory separator character but contains data."); } Directory.CreateDirectory(fullPath); } else { Directory.CreateDirectory(Path.GetDirectoryName(fullPath)); entry.ExtractToFile(fullPath, overwrite); } } } internal static ZipArchiveEntry DoCreateEntryFromFile(ZipArchive destination, string sourceFileName, string entryName, CompressionLevel? compressionLevel) { if (destination == null) { throw new ArgumentNullException("destination"); } if (sourceFileName == null) { throw new ArgumentNullException("sourceFileName"); } if (entryName == null) { throw new ArgumentNullException("entryName"); } using Stream stream = new FileStream(sourceFileName, FileMode.Open, FileAccess.Read, FileShare.Read, 4096, useAsync: false); ZipArchiveEntry zipArchiveEntry = (compressionLevel.HasValue ? destination.CreateEntry(entryName, compressionLevel.Value) : destination.CreateEntry(entryName)); DateTime dateTime = File.GetLastWriteTime(sourceFileName); if (dateTime.Year < 1980 || dateTime.Year > 2107) { dateTime = new DateTime(1980, 1, 1, 0, 0, 0); } zipArchiveEntry.LastWriteTime = dateTime; using (Stream destination2 = zipArchiveEntry.Open()) { stream.CopyTo(destination2); } return zipArchiveEntry; } public static void ExtractToFile(this ZipArchiveEntry source, string destinationFileName) { source.ExtractToFile(destinationFileName, overwrite: false); } public static void ExtractToFile(this ZipArchiveEntry source, string destinationFileName, bool overwrite) { if (source == null) { throw new ArgumentNullException("source"); } if (destinationFileName == null) { throw new ArgumentNullException("destinationFileName"); } FileMode mode = ((!overwrite) ? FileMode.CreateNew : FileMode.Create); using (Stream destination = new FileStream(destinationFileName, mode, FileAccess.Write, FileShare.None, 4096, useAsync: false)) { using Stream stream = source.Open(); stream.CopyTo(destination); } File.SetLastWriteTime(destinationFileName, source.LastWriteTime.DateTime); } } }