views:

1730

answers:

6

In Delphi 2009, SysUtils.pas contains this in line 425:

EProgrammerNotFound = class(Exception);
  • Is this simply an easter egg or something serious?
  • When should this exception be raised?
  • Does it also exist in Delphi Prism and/or Free Pascal?

Conclusion (after reading the answers so far):

This exception might appear in fun source code like

try
  ShootMySelfInTheFoot;
except
  raise EProgrammerNotFound.Create("D'oh!");
end;

(See D'oh!).

+4  A: 

The origin is debatable, but it's been known for a while...
Marco Cantu joked about it in a "Fun Side of Delphi" session.
IMO, it should be used more often ;-)

Read on:
http://wings-of-wind.com/2010/01/12/best-programming-feature-ever/
http://blog.barrkel.com/2008/11/reference-counted-pointers-revisited.html

PS: I don't think it exists in Delphi Prism, FreePascal or C# (but it should). <G>

François
+1  A: 

With programmer, it is not the programmer that is sitting behind Delphi that is referenced. I think it is used for the fact that in D2009 and above they planned (never used it don't know if it works) that every object was waitable.

Ritsaert Hornstra
Actually, it is usable. You can pass any object to `TMonitor.Enter` and `TMonitor.Exit`. And i'm not sure if it's an easter egg or not...
Smasher
What does an object being waitable have to do with programmers or whether they're found? And what programmer *is* being referenced?
Rob Kennedy
+11  A: 

It is used in conjunction with the "fix-inline" technology which requires that the programmer has to be linked into the exe file ;-)

Uwe Raabe
+1 for 'The Spirit of Delphi' in your answer :)
mjustin
A: 

I am a programmer, am I an exception than ?

Marco Cantù also describes this in his book 'Delphi 2009 handbook' - page 242. He tells it's never jused in the VCL source code.

Edelcom
+11  A: 

It was introduced in Delphi 2009, still present in Delphi 2010, and recently got some more attention on the internet.

I think it is an easter egg, similar to "EBCAK" (Error Between Chair and Keyboard), and the skipping of Delphi version number 13.

EProgrammerNotFound

  • is declared in the Win32 branch of the SysUtils unit, but not used anywhere in the RTL or VCL
  • is not present in Delphi Prism
  • was introduced in Delphi 2009, so not present in VCL.NET
  • has currently (version 3.5) nothing similar in the .NET framework (not sure why, these guys do have humour)

I don't think EProgrammerNotFound is actually meant to be used at all, but since it is there, people will jokingly use it (similar like putting a stray "const False = True; True = not False;" in someone elses sourcecode).

--jeroen

Jeroen Pluimers
Hmm, programmer is not only a person, but also a device (for programming e.g. flash of embedded devices). Do I smell an IPhone here? Naah, then it would be in the IDE source, not sysutils.
Marco van de Voort
Delphi device support. Hmm...
Jeroen Pluimers
EBCAK? I always heard it expressed as PEBKAC. (Problem Exists Between Keyboard And Chair).
Mason Wheeler
Too many abbreviations :-)
Jeroen Pluimers
+37  A: 

It is just the result of a long day and we had gotten a little giddy. For many, many years (ever since I'd been on the team), we'd always joked about replacing some error message in the compiler for one of the most common errors with a similar message. Internally we've always joked and poked fun at different things and people (mostly on the team itself). If you don't have a sense of humor, you're destined to an early grave.

It was a simple conversation;

"Oh, you should have raised the EProgrammerNotFound exception in that function."
"LOL! We should add that exception and see who notices."
"I wonder how much speculation there will be about why it is there?"

So, I guess all I can say is, "You've all played right into our hands ;-)... Buwahahaha! pwned!"

Allen Bauer