我有这个控制台类型的东西,它接受一行 C# 代码,将它包装在一些周围的代码中并将它编译成一个程序集。然后,我从该程序集中调用该方法,输出结果,就是这样。
问题是,程序集需要有一个名称,以便我可以将其设置为朋友程序集,以便它可以访问非公共类。我将其命名为“控制台”。
一切都按预期工作,但问题是我无法在一个脚本完成后运行第二个脚本,因为名为“console”的文件已经存在于目录中并且不能被覆盖。
我已经尝试处理所有具有 Dispose 方法的东西。我尝试使用 File.Delete 手动删除文件。没有任何帮助。
所以这是我正在使用的代码。我希望有一个人可以帮助我。
CSharpCodeProvider provider = new CSharpCodeProvider();
var param = new CompilerParameters();
param.GenerateInMemory = false;
param.GenerateExecutable = false;
param.OutputAssembly = "console";
param.ReferencedAssemblies.Add("System.dll");
param.ReferencedAssemblies.Add("System.Core.dll");
param.ReferencedAssemblies.Add(Assembly.GetExecutingAssembly().Location);
var results = provider.CompileAssemblyFromSource(param,
@"
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.IO;
namespace FireflyGL
{
class DebugConsole
{
static void Run(StringWriter writer)
{
var stdOut = Console.Out;
Console.SetOut(writer);
" + input.Text + @"
Console.SetOut(stdOut);
}
}
}");
if (results.Errors.HasErrors)
{
for (int i = 0; i < results.Errors.Count; ++i)
{
PushText(results.Errors[i].ErrorText);
}
}
else
{
try
{
var writter = new StringWriter();
results.CompiledAssembly.GetType("FireflyGL.DebugConsole").GetMethod("Run", BindingFlags.Static | BindingFlags.NonPublic).Invoke(null, new object[] { writter });
PushText(writter.ToString());
history.Add(input.Text);
currentHistory = history.Count;
input.Text = "";
writter.Dispose();
}
catch (Exception)
{
}
}
provider.Dispose();
File.Delete(results.CompiledAssembly.Location);