How do I create and use a .NET metadata-only 'Reference Assembly'?

后端 未结 4 927
栀梦
栀梦 2020-12-08 07:57

Since version 3.0, .NET installs a bunch of different \'reference assemblies\' under C:\\Program Files\\Reference Assemblies\\Microsoft...., to support different profiles (s

相关标签:
4条回答
  • 2020-12-08 08:01

    If you are still interested in this possibility, I've made a fork of the il-repack project based on Mono.Cecil which accepts a "/meta" command line argument to generate a metadata only assembly for the public and protected types.

    https://github.com/KarimLUCCIN/il-repack/tree/xna

    (I tried it on the full XNA Framework and its working afaik ...)

    0 讨论(0)
  • 2020-12-08 08:05

    You might have luck with the Cecil Library (from Mono); I think the implementation allows ILMerge functionality, it might just as well write metadata only assemblies.

    I have scanned the code base (documentation is sparse), but haven't found any obvious clues yet...

    YYMV

    0 讨论(0)
  • 2020-12-08 08:09

    Yes, this is new for .NET 4.0. I'm fairly sure this was done to avoid the nasty versioning problems in the .NET 2.0 service packs. Best example is the WaitHandle.WaitOne(int) overload, added and documented in SP2. A popular overload because it avoids having to guess at the proper value for *exitContext" in the WaitOne(int, bool) overload. Problem is, the program bombs when it is run on a version of 2.0 that's older than SP2. Not a happy diagnostic either. Isolating the reference assemblies ensures that this can't happen again.

    I think those reference assemblies were created by starting from a copy of the compiled assemblies (like it was done in previous versions) and running them through a tool that strips the IL from the assembly. That tool is however not available to us, nothing in the bin/netfx 4.0 tools Windows 7.1 SDK subdirectory that could do this. Not exactly a tool that gets used often so it is probably not production quality :)

    0 讨论(0)
  • 2020-12-08 08:28

    To create a reference assembly, you would add this line to your AssemblyInfo.cs file:

    [assembly: ReferenceAssembly]
    

    To load others, you can reference them as usual from your VisualStudio project references, or dynamically at runtime using:

    Assembly.ReflectionOnlyLoad()

    or

    Assembly.ReflectionOnlyLoadFrom()


    If you have added a reference to a metadata/reference assembly using VisualStudio, then intellisense and building your project will work just fine, however if you try to execute your application against one, you will get an error:

    System.BadImageFormatException: Cannot load a reference assembly for execution.

    So the expectation is that at runtime you would substitute in a real assembly that has the same metadata signature.

    If you have loaded an assembly dynamically with Assembly.ReflectionOnlyLoad() then you can only do all the reflection operations against it (read the types, methods, properties, attributes, etc, but can not dynamically invoke any of them).


    I am curious as to what your use case is for creating a metadata-only assembly. I've never had to do that before, and would love to know if you have found some interesting use for them...

    0 讨论(0)
提交回复
热议问题