Monday, September 28, 2009
Simple PowerShell way to change a string across multiple files
1) Position myself in the directory where the files are located
2) Type in this quicky applet in PowerShell:
$filenames = ls *.exe.config
$match = "devserver2"
$replacement = "prodserver1"
$filenames | %{
>> $content = get-content $_
>> $content = $content -creplace $match, $replacement
>> $content | set-content $_
>> }
Note that I used the case-sensitive PowerShell replace verb. I wish this could be a one-liner but I haven't been able to figure out how to do that.
Monday, September 21, 2009
Helpful tip when using VS2008 over slow network connection
Tools / Options / Environment / General -> uncheck the "animate environment tools" checkbox
Saturday, September 12, 2009
Installing VS2008 C# services under Vista
It's a pretty deep problem (see Alek Davis's post at http://alekdavis.blogspot.com/2007/09/deploy-windows-services-on-vista.html for details) ... and not worth the effort, in my estimation.
Just use INSTALLUTIL under the C:\Windows\Microsoft.NET\Framework\v2.0.50727 directory to install the service the old-fashioned way (INSTALLUTIL
I included the Alek Davis link in case I need to actually create a service setup program in the future, here's hoping I don't.
I'm curious as to whether this problem persists in Windows 7.
This is another reason that Vista is not working out for me. If I hadn't gotten that free copy at the Microsoft Roadshow I'd have never touched it; perhaps this is why it was free.
Thursday, September 10, 2009
Forcing Tortoise/SVN to refresh icon overlays
The easiest way I've found to force a "refresh" on these icons is to close the Windows Explorer window and run "TSVNCache.exe" from the command prompt. Give it a chance to run and wait a while (I'm finding that it takes my client's machines about 20 seconds), then start Windows Explorer. The icons should be back and (more importantly) should correctly reflect the status of files/directories.
Tuesday, September 8, 2009
Checking Session variables during Visual Studio 2008 debugging session
- Add a "Session" watch variable in the watch window
- Under the "Session" watch variable, look under "Keys"
- Look under "Non-public members"
- Look under "_col"
- Look under "Non-public members"
- Look under "_entriesarray"
Each Session variable will be listed along with its current value.
Tuesday, March 24, 2009
Calling ASP.NET web service methods directly from a remote machine
The prefab form is great for quick testing but unfortunately when you try and access it from a remote machine you get the message "The test form is only available for requests from the local machine."
There's a simple solution. Add these settings to the Web.Config file of the web service application:
<system.web>
<webServices>
<protocols>
<add name="HttpGet"/>
<add name="HttpPost"/>
</protocols>
</webServices>
</system.web>
This opens up a big security hole by letting remote users directly access the web service itself so you'd should naturally never do this in a production environment, but for quick-and-dirty testing it's quite useful.
Tuesday, March 3, 2009
Visual Studio 2008 setup projects always require .NET 3.5
Despite my specifically building the app to run under .NET framework 2.0 the setup program told the client that he had to install .NET framework 3.5 before continuing. I checked each dependency of the console app and the setup program itself and in each case it was built to run under .NET framework 2.0.
The solution was pretty out of the way -- in Visual Studio 2008 when building the setup program click on the "View" menu item, then "Editor," then "Launch Conditions" ... that's where the requirement for NET framework 3.5 is. Reset this to NET framework 2.0, rebuild the setup program, and the setup program will be satisfied with NET framework 2.0.
Thursday, February 19, 2009
"The entry 'ConnectionString1' has already been added" error
An examination of the web.config file showed a single entry for ConnectionString1, no double entries anywhere, so I began walking through the code on the development server line by line in the debugger. No problems.
I went back to the client's server, completely cleared out my code, and then republished it. Got the same error.
A simple file search of the INETPUB directory showed an old WEB.CONFIG file in the root directory, one I'd actually put there months earlier when testing something and neglected to remove. Sure enough, there was the "second" entry for the connection string in there ... I simply deleted the old WEB.CONFIG file in the web root directory and it started working fine.
Another lesson in how important it is to clean up after yourself.
Wednesday, February 18, 2009
Tortoise/SVN ignore patterns for Windows development
I've used a variety of ignore patterns for doing C# Windows development in Visual Studio 2005/2008 and this one(from http://www.mokesit.com/Blogs/tabid/89/EntryID/18/Default.aspx) seems to work best, at least for now.
The pattern is:
*.cache bin obj *.suo *.obj *.pdb *.exe *.dll *.csproj.user
Note also that I use "_svn" directories rather than the default ".svn" just because it works so much better with the Microsoft OS.
Saturday, February 7, 2009
Getting Juice 2.2 Podcatcher to work in Windows 7
Install Juice 2.2 as usual.
Go down into C:\Program Files\Juice and right-click on the JUICE.EXE file. In the properties window, click on "Compatability" and select "Windows XP (Service Pack 2)" compatibility mode.
Go down into C:\USERS\
Close everything and restart Juice -- it should run as it did under XP or W2003.
Wednesday, February 4, 2009
Using curly braces in the .NET string.format command
I'm writing a C# application which accepts, parses, and passes PowerShell commands to an internal runtime instance of PowerShell.
The preferred method for string formatting with .NET is using the "string.format" method but I quickly ran into problems with the curly brackets used both by string.format (for placeholders) and PowerShell (for loop constructs).
For instance, this command will compile but will clearly screw up:
- results = shl.RunspaceInvoke(string.Format(@"get-mailbox -identity {0} | %{$_.AcceptMessagesOnlyFromDLMembers | %{$_.DistinguishedName}}", Input1), out IErrors);
My first impulse was to remove the "@" from the string literal and escape the curly brackets but that looked simply dreadful and was too hard to debug -- the next solution which I tried, which worked was to simply double the curly brackets for anything other than string.format placeholders:
- results = shl.RunspaceInvoke(string.Format(@"get-mailbox -identity {0} | %{{$_.AcceptMessagesOnlyFromDLMembers | %{{$_.DistinguishedName}}}}", Input1), out IErrors);
This is significantly easier to read and debug.
Monday, January 26, 2009
Enumerating an enum
enum UserAttributes {alias, cn, co, companyname, country, displayname}
foreach (UserAttributes enumValue in Enum.GetValues(typeof(UserAttributes)))
{
Console.WriteLine(enumValue.ToString());
}
I use enums a lot with command-line utilities and this is useful for putting together a cleaner, smaller "displaySyntax" function.