using System; using System.Collections.Generic; using System.Linq; using BepInEx; using BepInEx.Configuration; using HarmonyLib; using HarmonyLib.Tools; namespace CykaOfQud { [BepInPlugin(pluginGuid, pluginName, pluginVersion)] public class Main : BaseUnityPlugin { private const string pluginGuid = "CykaOfQud"; private const string pluginName = "CykaOfQud"; private const string pluginVersion = "1.0.0"; public static ConfigEntry excavatorCapacityMultiplier; public static ConfigEntry excavatorMineTileIterationsMultiplier; public static ConfigEntry truckCapacityMultiplier; public static ConfigEntry cargoShipCapacityMultiplier; public static ConfigEntry excavatorMiningCapacityMultiplier; public static ConfigEntry excavatorMiningAreaMultiplier; public static ConfigEntry excavatorMinReachMultiplier; public static ConfigEntry excavatorMaxReachMultiplier; public static ConfigEntry bufferCapacityMultiplier; public static ConfigEntry unityGenerationMultiplier; public static ConfigEntry depotTransferSpeedMultiplier; public static ConfigEntry worldMineSpeedMultiplier; public static ConfigEntry housingCapacityMultiplier; public static ConfigEntry dumpDelayMultiplier; public static ConfigEntry transportSpeedMultiplier; public static ConfigEntry shipyardCargoMultiplier; public static ConfigEntry autosaveInterval; public static ConfigEntry recipeMultipliers; public static Dictionary recipeMultipliersDict; public static ConfigEntry debugMode; public void Awake() { excavatorCapacityMultiplier = Config.Bind("General", "Excavator Capacity Multiplier", 1, new ConfigDescription("Excavator Capacity Multiplier")); excavatorMineTileIterationsMultiplier = Config.Bind("General", "Excavator Mine Tile Iterations Multiplier", 1f, new ConfigDescription("Excavator Mine Tile Iterations Multiplier")); truckCapacityMultiplier = Config.Bind("General", "Truck Capacity Multiplier", 1, new ConfigDescription("Truck Capacity Multiplier")); cargoShipCapacityMultiplier = Config.Bind("General", "Cargo Ship Capacity Multiplier", 1, new ConfigDescription("Cargo Ship Capacity Multiplier")); excavatorMiningAreaMultiplier = Config.Bind("General", "Excavator Mining Area Multiplier", 1, new ConfigDescription("Excavator Mining Area Multiplier")); excavatorMiningCapacityMultiplier = Config.Bind("General", "Excavator Mining Capacity Multiplier", 1f, new ConfigDescription("Excavator Mining Capacity Multiplier")); excavatorMinReachMultiplier = Config.Bind("General", "Excavator Min Reach Multiplier", 1f, new ConfigDescription("Excavator Min Reach Multiplier")); excavatorMaxReachMultiplier = Config.Bind("General", "Excavator Max Reach Multiplier", 1f, new ConfigDescription("Excavator Max Reach Multiplier")); bufferCapacityMultiplier = Config.Bind("General", "Buffer Capacity Multiplier", 1f, new ConfigDescription("Buffer Capacity Multiplier")); unityGenerationMultiplier = Config.Bind("General", "Unity Generation Multiplier", 1f, new ConfigDescription("Unity Generation Multiplier")); depotTransferSpeedMultiplier = Config.Bind("General", "Depot Transfer Speed Multiplier", 1f, new ConfigDescription("Depot Transfer Speed Multiplier")); worldMineSpeedMultiplier = Config.Bind("General", "World Mine Speed Multiplier", 1f, new ConfigDescription("World Mine Speed Multiplier")); housingCapacityMultiplier = Config.Bind("General", "Housing Capacity Multiplier", 1f, new ConfigDescription("Housing Capacity Multiplier")); dumpDelayMultiplier = Config.Bind("General", "Dump Delay Multiplier", 1f, new ConfigDescription("Dump Delay Multiplier")); transportSpeedMultiplier = Config.Bind("General", "Transport Speed Multiplier", 1f, new ConfigDescription("Transport Speed Multiplier")); shipyardCargoMultiplier = Config.Bind("General", "Shipyard Cargo Multiplier", 1f, new ConfigDescription("Shipyard Cargo Multiplier")); autosaveInterval = Config.Bind("General", "Autosave Interval", 1, new ConfigDescription("Autosave Interval in minutes")); recipeMultipliers = Config.Bind("General", "Recipe Multipliers", "dirt:4", new ConfigDescription("Recipe Multipliers")); recipeMultipliersDict = recipeMultipliers.Value.Split(',') .ToDictionary(x => x.Split(':')[0], x => int.Parse(x.Split(':')[1])); recipeMultipliers.SettingChanged += (sender, args) => { recipeMultipliersDict = recipeMultipliers.Value.Split(',') .ToDictionary(x => x.Split(':')[0], x => int.Parse(x.Split(':')[1])); Console.WriteLine("IndustrialCyka: Recipe multipliers parsed as:"); foreach (var kvp in recipeMultipliersDict) Console.WriteLine("\tIndustrialCyka: {0} x {1}", kvp.Key, kvp.Value); }; debugMode = Config.Bind("General", "Debug Mode", false, new ConfigDescription("Debug Mode")); Logger.LogInfo("Cyka mod loaded"); HarmonyFileLog.Enabled = true; Harmony harmony = new Harmony(pluginGuid); harmony.PatchAll(); var originalMethods = harmony.GetPatchedMethods(); Logger.LogInfo("Patched " + originalMethods.Count() + " methods"); foreach (var method in originalMethods) { Logger.LogInfo("Patched " + method.Name); } } } }