| 
									
										
										
										
											2025-07-21 15:49:39 +08:00
										 |  |  | using System; | 
					
						
							|  |  |  | using System.Collections; | 
					
						
							|  |  |  | using System.Collections.Generic; | 
					
						
							| 
									
										
										
										
											2025-08-30 22:31:13 +08:00
										 |  |  | using UnityEngine; | 
					
						
							| 
									
										
										
										
											2025-07-21 15:49:39 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace Convention | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     public class GlobalConfig : IEnumerable<KeyValuePair<string, object>> | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         public static string ConstConfigFile = "config.json"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         public static void InitExtensionEnv() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             ConstConfigFile = "config.json"; | 
					
						
							|  |  |  |             ProjectConfig.InitExtensionEnv(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         private int configLogging_tspace = "Property not found".Length; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         private ToolFile DataDir; | 
					
						
							|  |  |  |         private Dictionary<string, object> data_pair = new(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         public GlobalConfig(string dataDir, bool isTryCreateDataDir = false, bool isLoad = true) | 
					
						
							|  |  |  |             : this(new ToolFile(dataDir), isTryCreateDataDir, isLoad) { } | 
					
						
							|  |  |  |         public GlobalConfig(ToolFile dataDir, bool isTryCreateDataDir = false, bool isLoad = true) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             // build up data folder | 
					
						
							|  |  |  |             dataDir ??= new ToolFile("./"); | 
					
						
							|  |  |  |             this.DataDir = dataDir; | 
					
						
							|  |  |  |             if (this.DataDir.IsDir() == false) | 
					
						
							|  |  |  |                 this.DataDir.BackToParentDir(); | 
					
						
							|  |  |  |             if (this.DataDir.Exists() == false) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 if (isTryCreateDataDir) | 
					
						
							|  |  |  |                     this.DataDir.MustExistsPath(); | 
					
						
							|  |  |  |                 else | 
					
						
							|  |  |  |                     throw new Exception($"Data dir not found: {this.DataDir}"); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             // build up init data file | 
					
						
							|  |  |  |             var configFile = this.ConfigFile; | 
					
						
							|  |  |  |             if (configFile.Exists() == false) | 
					
						
							| 
									
										
										
										
											2025-08-30 22:31:13 +08:00
										 |  |  |                 SaveProperties(); | 
					
						
							| 
									
										
										
										
											2025-07-21 15:49:39 +08:00
										 |  |  |             else if (isLoad) | 
					
						
							|  |  |  |                 this.LoadProperties(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         ~GlobalConfig() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         public ToolFile GetConfigFile() => DataDir | ConstConfigFile; | 
					
						
							|  |  |  |         public ToolFile ConfigFile => GetConfigFile(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         public ToolFile GetFile(string path, bool isMustExist = false) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             var file = DataDir | path; | 
					
						
							|  |  |  |             if (isMustExist) | 
					
						
							|  |  |  |                 file.MustExistsPath(); | 
					
						
							|  |  |  |             return file; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         public bool EraseFile(string path) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             var file = DataDir | path; | 
					
						
							|  |  |  |             if (file.Exists()) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 file.Delete(); | 
					
						
							|  |  |  |                 file.Create(); | 
					
						
							|  |  |  |                 return true; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         public bool RemoveFile(string path) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             var file = DataDir | path; | 
					
						
							|  |  |  |             if (file.Exists()) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 try | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     file.Delete(); | 
					
						
							|  |  |  |                     return true; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 catch (Exception) { } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         public bool CreateFile(string path) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             var file = DataDir | path; | 
					
						
							|  |  |  |             if (file.Exists()) | 
					
						
							|  |  |  |                 return false; | 
					
						
							|  |  |  |             if (file.GetParentDir().Exists() == false) | 
					
						
							|  |  |  |                 return false; | 
					
						
							|  |  |  |             file.Create(); | 
					
						
							|  |  |  |             return true; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         public object this[string key] | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             get | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 return data_pair[key]; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             set | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 data_pair[key] = value; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         public bool Contains(string key) => data_pair.ContainsKey(key); | 
					
						
							|  |  |  |         public bool Remove(string key) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             if (data_pair.ContainsKey(key)) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 data_pair.Remove(key); | 
					
						
							|  |  |  |                 return true; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         public IEnumerator<KeyValuePair<string, object>> GetEnumerator() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             return ((IEnumerable<KeyValuePair<string, object>>)this.data_pair).GetEnumerator(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         IEnumerator IEnumerable.GetEnumerator() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             return ((IEnumerable)this.data_pair).GetEnumerator(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         public int DataSize() => data_pair.Count; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-08-30 22:31:13 +08:00
										 |  |  |         [Serializable] | 
					
						
							|  |  |  |         public class InternalProperty | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             public Dictionary<string, object> property = new(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-21 15:49:39 +08:00
										 |  |  |         public GlobalConfig SaveProperties() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             var configFile = this.ConfigFile; | 
					
						
							| 
									
										
										
										
											2025-08-30 22:31:13 +08:00
										 |  |  |             configFile.SaveAsJson(new InternalProperty() { property = data_pair }); | 
					
						
							| 
									
										
										
										
											2025-07-21 15:49:39 +08:00
										 |  |  |             return this; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         public GlobalConfig LoadProperties() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             var configFile = this.ConfigFile; | 
					
						
							|  |  |  |             if (configFile.Exists() == false) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 data_pair = new(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |             { | 
					
						
							| 
									
										
										
										
											2025-08-30 22:31:13 +08:00
										 |  |  |                 data_pair = configFile.LoadAsJson<InternalProperty>().property; | 
					
						
							| 
									
										
										
										
											2025-07-21 15:49:39 +08:00
										 |  |  |             } | 
					
						
							|  |  |  |             return this; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         public ToolFile GetLogFile() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             return this.GetFile(ConfigFile.GetName(true) + "_log.txt", true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         public ToolFile LogFile => GetLogFile(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         private Action<string> MyDefaultLogger; | 
					
						
							|  |  |  |         public Action<string> DefaultLogger | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             get | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 return MyDefaultLogger ?? Console.WriteLine; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             set | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 MyDefaultLogger = value; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         public virtual void Log(string messageType, string message, Action<string> logger) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             configLogging_tspace = Math.Max(configLogging_tspace, messageType.Length); | 
					
						
							|  |  |  |             (logger ?? DefaultLogger)($"[{Utility.NowFormat()}]{new string(' ', configLogging_tspace / 2)}{messageType}{new string(' ', configLogging_tspace - configLogging_tspace / 2)}: {message}"); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         public void Log(string messageType, string message) => Log(messageType, message, null); | 
					
						
							|  |  |  |         public void LogPropertyNotFound(string message, Action<string> logger, object @default = null) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             if (@default != null) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 message = $"{message} (default: {@default})"; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             Log("Property not found", message); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         public void LogPropertyNotFound(string message, object @default = null) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             if (@default != null) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 message = $"{message} (default: {@default})"; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             Log("Property not found", message); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         public void LogMessageOfPleaseCompleteConfiguration() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             var message = "Please complete configuration"; | 
					
						
							|  |  |  |             Log("Error", message); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         public object FindItem(string key, object @default = null) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             if (Contains(key)) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 return this[key]; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 LogPropertyNotFound(key, @default); | 
					
						
							|  |  |  |                 return @default; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public class ProjectConfig : GlobalConfig | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         private static string ProjectConfigFileFocus = "Assets/"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         public static new void InitExtensionEnv() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             ProjectConfigFileFocus = "Assets/"; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         public ProjectConfig(bool isLoad = true) : base(ProjectConfigFileFocus, true, isLoad) { } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         public static void SetProjectConfigFileFocus(string path) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             ProjectConfigFileFocus = path; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         public static string GetProjectConfigFileFocus() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             return ProjectConfigFileFocus; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |