|
Yes, but only the first time, if the variable is global, that a given
module or program is called. In my opinion, that is a bug. I think
every time you call a program or module it should execute the
initialize logic for a global variable if the variable has a INZ
keyword on the variable.
To prove it just take the test program and add the INZ keyword to the
global variable and you will see the following:
DSPLY 'TANGO' -- INZ value
DSPLY 'ZEBRA'
DSPLY 'ZEBRA'
On Wed, Sep 26, 2012 at 1:45 PM, Dennis <iseries@xxxxxxxxxxxx> wrote:
INZ, by my experience, will initialize global/static and localvariables equally well.
++works
Dennis
++
"Guidelines for Bureaucrats:
(1) When in charge ponder.
(2) When in trouble delegate.
(3) When in doubt mumble."
-- James H. Boren
Bravely sent from my Galaxy tablet phone.
++
Alan Campin <alan0307d@xxxxxxxxx> wrote:
If you are talking about the global or static variable that only
atthe first time the program or module is called. After that it stays
sp.the value it was last set to in the program before it exited. If the
variable is global, you must initialize the variable in code before
you use it if you must have at a certain value before you start.
On Wed, Sep 26, 2012 at 1:34 PM, DeLong, Eric
<EDeLong@xxxxxxxxxxxxxxx>
wrote:
Hm, I just add the INZ option to the variable definition, to ensurethat the automatic storage is initialized to an expected value... I
guess I like to be explicit with my code.
[mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Alan Campin
-Eric DeLong
-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx
Sent: Wednesday, September 26, 2012 12:13 PMoutput
To: RPG programming on the IBM i / System i
Subject: Re: MAIN and LR
I wrote the following test program awhile ago. This is what the
looks like if called multiple times.same.
DSPLY
DSPLY ZEBRA
DSPLY ZEBRA
DSPLY ZEBRA
In other words, between each call the static storage remains the
of
h Option(*Srcstmt:*Nodebugio:*NoUnref:*NoShowCpy)
h Main(TestStatic)
/copy *libl/qsrcf,cb_StdType
/copy *libl/qsrcf,cb_Std_Con
d TestStatic...
d pr ExtPgm('TESTMAIN')
d g_TestVariable...
d s Like(StdNam)
p TestStatic...
p b
d pi
/Free
Dsply g_TestVariable;
g_TestVariable = 'ZEBRA';
Return;
/End-Free
p e
On Wed, Sep 26, 2012 at 9:56 AM, Dave <dfx1@xxxxxxxxxxxxxx> wrote:
Vern, your questions are starting to scare me, as I wrote a couple
MAIN programs a couple of years ago, left the company for a year
and came back. I didn't think about the initialisation of the main
wouldAs
it's variables are not global as in a program without MAIN, I
inthink so. I notice that MAIN has not been used yet anywhere else
doour shop and I suspect that noone else has tried it or even knows
about it. I stopped using it as I had to keep remembering how to
whyit
when I was writing a new program, which is rare, and I wondered
onbother, you win on performance because of the cycle but you lose
nothassle because the programmers have to learn new stuff. IBM has
passingreference andpushed us towards using it as far as I know, so who will bother?
2012/9/26 Vernon Hamberg <vhamberg@xxxxxxxxxxxxxxx>:
Hi Barbara
So to clarify about initialization - and I did look at the
initializationprogrammer's guide just now - when using MAIN, the extra
thatfor the cycle doesn't happen. You can't even HAVE an *INZSR, as I
understand.
I assume that data declared in the MAIN subprocedure is
initialized every time it is called, unless declared as STATIC.
So what happens with global data? If running in *DFTACTGRP? Or is
modulenot possible with a linear-main module? I did see the section on
clearinitialization, with the subtopic on global data. But it wasn't
initialization.what happens with global data when there is no cycle
Maybe, too, this is a stimulus to avoiding global data and
that!it
along in parameters from the MAIN subprocedure, eh?
I have to find a few minutes to try out some stuff, I can see
theythat on
Thanks
Vern
On 9/25/2012 7:16 PM, Barbara Morris wrote:
On 2012/9/25 1:49 AM, Vernon Hamberg wrote:
Help me out here - I've always thought leaving *INLR *OFF means
another call to the program, variables will have the values
thanhad
keyword -when the program ended before. Is this different with the MAIN
module.)remember, we don't compile to 7.1 (blushing!).Vern, you're right about how *INLR works for what's now called a
cycle-main module. (And was formerly just not called a NOMAIN
will
With the MAIN keyword, you have something very similar to a
NOMAIN module, but the MAIN keyword indicates which of your
subprocedures
be the program-entry procedure. The main procedure is called a
linear-main procedure (running from beginning to end) rather
takea
mailing listcycle-main procedure (running the RPG cycle).
Cycle-main:
/free
dsply 'hello';
return;
Linear-main:
H main(mypgm)
P mypgm b
/free
dsply 'hello';
// return opcode not needed
/end-free
P e
--
This is the RPG programming on the IBM i / System i (RPG400-L)
mailing listTo 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.
This is the RPG programming on the IBM i / System i (RPG400-L)
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
mailingmailing lista moment to review the archives at--
http://archive.midrange.com/rpg400-l.
This is the RPG programming on the IBM i / System i (RPG400-L)
To post a message email: RPG400-L@xxxxxxxxxxxx To subscribe,mailing list
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.
--
This is the RPG programming on the IBM i / System i (RPG400-L)
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.
This is the RPG programming on the IBM i / System i (RPG400-L)
mailinglist 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.
This is the RPG programming on the IBM i / System i (RPG400-L)
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.
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-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.