|
-----Message d'origine-----
De : rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx] De la part de Mark S. Waterbury
Envoyé : mardi 25 janvier 2011 18:19
À : RPG programming on the IBM i / System i
Objet : Re: global pgm variable and file field with same name
and attributes
David:
RPG IV is not case sensitive, so "gPgmId" is equivalent to "GPGMID".
The RPG compilers do not complain if you define the same
variable name on a D-spec that is also defined in an
externally described file, unless the type, length or decimal
places are defined differently.
Perhaps your naming standards could be amended to help avoid
this situation. For example, if a "g" prefix denotes a
"global" variable, then "GPGMID" should not be permitted as a
field name in an externally described database file. Or, you
perhaps could change the "global"
prefix to something like "g_" for internally declared variable names.
HTH,
Mark S. Waterbury
Hi,coding gPgmId was different to GPGMID.
I hope someone will be able to explain this to me.
In this program, it looks like the programmer thought that
display file field EPGMID. Then the global variable gPgmId is
In the code, a file containing field GPGMID is read into
populated with EPGMID, read from a subfile.
global variables. The source numbers next to it show that it
D Main_procedure PI
D gPgmId S Like(....)
/free
CAllp subproc
gPgmId = EPGMID;
/end-free
In subproc :
EPGMID = GPGMID;
In the compiler listing, GPGMID appears once in the list of
does not seem to differentiate between the global variable
declared by the programmer and the global field from the file.
is really initialising the file field GPGMID.
So can anyone tell me what is actually happening in the program ? I
think there is a danger that by coding gPgmId = EPGMID; It
--
Références de zone globales :
This is the RPG programming on the IBM i / System i
(RPG400-L) mailing list To post a message email:
RPG400-L@xxxxxxxxxxxx To subscribe, unsubscribe, or change
list options,
visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives
at http://archive.midrange.com/rpg400-l.
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2024 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.