using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Reflection;
using System.Runtime.CompilerServices;
using System.Runtime.Versioning;
using System.Security;
using System.Security.Permissions;
using System.Text.RegularExpressions;
using BepInEx;
using BepInEx.Bootstrap;
using BepInEx.Configuration;
using BepInEx.Logging;
using DeminishingReturns.Patches;
using HarmonyLib;
using LethalLevelLoader;
using LethalModDataLib.Attributes;
using LethalNetworkAPI;
using LobbyCompatibility.Attributes;
using Microsoft.CodeAnalysis;
using Unity.Netcode;
using UnityEngine;
[assembly: CompilationRelaxations(8)]
[assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)]
[assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)]
[assembly: TargetFramework(".NETStandard,Version=v2.1", FrameworkDisplayName = ".NET Standard 2.1")]
[assembly: AssemblyCompany("coookies369.DeminishingReturns")]
[assembly: AssemblyConfiguration("Release")]
[assembly: AssemblyFileVersion("1.3.1.0")]
[assembly: AssemblyInformationalVersion("1.3.1")]
[assembly: AssemblyProduct("DeminishingReturns")]
[assembly: AssemblyTitle("coookies369.DeminishingReturns")]
[assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)]
[assembly: AssemblyVersion("1.3.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;
}
}
}
public class Config
{
public static ConfigEntry<bool> resetAfterQuota;
public static ConfigEntry<float> dailyRegen;
public static ConfigEntry<float> reductionMultiplier;
public Config(ConfigFile cfg)
{
resetAfterQuota = cfg.Bind<bool>("General", "ResetAfterQuota", false, "Reset all scrap reduction after each quota cycle");
dailyRegen = cfg.Bind<float>("General", "DailyRegen", 0.25f, "How much of a moon's multiplier should be restored each day");
reductionMultiplier = cfg.Bind<float>("General", "ReductionMultiplier", 1f, "Multiplier for scrap reduction. For example: if a moon has a 100% multiplier, 9 of 12 scrap is collected, and reductionMultiplier is 0.5, the moon's final multiplier will be 62.5% instead of 25%");
}
}
namespace DeminishingReturns
{
[BepInPlugin("coookies369.DeminishingReturns", "DeminishingReturns", "1.3.1")]
[BepInDependency(/*Could not decode attribute arguments.*/)]
[LobbyCompatibility(/*Could not decode attribute arguments.*/)]
[BepInDependency(/*Could not decode attribute arguments.*/)]
[BepInDependency(/*Could not decode attribute arguments.*/)]
[BepInDependency(/*Could not decode attribute arguments.*/)]
public class Plugin : BaseUnityPlugin
{
[ModData(/*Could not decode attribute arguments.*/)]
public static Dictionary<int, float> moonMultipliers = new Dictionary<int, float>();
public static Plugin Instance { get; private set; } = null;
internal static ManualLogSource Logger { get; private set; } = null;
internal static Harmony Harmony { get; set; }
public static Config MyConfig { get; internal set; }
private void Awake()
{
Logger = ((BaseUnityPlugin)this).Logger;
Instance = this;
MyConfig = new Config(((BaseUnityPlugin)this).Config);
Patch();
StartOfRoundPatch.Init();
Logger.LogInfo((object)"coookies369.DeminishingReturns v1.3.1 has loaded!");
}
internal static void Patch()
{
//IL_000c: Unknown result type (might be due to invalid IL or missing references)
//IL_0011: Unknown result type (might be due to invalid IL or missing references)
//IL_0017: Expected O, but got Unknown
if (Harmony == null)
{
Harmony = new Harmony("coookies369.DeminishingReturns");
}
Logger.LogDebug((object)"Patching...");
Harmony.PatchAll();
if (Chainloader.PluginInfos.ContainsKey("imabatby.lethallevelloader"))
{
LLLTerminalPatch.Init();
}
Logger.LogDebug((object)"Finished patching!");
}
internal static void Unpatch()
{
Logger.LogDebug((object)"Unpatching...");
Harmony harmony = Harmony;
if (harmony != null)
{
harmony.UnpatchSelf();
}
Logger.LogDebug((object)"Finished unpatching!");
}
}
public static class MyPluginInfo
{
public const string PLUGIN_GUID = "coookies369.DeminishingReturns";
public const string PLUGIN_NAME = "DeminishingReturns";
public const string PLUGIN_VERSION = "1.3.1";
}
}
namespace DeminishingReturns.Patches
{
public class LLLTerminalPatch
{
internal static void Init()
{
//IL_002c: Unknown result type (might be due to invalid IL or missing references)
//IL_0039: Expected O, but got Unknown
Plugin.Harmony.Patch((MethodBase)AccessTools.Method(typeof(TerminalManager), "GetWeatherConditions", (Type[])null, (Type[])null), (HarmonyMethod)null, new HarmonyMethod(typeof(LLLTerminalPatch), "AddDeminishedWarning", (Type[])null), (HarmonyMethod)null, (HarmonyMethod)null, (HarmonyMethod)null);
}
[HarmonyPriority(0)]
private static void AddDeminishedWarning(ExtendedLevel extendedLevel, ref string __result)
{
float num = (Plugin.moonMultipliers.ContainsKey(extendedLevel.SelectableLevel.levelID) ? Plugin.moonMultipliers[extendedLevel.SelectableLevel.levelID] : 1f);
__result += (((double)num < 1.0) ? $"{(double)num * 100.0:N0}%" : "");
}
}
[HarmonyPatch(typeof(StartOfRound))]
public class StartOfRoundPatch
{
public static LethalServerMessage<Dictionary<int, float>> syncMoonMultipliersServer = new LethalServerMessage<Dictionary<int, float>>("moonMultipliers", (Action<Dictionary<int, float>, ulong>)null);
public static LethalClientMessage<Dictionary<int, float>> syncMoonMultipliersClient = new LethalClientMessage<Dictionary<int, float>>("moonMultipliers", (Action<Dictionary<int, float>>)null, (Action<Dictionary<int, float>, ulong>)null);
private static List<GrabbableObject> new_scrap = new List<GrabbableObject>();
private static int scrap_count;
public static void Init()
{
syncMoonMultipliersClient.OnReceived += SyncMoonMultipliers;
}
private static void SyncMoonMultipliers(Dictionary<int, float> data)
{
Plugin.moonMultipliers = data;
}
[HarmonyPatch("StartGame")]
[HarmonyPrefix]
private static void ReduceScrapAmount(StartOfRound __instance)
{
if (((NetworkBehaviour)__instance).IsServer && __instance.inShipPhase)
{
if (!Plugin.moonMultipliers.ContainsKey(__instance.currentLevel.levelID))
{
Plugin.moonMultipliers[__instance.currentLevel.levelID] = 1f;
}
RoundManager.Instance.scrapAmountMultiplier = Plugin.moonMultipliers[__instance.currentLevel.levelID];
}
}
[HarmonyPatch("EndOfGame")]
[HarmonyPrefix]
private static void RecordScrapCount(StartOfRound __instance)
{
if (!((NetworkBehaviour)__instance).IsServer)
{
return;
}
GrabbableObject[] array = Object.FindObjectsOfType<GrabbableObject>();
scrap_count = 0;
for (int i = 0; i < array.Length; i++)
{
if (array[i].itemProperties.isScrap)
{
scrap_count++;
}
}
new_scrap = new List<GrabbableObject>(RoundManager.Instance.scrapCollectedThisRound);
}
[HarmonyPatch("PassTimeToNextDay")]
[HarmonyPrefix]
private static void SetMoonMultipliers(StartOfRound __instance)
{
if (!((NetworkBehaviour)__instance).IsServer)
{
return;
}
Dictionary<int, float> dictionary = new Dictionary<int, float>();
if (__instance.currentLevel.planetHasTime)
{
List<int> list = Plugin.moonMultipliers.Keys.ToList();
foreach (int item in list)
{
float num = Plugin.moonMultipliers[item];
num += Config.dailyRegen.Value;
num = Mathf.Clamp(num, 0f, 1f);
dictionary[item] = num;
}
int num2 = 0;
foreach (GrabbableObject item2 in new_scrap)
{
if ((Object)(object)item2 != (Object)null)
{
num2++;
}
}
Plugin.Logger.LogDebug((object)$"Collected {num2} scrap of {scrap_count} total");
dictionary[__instance.currentLevel.levelID] -= (float)num2 / (float)scrap_count * Config.reductionMultiplier.Value;
dictionary[__instance.currentLevel.levelID] = Mathf.Clamp(dictionary[__instance.currentLevel.levelID], 0f, 1f);
}
if (Config.resetAfterQuota.Value && ((float)(TimeOfDay.Instance.profitQuota - TimeOfDay.Instance.quotaFulfilled) <= 0f || __instance.isChallengeFile))
{
dictionary.Clear();
Plugin.Logger.LogDebug((object)"Cleared moon multipliers");
}
syncMoonMultipliersServer.SendAllClients(dictionary, true);
}
[HarmonyPatch("OnClientConnect")]
[HarmonyPrefix]
private static void OnClientConnect(ulong clientId)
{
syncMoonMultipliersServer.SendClient(Plugin.moonMultipliers, clientId);
}
}
[HarmonyPatch(typeof(Terminal))]
public class TerminalPatch
{
[HarmonyPatch("TextPostProcess")]
[HarmonyPrefix]
private static void AddDeminishedWarning(ref string modifiedDisplayText, Terminal __instance)
{
//IL_008b: Unknown result type (might be due to invalid IL or missing references)
//IL_0091: Invalid comparison between Unknown and I4
int num = modifiedDisplayText.Split("[planetTime]").Length - 1;
if (num > 0)
{
Regex regex = new Regex(Regex.Escape("[planetTime]"));
for (int i = 0; i < num && __instance.moonsCatalogueList.Length > i; i++)
{
float num2 = (Plugin.moonMultipliers.ContainsKey(__instance.moonsCatalogueList[i].levelID) ? Plugin.moonMultipliers[__instance.moonsCatalogueList[i].levelID] : 1f);
string replacement = ((GameNetworkManager.Instance.isDemo && __instance.moonsCatalogueList[i].lockedForDemo) ? "(Locked)" : ((((int)__instance.moonsCatalogueList[i].currentWeather != -1) ? ("(" + ((object)(LevelWeatherType)(ref __instance.moonsCatalogueList[i].currentWeather)).ToString() + ") ") : "") + (((double)num2 < 1.0) ? $"{(double)num2 * 100.0:N0}%" : "")));
modifiedDisplayText = regex.Replace(modifiedDisplayText, replacement, 1);
}
}
}
}
}