Monday, April 13, 2009

Why did my machine blue screen?

My machine blue screened this morning and restarted itself.  I went into safe mode and then restarted normally with no problems.
But I was concerned about why my computer blue screened.
Using WinDbg, which is part of the Debugging Tools for Windows package I was able to determine the cause:
ERROR_CODE: (NTSTATUS) 0xc0000218 - {Registry File Failure}  The registry cannot load the hive (file):  %hs  or its log or alternate.  It is corrupt, absent, or not writable.
ADDITIONAL_DEBUG_TEXT:  \SystemRoot\System32\Config\SOFTWARE - hive could not be loaded.
Here are the steps I followed:
  1. Installed debugging tools.
  2. Looked at my System Properties --> Startup and Recovery Settings --> small dump location
  3. From a command prompt:"c:\Program Files\Debugging Tools for Windows (x86)\windbg.exe" -y srv*c:\symbols*http://msdl.microsoft.com/download/symbols -z c:\windows\Minidump\Mini032709-01.dmp
  4. from the WinDbg prompt: !analyze -v
  5. Read the results.

Monday, April 6, 2009

My Personality Type

My type: ENTJ

Outgoing, logical and decisive, the ENTJ leads by providing conceptual structure and setting goals, rather than by detailing and enforcing procedures, codes and regulations. This “big picture” type rises naturally to conspicuous positions of power and responsibility in all organizational settings (business, military, educational, governmental.) Disorganization, confusion, emotion, inefficiency and illogic drive ENTJs to take charge of situations and institutions. Their intuition fuels their vision and defines their goals. They deal with the world boldly, in an assertive, analytical, objective and organized way which inspires others to salute them and do whatever the ENTJ needs done--including all the detail work! ENTJs certainly do get things done, both at home and at work, but often at substantial cost in terms of wear and tear on the human spirit, for they may neglect the importance of the personal element in accomplishing their purpose. More than any other, this type seems to struggle between an inner drive toward creative spontaneity and the desire for order in the universe.

Final Score: Extrovert: 7 Sensing:5 Thinking:9 Perception:1 Introvert: 2 iNtuition:4 Feeling:0 Judging:8

EDIT: I took a similar test on September 9, 2016 and my type was classified as INTJ

Introverted (I) 55% Extroverted (E) 45%
Intuitive (N) 60% Sensing (S) 40%
Thinking (T) 62% Feeling (F) 38%
Judging (J) 53% Perceiving (P) 47%
INTJ - "Mastermind". Introverted intellectual with a preference for finding certainty. A builder of systems and the applier of theoretical models. 2.1% of total population.

Monday, March 30, 2009

Marketing Your Business in Detroit via Viral and Social Media

I went to my frist Model D event which was co sponsored by Open City
Charlie Wolborg and Terry Bean gave an captivating presentation on social media giving me a lot to think about over the past couple days.  It is why I signed up on Twitter as smithd98.
Here are my notes from the meeting:
Social Media Categories:
  • Online Rolodexes
  • Blogging
  • Feeds - like magazine subscriptions
  • Video
  • Photos - Facebook has the most photos of any social sites.
  • Podcasts
  • Bookmarks
  • Networks
Passion - be remarkable
In six months more content is uploaded to YouTube than has been created in 60 years of NBC and CBS programming.
Facebook's #1 growing demographic is 30 and older.  This means your customers are on or will be on Facebook.
  1. Ready. Fire. Aim.  - it is most important to have a presence on these networks and refine the presence later than getting it right the first time.
  2. Join All.  Participate Few.  - The flood of information from all the social sites will overwhelm you.  Find out which sites your customers use and play in that space.
  3. Go to Where Your Prospects Play
    1. LinkedIn --> web jobs --> simplyhired shows who works there.
    2. MySpace - important for entertainers and artists
    3. MotorCityConnect - if you are in the Detroit area.
    4. Facebook - allows you to connect with your past.
      1. People hang out on Facebook like it was a club.  This is different than transactional where users seek out a service from a site.
      2. Fan pages can be created for companies and products.
    5. Twitter - this is where you can go to initially make contacts.  These are the early adoptors.
  4. Personal Brand Optimization
  5. Social Media is a conversation not a sales pitch.
  6. Feed Your Networks and stay visible.  FriendFeed can help
  7. ROI or Die
  8. Find your golden ratio - give value to these networks, don't just try to monetize them.
  9. Build it before you need it - relationships take a long time to build and need nurturing.  Do that in advance of a need.
  10. Tools are not the tactics - hire a professionals like Networked inc

