YOUR FEEDBACK
Three RIA Platforms Compared: Adobe Flex, Google Web Toolkit, and OpenLaszlo
NN wrote: Yeah you are right GWT is poor man's Flex. After using GWT on two...

SYS-CON.TV
TOP MICROSOFT .NET LINKS


Hanselminutes Interview with Raymond Chen
Hanselminutes is a weekly audio talk show with noted Web developer and technologist Scott Hanselman and hosted by Carl Franklin

Digg This!

Page 1 of 5   next page »

Hanselminutes is a weekly audio talk show with noted Web developer and technologist Scott Hanselman and hosted by Carl Franklin. Scott discusses utilities and tools, gives practical how-to advice, and discusses ASP.NET or Windows issues and workarounds (www.hanselminutes.com/).

In this interview Scott sits down with the original raconteur of Windows, Raymond Chen, to talk about all things Win32 and where Microsoft Bob is currently.

Scott Hanselman: I'm sitting in the office of Raymond Chen, the author of The Old New Thing. I love the book, and when they said, "Hey, put a quote in the front," I said I have to be a part of that. I really appreciate your taking the time to talk to us here. I want to get down to the brass tacks here and find out some of the fundamentals about what you work on? You're doing Win32 in the Shell, right?

Chen: Yeah, I don't even remember when I came over to the User-Interface Group in the Shell team; we're the people who deal with Explorer and common dialogs and that sort of thing. It is mostly Shell32 and Com Dialog, and Com Control and things that hang out in that world.

Hanselman: I remember the great 3D wars of the late mid to late '90s when there were 15-16 different versions of - was it control?

Chen: Control 3D, Control 3D 2.0, Control 3D 2.32.

Hanselman: And hand in subversions within those; why was that such a problem?

Chen: Because if 3D is good, more 3D must be better.

Hanselman: Absolutely. I had a lot of trouble with that. That was DLL Hell; that was the beginning of it, wasn't it?

Chen: I don't know; I was asleep for that part.

Hanselman: Is it really difficult to do versioning like that? You're just exporting a function table; how hard is it to keep those functions looking the same? Why do we get these big - I guess they weren't called GPS back in the day, they were unhandled application exceptions - AUEA; UAE - Unrecoverable Application Error...

Chen: That's' right. Wow! That brings back horrible memories. And you have to make sure not to confuse it with the United Arab Emirates.

Hanselman: In fact yes, the people in Dubai do not appreciate that in any way.

Chen: The people don't like UAEs for some reason. It's like, "We are just minding our own business."

Hanselman: Why was versioning so hard? Why were there so many copies of that DLL?

Chen: I wasn't around for that, but I assume that the reason there were so many copies of that DLL was that everybody thought it was really awesome - or everybody wanted to have their own version of it, because mine is cooler than yours. I realize that I wrote it, it must necessarily be cooler than yours.

Hanselman: Yes, "invented here" syndrome.

Chen: Exactly.

Hanselman: Specifically invented here. Now, I know that you're known for volleying back questions that are not - I wasn't here, sorry, I was sick that day.

Chen: I am very good at rejecting questions.

Hanselman: I appreciate that. Most of this interview will be rejected questions. But I'm more interested in...

Chen: You can listen for them on the deleted scenes.

Hanselman: In fact yes, on the special features. I am interested in versioning because you're living in a non-managed world and I haven't lived there in a while. I flunked the last - last time I flunked was at least 10 years ago and I appreciate the occasional...

Chen: Scars are healed.

Hanselman: In fact, I appreciate the occasional reference pointer and that's great that you guys do that, but is versioning really hard in an unmanaged world, and then you have Methods inside of Shell32 and the different things that you maintain that probably you wish you could yank out, but you just can't for compatibility, right?

Chen: There's stuff that we want to yank out all the time, but we publish the Function, we document it, now we're stuck with it.

Hanselman: From a Static Dependency Analysis perspective, if you can keep those functions looking the same, things will line up, they take the right parameters, but is it really difficult to make sure that the semantics of those functions, including bugs, stays the same?

Chen: Bug-for-bug compatibility is one of the things that you don't appreciate until you have to do it. In fact, looking at the changes between Windows XP and Vista, we see people complaining about things, saying, "Hey, if I pass this invalid string to path is..." and they're like, "path is network path - it used to say it was, and now it says it isn't." We say, "That's right because it isn't." "Well, I was sort of hoping it would still be one because now it's slowing down my program."

