Bug Report B145400
Visible to All Users

Error from loader while loading plugin, but only in 64-bit

created 15 years ago

In Windows 7 Enterprise 64-bit, the community plugin CR_Documentor (version 2.4.0.0, available here: http://cr-documentor.googlecode.com/files/CR_Documentor-2.4.0.0.zip) appears to cause a loader error which doesn't allow the plugin to load. This same error is not received in a Windows XP 32-bit environment.
The relevant error appears to be:
<item category="DXCore Loader" color="ARGB:255:225:225:225">
<message>Exception occurred while attempting to load assembly at "C:\Users\grosch\Documents\DevExpress\IDE Tools\Community\PlugIns\CR_Documentor.dll". (System.IO.FileLoadException)</message>
<imageindex>3</imageindex>
<timestamp>2010-03-05 12:54:22Z</timestamp>
<datatype>System.IO.FileLoadException, mscorlib</datatype>
<data>System.IO.FileLoadException
Could not load file or assembly 'file:///C:\Users\grosch\Documents\DevExpress\IDE Tools\Community\PlugIns\CR_Documentor.dll' or one of its dependencies. Operation is not supported. (Exception from HRESULT: 0x80131515)
mscorlib
System.Reflection.RuntimeAssembly _nLoad(System.Reflection.AssemblyName, System.String, System.Security.Policy.Evidence, System.Reflection.RuntimeAssembly, System.Threading.StackCrawlMark ByRef, Boolean, Boolean, Boolean)
at System.Reflection.RuntimeAssembly._nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, RuntimeAssembly locationHint, StackCrawlMark& stackMark, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks)
at System.Reflection.RuntimeAssembly.nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, RuntimeAssembly locationHint, StackCrawlMark& stackMark, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks)
at System.Reflection.RuntimeAssembly.InternalLoadAssemblyName(AssemblyName assemblyRef, Evidence assemblySecurity, StackCrawlMark& stackMark, Boolean forIntrospection, Boolean suppressSecurityChecks)
at System.Reflection.RuntimeAssembly.InternalLoadFrom(String assemblyFile, Evidence securityEvidence, Byte[] hashValue, AssemblyHashAlgorithm hashAlgorithm, Boolean forIntrospection, Boolean suppressSecurityChecks, StackCrawlMark& stackMark)
at System.Reflection.Assembly.LoadFrom(String assemblyFile)
at DevExpress.DXCore.Loader.PlugInAssembly.LoadAssembly(String path, Assembly& loadedAssembly)</data>
<items>
  <item category="DXCore Loader" color="ARGB:255:225:225:225">
    <message>Exception occurred while attempting to load assembly at "C:\Users\grosch\Documents\DevExpress\IDE Tools\Community\PlugIns\CR_Documentor.dll". (System.NotSupportedException)</message>
    <imageindex>3</imageindex>
    <timestamp>2010-03-05 12:54:22Z</timestamp>
    <datatype>System.NotSupportedException, mscorlib</datatype>
    <data>System.NotSupportedException
An attempt was made to load an assembly from a network location which would have caused the assembly to be sandboxed in previous versions of the .NET Framework. This release of the .NET Framework does not enable CAS policy by default, so this load may be dangerous. If this load is not intended to sandbox the assembly, please enable the loadFromRemoteSources switch. See http://go.microsoft.com/fwlink/?LinkId=155569 for more information.
</data>
  </item>
</items>
</item>
The plugin has a [assembly: SecurityPermission(SecurityAction.RequestMinimum)] attribute on it, and I'm guessing this has something to do with that, but this doesn't appear to affect the 32-bit environment.
A full log is attached.
Steps to Reproduce:

  1. Install the CR_Documentor plugin on a 32-bit environment.
  2. Load VS2010.
  3. Open the DevExpress menu and then the Tool Windows menu.
  4. Select "Documentor." The CR_Documentor window should appear.
  5. Install the CR_Documentor plugin on a 64-bit environment.
  6. Load VS2010.
  7. Open the DevExpress menu and then the Tool Windows menu.
  8. Notice the Documentor tool window is not available.
    Actual Results:
    CR_Documentor is not available on 64-bit but is on 32-bit.
    Expected Results:
    CR_Documentor should be available on all platforms.
Show previous comments (4)

    I had my end user test the version of CR_Documentor that you compiled as well as the version I provided without the [SecurityPermission] attribute. Neither version worked for him - the CR_Documentor tool window entry never showed up on the DevExpress tool window menu.

      My end user was able to compile the code himself and it worked fine. After hearing that, I had him try something else that maybe you could try:
      Use the original CR_Documentor assembly from the CR_Documentor web site. Put it in your Community Plugins folder as usual. Before loading VS, right-click it, go to the Properties on the assembly, and "unblock" the assembly. Win7 knows the assembly didn't originate on your machine so it may be blocking something that lets it load.
      Does that work for you? It worked for my end user. If that's the solution, I can update my install instructions with info on how to fix it. It'll be something all the community extension writers will need to be aware of.

      DevExpress Support Team 15 years ago

        Hi Travis,
        Thank you for the response, and for providing additional information.
        Yes, the initial assembly you provided is loaded fine on our side if we "unblock" it. So, it looks as if this Windows 7 specificity is the cause of this loading problem.
        Thanks,
        Vito

        Disclaimer: The information provided on DevExpress.com and affiliated web properties (including the DevExpress Support Center) is provided "as is" without warranty of any kind. Developer Express Inc disclaims all warranties, either express or implied, including the warranties of merchantability and fitness for a particular purpose. Please refer to the DevExpress.com Website Terms of Use for more information in this regard.

        Confidential Information: Developer Express Inc does not wish to receive, will not act to procure, nor will it solicit, confidential or proprietary materials and information from you through the DevExpress Support Center or its web properties. Any and all materials or information divulged during chats, email communications, online discussions, Support Center tickets, or made available to Developer Express Inc in any manner will be deemed NOT to be confidential by Developer Express Inc. Please refer to the DevExpress.com Website Terms of Use for more information in this regard.