Wednesday, February 4, 2009

Binding to XAML declared types with non-default constructors using ElementName binding syntax

Some of our XAML files were using Element name binding like this Binding="{Binding ElementName=Window}" to bind to the class itself.  While refactoring and adding a non default constructor Visual Studio complains: "The type CLASSNAME cannot have a Name attribute. Value types and types without a default constructor can be used as items within a ResourceDictionary."

For most of the day I changed class bindings to use DataContext = this in the constructor or FindAncestor calls at the binding declaration.  Late in the day I ran into an infinite recursion problem.  Not wanting to diagnose it I found an MSDN article pointing me to use RegisterName("Window", this); in the constructor after InitializeComponent() to work around the issue.

Wednesday, January 28, 2009

Tracking down boxing

I just found a cool extension, CodeSearch, for Reflector, a disassembler for .NET assemblies.  I used it to search some of our code for the Intermediate Language box instructions and unbox.

I found a lot more of those than I'd hoped.  But in my test cases they all seemed to be necessary.

Wednesday, January 21, 2009

Converting Com ErrorCodes to friendly messages

Using PerfMon to do some .NET profiling today, I wanted the ability to easily retarget my counters at a specific application running on my machine.

Everything went very well except for the error handling.  When adding my counters a  COMException may be thrown.  The Exception's message has the hex error code while the ErrorCode property has the value as an integer. I used the following code to convert the ErrorCode to be comparable against hex values provided by MSDN.

Update, an easier way to do this is comException.ErrorCode.ToString("X");


UInt32 errorCodeLookup = 0;
unchecked
{
    errorCodeLookup = (UInt32)comException.ErrorCode;
}

I didn't end up using this method as it was my own application.  I thought about using a uint enumeration to store all the error codes and then a dictionary to go lookup the user friendly error messages provided by MSDN, but since it is just a scrap app I didn't bother.

Wednesday, January 14, 2009

Identifying Duplicated Code (Refactoring Opportunities)

On our project we have some accidentally similar code and some knowingly similar code.  Today I found a great tool we could easily incorporate into our Continuous Integration Process to stop code duplication.

Simian, a configurable command line utility, took less than 5 minutes to setup and cranked through 204,930 lines of C# in about 6.5 seconds.  The application is free for noncommercial use and can be evaluated free of charge for 15 days.

Friday, December 19, 2008

Coding WPF styles in C#

WPF styles let you specify the look of your controls consistently across your application.  Today I needed to create menu items in a different part of the application based on the currently focused element.
I got the menu creation code to work, and then wanted to apply my WPF style instead of typing a bunch of header names in and then maybe having to change them later.

Here is the WPF style:
<Button.ContextMenu>
   
<ContextMenu>
       
<ContextMenu.Resources>
           
<Style x:Key="{x:Type MenuItem}" TargetType="{x:Type MenuItem}" BasedOn="{StaticResource {x:Type MenuItem}}">
               
<Setter Property="Header" Value="{Binding Command.Name, RelativeSource={RelativeSource Self}}"/>
           
</Style>
       
</ContextMenu.Resources>
   
<MenuItem Command="ApplicationCommands.Cut"/>
</Button.ContextMenu>

Here is the C# equivalent:

new returnValue = ContextMenu();
//base our style on the current MenuItem Style. No need for null check.
var headerStyle = new Style(typeof(MenuItem), TryFindResource(typeof(MenuItem)) as Style);
var commandNameBinding = new Binding("Command.Name");
commandNameBinding.RelativeSource =
RelativeSource.Self;
headerStyle.Setters.Add( new Setter(HeaderedItemsControl.HeaderProperty, commandNameBinding));
returnValue.Resources.Add(typeof(MenuItem), headerStyle);
returnValue.Items.Add(new MenuItem() { Command = ApplicationCommands.Cut });

