✅ WulaFallenEmpireSettings.cs - 添加了 public bool enableDebugLogs = false; 字段和保存配置
✅ WulaLog.cs - 修改了DebugEnabled属性,仅检查enableDebugLogs设置(不检查DevMode) ✅ WulaFallenEmpireMod.cs - 在DoSettingsWindowContents中添加了UI复选框,显示"Enable Debug Logs"选项 ✅ 替换了所有848个Log.Message/Error/Warning调用为WulaLog.Debug()
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
using System;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
using System.Text;
|
||||
@@ -57,7 +57,7 @@ namespace WulaFallenEmpire.EventSystem.AI
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Log.Error($"[WulaFallenEmpire] Failed to load AI history from {path}: {ex}");
|
||||
WulaLog.Debug($"[WulaFallenEmpire] Failed to load AI history from {path}: {ex}");
|
||||
}
|
||||
}
|
||||
|
||||
@@ -75,7 +75,7 @@ namespace WulaFallenEmpire.EventSystem.AI
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Log.Error($"[WulaFallenEmpire] Failed to save AI history to {path}: {ex}");
|
||||
WulaLog.Debug($"[WulaFallenEmpire] Failed to save AI history to {path}: {ex}");
|
||||
}
|
||||
}
|
||||
|
||||
@@ -92,7 +92,7 @@ namespace WulaFallenEmpire.EventSystem.AI
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Log.Error($"[WulaFallenEmpire] Failed to clear AI history at {path}: {ex}");
|
||||
WulaLog.Debug($"[WulaFallenEmpire] Failed to clear AI history at {path}: {ex}");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
using System;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
@@ -25,7 +25,7 @@ namespace WulaFallenEmpire.EventSystem.AI
|
||||
{
|
||||
if (string.IsNullOrEmpty(_baseUrl))
|
||||
{
|
||||
Log.Error("[WulaAI] Base URL is missing.");
|
||||
WulaLog.Debug("[WulaAI] Base URL is missing.");
|
||||
return null;
|
||||
}
|
||||
|
||||
@@ -69,8 +69,8 @@ namespace WulaFallenEmpire.EventSystem.AI
|
||||
string jsonBody = jsonBuilder.ToString();
|
||||
if (Prefs.DevMode)
|
||||
{
|
||||
Log.Message($"[WulaAI] Sending request to {endpoint} (model={_model}, messages={messages?.Count ?? 0})");
|
||||
Log.Message($"[WulaAI] Request body (truncated):\n{TruncateForLog(jsonBody)}");
|
||||
WulaLog.Debug($"[WulaAI] Sending request to {endpoint} (model={_model}, messages={messages?.Count ?? 0})");
|
||||
WulaLog.Debug($"[WulaAI] Request body (truncated):\n{TruncateForLog(jsonBody)}");
|
||||
}
|
||||
|
||||
using (UnityWebRequest request = new UnityWebRequest(endpoint, "POST"))
|
||||
@@ -93,14 +93,14 @@ namespace WulaFallenEmpire.EventSystem.AI
|
||||
|
||||
if (request.result == UnityWebRequest.Result.ConnectionError || request.result == UnityWebRequest.Result.ProtocolError)
|
||||
{
|
||||
Log.Error($"[WulaAI] API Error: {request.error}\nResponse (truncated): {TruncateForLog(request.downloadHandler.text)}");
|
||||
WulaLog.Debug($"[WulaAI] API Error: {request.error}\nResponse (truncated): {TruncateForLog(request.downloadHandler.text)}");
|
||||
return null;
|
||||
}
|
||||
|
||||
string responseText = request.downloadHandler.text;
|
||||
if (Prefs.DevMode)
|
||||
{
|
||||
Log.Message($"[WulaAI] Raw Response (truncated): {TruncateForLog(responseText)}");
|
||||
WulaLog.Debug($"[WulaAI] Raw Response (truncated): {TruncateForLog(responseText)}");
|
||||
}
|
||||
return ExtractContent(responseText);
|
||||
}
|
||||
@@ -181,7 +181,7 @@ namespace WulaFallenEmpire.EventSystem.AI
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Log.Error($"[WulaAI] Error parsing response: {ex}");
|
||||
WulaLog.Debug($"[WulaAI] Error parsing response: {ex}");
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
using System;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
@@ -129,7 +129,7 @@ namespace WulaFallenEmpire.EventSystem.AI.Tools
|
||||
float baseMaxPoints = StorytellerUtility.DefaultThreatPointsNow(map);
|
||||
float adjustedMaxPoints = baseMaxPoints * goodwillFactor * 1.5f;
|
||||
|
||||
Log.Message($"[WulaAI] send_reinforcement: totalCost={totalCost}, adjustedMaxPoints={adjustedMaxPoints}");
|
||||
WulaLog.Debug($"[WulaAI] send_reinforcement: totalCost={totalCost}, adjustedMaxPoints={adjustedMaxPoints}");
|
||||
if (totalCost > adjustedMaxPoints)
|
||||
{
|
||||
return $"Error: Total cost {totalCost} exceeds limit {adjustedMaxPoints:F0}. Reduce unit count.";
|
||||
|
||||
@@ -127,7 +127,7 @@ You are 'The Legion', a super AI of the Wula Empire. Your personality is authori
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Log.Error($"[WulaAI] Failed to persist AI history: {ex}");
|
||||
WulaLog.Debug($"[WulaAI] Failed to persist AI history: {ex}");
|
||||
}
|
||||
}
|
||||
|
||||
@@ -143,7 +143,7 @@ You are 'The Legion', a super AI of the Wula Empire. Your personality is authori
|
||||
}
|
||||
else
|
||||
{
|
||||
Log.Warning($"[WulaAI] Failed to load portrait: {path}");
|
||||
WulaLog.Debug($"[WulaAI] Failed to load portrait: {path}");
|
||||
}
|
||||
}
|
||||
|
||||
@@ -173,7 +173,7 @@ You are 'The Legion', a super AI of the Wula Empire. Your personality is authori
|
||||
}
|
||||
else
|
||||
{
|
||||
Log.Warning($"[WulaAI] Portrait ID {id} not found.");
|
||||
WulaLog.Debug($"[WulaAI] Portrait ID {id} not found.");
|
||||
}
|
||||
}
|
||||
|
||||
@@ -578,7 +578,7 @@ Example (changing to a neutral expression):
|
||||
var phase = (RequestPhase)phaseIndex;
|
||||
if (Prefs.DevMode)
|
||||
{
|
||||
Log.Message($"[WulaAI] ===== Turn {phaseIndex}/4 ({phase}) =====");
|
||||
WulaLog.Debug($"[WulaAI] ===== Turn {phaseIndex}/4 ({phase}) =====");
|
||||
}
|
||||
|
||||
bool toolsEnabled = phase != RequestPhase.Reply;
|
||||
@@ -592,7 +592,7 @@ Example (changing to a neutral expression):
|
||||
{
|
||||
if (Prefs.DevMode)
|
||||
{
|
||||
Log.Message($"[WulaAI] Turn {phaseIndex}/4 reply request (attempt {attempts + 1})");
|
||||
WulaLog.Debug($"[WulaAI] Turn {phaseIndex}/4 reply request (attempt {attempts + 1})");
|
||||
}
|
||||
string reply = await client.GetChatCompletionAsync(systemInstruction, _history);
|
||||
if (string.IsNullOrEmpty(reply))
|
||||
@@ -622,7 +622,7 @@ Example (changing to a neutral expression):
|
||||
|
||||
if (Prefs.DevMode)
|
||||
{
|
||||
Log.Message($"[WulaAI] Turn {phaseIndex}/4 tool request");
|
||||
WulaLog.Debug($"[WulaAI] Turn {phaseIndex}/4 tool request");
|
||||
}
|
||||
string response = await client.GetChatCompletionAsync(systemInstruction, _history);
|
||||
if (string.IsNullOrEmpty(response))
|
||||
@@ -638,7 +638,7 @@ Example (changing to a neutral expression):
|
||||
PersistHistory();
|
||||
if (Prefs.DevMode)
|
||||
{
|
||||
Log.Message($"[WulaAI] Turn {phaseIndex}/4 missing XML; retrying once");
|
||||
WulaLog.Debug($"[WulaAI] Turn {phaseIndex}/4 missing XML; retrying once");
|
||||
}
|
||||
response = await client.GetChatCompletionAsync(systemInstruction, _history);
|
||||
if (string.IsNullOrEmpty(response))
|
||||
@@ -652,7 +652,7 @@ Example (changing to a neutral expression):
|
||||
{
|
||||
if (Prefs.DevMode)
|
||||
{
|
||||
Log.Warning($"[WulaAI] Turn {phaseIndex}/4 still missing XML after retry; forcing <no_action/>");
|
||||
WulaLog.Debug($"[WulaAI] Turn {phaseIndex}/4 still missing XML after retry; forcing <no_action/>");
|
||||
}
|
||||
response = phase == RequestPhase.Cosmetic
|
||||
? "<change_expression><expression_id>2</expression_id></change_expression>"
|
||||
@@ -666,7 +666,7 @@ Example (changing to a neutral expression):
|
||||
PersistHistory();
|
||||
if (Prefs.DevMode)
|
||||
{
|
||||
Log.Message("[WulaAI] Turn 3/4 missing <change_expression>; retrying once");
|
||||
WulaLog.Debug("[WulaAI] Turn 3/4 missing <change_expression>; retrying once");
|
||||
}
|
||||
|
||||
string retry = await client.GetChatCompletionAsync(systemInstruction, _history);
|
||||
@@ -678,7 +678,7 @@ Example (changing to a neutral expression):
|
||||
{
|
||||
if (Prefs.DevMode)
|
||||
{
|
||||
Log.Warning("[WulaAI] Turn 3/4 still missing <change_expression> after retry; forcing default expression_id=2");
|
||||
WulaLog.Debug("[WulaAI] Turn 3/4 still missing <change_expression> after retry; forcing default expression_id=2");
|
||||
}
|
||||
response = "<change_expression><expression_id>2</expression_id></change_expression>";
|
||||
}
|
||||
@@ -689,7 +689,7 @@ Example (changing to a neutral expression):
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Log.Error($"[WulaAI] Exception in RunPhasedRequestAsync: {ex}");
|
||||
WulaLog.Debug($"[WulaAI] Exception in RunPhasedRequestAsync: {ex}");
|
||||
_currentResponse = "Wula_AI_Error_Internal".Translate(ex.Message);
|
||||
}
|
||||
finally
|
||||
@@ -792,7 +792,7 @@ Example (changing to a neutral expression):
|
||||
|
||||
if (Prefs.DevMode)
|
||||
{
|
||||
Log.Message($"[WulaAI] Executing tool (phase {phase}): {toolName} with args: {argsXml}");
|
||||
WulaLog.Debug($"[WulaAI] Executing tool (phase {phase}): {toolName} with args: {argsXml}");
|
||||
}
|
||||
|
||||
string signature = $"{toolName}:{Regex.Replace(argsXml ?? "", @"\s+", " ").Trim()}";
|
||||
@@ -918,7 +918,7 @@ Example (changing to a neutral expression):
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Log.Error($"[WulaAI] Exception in GenerateResponse: {ex}");
|
||||
WulaLog.Debug($"[WulaAI] Exception in GenerateResponse: {ex}");
|
||||
_currentResponse = "Wula_AI_Error_Internal".Translate(ex.Message);
|
||||
}
|
||||
finally
|
||||
@@ -1069,7 +1069,7 @@ Example (changing to a neutral expression):
|
||||
if (tool == null)
|
||||
{
|
||||
string errorMsg = $"Error: Tool '{toolName}' not found.";
|
||||
Log.Error($"[WulaAI] {errorMsg}");
|
||||
WulaLog.Debug($"[WulaAI] {errorMsg}");
|
||||
combinedResults.AppendLine(errorMsg);
|
||||
continue;
|
||||
}
|
||||
@@ -1084,7 +1084,7 @@ Example (changing to a neutral expression):
|
||||
|
||||
if (Prefs.DevMode)
|
||||
{
|
||||
Log.Message($"[WulaAI] Executing tool: {toolName} with args: {argsXml}");
|
||||
WulaLog.Debug($"[WulaAI] Executing tool: {toolName} with args: {argsXml}");
|
||||
}
|
||||
|
||||
// Record tool signature for loop detection (before execution, so errors also count)
|
||||
@@ -1096,7 +1096,7 @@ Example (changing to a neutral expression):
|
||||
if (Prefs.DevMode && !string.IsNullOrEmpty(result))
|
||||
{
|
||||
string toLog = result.Length <= 2000 ? result : result.Substring(0, 2000) + $"... (truncated, total {result.Length} chars)";
|
||||
Log.Message($"[WulaAI] Tool '{toolName}' result: {toLog}");
|
||||
WulaLog.Debug($"[WulaAI] Tool '{toolName}' result: {toLog}");
|
||||
}
|
||||
|
||||
if (toolName == "modify_goodwill")
|
||||
@@ -1154,7 +1154,7 @@ Example (changing to a neutral expression):
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Log.Error($"[WulaAI] Exception in HandleXmlToolUsage: {ex}");
|
||||
WulaLog.Debug($"[WulaAI] Exception in HandleXmlToolUsage: {ex}");
|
||||
_history.Add(("tool", $"Error processing tool call: {ex.Message}"));
|
||||
PersistHistory();
|
||||
await GenerateResponse(isContinuation: true);
|
||||
@@ -1535,7 +1535,7 @@ Example (changing to a neutral expression):
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Log.Error($"[WulaAI] Failed to clear AI history: {ex}");
|
||||
WulaLog.Debug($"[WulaAI] Failed to clear AI history: {ex}");
|
||||
}
|
||||
|
||||
Messages.Message("已清除 AI 对话上下文历史。", MessageTypeDefOf.NeutralEvent);
|
||||
|
||||
Reference in New Issue
Block a user