The INDARA/INDDS keywords divorce the *IN and *IN() reserved variables from the Display/Print File indicators.

In your code, EDITRECORDMODE and *IN82 are now two completely different variables and *IN82/*IN(82) no longer have any association with Indicator 82 in your program

This works for you, because you ONLY use Indicator 82 in a specific Display File. But what about (older) code which may make a broader use of Indicators? The Pointers/Indicators approach allows new code to be inserted in a program, using meaningful names for existing indicators - without disturbing older existing code. In Jay's example, SFL_CLEAR, *IN80, or *IN(80) can all be used interchangeably to map on to Indicator 80 - wherever it specified or used.

INDARA/INDDS are, (in my opinion) much less flexible than the Pointers/Data Structure approach.

Hope this helps.
Brian.

On 11/07/2019 20:58, Alan Campin wrote:
I don't understand all this pointers to indicators stuff. I just do the
following.

dcl-f PLBG01_D01 WorkStn InfDs(gFileInfo)
InDDS(gIndicators)
Include(RD01_02: SFMSG_CTL)
UsrOpn;

dcl-ds gIndicators Len(99);
InvalidFrontierManaged Ind Pos(53);
InvalidErrorDescription Ind Pos(56);
ServiceOrderMode Ind Pos(81);
EditRecordMode Ind Pos(82);
DisplayRecordMode Ind Pos(83);
DisplaySubfileEndOnSubfileMessageQueue Ind Pos(95);
end-ds;


As an Amazon Associate we earn from qualifying purchases.

This thread ...

Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.