Thursday, November 27, 2008

XAML factoring


We are using the Infragistics Ribbon component in our application.  Our application has the same Ribbon Group content specified in multiple tabs.  I was looking for a way to share the group content so it wasn't copied and pasted in both locations.

I searched online and found a forum where one of their staff said it was not a feature.

This is not a problem as WPF allows you to share UI elements for compiled resource dictionaries.

When we compile XAML we get BAML stored inside the assembly as a resource.  This allows the x:Shared keyword to enable special functionality not available from C#.   Why not IL?  BAML is more compact than IL, can be localized after compilation, and is less of a security threat.

Specifying x:Shared in a resource dictionary means the content will be fetched new each time it is requested allowing the same user interface elements to be added in multiple places.

Here is an example:
    <Window.Resources>
        <StackPanel x:Key="moreContent" x:Shared="false">
            <TextBlock Text="local" />
        </StackPanel>
    </Window.Resources>
    <StackPanel>
        <StaticResourceExtension ResourceKey="moreContent" />
        <StaticResourceExtension ResourceKey="moreContent" />
    </StackPanel>
One may also put the shared content in another XAML file to share the resource with other XAML files in your application:
Window1.xaml

    <Window.Resources>
        <ResourceDictionary >
            <ResourceDictionary.MergedDictionaries>
                <ResourceDictionary Source="Ribbon.xaml" />
            </ResourceDictionary.MergedDictionaries>
            <StackPanel x:Key="moreContent" x:Shared="false">
                <TextBlock Text="local" />
            </StackPanel>
        </ResourceDictionary>
    </Window.Resources>
    <StackPanel>
        <StaticResourceExtension ResourceKey="moreContent" />
        <StaticResourceExtension ResourceKey="content" />
        <StaticResourceExtension ResourceKey="moreContent" />
    </StackPanel>

Ribbon.xaml:
    <StackPanel x:Key="content" x:Shared="false">
        <TextBlock Text="From Ribbon" />
    </StackPanel>
</ResourceDictionary>

Thursday, November 20, 2008

Clarity of intent and newing up structs

Sometimes it is useful to see if a struct hasn't been set.  Of course this can get you into trouble if the unset value is a legal value, but sometimes it's not, like when dividing an int 0 will throw.

Previously I had been using code like if (divisor != new int() ) to check the value prior to calling my function.

This struck me as very odd to be newing up a struct.

Then I recalled the default keyword, which I'd only used for generics before.  It turns out default works the same and declares intent better.

if (divisor != default(int) )
{

}

Of course in this contrived example it makes more sense to do != 0, but when more complex structs are involved the syntax works quite nicely.

Tuesday, November 11, 2008

Visual Studio Post-Build Events.

I haven't been a fan of Visual Studio Post-build command line events.

Problem:
We need to copy app.config during the build process and it needs to be mstest.exe.config in the test out directory.  During our Unit Testing process on the build server we've been referencing a static class to provide all of our configurations.  Now we are switching over to a real file.  This makes all the unit tests referencing our configurations fail because System.Configuration.ConfigurationManager.GetSection returns null.  The problem is our unit tests are being executed by MS test.  Ideally we would maintain a configuration class reading from a file and a configuration class for testing which uses test values.  Unfortunately due to time pressures that is not an option.

Solution:
By going into Visual Studio, project properties, Build Events Tab, Post-build event command line and typing copy "$(ProjectDir)app.config" "$(TargetDir)mstest.exe.config" /y
MSDN describes the $(ProjectDir) and $(TargetDir) variables
In our testrunconfig file we have a Deployment section and then a DeploymentItem with filename set to mstest.exe.config.  My frist thought was to do the file copy on our build server after getting the source files and then have our testrunconfig file copy the mstest.exe.config using a DeploymentItem.  Thinking about it for a minute I realized this would cause differences when we are building in Visual Studio and when we are building on the server which would easily cause confusion in the future.

Not to happy we are relying on the filesystem for our test, but happy that the build behaves the same on desktops and servers and anyone can figure out what is going on.

