ASP.NET MVC 3.0 Build Views as 64 bit - asp.net-mvc-3

I need to build an MVC 3.0 site and target x64 specifically. I'm having an issue trying to build my MVC 3.0 site with the Platform Target set to x64 and MvcBuildViews set to True. Everything builds fine until it tries to compile the views. If I set the Platform Target to AnyCPU everything will compile, but when set to x64 I get this error:
Could not load file or assembly 'Mvc64Bit' or one of its dependencies. An attempt was made to load a program with an incorrect format.
This can easily be recreated by creating a blank MVC 3.0 project, unload the project, edit the project file to set the MvcBuildViews item to "true", reload the project, change the Platform Target in the Project's Build Properties to x64, and then build.
I haven't been able to find anything about the above error online, just that it deals with mismatched DLLs (one x32, one x64) but this doesn't make sense unless the view build engine is 32 bit or something.
Any hints to point me in the right direction will be GREATLY appreciated. Thanks for reading!!

I got a response from Microsoft on this issue. I guess what is happening is that Visual Studio calls a 32-bit compiler that compiles the website into a 64 bit DLL. After that, it calls the 32-bit compiler again for the views. The view compilation needs to load the 64 bit Web project DLLs to get information from the defined models. This is where the "Incorrect format" comes in. The 32 bit compiler tries to load the 64 bit Web project DLLs.
Now, calling the 64 bit aspnet_compiler.exe from the Visual Studio Command Prompt works perfectly. But, I guess, since Visual Studio is a 32 bit application, it can't load the 64 bit compiler. I'm not sure of any way to call the 64 bit, and even if there was a way, Visual studio probably couldn't give the nice list of errors that typically does (just an assumption there as I don't know how Visual Studio calls the compiler...a simple command line execution works, but maybe it actually loads the DLL and calls from inside the VS code)
So, my work around was to put the MVCBuildViews=true declaration inside the property. I then put MVCBuildViews=false in the 'Release|AnyCPU' propertyGroup and I just let IIS compile the views when the site first loads. It's not precompiling completely, but it will work.

Related

Visual Studio custom data visualizer throws BadImageFormatException

