How can I embed the line number of code into a compiled exe in Delphi?

Posted on 2012-03-28
Medium Priority
Last Modified: 2012-03-28
Hi all,
I wish to embed the Source Code line number into some Delphi Source.

S1 := 'Something';
S2 := 'Something at line {$LINENO}';

Now, no matter where this code is, I want S2 to reflect the actual line it appears at the code.
Putting a literal line in is not really practical as this may be in many places, and as soon as any text is inserted above the line in question, they are immediately wrong :-(
Also, this text is not necessarily in an exception handler; it may just be in the middle of a code block.

Any ideas if this is possible?

Is there some wonderful {$LINENO} that is available :-)

Any help would be appreciated.

Best regards,

Question by:James Atkin
  • 5
  • 4
  • 2
LVL 19

Expert Comment

ID: 37776082
Perhaps this helps you...
How to get line number at runtime

Author Comment

by:James Atkin
ID: 37776089
Thanks for the reply. I did look at this article but it appears to deal with overriding the exception handling, which is not really what I am after - unless I am misinterpreting something?
LVL 19

Accepted Solution

Thommy earned 1000 total points
ID: 37776193
It's not basically about excepting handling!
I think the main statement of my suggested link is this:

You can't do this without a map file or something equivalent. The process of compilation leaves the source code behind. ...

Please read this part at How to get line number at runtime
Free Tool: Subnet Calculator

The subnet calculator helps you design networks by taking an IP address and network mask and returning information such as network, broadcast address, and host range.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

LVL 38

Expert Comment

by:Geert G
ID: 37776200
embed into to the source code ????
source code doesn't contain line numbers

find the source code line when trying to resolve an error may be handy
> in this case use a error logging tool like MadExcept or Eurekalog

why do you want to add line numbers to code ???
>> delphi wouldn't compile
LVL 38

Assisted Solution

by:Geert G
Geert G earned 1000 total points
ID: 37776207
if it's not for exception handling, then this $LINENO variables doesn't exist

Author Closing Comment

by:James Atkin
ID: 37776221
I had come to the same conclusion :-(
Thanks anyway...
LVL 38

Expert Comment

by:Geert G
ID: 37776225
what are you trying to do anyway ?

there may be other solutions to your problem ...
or the problem may not be what you think it is

Author Comment

by:James Atkin
ID: 37776234
I have various comments logged to an event log during execution of a program, some of which are the same within a module. I wanted a way to distinguish between these comments without manually needing to ensure that these are kept identifiable by adding a suffix of 1, 2, 3..... etc.
I thought simply using Line numbers in place of the number would be the simplest way to do this in a generic manner.
LVL 38

Expert Comment

by:Geert G
ID: 37776242
if you were to save text in a separate file (say for config)
and you want a line number:


Open in new window

  s: TStrings;
  I: Integer;
  s := TStringList.Create;
    for I := 0 to s.Count-1 do
      if Pos('[LINENO'], s[I]) > 0 then 
        s[I] := StringReplace(s[I], ['LINENO'], IntToStr(I), [rfReplaceAll]);
    ShowMessage(S.Values['param4]); // >> showMessage('2'); // 0 based = line 3

Open in new window

LVL 38

Expert Comment

by:Geert G
ID: 37776285
why not simply use a timestamp in the comment ?

Author Comment

by:James Atkin
ID: 37776495
I need to identify the section of code that was executing rather than making it unique within the log.

What I have at the moment is something like...

Log('Command Executed Successfully : 1');
Log('Command Executed Successfully : 2');
Log('Command Executed Successfully : 3');

I cannot just do :

Log('Command Executed Successfully : ' + IntToStr(X)); inc(X);

as there is no guarantee that these are all executed throughout the execution, so if the 1st and 3rd were executed, I would see:

      Command Executed Successfully : 1
      Command Executed Successfully : 2

Which would not really help me.

Featured Post

Upgrade your Question Security!

Your question, your audience. Choose who sees your identity—and your question—with question security.

Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Objective: - This article will help user in how to convert their numeric value become words. How to use 1. You can copy this code in your Unit as function 2. than you can perform your function by type this code The Code   (CODE) The Im…
Introduction The parallel port is a very commonly known port, it was widely used to connect a printer to the PC, if you look at the back of your computer, for those who don't have newer computers, there will be a port with 25 pins and a small print…
Planning to migrate your EDB file(s) to a new or an existing Outlook PST file? This video will guide you how to convert EDB file(s) to PST. Besides this, it also describes, how one can easily search any item(s) from multiple folders or mailboxes…
When you have multiple client accounts to manage, it often feels like there aren’t enough hours in the day. With too many applications to juggle, you can’t focus on your clients, much less your growing to-do list. But that doesn’t have to be the cas…

600 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question