Wednesday, October 29, 2008

Freeing space on your computer by customizing Visual Studio

My computer has been running slowly lately which really bothers me.  I went to defrag my hard drive and didn't have 10% free space disk defragmentor recommends.

I use a utility called TreeSize which presents a navigable tree view of how much space each folder is consuming.

Previously I took for granted the fact that Visual Studio 2005 consumes 2,730 MB and Visual Studio 2008 eats up 2,562 MB.  This time I decided to look at why the are such hogs.  It turns out in my Visual Studio 2005 installation c:\program Files\Microsoft Visual Studio 8 there is a sub folder VC taking up 1,574MB.  This is for Visual C++ 2005 which I never plan to use.  Using Add / Remove Programs and clicking Change/Remove on Microsoft Visual Studio 2005 Team Suite - ENU allowed me to easily remove Visual C++ 2005.

I'm keeping Visual C++ 2008 because I hope to play with it in the next six months or so.

During this exercise I also noticed OneNote sucking up 2,616 MB.  1,646 of it for backup files.  Our notebooks are on a network location so I don't need to be backing these up.  I turned it off by opening OneNote going to Tools, Options, Backup and unchecking "Automatically Backup".

Wednesday, October 22, 2008

Books I've read this past year

These are the books I've read this past year in roughly the order I read them.

Programming .NET Components, 2nd Edition - Covers many advanced topics on application maintainability, extensibility, and reusability.  Some of the greatness was lost on me at the time because I didn't see the applications of the ideas.  I recommend reading this book after having a thorough understanding of .NET and programming.  I forgot how great this book was and I'll probably be re-reading it.

MCTS Self-Paced Training Kit (Exam 70-536): Microsoft .NET Framework 2.0 Application Development Foundation - Good introductory book about the .NET framework.  Skip it if you are already comfortable with framework classes.

Extreme Programming Adventures in C# - A fun quick read.  It makes some interesting points about extreme programming.  The book discusses a small project developed by one and a half developers.  I would be more interested in a book discussing a larger team to see how the process scales.

Code Complete: A Practical Handbook of Software Construction - Should be read by all programmers.  It goes into great depth discussing seemingly mundane topics and explains why they aren't trivial.

Software Project Survival Guide - Another great book by Steve McConnell.  It is thought provoking and may enlighten you to aspects of your development process you can improve.

The Pragmatic Programmer: From Journeyman to Master - Seemed to be Code Complete light to me.  It covered a lot of the same issues in less depth.  If you read Code Complete you can skip this book or read it first to whet your appetite.

The Mythical Man-Month: Essays on Software Engineering, Anniversary Edition (2nd Edition) - Discusses large scale software construction and team scalability challenges.  People often summarize it by saying you can't make a baby in nine months.  I don't think this summary does justice to the book and recommend you read it.

Windows Presentation Foundation Unleashed (WPF) (Unleashed) - This was a good introduction and overview of WPF.  You should read this book or something like it before professionally programming in WPF.

Programming WPF - This book deep dives into WPF.  After you've been professionally programming WPF for a couple weeks this book should help increase your understanding of the technology.

The Build Master: Microsoft's Software Configuration Management Best Practices - Short guide to building and deploying software.  Good read for developers who've been appointed the build master for their project.  If you find yourself in this situation consider using Windows Installer XML (WiX).  It allows you to build your install files via XML and fits perfectly with MSBuild.

Thursday, May 1, 2008

Extreme Programming Adentures in C# (book review)

At the Central Ohio Day of .NET last week I won Extreme Programming Adventures in C# (DV-Microsoft Professional) by Ron Jeffries. The book is a case study about using XP programming on a small scale project and team. It is well written and immediately sucked me in. I have been experimenting at work by trying the simplest thing that works and using test driven development.

Wednesday, April 23, 2008

Central Ohio Day of .NET 2008 Synopsis

I rode down to the Central Day of Central Ohio Day of .NET 2008 with Rich Hamilton and Joe Kunk on Saturday.



