From 5139160ce4fd0f2abfa2ca2b26bbcfcb884fe2ce Mon Sep 17 00:00:00 2001 From: Melanie Thielker Date: Sat, 6 Jun 2009 16:39:28 +0000 Subject: Correct an error where the config file name was always considered to be a local file. This caused llHttpRequest and llSetInventoryPermsMask to fail on regions that load their config from a web server --- OpenSim/Region/ScriptEngine/DotNetEngine/ScriptEngine.cs | 9 +++++++-- OpenSim/Region/ScriptEngine/Interfaces/IScriptEngine.cs | 1 + OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs | 7 ++----- OpenSim/Region/ScriptEngine/Shared/Instance/ScriptInstance.cs | 1 + OpenSim/Region/ScriptEngine/XEngine/XEngine.cs | 7 +++++++ 5 files changed, 18 insertions(+), 7 deletions(-) (limited to 'OpenSim') diff --git a/OpenSim/Region/ScriptEngine/DotNetEngine/ScriptEngine.cs b/OpenSim/Region/ScriptEngine/DotNetEngine/ScriptEngine.cs index 8651b03..5549ea8 100644 --- a/OpenSim/Region/ScriptEngine/DotNetEngine/ScriptEngine.cs +++ b/OpenSim/Region/ScriptEngine/DotNetEngine/ScriptEngine.cs @@ -73,7 +73,7 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine // that has been running too long public static MaintenanceThread m_MaintenanceThread; - public IConfigSource ConfigSource; + private IConfigSource m_ConfigSource; public IConfig ScriptConfigSource; private bool m_enabled = false; @@ -82,6 +82,11 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine get { return ScriptConfigSource; } } + public IConfigSource ConfigSource + { + get { return m_ConfigSource; } + } + // How many seconds between re-reading config-file. // 0 = never. ScriptEngine will try to adjust to new config changes. public int RefreshConfigFileSeconds { @@ -119,7 +124,7 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine public void Initialise(IConfigSource config) { - ConfigSource = config; + m_ConfigSource = config; } public void AddRegion(Scene Sceneworld) diff --git a/OpenSim/Region/ScriptEngine/Interfaces/IScriptEngine.cs b/OpenSim/Region/ScriptEngine/Interfaces/IScriptEngine.cs index 1fadc79..02d1511 100644 --- a/OpenSim/Region/ScriptEngine/Interfaces/IScriptEngine.cs +++ b/OpenSim/Region/ScriptEngine/Interfaces/IScriptEngine.cs @@ -80,6 +80,7 @@ namespace OpenSim.Region.ScriptEngine.Interfaces void ApiResetScript(UUID itemID); void ResetScript(UUID itemID); IConfig Config { get; } + IConfigSource ConfigSource { get; } string ScriptEngineName { get; } IScriptApi GetApi(UUID itemID, string name); } diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs index a10ca3d..40889ca 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs @@ -7978,11 +7978,8 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void llSetObjectPermMask(int mask, int value) { m_host.AddScriptLPS(1); - IConfigSource config = new IniConfigSource(Application.iniFilePath); - if (config.Configs["XEngine"] == null) - config.AddConfig("XEngine"); - if (config.Configs["XEngine"].GetBoolean("AllowGodFunctions", false)) + if (m_ScriptEngine.Config.GetBoolean("AllowGodFunctions", false)) { if (World.Permissions.CanRunConsoleCommand(m_host.OwnerID)) { @@ -8990,7 +8987,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api Dictionary httpHeaders = new Dictionary(); string shard = "OpenSim"; - IConfigSource config = new IniConfigSource(Application.iniFilePath); + IConfigSource config = m_ScriptEngine.ConfigSource; if (config.Configs["Network"] != null) { shard diff --git a/OpenSim/Region/ScriptEngine/Shared/Instance/ScriptInstance.cs b/OpenSim/Region/ScriptEngine/Shared/Instance/ScriptInstance.cs index 5090e89..2457b3a 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Instance/ScriptInstance.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Instance/ScriptInstance.cs @@ -950,6 +950,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance "Line ({0}): {1}", scriptLine - 1, e.InnerException.Message); + System.Console.WriteLine(e.ToString()+"\n"); return message; } } diff --git a/OpenSim/Region/ScriptEngine/XEngine/XEngine.cs b/OpenSim/Region/ScriptEngine/XEngine/XEngine.cs index 34f8145..4ab564b 100644 --- a/OpenSim/Region/ScriptEngine/XEngine/XEngine.cs +++ b/OpenSim/Region/ScriptEngine/XEngine/XEngine.cs @@ -60,6 +60,7 @@ namespace OpenSim.Region.ScriptEngine.XEngine private int m_MaxScriptQueue; private Scene m_Scene; private IConfig m_ScriptConfig = null; + private IConfigSource m_ConfigSource = null; private ICompiler m_Compiler; private int m_MinThreads; private int m_MaxThreads ; @@ -148,6 +149,11 @@ namespace OpenSim.Region.ScriptEngine.XEngine get { return m_ScriptConfig; } } + public IConfigSource ConfigSource + { + get { return m_ConfigSource; } + } + public event ScriptRemoved OnScriptRemoved; public event ObjectRemoved OnObjectRemoved; @@ -160,6 +166,7 @@ namespace OpenSim.Region.ScriptEngine.XEngine return; m_ScriptConfig = configSource.Configs["XEngine"]; + m_ConfigSource = configSource; } public void AddRegion(Scene scene) -- cgit v1.1