Reputation: 1946
I've got a really simple powershell script (see below). I've got installutil aliased using the following in my profile:
set-alias installutil $env:windir\Microsoft.NET\Framework\v2.0.50727\installutil
In powershell I simply:
installutil assemplylocation.dll
This returns successfully. (Install/Commit both complete successfully). Yet when I check the registry, or in powershell using get-pssnapin -registered it doesn't show my assembly. I did this the other day and it worked fine, but I don't seem to be able to duplicate it ... please advise.
using System;
using System.Management.Automation;
using System.ComponentModel;
namespace PSBook_2_1
{
[RunInstaller(true)]
public class PSBookChapter2MySnapIn : PSSnapIn
{
public PSBookChapter2MySnapIn()
: base()
{ }
// Name for the PowerShell snap-in.
public override string Name
{
get
{
return "Wiley.PSProfessional.Chapter2";
}
}
// Vendor information for the PowerShell snap-in.
public override string Vendor
{
get
{
return "Wiley";
}
}
// Description of the PowerShell snap-in
public override string Description
{
get
{
return "This is a sample PowerShell snap-in";
}
}
}
// Code to implement cmdlet Write-Hi
[Cmdlet(VerbsCommunications.Write, "Hi")]
public class SayHi : Cmdlet
{
protected override void ProcessRecord()
{
WriteObject("Hi, World!");
}
}
// Code to implement cmdlet Write-Hello
[Cmdlet(VerbsCommunications.Write, "Hello")]
public class SayHello : Cmdlet
{
protected override void ProcessRecord()
{
WriteObject("Hello, World!");
}
}
}
Upvotes: 13
Views: 9220
Reputation: 2013
I had to use the x86 (32bit) version of PowerShell to add the Snapin. As I found it not as straight forward as it's supposed to be here's a helpful link how to open PowerShell 32bit:
http://technet.microsoft.com/en-us/library/hh847733.aspx
Upvotes: 0
Reputation: 11
Experienced the same issue - I was trying to use command
C:\Windows\Microsoft.net\Framework\V4.0.30319\installutil myDLL.dll
instead of
C:\Windows\Microsoft.net\Framework64\V4.0.30319\installutil myDLL.dll
while having 64 bit cmdlet (project config. Any CPU) on OS win2k8 x64..
Upvotes: 0
Reputation: 1900
downatone's answer put me on the right track but my problem was the opposite way round. My project is set to any CPU and I am on Win7 x64 so the powershell being launched from my code and then installing the dll with the snapin was 64 bit. However the install command I used was pointing to the 32 bit .net runtime i.e.
C:\Windows\Microsoft.net\Framework\V4.0.30319\installutil myDLL.dll
when it should have been
C:\Windows\Microsoft.net\Framework64\V4.0.30319\installutil myDLL.dll
Note the 64 in the Framework path.
Upvotes: 14
Reputation: 11
The key point for me here was remembering that Visual Studio 2010 is still a 32 bit application meaning that when I used the Command Prompt it defaulted to the 32-bit variant of InstallUtil. Its not immediately obvious in this case that the registry keys are therefore written to the Wow64-bit node instead of the 64-bit registry proper.
Upvotes: 1
Reputation: 1946
Turns out the issue was that I had a 32-bit cmdlet - but was only checking the 64-bit version of powershell ...
Upvotes: 11
Reputation: 755327
Did you run installutil as an elevated user? It writes information to protected portions of the registry. If you do this as a non-admin on Vista it can produce strange results.
Upvotes: 1