3

I'm trying to add a plugin architecture to my C# app. I've chosen IronScheme as the language, and also because it's built on the DLR, which should make it easier to embed.

On the Codeplex Wiki, they have the following example. I changed it slightly:

public class PluggerInner
{
    IScriptEngine scheme;

    public PluggerInner()
    {
        InitScheme();
    }

    private void InitScheme()
    {
        var domMgr = ScriptDomainManager.CurrentManager;
        var schemePrv = new IronSchemeLanguageProvider(domMgr);

        scheme = schemePrv.GetEngine();
    }

    public void RunSchemePlugin(string fileName)
    {
        scheme.ExecuteFile(fileName);
    }

    public void RunPlugins()
    {
        foreach (var fl in new DirectoryInfo("../../plugins").GetFiles())
        {
            if (fl.Extension == ".ss")
            {
                RunSchemePlugin(fl.FullName);
            }
        }
    }
}

(This is executed basically as new PluggerInner().RunPlugins())

It finds my example .ss file in the directory (yes, I know I shouldn't use ../..), but throws a massive error on this line:

scheme.ExecuteFile(fileName);

The exception I get is:

IronScheme.Runtime.R6RS.CompoundCondition was unhandled
  Source="IronScheme"
  StackTrace:
       at IronScheme.Runtime.R6RS.Exceptions.Raise(Object obj)
       at IronScheme.Runtime.R6RS.Exceptions.RaiseContinueable(Object obj)
       at IronScheme.Runtime.Builtins.UndefinedError(Object sym)
       at IronScheme.IronSchemeLanguageContext.MissingName(SymbolId name)
       at Microsoft.Scripting.ModuleGlobalWrapper.GetCachedValue()
       at Microsoft.Scripting.ModuleGlobalWrapper.get_CurrentValue()
       at hello.Initialize(CodeContext )
       at Microsoft.Scripting.ScriptCode.Run(CodeContext codeContext, Boolean tryEvaluate)
       at Microsoft.Scripting.ScriptModule.Execute()
       at Microsoft.Scripting.Hosting.ScriptEngine.ExecuteFile(String path)
       at ExEdit.PluggerInner.RunSchemePlugin(String fileName) in D:\VSProjects\ExEdit\Infra.cs:line 35
       at ExEdit.PluggerInner.RunPlugins() in D:\VSProjects\ExEdit\Infra.cs:line 44
       at ExEdit.MainForm.MainForm_Load(Object sender, EventArgs e) in D:\VSProjects\ExEdit\MainForm.cs:line 22
       at System.Windows.Forms.Form.OnLoad(EventArgs e)
       at System.Windows.Forms.Form.OnCreateControl()
       at System.Windows.Forms.Control.CreateControl(Boolean fIgnoreVisible)
       at System.Windows.Forms.Control.CreateControl()
       at System.Windows.Forms.Control.WmShowWindow(Message& m)
       at System.Windows.Forms.Control.WndProc(Message& m)
       at System.Windows.Forms.ScrollableControl.WndProc(Message& m)
       at System.Windows.Forms.ContainerControl.WndProc(Message& m)
       at System.Windows.Forms.Form.WmShowWindow(Message& m)
       at System.Windows.Forms.Form.WndProc(Message& m)
       at System.Windows.Forms.Control.ControlNativeWindow.OnMessage(Message& m)
       at System.Windows.Forms.Control.ControlNativeWindow.WndProc(Message& m)
       at System.Windows.Forms.NativeWindow.DebuggableCallback(IntPtr hWnd, Int32 msg, IntPtr wparam, IntPtr lparam)
       at System.Windows.Forms.SafeNativeMethods.ShowWindow(HandleRef hWnd, Int32 nCmdShow)
       at System.Windows.Forms.Control.SetVisibleCore(Boolean value)
       at System.Windows.Forms.Form.SetVisibleCore(Boolean value)
       at System.Windows.Forms.Control.set_Visible(Boolean value)
       at System.Windows.Forms.Application.ThreadContext.RunMessageLoopInner(Int32 reason, ApplicationContext context)
       at System.Windows.Forms.Application.ThreadContext.RunMessageLoop(Int32 reason, ApplicationContext context)
       at System.Windows.Forms.Application.Run(Form mainForm)
       at ExEdit.Program.Main() in D:\VSProjects\ExEdit\Program.cs:line 18
       at System.AppDomain._nExecuteAssembly(Assembly assembly, String[] args)
       at System.AppDomain.ExecuteAssembly(String assemblyFile, Evidence assemblySecurity, String[] args)
       at Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
       at System.Threading.ThreadHelper.ThreadStart_Context(Object state)
       at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
       at System.Threading.ThreadHelper.ThreadStart()
  InnerException: 

My example Scheme code:

(define (test) (+ 1 1))

I have no idea what the exception is actually talking about, as it has no InnerException.

Lucas Jones
  • 19,767
  • 8
  • 75
  • 88
  • I don't know anything about scheme but in relation to the DLR have you verified that the a basic script works using the ScriptEninge.Execute method? That's where I start from with IronRuby. – sipsorcery Oct 10 '09 at 12:30
  • I'll just try that now... Thanks! :) – Lucas Jones Oct 10 '09 at 12:38
  • Its rather odd; I can `engine.Execute("(+ 1 1)")` without an exception, but when I add a couple of lines to use WinForms, it stops. – Lucas Jones Oct 10 '09 at 12:42
  • Actually, if I add more than one line at all, it stops. I'll need to look into this :). Thanks. – Lucas Jones Oct 10 '09 at 12:43

1 Answers1

5

I dont think I implemented ExecuteFile correctly.

The easiest is just to grab hold of the load procedure.

Also the extension methods, make life easier.

Example

using IronScheme; // for extension methods
...
Callable load = "load".Eval<Callable>();
...
load.Call("myfile.ss");

I have updated the exception handling to give better error messages (I hope!).

leppie
  • 115,091
  • 17
  • 196
  • 297