I attended these session:


  1. A Linq to Everything (Leon Gersing)

  2. User Interface Design for Programmers (Chris Poteet)

  3. Happy Marriage of Agile and TFS (Alexei Govorine)

  4. Test Driven Development (Phil Japikse)

  5. Well, Isn't that Spatial... (Jason Follas)

I had heard of recording users running an application but have never done it before. Chris's presentation had some recorded user sessions. It was interesting to watch the sessions and listen to his commentary about the design changes viewing the user interaction caused.


After the conference Jeff Blankenburg held a poker tournament back in his hotel room. It was a lot of fun to hang out with like minded individuals in a casual atmosphere. This was my favorite part of the conference.

Tuesday, April 22, 2008

00 Querying Named instance Linked SQL Server

This is how you query against a linked named instance of sql server.


sp_addlinkedserver 'servername\instanceName' --create the link.

select * from [servername\instanceName].databaseName.dbo.TableName --execute the query.

Wednesday, April 16, 2008

Search for Detroit Software Developer Community

I ran across an interesting group this morning in my search for the Detroit Software Developer Community: the detroit software engineers' grotto. The group's goal is interesting for anyone to read. They are trying to rent a space for software engineers to work instead of their office. The space will have comfortable couches, chairs, and like minded individuals. It is modeled on a Writer's Grotto founded in San Francisco.

Unfortunately for me it states Windows is a legacy operating system, Web 2.0 is dead, and Mac OS X is the wave of the future. Interesting ideas.

I'm looking to get involved in the Detroit software developer community. We have companies with lots of developers here: Compuware, Electronic Data Systems (EDS), Accenture, and Deloitte come to mind right off the top of my head.

The Great Lakes .net Users Group, but as that is in Southfield I have to battle traffic to get out there. I came from the Lansing area which has a great developer community especially for the relatively low population of the area. Being involved in the Greater Lansing User Group .net continues to positively impact my life.

This morning I went looking for the Detroit developer community. My assumption is that it must exist given the larger population and I'm just not connected. Yet :)

Tuesday, April 1, 2008

Clustered Index slows down BCP signiificantly

Our 19 hour job was reduced to about 30 minutes using this technique.

We had to import 110 million rows into a SQL Server table containing 5 ints during 4 import sessions. There was a clustered index over 4 of those ints.

We used the System.Data.SqlClient.SqlBulkCopy class to do the import (class mirroring the sql server bcp utility). The initial import took ~19 hours. On a new table we removed the clustered index and inserted all the rows again. This took about 12 minutes. Applying the clustered index took about 20 minutes.

Monday, March 24, 2008

Programmatically Executing SQL Scripts

I didn't realize GO is not a SQL keyword. When I was trying to execute a script that worked in SQL Server Management Studio I was getting SQLException Incorrect syntax near 'Go'. The solution is to split the input script on GOs and execute those scripts.

const char splitChar = '☻'; //this character should never appear in command files
if (createDatabaseScript.Contains(splitChar.ToString()) == true)
throw new Exception("Aborting. Splitting this file may break the script because the script contains the split character");
using (dbConnnection)
{
dbConnnection.Open();
SqlCommand createDbCommand = new SqlCommand(string.Empty, dbConnnection);

//split the input script into multiple scripts based on GOs
foreach (string command in createDatabaseScript.Replace("GO", splitChar.ToString()).Split(new Char[] { splitChar }))
{
try
{
createDbCommand.CommandText = command;
createDbCommand.ExecuteNonQuery();
}
catch (Exception ex)
{
//log the error for later review.
results += ex.Message + Environment.NewLine;
}
}
}
Console.Write(results);

Monday, March 17, 2008

FxCop bug - CA1709 & CA 1707

CA 1707 IdentifiersShouldNotContainUnderscores
CA 1709 IdentifiersShouldBeCasedCorrectly

I ran into a surprise last week. FxCop is throwing warnings for properties on 2 out of 5 interfaces in a particular project. Interface A implements interface B.

I'm assuming the bug described in this article is causing it: http://forums.microsoft.com/MSDN/ShowPost.aspx?PostID=2344375&SiteID=1 and that it will be fixed in Visual Studio 2008 Service Pack 1.