truly annoying programming problems

I spent a few hours on Friday working on a problem that’s weird enough that I feel it warrants a blog entry. I made a few changes to one of our systems at work recently, and rolled them out Friday morning. This system is a VS 2008 solution with several projects in it. One of the projects is a bunch of web services, both SOAP and REST, that are deployed as a single DLL. I made a minor change to one of the REST services, but didn’t touch the SOAP services. And I made a minor change to a class in what is essentially a data access layer project that is referenced in the web service project, but nothing that should have affected the SOAP services. I’m saying all this to establish that I did not change anything that should have changed the SOAP services at all.

Returning to the data access project: this project was initially auto-generated through some CodeSmith templates, long before I started working for the company. The idea was that every class was implemented as a partial class broken into two files, with one file that contained auto-generated code, and one that could be used to add custom code. Now, some of these classes are used as output for the SOAP services. And those services just use the default XML serialization. (Some of you may see where this is heading.)

So we’re got a class called, let’s say, “Location,” broken into file X and file Y. File X contains properties A, B, and C, and file Y contains properties D, E, and F. Up until Friday, these properties had always been serialized from file X, then file Y, so they appeared in the output as A, B, C, D, E, and F. For some reason, on Friday, the compiler decided to process file Y before file X, and give me an XML document ordered as D, E, F, A, B, C. And, of course, the C# programs we have that actually call these web services don’t like getting their properties out of order. They expect everything to look exactly like the WSDL that was pulled in when they were last deployed. Oh, and most of them don’t have any useful error-handling or logging, and do a lot of their work in a declarative manner, through controls in the .aspx files rather than in code-behind, where I can see what’s going on step-by-step in the debugger. So figuring out what had gone wrong was interesting.

It had never really occurred to me, though I’m sure I read it at some point, that there is no guarantee as to the order in which the C# compiler will process the individual files that make up a partial class. (See this Stack Overflow question for reference.) I think the reason it changed now is that I moved the project from VSS to Mercurial recently, and that change probably caused enough of a disturbance to muck things up a bit.

I think if I had been the one that had implemented this thing in the first place, I would probably have done custom XML serialization, just because I’m a bit of a control freak, so I wouldn’t have ever had this problem.

Well, anyway, the moral of this story is that you shouldn’t assume that, just because a bit of code has been working for years, and you honestly haven’t touched it at all, that nothing can go wrong with it, and that the compiler will always output the same code given the same source code.

Borders

I’m really sorry to see Borders going into liquidation and closing all their stores. There’s a good article about this on AnnArbor.com. (Ann Arbor is where Borders started out.)
Our local Borders, in Bridgewater, has been around for about 10 years, I think. I’ve spent a lot of time in there, poking through SF novels, computer books, comics, and CDs. I will admit that I’m one of those guys who often looked through books at Borders, then bought them through Amazon. I did buy a fair amount of stuff in-store though, especially when I had 30% or 40% off coupons from Borders Rewards.
There’s a Barnes & Noble at the Somerville circle, so I guess that’s where I’ll be going when I want to actually look at a hard-copy book before buying it.
There used to be a Waldenbooks (or maybe B. Dalton) right here in downtown Somerville, along with two different used book stores. Now, there are no book stores at all in Somerville. (One of the used book stores moved to Raritan, I think, and is probably still in business, but I haven’t checked lately.)
I can’t help wondering if brick & mortar book stores (and even hard-copy books) are on their way out. I like my Kindle and my iPad, and I like Amazon, but I’m not sure I’m ready to start buying and reading everything electronically.

SDCC 2011, day one

This is now the third year in a row that I’ve skipped Comic-Con. The last time I went was 2008. I’m hoping I can find some way to get a full four-day pass and hotel reservation for next year. It’s been too long since I’ve been out there.
Meanwhile, as usual, I’ve been poking around the web for interesting articles about the con. Here are a few from SignOnSanDiego.com:
Comic-Con makes itself at home
Comic-Con and Hollywood
Comic-Con 2011 Preview

PHP Cookbook

I’m going to be doing some maintenance programming on a PHP/MySQL site pretty soon. I know a little PHP, probably enough to get by on this project, but I’d like to learn more. I have an old introductory PHP book around here somewhere, but I wanted to pick up something more substantial. So I picked up O’Reilly’s PHP Cookbook at Borders on my way home from work today. I have so many programming books that I’ve barely started reading, but this one looks like it’ll be a good reference.

TortoiseHg 2.1

I upgraded to TortoiseHg 2.1 yesterday.
This item, under the “improvements” list, is huge:

(file history) added context menu for file revision features

Thank you so much for implementing this! I’m using it every day now. Of course, I see that a bug fix release, 2.1.1, was made available this morning, so now I need to upgrade again. Well, the install is pretty painless, so that’s OK.

fun with Twitter and Facebook

I just finished working on a module to automatically post news stories from a client web site to Twitter and Facebook. I know that’s not a big deal, but it was kind of cool, and it took a bit of effort to get the Facebook thing figured out. (See this stackoverflow.com post for some detail on that.)

I used the Facebook C# SDK for the Facebook stuff, Twitterizer for the Twitter stuff, and EasyHttp to access the bit.ly API, for URL shortening. And of course I pulled them all into the project with NuGet. I feel like the master of all social media APIs now.

ten years

I’m scheduling this entry to auto-post on June 19, 2011 at 8pm. I started this blog on June 19,2001, so this will be my tenth anniversary of blogging. Here’s a link to the June 2001 archive page.

Looks like I was talking about PC Expo a bit. There’s a blast from the past. Are there any tech trade shows still happening in NYC? I can’t think of any, but then again I’m probably out of the loop on that kind of thing right now.

Let’s see, what else was going on…

  • Sept 11, 2001 was three months in the future.
  • Version 1.0 of the .NET Framework was about eight months away from release. [ref]
  • PowerBuilder version 8 had just been released. [ref]
  • Adventures of Barry Ween: Monkey Tales #3 was released [ref]
  • Harry Potter and the Goblet of Fire had been released in 2000, and Harry Potter and the Order of the Phoenix would not be released until 2003. [ref]

Okay, that was a pretty random list.  I don’t suppose I have any point to make, other than marking the fact that I’ve been consistently blogging for 10 years.  I’ve never written anything really substantial here, but I’ve tried to write in complete sentences, usually, and I’ve tried to post stuff that other people might find useful or amusing, if they were to somehow stumble across this blog.

last photos

When my Dad passed away, he still had a roll of film in his old 35mm camera. I wanted to finish off the roll, get it developed, and see what his last few photos were, but I kept putting it off. Since I’m having an estate sale this weekend, I decided it was time to finally finish the roll and send it off, so I could include the camera in the estate sale. I sent the roll off to Snapfish for processing. (It’s been many years since I’ve had a roll of film developed. Snapfish has a mail-in service that’s pretty cheap, so I decided to try them.)

I just got an e-mail back from them with a link to the photos. (I guess I’ll get the negatives and prints back in the mail soon.) Sadly, his last few photos weren’t that interesting. It looks like he’d just taken a couple of snapshots from the front porch after a snowfall, probably in early 09. (The timestamp on the photos says Feb 06, but they can’t be that old. I don’t think he had the date set correctly on the camera.) I was hoping I’d have a couple of final photos of Mom and Dad on that roll, but alas, no.

All the photos came out looking a lot more purple than they should. I’m guessing that’s because the film was so old? Or maybe just a bad job of processing?

tree1

tree2