Sunday, January 11, 2009
ClickOnce - Manually modifying the Application file list.
You can include files in the "Applciation Files" list by adding them to the project. (i.e In VS rightclick on the ClickOnce project and select Add->Existing Item.
The problem with this is that the files are copies into the Project directory.
A better way to handle this is to use an Xml editor to manually edit the project file (*.csproj).
Refer to blogs.msdn.com/mwade/archive/2008/06/29/how-to-publish-files-which-are-not-in-the-project
Regards
Andy
Install Opera Code Signing Certificates into Vista
The certificate transfer process is pretty tricky and the certificate ends up installed in the Certificate store of the browser used to request and transfer it.
YOU MUST USE THE SAME BROWSER TO ORDER AND DOWNLOAD THE CERTIFICATE.
I recommend using Opera 9.6 to order and download certificates.
Because I had difficulties with the ordering and download process Comodo issued a replacement certificate. Unfortunately I then used the first certificate for code signing. Comodo had revoked this certificate and the ClickOnce install dialog indicated "Unknown Publish". However, there was NO indication in the Windows Certificate Manager "CertMrg.msc" that the certifcate had been revoked. This issue was only resolved when Comodo support told me the serial number of working certificate.
To install the certificate in Vista proceed as follows:
First export the certificate from the browser ( In this case Opera 9.63 ).
Tools->Preferences->Advanced Tab.
You should see a "Manage Certificates" button.
Press the button.
The browser certificate manager will be displayed. The downloaded code signing certificates should be shown under the "Personal" tab.
Select the certificate and press the "Export" button on the right side of the form.
A file create dialog is displayed. Give the exported certificate a file name and select to save as type "PKCS #12 (*.p12) This type is equivalent to the Windows .pfx type.
Follow the dialogs to export the certificate.
Now install the certificate into the Vista certificate store.
First run the Vista Certificate manage program "certmgr.msc"
Select the Personal/Certificates folder and then Ations->All Tasks->Import
Select the file exported above ( be sure to filter on file type .p12 ).
Follow the import wizard. Be sure NOT to select the
"Enable strong private key protecion" VS Code signing cannot handle the password request
Place the certicate in the "Personal" folder.
The certificate should now be availabe for code signing in VS.
Good luck. Andy
Friday, January 9, 2009
Microsoft StyleCop - Editing setting under Vista 64
This file may be edited with the StyleCopSettingsEditor.exe.
Under Vista 64 write access to the program folders is restricted to users with Administrator privileges.
Here's the rub.
StyleCopSettingsEditor must be running as Administrator to write setting changes to
Settings.StyleCop.
Settings.StyleCop is associated with StyleCopSettingsEditor.exe thru the StyleCop extension, but the "Run as Administrator" option is only available when clicking on exe's.
You can "Run as Administrator" StyleCopSettingsEditor.exe but the exe requires a command line parameter pointing to Settings.StyleCop.
The solution:
Create a shortcut on the desktop to StyleCopSettingsEditor.exe.
Append "Settings.StyleCop" to the target which becomes:
"C:\Program Files (x86)\Microsoft StyleCop 4.3\StyleCopSettingsEditor.exe" "Settings.StyleCop"
Under the Compatibility tab check "Run as Administrator"
Double Click the shortcut to launch StyleCopSettingsEditor.exe. The program is now running as Administrator and has sufficient rights to update Settings.StyleCop in the program folder.
Wednesday, November 12, 2008
Microsoft.mshtml.dll cannot be referenced in VS 2008 3.5 project
When doing this I checked the Client-only Framework subset option. When I compiled I had errors indicating that the compiler could not reference Microsoft.mshtml.dll.
When I checked the project references this one was marked with the asterisk.
Unchecking Client-only Framework subset option corrected the problem.
Andy
Sunday, September 7, 2008
Testing Enumerations in Eco Ocl
I can never remember the Ocl syntax used to refer to the value of an enumeration.
The syntax is $enumname$::$enumvalue$
Here is a sample Ocl string to select a particular value of VehicleTypes
"VehicleSupplier.allInstances->select( Type = VehicleTypes::MotorHome)"
Monday, August 18, 2008
Using Linq extension methods with arrays
I was generating a file path and file name from user text.
This routine was vulnerable to chars illegal to the file system in the user text.
I needed to strip any illegal chars from the user text.
The Path class has two static methods which return path and file name illegal chars.
These are:
Path.GetInvalidPathChars( ) -> char[]
Path.GetInvalidFileNameChars( ) -> char[]
In order to strip both I wanted to create the set union of these two arrays.
The Linq set extension methods return IEnumerable
In the end I used the following to generate a set comprising the union of both sets of illegal chars.
List
Note that if you wish to change the file extension it is important to add '.' to the list of illegal chars. Failure to do so may result in your filename being truncated at the '.'.
Monday, June 23, 2008
Running wsewsdl3.exe in Vista 64 with VS2008.
Hi,
I ported a VS2005 project from my old XP machine to my new Vista 64 machine running VS2008.
In my project I was using Wsewsdl3.exe to generate c# code from wsdl definitions.
Wsewsdl3 refused to run with the error:
"Could not get the install directory for .NET Framework v2.0 SDK. Please install the .NET Framework v2.0 SDK."
I know that Wsewsdl3 is a pre-processor for Wsdl.exe and also knew that Wsdl.exe had changed paths between VS versions.
Luckily Wsewsdl3.exe is written in .Net and I was able to use Reflector to disassemble the source and find where it was looking for Wsdl.exe.
Here are the code fragments:
Registry.LocalMachine.OpenSubKey(@"Software\Microsoft\.NETFramework");
key.GetValue("sdkInstallRootv2.0")
When I looked in the registry of the old machine I saw this key.
At this point I installed the .Net 2/0 SDK
http://www.microsoft.com/downloads/details.aspx?FamilyID=fe6f2099-b7b4-4f47-a244-c96d69c35dec&displaylang=en
This installed itself at:
C:\Program Files (x86)\Microsoft Visual Studio 8\SDK\v2.0
Now I opened the registry editor RegEdit.exe, moved to HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\.NETFramework and added a new string value with name
"sdkInstallRootv2.0" and value "C:\Program Files (x86)\Microsoft Visual Studio 8\SDK\v2.0"
Wsewsdl3.exe now runs.
I hope this has not screwed anything else!
Hope this helps someone.
Andy