Мне нужно создать новый интерфейс во время выполнения со всеми теми же членами, что и в существующем интерфейсе, за исключением того, что я буду помещать разные атрибуты в некоторые методы (некоторые параметры атрибутов неизвестны до времени выполнения). Как этого добиться?





Ваш вопрос не очень конкретный. Если вы обновите его дополнительной информацией, я дополню этот ответ дополнительными подробностями.
Вот обзор необходимых шагов вручную.
TypeAttributes.Interface, чтобы ваш тип стал интерфейсом.TypeBuilder.CreateType, чтобы завершить создание интерфейса.Чтобы динамически создать сборку с интерфейсом, имеющим атрибуты:
using System.Reflection;
using System.Reflection.Emit;
// Need the output the assembly to a specific directory
string outputdir = "F:\tmp\";
string fname = "Hello.World.dll";
// Define the assembly name
AssemblyName bAssemblyName = new AssemblyName();
bAssemblyName.Name = "Hello.World";
bAssemblyName.Version = new system.Version(1,2,3,4);
// Define the new assembly and module
AssemblyBuilder bAssembly = System.AppDomain.CurrentDomain.DefineDynamicAssembly(bAssemblyName, AssemblyBuilderAccess.Save, outputdir);
ModuleBuilder bModule = bAssembly.DefineDynamicModule(fname, true);
TypeBuilder tInterface = bModule.DefineType("IFoo", TypeAttributes.Interface | TypeAttributes.Public);
ConstructorInfo con = typeof(FunAttribute).GetConstructor(new Type[] { typeof(string) });
CustomAttributeBuilder cab = new CustomAttributeBuilder(con, new object[] { "Hello" });
tInterface.SetCustomAttribute(cab);
Type tInt = tInterface.CreateType();
bAssembly.Save(fname);
Это создает следующее:
namespace Hello.World
{
[Fun("Hello")]
public interface IFoo
{}
}
При добавлении методов используется класс MethodBuilder путем вызова TypeBuilder.DefineMethod.
Нет, это круто. Раньше мне не нужно было использовать Reflection.Emit, поэтому я просто хотел посмотреть, сможет ли кто-нибудь найти камень преткновения в моем злом генеральном плане.