In our c# code base (hence managed code), we have a class that we make extensive use of throughout the code.
Given its ubiquity, I decided to write a custom debugger visualizer so that we could easily examine such objects when debugging.
But, I hit a snag - when I try to run the visualizer in the IDE, I get a BadImageFormatException.
I am posting this to help others who come across the same error. I know what the issue and solution is and will post.
Currently (as of Visual Studio 2019) it's possible to split the visualizer into two:
debuggee-side DLL -- gets injected into the target process, and
debugger-side DLL -- loaded into Visual Studio.
The two halves pass data between each other using serialization/deserialization.
This architecture is required for visualizers to target multiple frameworks -- the debugger side is loaded into Visual Studio, so it must target .NET Framework; the debuggee side is injected into the target process, which might target .NET Core or .NET 5+. (I refer you to this repo for a minimal visualizer with this structure; and to other visualizers I've written (1 2) which also use a similar architecture.)
The same architecture works for bit-ness. Visual Studio is a 32-bit application, so the debugger side cannot be 64-bit; it must be 32-bit or AnyCPU. But if the target process might be 64-bit, the debuggee side has to match the target process and must be 64-bit or AnyCPU.
Per the docs:
Typically, it is best if both the debugger-side DLL and the debuggee-side DLL specify Any CPU as the target platform. The debugger-side DLL must be either Any CPU or 32-bit. The target platform for the debuggee-side DLL should correspond to the debugee process.
The issue is that Visual Studio itself, the IDE, runs as a 32-bit process only. If it is to run a custom data visualizer for you while debugging, the custom visualizer and all the code that this visualizer loads must be loadable and runnable by a 32-bit process. The custom visualizer gets the object to visualize by a serialization/deserialization process. To deserialize the object, the visualizer must be able to load the .dll in which the object is defined. And here we run in to the snag: if we are building our application to an x64 target (rather than an AnyCpu target), we’re up a creek – it doesn’t matter if the custom visualizer itself is built to a 32-bit target, because it’s the application code that must be used for deserialization.
So if your application is built to a 64-bit target, you cannot run a custom visualizer (big, big OUCH Microsoft!). To get around the snag, you can build to a target of AnyCpu, and then things work well: the application loads and runs as 64-bit (since targeted to AnyCpu), but the IDE is still able to load the .dll’s as 32-bit for the purposes of the custom data visualizer running in the IDE’s process space.
If I am wrong on this and there is a better work-around, I would love to be corrected! Thanks.

Can a Winforms application use the Forms Designer and access the SharePoint Server Side Object Model

I am developing a Windows Forms application that needs to access and manipulate a SharePoint 2013 Site Collection, preferably via the Server-Side Object Model (SSOM). I seem to be running into a problem similar to the question "Visual studio designer in x64 doesn't work"
I cannot run the SSOM code in x86 or AnyCPU, and when I try to open a form with user controls in the forms designer after compiling to x64, I get the following error:
Could not find type '[UserControl]'. Please make sure that the assembly that contains this type is referenced. If this type is a part of your development project, make sure that the project has been successfully built using settings for your current platform or Any CPU.
It would seem the UserControl(s) are being compiled into x64, but cannot be rendered by the designer, which I suppose is running in x86. These user controls are all in the same project, and recompiling the whole project as x86 allows the forms designer to render
Is my only option to completely rebuild my entire code base each time I want to switch between form design and interfacing with SharePoint?
Until or unless Hans Passant comes along and claims the answer he essentially gave me in the comment thread, I'll post my resolution to the issue:
Solution
Ensure that any user controls used in a 64 bit targeted forms/projects are in a separate project, which is compiled to target "AnyCPU", and then rebuild and reference that project.
When the forms designer, which is running as x86, tries to load your user controls for rendering, it will run the controls as x86, but when you build the 64 bit project and run it, the references will be coming from an x64 process, and will thus run the controls as x64.

In what ways does native multi-targeting affect the output of a build

I have a large solution made from a combination of c++ and c# projects, most of which output dll's. We also have an executable which depends on the outputs from those projects. Our entire solution is currently built in VS2005. For numerous reasons we have to target v80 for our builds, but we've finally found time to move to the 2010 IDE.
When we build in 2010, our solution all compiles fine, but we get an access violation when running the app. This exception occurs in a number of scenarios, but always at the same point in code - It also shows as an "exception encountered during a user callback". If we edit out the line of code where the exception throws, it simply moves to somewhere else, which makes sense. The scenario's in which we have the issue are as follows:
All dll's and exe built in 2010 against the v80 toolset.
All dll's build in 2005, exe built in 2010 against the v80 toolset.
Notably though, if we use the dll's built in 2010 (against v80) but the exe built in 2005, everything works fine.
My question then is: What is the difference between the output from a build in 2005 and the output from a build in 2010 using the v80 toolset?
The above is probably dependent on whether it is possible to exactly match the commandline arguments for the build (ie, c++ and linker configuration) as it may be we haven't quite got those right. If needed I can link the settings from 2005 and those from 2010.
Any help would be much appreciated.
UPDATE:
I've recently created a very simple application in 2005, consisting of a dll and exe. The dll has a function static __declspec(dllexport) int add(int a, int b). The exe is a simple console application which calls the add function from the dll.
I then ported this to VS2010 and set it to the v80 toolset. Building this produces a dll with the same size as the original, the exe however is 4KB bigger. I'm using dumpbin to try and find out why, but I don't know it too well at the minute. If anyone else can identify in this simple case why the exe's are different sizes, this may help solve my overall problem
Solved this now, the issue was caused by DEP being turned on by default. I can confirm for anyone else though that the output from the builds should and will match exactly if you use the same compiler and linker settings.

Cannot find wrapper assembly for type library "Redemption"

Okay, I am trying to add a .dll file to my application in Visual Studio 2010. If it is set for 32 bit, everything is fine. However, once I switch it to 64 bit, the library has a warning on it and wont load. I'm assuming the error "A single valid machine type compatible with the input type library must be specified" is related to the .dll not loading properly. It works fine if the application is moved up to .NET4.0 but I need to try and get this to work in .NET2.0. Any advice you can give on what is causing Visual Studio to not recognize the redemption64.dll would be greatly appreciated.
Make sure you project is set to build as "Any CPU", not x86 or x64 when you import the Redemption type library.

Building a website project as 32-bit on a 64-bit build server

I have a VS 2010 solution that contains a website that has a web service within it. The web service references a COM dll that is causing problems when the solution is built on our 64-bit build server. I get the typical 32/64-bit error:
ASPNETCOMPILER : error ASPCONFIG: Could not load file or assembly 'xxx' or one of its dependencies. An attempt was made to load a program with an incorrect format
When I build the site using the 32-bit aspnet_compiler it builds okay. So, how do I specify that a website should be built as 32-bit? The Configuration Manager within VS will only let me choose Any CPU, so I cannot change it to x86 for this website...
Thanks.
You can use the following command. Actually, in this case you are using ASPNetCompiler x86 edition to build your own project
call "C:\Program Files\Microsoft Visual Studio 2008\VC\vcvarsall.bat" x86
MSBuild MySolutiuon.sln
You can also use x86_amd64 for any cpu. Note that instead of using MSBuild you can load your confiiguration like
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<Target Name="PrecompileWeb">
<AspNetCompiler
VirtualPath="/MyWebSite"
PhysicalPath="c:\inetpub\wwwroot\MyWebSite\"
TargetPath="c:\precompiledweb\MyWebSite\"
Force="true"
Debug="true"
FixedNames="True"
/>
</Target>
</Project>
to use above confiuguration you have to use
MSBuild your.xml /p:Configuration=Release
#Vilx, Check the dependency walker to find out how far it gets. My guess is it would probably stop at vjsnativ.dll. If that's as far as it gets, try this workaround.
Otherwise you'll have to chase down each DLL that the program can't find, and copy them into your program (or its bin) directory.
Its not the compilation problem but the environment problem. The ASP.NET Website will always be built as Any CPU.
However, if you load it on 64 bit machine, by default 64 bit version of IIS is running which
is unable to load COM DLL and it fails.
You need to configure IIS to run 32 bit applications on 64 bit Windows:
http://www.microsoft.com/technet/prodtechnol/windowsserver2003/library/iis/405f5bb5-87a3-43d2-8138-54b75db73aa1.mspx
You need to use the ASP.NET Compilation Tool (Aspnet_compiler.exe). Look for the ' Finding the Correct Version of Aspnet_compiler.exe' chapter at the end of the doc, it explains how to find the 32 vs 64 bit versions of the tool.
Right-Click on your Web Project in Visual Studio.
Select "Properties".
Click the "Build" tab on the left.
Under "General" change the "Platform Target" to "x86" so it will always build for 32-bit.
Now when you do this you may notice on the same "Build" tab that the "Configuration" is set to "Active (Debug)". You will need to change that drop-down to all the different configuration settings you have (i.e. "Release", "QA", "Staging", "Demo", etc..) and make the same "Platform Target" change to "x86" for each one.
Don't forget to click the "Save" button when you're done - remember to set it back to "Debug" if you're on your development box.
That's probably why it only works when you build it on your machine, and not on the Build Server as the Build Server is most likely set up to build against a different configuration - which is correct, because you shouldn't be using the "Debug" configuration on a Build Server.
Although this is an old question, I was faced with the same problem and I had some troubles finding an answer.
Visual studio offers two options for developing web applications: web sites and web applications. We applications generate assemblies per page, which are dynamically updated if the source changes. On the other hand web application projects are compiled in visual studio to one assembly. This assembly is not automatically rebuilt after changes to the source code. The differences are explained in detail in this document: http://msdn.microsoft.com/en-us/library/aa730880(VS.80).aspx#wapp_topic5
Another difference, which is relevant here is that web application projects allow you to actually choose an architecture contrary to web site projects. Converting a web site to a web application is not very hard, but not too straightforward (the option convert to web application is only available after creating a ... web application). Steps you can take:
Create a new web empty web application
Browse to the directory of new web application and copy all files from your website (overwriting anything in the directory)
Add all files to the project
Right click the project and choose “Convert to web application”.
It may be needed to solve a few namespace issues.

Resources