Hanselman: I remember literally the day that I double-clicked on the time-date thing and saw that the time-date applet, you had removed the time zones because of that border war or whatever with Peru?

Chen: The time zone one was an Ecuador-Peru Border Wars, I recall.

Hanselman: I was sad; and I said, a feature has been removed and I have seen it happen - I noticed. I am sure that a lot of people didn't notice. I know that you said on Carl's talk, that they remove scraps and then you remove scraps personally...

Chen: I remove scraps.

Hanselman: I noticed damn it. No I didn't really notice. No, I'm kidding.

Chen: I don't think anybody has even noticed yet.

Hanselman: I actually noticed when I make a scrap, and I go, "What the hell is that?"

Chen: What was that? How do I get rid of this thing?

Hanselman: I got that immediately off my desktop. I didn't even open one up once; put to the MZ header to see if it was evil.

Chen: I suspect that most people who created scraps did it completely by mistake, and all the support calls were questions of the form "How do I get rid of this thing?"



Page 1 of 5   next page »

About Carl Franklin
Carl Franklin has been a figurehead in the VB community since the very early days when he wrote for Visual Basic Programmers Journal. He authored the Q&A column of that magazine as well as many feature articles for VBPJ and other magazines. He has authored two books for John Wiley & Sons on sockets programming in VB, and in 1994 he helped create the very first web site for VB developers, Carl & Gary's VB Home Page. He now teaches hands-on VB .NET classes for his company, Franklins.Net. He has taught developers from Citigroup, Aetna, Fidelity Investments, Fleet Bank, Foxwoods Casino, UTC, Hubbell, Microsoft, Mohegan Sun Casino, Northeast Utilities, to name a few. Carl is co-host of a weekly talk show on his website for .NET programmers called .NET Rocks! Carl is MSDN Regional Director for Connecticut.

MICROSOFT .NET LATEST STORIES
Peer Networking Series - A Closer Look at PNRP vs. Bonjour/ZeroConf
It seems as though whenever I bring up PNRP and its benefits, I am immediately inundated with a list of questions or comments indicating that Microsoft is re-inventing the wheel and that PNRP has already been implemented before in the form of ZeroConf and, more specifically, Apple's im
Microsoft, Unisys, Yahoo and Vista
Microsoft, which spent $6 billion on aQuantive and was chasing Yahoo for its ads before it came to a dead stop, has been supporting - as in helping write - legislation in New York and Connecticut that would regulate the data that companies like Yahoo and Google collect for targeted adv
AJAX World - Xceed Launches Microsoft Silverlight 2 Control
Xceed launched Xceed Upload for Silverlight, the commercial offering in support of Microsoft's promising new Silverlight technology. The product is available now for purchase or as a fully functional 45-day trial on Xceed's website. Xceed Upload for Silverlight lets developers add uplo
Microsoft To Keynote 4th International Virtualization Conference & Expo
Mike Neil is general manager for virtualization strategy in the Windows Server Division at Microsoft. Mike is focused on the delivery of the Windows virtualization technology, including Windows Server 2008 Hyper-V, Microsoft Hyper-V Server and Virtual PC 2007. Mike also directs the tec
Microsoft Virtualization Takes Management Cross-Platform
Microsoft is making System Center, its central management scheme, natively manage Linux, Unix and VMware virtual servers. The widgetry has always been a Windows-only affair, but now there are betas available showing off Microsoft's cross-platform prowess, important to Microsoft's place
SUBSCRIBE TO THE WORLD'S MOST POWERFUL NEWSLETTERS
SUBSCRIBE TO OUR RSS FEEDS & GET YOUR SYS-CON NEWS LIVE!
Click to Add our RSS Feeds to the Service of Your Choice:
Google Reader or Homepage Add to My Yahoo! Subscribe with Bloglines Subscribe in NewsGator Online
myFeedster Add to My AOL Subscribe in Rojo Add 'Hugg' to Newsburst from CNET News.com Kinja Digest View Additional SYS-CON Feeds
Publish Your Article! Please send it to editorial(at)sys-con.com!

Advertise on this site! Contact advertising(at)sys-con.com! 201 802-3021

SYS-CON FEATURED WHITEPAPERS

ADS BY GOOGLE
BREAKING NEWS FROM THE WIRES
Open-E Data Storage Server Solution Empowers Nor-Tech's Robust Voyageur(TM) Storage Server
Open-E, Inc., a leading developer of innovative storage management software, announced today