PROGRAM-NAME function
- Last Updated: January 16, 2024
- 2 minute read
- OpenEdge
- Version 12.8
- Documentation
Returns the name of the calling program.
Syntax
|
- n
- The numeric argument. If n is 1, the name
of the current program is returned. If n is 2,
the name of the calling program is returned. If there is no calling
program then you have reached the top of the call stack and the
AVM returns the Unknown value (
?).
Example
This procedure returns the names of any procedure(s) that called it and displays the number of levels that the procedure was nested:
r-prgnm.p
|
Notes
- If you execute a procedure directly from the Procedure Editor or the AppBuilder, then PROGRAM-NAME(1) returns the name of a temporary file rather than the name of the actual procedure file.
- The PROGRAM-NAME function is useful when developing on-line help.
For example, you can use the following code in your help routine
to produce a program trace:
r-trace.p
DEFINE VARIABLE ix AS INTEGER NO-UNDO INITIAL 2. DEFINE VARIABLE plist AS CHARACTER NO-UNDO FORMAT "x(70)". FORM plist WITH FRAME what-prog OVERLAY ROW 10 CENTERED 5 DOWN NO-LABELS TITLE " Program Trace ". /* ix = 2, so skip the current routine: PROGRAM-NAME(1) */ DO WHILE PROGRAM-NAME(ix) <> ?: IF ix = 2 THEN plist = "Currently in : " + PROGRAM-NAME(ix). ELSE plist = "Which was called by: " + PROGRAM-NAME(ix). ix = ix + 1. DISPLAY plist WITH FRAME what-prog. DOWN WITH FRAME what-prog. END. PAUSE. HIDE FRAME what-prog. - If the procedure you reference is an internal procedure, then PROGRAM-NAME
returns a string with the following form:
"internal-procedure-name source-file-name" - If the procedure you reference is a user interface trigger associated with
a widget, then PROGRAM-NAME returns a string with the following
form:
"USER-INTERFACE-TRIGGER source-file-name" - If the procedure you reference is a user interface trigger that
uses the ANYWHERE keyword, then PROGRAM-NAME returns a string with the
following form:
"SYSTEM-TRIGGER source-file-name" - If the procedure you reference is a session database trigger,
then PROGRAM-NAME returns a string with the following form:
"type-TRIGGER source-file-name"Where type is either ASSIGN, CREATE, DELETE, FIND, or WRITE.
- If the call stack contains a method reference, then PROGRAM-NAME
returns a string with the following form:
"method-name class-file-name"Where class-file-name is the name of the class definition (
.cls) file in which method-name is implemented.