Hans Karlsen (talk | contribs) No edit summary |
m ((username removed) (log details removed)) |
||
(4 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
==== Did you | ==== Did you know: to prevent possible data loss before loading the Designer, the following errors must be resolved? ==== | ||
There can be many reasons, one known reason is described here. | |||
In | In Visual Studio, we have MDriven code that makes up the design-time experience. This is the model and the OCL-Editor and the like. | ||
One of the older things of MDriven are the WindowsForms Handles; ExpressionHandle, ReferenceHandle and CursorHandle to mention a few. | One of the older things of MDriven are the WindowsForms Handles; ExpressionHandle, ReferenceHandle, and CursorHandle to mention a few. | ||
These handles | These handles connect to the DesignTime code for Visual Studio that we find in Eco.Handles.Design. | ||
We run into a problem when Visual Studio compiles your code and | We run into a problem when Visual Studio compiles your code and finds MDriven assemblies in it - specifically the Eco.Handles.dll. Visual Studio will copy that Eco.Handles.dll from your project and put it in a directory like this: | ||
C:\Users\hans\AppData\Local\Microsoft\VisualStudio\''17.0_d364b061Exp''\ProjectAssemblies\''cobgw1bv.p2l01''\Eco.Handles.dll | C:\Users\hans\AppData\Local\Microsoft\VisualStudio\''17.0_d364b061Exp''\ProjectAssemblies\''cobgw1bv.p2l01''\Eco.Handles.dll | ||
Now whenever your WindowsForms designer code is de-serialized in design time (executed to actually assign properties) - Visual Studio will first look in ProjectAssemblies | Now whenever your WindowsForms designer code is de-serialized in design time (executed to actually assign properties) - Visual Studio will first look in ProjectAssemblies and find a copy of Eco.Handles.dll there - it will load this even though we have one loaded from where we installed the MDriven-Extension: | ||
C:\USERS\HANS\APPDATA\LOCAL\MICROSOFT\VISUALSTUDIO\''17.0_D364B061EXP''\EXTENSIONS\MDRIVEN AB\MDRIVENFRAMEWORK\''7.0.0.14859''\Eco.Handles.dll | C:\USERS\HANS\APPDATA\LOCAL\MICROSOFT\VISUALSTUDIO\''17.0_D364B061EXP''\EXTENSIONS\MDRIVEN AB\MDRIVENFRAMEWORK\''7.0.0.14859''\Eco.Handles.dll | ||
After this has happened Visual Studio has 2 code | After this has happened, Visual Studio has 2 code bases for the Handles - one that the Plugin uses and one that the WindowsForms de-serialized from. | ||
This gives us strange exceptions as: | This gives us strange exceptions as: | ||
Object of type 'Eco.Handles.ExpressionHandle' cannot be converted to type 'Eco.Handles.ElementHandle'. | Object of type 'Eco.Handles.ExpressionHandle' cannot be converted to type 'Eco.Handles.ElementHandle'. | ||
Method 'Eco.Handles.ColumnCollection.AddRange' not found. | Method 'Eco.Handles.ColumnCollection.AddRange' not found. | ||
...these exceptions | ...these exceptions do not make logical sense until one understands that Visual Studio has mixed the code bases from two different places: our MDriven extension installation and your ProjectAssemblies. | ||
To stop | To stop Visual Studio from making this mistake, we must ensure that it finds the Eco.Handles.dll from the extension and does not load the Eco.Handles.dll from ProjectFiles. | ||
...it turns out that no matter what probing path we put eco.handles.dll in we cannot jump in front the projectassemblies path... | ...it turns out that no matter what probing path we put eco.handles.dll in, we cannot jump in front of the projectassemblies path... | ||
...except when we put the assembly in the GAC - the GAC beats everything, including the | ...except when we put the assembly in the GAC - the GAC beats everything, including the ProjectAssemblies... | ||
...Why is GAC not perfect then: | ...Why is GAC not perfect then: | ||
# The VSIX installation is not allowed to put things into the GAC, | # The VSIX installation is not allowed to put things into the GAC, | ||
# GAC will also trump your bin catalog when executing your app (so if you use | # GAC will also trump your bin catalog when executing your app (so if you use another version from Nuget - GAC will win). | ||
# Due to point 2 it becomes important that your MDrivenExtension has the same version as your Nuget packages (EcoCore) - or you may run on other code than you think | # Due to point 2, it becomes important that your MDrivenExtension has the same version as your Nuget packages (EcoCore) - or you may run on other code than you think | ||
=== How to solve === | === How to solve === | ||
When using WinForms designer capabilities you will want the Eco.Handles.dll installed in GAC. | When using WinForms designer capabilities, you will want the Eco.Handles.dll installed in GAC. | ||
To add Eco.Handles to GAC: | To add Eco.Handles to GAC: | ||
# Open the AboutForm for MDriven | |||
Open the | # Copy the text from the Gacutil /i option | ||
# Close the AboutForm | |||
# Open View/Terminal | |||
# Paste Gacutil /i option | |||
# Execute | |||
# Restart VS. | |||
To remove Eco.Handles from GAC: | To remove Eco.Handles from GAC: | ||
# Open the AboutForm for MDriven | |||
Open the | # Copy the text from the Gacutil /u option | ||
[[File:2023-07-17 18h51 28.png|none|thumb| | # Close the AboutForm | ||
# Open View/Terminal | |||
# Paste Gacutil /i option | |||
# Execute | |||
# Restart VS. | |||
[[File:2023-07-17 18h51 28.png|none|thumb|497x497px]] | |||
{{Edited|July|12|2024}} | |||
[[Category:MDriven Designer]] |
Latest revision as of 06:27, 13 March 2024
Did you know: to prevent possible data loss before loading the Designer, the following errors must be resolved?
There can be many reasons, one known reason is described here.
In Visual Studio, we have MDriven code that makes up the design-time experience. This is the model and the OCL-Editor and the like.
One of the older things of MDriven are the WindowsForms Handles; ExpressionHandle, ReferenceHandle, and CursorHandle to mention a few.
These handles connect to the DesignTime code for Visual Studio that we find in Eco.Handles.Design.
We run into a problem when Visual Studio compiles your code and finds MDriven assemblies in it - specifically the Eco.Handles.dll. Visual Studio will copy that Eco.Handles.dll from your project and put it in a directory like this:
C:\Users\hans\AppData\Local\Microsoft\VisualStudio\17.0_d364b061Exp\ProjectAssemblies\cobgw1bv.p2l01\Eco.Handles.dll
Now whenever your WindowsForms designer code is de-serialized in design time (executed to actually assign properties) - Visual Studio will first look in ProjectAssemblies and find a copy of Eco.Handles.dll there - it will load this even though we have one loaded from where we installed the MDriven-Extension:
C:\USERS\HANS\APPDATA\LOCAL\MICROSOFT\VISUALSTUDIO\17.0_D364B061EXP\EXTENSIONS\MDRIVEN AB\MDRIVENFRAMEWORK\7.0.0.14859\Eco.Handles.dll
After this has happened, Visual Studio has 2 code bases for the Handles - one that the Plugin uses and one that the WindowsForms de-serialized from.
This gives us strange exceptions as:
Object of type 'Eco.Handles.ExpressionHandle' cannot be converted to type 'Eco.Handles.ElementHandle'. Method 'Eco.Handles.ColumnCollection.AddRange' not found.
...these exceptions do not make logical sense until one understands that Visual Studio has mixed the code bases from two different places: our MDriven extension installation and your ProjectAssemblies.
To stop Visual Studio from making this mistake, we must ensure that it finds the Eco.Handles.dll from the extension and does not load the Eco.Handles.dll from ProjectFiles.
...it turns out that no matter what probing path we put eco.handles.dll in, we cannot jump in front of the projectassemblies path...
...except when we put the assembly in the GAC - the GAC beats everything, including the ProjectAssemblies...
...Why is GAC not perfect then:
- The VSIX installation is not allowed to put things into the GAC,
- GAC will also trump your bin catalog when executing your app (so if you use another version from Nuget - GAC will win).
- Due to point 2, it becomes important that your MDrivenExtension has the same version as your Nuget packages (EcoCore) - or you may run on other code than you think
How to solve
When using WinForms designer capabilities, you will want the Eco.Handles.dll installed in GAC.
To add Eco.Handles to GAC:
- Open the AboutForm for MDriven
- Copy the text from the Gacutil /i option
- Close the AboutForm
- Open View/Terminal
- Paste Gacutil /i option
- Execute
- Restart VS.
To remove Eco.Handles from GAC:
- Open the AboutForm for MDriven
- Copy the text from the Gacutil /u option
- Close the AboutForm
- Open View/Terminal
- Paste Gacutil /i option
- Execute
- Restart VS.