Put fcache commands output to console, not log

link-sitting
Justin Clark-Casey (justincc) 2013-10-30 18:32:53 +00:00
parent edaf0a98d6
commit 28f36d8db5
1 changed files with 25 additions and 28 deletions

View File

@ -36,12 +36,10 @@ using System.Runtime.Serialization;
using System.Runtime.Serialization.Formatters.Binary; using System.Runtime.Serialization.Formatters.Binary;
using System.Threading; using System.Threading;
using System.Timers; using System.Timers;
using log4net; using log4net;
using Nini.Config; using Nini.Config;
using Mono.Addins; using Mono.Addins;
using OpenMetaverse; using OpenMetaverse;
using OpenSim.Framework; using OpenSim.Framework;
using OpenSim.Framework.Console; using OpenSim.Framework.Console;
using OpenSim.Region.Framework.Interfaces; using OpenSim.Region.Framework.Interfaces;
@ -810,34 +808,36 @@ namespace OpenSim.Region.CoreModules.Asset
#region Console Commands #region Console Commands
private void HandleConsoleCommand(string module, string[] cmdparams) private void HandleConsoleCommand(string module, string[] cmdparams)
{ {
ICommandConsole con = MainConsole.Instance;
if (cmdparams.Length >= 2) if (cmdparams.Length >= 2)
{ {
string cmd = cmdparams[1]; string cmd = cmdparams[1];
switch (cmd) switch (cmd)
{ {
case "status": case "status":
if (m_MemoryCacheEnabled) if (m_MemoryCacheEnabled)
m_log.InfoFormat("[FLOTSAM ASSET CACHE]: Memory Cache : {0} assets", m_MemoryCache.Count); con.OutputFormat("Memory Cache : {0} assets", m_MemoryCache.Count);
else else
m_log.InfoFormat("[FLOTSAM ASSET CACHE]: Memory cache disabled"); con.OutputFormat("Memory cache disabled");
if (m_FileCacheEnabled) if (m_FileCacheEnabled)
{ {
int fileCount = GetFileCacheCount(m_CacheDirectory); int fileCount = GetFileCacheCount(m_CacheDirectory);
m_log.InfoFormat("[FLOTSAM ASSET CACHE]: File Cache : {0} assets", fileCount); con.OutputFormat("File Cache : {0} assets", fileCount);
con.Output("Deep scans have previously been performed on the following regions:");
foreach (string s in Directory.GetFiles(m_CacheDirectory, "*.fac")) foreach (string s in Directory.GetFiles(m_CacheDirectory, "*.fac"))
{ {
m_log.Info("[FLOTSAM ASSET CACHE]: Deep scans have previously been performed on the following regions:");
string RegionID = s.Remove(0,s.IndexOf("_")).Replace(".fac",""); string RegionID = s.Remove(0,s.IndexOf("_")).Replace(".fac","");
DateTime RegionDeepScanTMStamp = File.GetLastWriteTime(s); DateTime RegionDeepScanTMStamp = File.GetLastWriteTime(s);
m_log.InfoFormat("[FLOTSAM ASSET CACHE]: Region: {0}, {1}", RegionID, RegionDeepScanTMStamp.ToString("MM/dd/yyyy hh:mm:ss")); con.OutputFormat("Region: {0}, {1}", RegionID, RegionDeepScanTMStamp.ToString("MM/dd/yyyy hh:mm:ss"));
} }
} }
else else
{ {
m_log.InfoFormat("[FLOTSAM ASSET CACHE]: File cache disabled"); con.Output("File cache disabled");
} }
break; break;
@ -845,7 +845,7 @@ namespace OpenSim.Region.CoreModules.Asset
case "clear": case "clear":
if (cmdparams.Length < 2) if (cmdparams.Length < 2)
{ {
m_log.Warn("[FLOTSAM ASSET CACHE]: Usage is fcache clear [file] [memory]"); con.Output("Usage is fcache clear [file] [memory]");
break; break;
} }
@ -869,11 +869,11 @@ namespace OpenSim.Region.CoreModules.Asset
if (m_MemoryCacheEnabled) if (m_MemoryCacheEnabled)
{ {
m_MemoryCache.Clear(); m_MemoryCache.Clear();
m_log.Info("[FLOTSAM ASSET CACHE]: Memory cache cleared."); con.Output("Memory cache cleared.");
} }
else else
{ {
m_log.Info("[FLOTSAM ASSET CACHE]: Memory cache not enabled."); con.Output("Memory cache not enabled.");
} }
} }
@ -882,24 +882,22 @@ namespace OpenSim.Region.CoreModules.Asset
if (m_FileCacheEnabled) if (m_FileCacheEnabled)
{ {
ClearFileCache(); ClearFileCache();
m_log.Info("[FLOTSAM ASSET CACHE]: File cache cleared."); con.Output("File cache cleared.");
} }
else else
{ {
m_log.Info("[FLOTSAM ASSET CACHE]: File cache not enabled."); con.Output("File cache not enabled.");
} }
} }
break; break;
case "assets": case "assets":
m_log.Info("[FLOTSAM ASSET CACHE]: Ensuring assets are cached for all scenes."); con.Output("Ensuring assets are cached for all scenes.");
Util.FireAndForget(delegate { Util.FireAndForget(delegate {
int assetReferenceTotal = TouchAllSceneAssets(true); int assetReferenceTotal = TouchAllSceneAssets(true);
m_log.InfoFormat( con.OutputFormat("Completed check with {0} assets.", assetReferenceTotal);
"[FLOTSAM ASSET CACHE]: Completed check with {0} assets.",
assetReferenceTotal);
}); });
break; break;
@ -907,7 +905,7 @@ namespace OpenSim.Region.CoreModules.Asset
case "expire": case "expire":
if (cmdparams.Length < 3) if (cmdparams.Length < 3)
{ {
m_log.InfoFormat("[FLOTSAM ASSET CACHE]: Invalid parameters for Expire, please specify a valid date & time", cmd); con.OutputFormat("Invalid parameters for Expire, please specify a valid date & time", cmd);
break; break;
} }
@ -925,28 +923,27 @@ namespace OpenSim.Region.CoreModules.Asset
if (!DateTime.TryParse(s_expirationDate, out expirationDate)) if (!DateTime.TryParse(s_expirationDate, out expirationDate))
{ {
m_log.InfoFormat("[FLOTSAM ASSET CACHE]: {0} is not a valid date & time", cmd); con.OutputFormat("{0} is not a valid date & time", cmd);
break; break;
} }
if (m_FileCacheEnabled) if (m_FileCacheEnabled)
CleanExpiredFiles(m_CacheDirectory, expirationDate); CleanExpiredFiles(m_CacheDirectory, expirationDate);
else else
m_log.InfoFormat("[FLOTSAM ASSET CACHE]: File cache not active, not clearing."); con.OutputFormat("File cache not active, not clearing.");
break; break;
default: default:
m_log.InfoFormat("[FLOTSAM ASSET CACHE]: Unknown command {0}", cmd); con.OutputFormat("Unknown command {0}", cmd);
break; break;
} }
} }
else if (cmdparams.Length == 1) else if (cmdparams.Length == 1)
{ {
m_log.InfoFormat("[FLOTSAM ASSET CACHE]: fcache status - Display cache status"); con.Output("fcache assets - Attempt a deep cache of all assets in all scenes");
m_log.InfoFormat("[FLOTSAM ASSET CACHE]: fcache clearmem - Remove all assets cached in memory"); con.Output("fcache expire <datetime> - Purge assets older then the specified date & time");
m_log.InfoFormat("[FLOTSAM ASSET CACHE]: fcache clearfile - Remove all assets cached on disk"); con.Output("fcache clear [file] [memory] - Remove cached assets");
m_log.InfoFormat("[FLOTSAM ASSET CACHE]: fcache cachescenes - Attempt a deep cache of all assets in all scenes"); con.Output("fcache status - Display cache status");
m_log.InfoFormat("[FLOTSAM ASSET CACHE]: fcache <datetime> - Purge assets older then the specified date & time");
} }
} }