EProgrammerNotFound exception in Delphi?

DelphiDelphi 2009Delphi Xe7

Delphi Problem Overview


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?

Q: Is this exception class still declared in Delphi (currently XE7)? A: Yes, and it is even documented!

> Nonstandard way to indicate software faults. > > You can use EProgrammerNotFound as an alternative to indicate software > faults detected at run time.

Delphi Solutions


Solution 1 - Delphi

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!"

Solution 2 - Delphi

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

Solution 3 - Delphi

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

Solution 4 - Delphi

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>

Solution 5 - Delphi

It's the runtime analog of the compiler's "Syntax error: Programer expected." ;>

Solution 6 - Delphi

It is a kind of self describing joke, you can try this code

raise EProgrammerNotFound.Create('Jack is away');

or

raise ENotImplemented.Create('May be in future this will work');

The above works in Delphi 10 Seattle.

Solution 7 - Delphi

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.

Solution 8 - Delphi

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.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionmjnView Question on Stackoverflow
Solution 1 - DelphiAllen BauerView Answer on Stackoverflow
Solution 2 - DelphiUwe RaabeView Answer on Stackoverflow
Solution 3 - DelphiJeroen Wiert PluimersView Answer on Stackoverflow
Solution 4 - DelphiFrancescaView Answer on Stackoverflow
Solution 5 - DelphidthorpeView Answer on Stackoverflow
Solution 6 - DelphiUnDiUdinView Answer on Stackoverflow
Solution 7 - DelphiRitsaert HornstraView Answer on Stackoverflow
Solution 8 - DelphiEdelcomView Answer on Stackoverflow