//-------------------------------------------------------- // [Author]: Fish // [ Date ]: 2024年5月17日 //-------------------------------------------------------- using System.Collections.Generic; using System.IO; using System.Threading; using System; using UnityEngine; using LitJson; public partial class SuccessConfig { public readonly int ID; public readonly int Type; public readonly int Group; public readonly int NeedCnt; public readonly int[] Condition; public readonly string Condition2; public readonly int Condition3; public readonly string AwardItemList; public readonly string AwardItemList2; public readonly string Money; public readonly int Exp; public readonly int[] AwardAttribute; public readonly int RedPacketID; public readonly int MagicWeaponID; public readonly string MagicWeaponExp; public readonly string Describe; public readonly int NeedGoto; public readonly int Jump; public readonly int ReOrder; public readonly int RealmPracticeID; public SuccessConfig() { } public SuccessConfig(string input) { try { var tables = input.Split('\t'); int.TryParse(tables[0],out ID); int.TryParse(tables[1],out Type); int.TryParse(tables[2],out Group); int.TryParse(tables[3],out NeedCnt); if (tables[4].Contains("[")) { Condition = JsonMapper.ToObject(tables[4]); } else { string[] ConditionStringArray = tables[4].Trim().Split(StringUtility.splitSeparator,StringSplitOptions.RemoveEmptyEntries); Condition = new int[ConditionStringArray.Length]; for (int i=0;i(tables[11]); } else { string[] AwardAttributeStringArray = tables[11].Trim().Split(StringUtility.splitSeparator,StringSplitOptions.RemoveEmptyEntries); AwardAttribute = new int[AwardAttributeStringArray.Length]; for (int i=0;i configs = new Dictionary(); public static SuccessConfig Get(string id) { if (!inited) { Debug.LogError("SuccessConfig 还未完成初始化。"); return null; } if (configs.ContainsKey(id)) { return configs[id]; } SuccessConfig config = null; if (rawDatas.ContainsKey(id)) { config = configs[id] = new SuccessConfig(rawDatas[id]); rawDatas.Remove(id); } return config; } public static SuccessConfig Get(int id) { return Get(id.ToString()); } public static List GetKeys() { var keys = new List(); keys.AddRange(configs.Keys); keys.AddRange(rawDatas.Keys); return keys; } public static List GetValues() { var values = new List(); values.AddRange(configs.Values); var keys = new List(rawDatas.Keys); for (int i = 0; i < keys.Count; i++) { values.Add(Get(keys[i])); } return values; } public static bool Has(string id) { return configs.ContainsKey(id) || rawDatas.ContainsKey(id); } public static bool Has(int id) { return Has(id.ToString()); } public static bool inited { get; private set; } protected static Dictionary rawDatas = new Dictionary(); public static void Init(bool sync=false) { inited = false; var path = string.Empty; if (AssetSource.refdataFromEditor) { path = ResourcesPath.CONFIG_FODLER +"/Success.txt"; } else { path = AssetVersionUtility.GetAssetFilePath("config/Success.txt"); } configs.Clear(); var tempConfig = new SuccessConfig(); var preParse = tempConfig is IConfigPostProcess; if (sync) { var lines = File.ReadAllLines(path); if (!preParse) { rawDatas = new Dictionary(lines.Length - 3); } for (int i = 3; i < lines.Length; i++) { try { var line = lines[i]; var index = line.IndexOf("\t"); if (index == -1) { continue; } var id = line.Substring(0, index); if (preParse) { var config = new SuccessConfig(line); configs[id] = config; (config as IConfigPostProcess).OnConfigParseCompleted(); } else { rawDatas[id] = line; } } catch (System.Exception ex) { Debug.LogError(ex); } } inited = true; } else { ThreadPool.QueueUserWorkItem((object _object) => { var lines = File.ReadAllLines(path); if (!preParse) { rawDatas = new Dictionary(lines.Length - 3); } for (int i = 3; i < lines.Length; i++) { try { var line = lines[i]; var index = line.IndexOf("\t"); if (index == -1) { continue; } var id = line.Substring(0, index); if (preParse) { var config = new SuccessConfig(line); configs[id] = config; (config as IConfigPostProcess).OnConfigParseCompleted(); } else { rawDatas[id] = line; } } catch (System.Exception ex) { Debug.LogError(ex); } } inited = true; }); } } }