• Subject: Re: File/Service Program/Data Structure Problem...
  • From: Scott Klement <klemscot@xxxxxxxxxxxx>
  • Date: Thu, 11 May 2000 19:17:05 -0500 (CDT)


Hi Brad,

Interesting problem! :)   I tried it myself, and got the same results that
you describe...  Rather strange.  Here's my only guess at the problem:

The compiler must create a routine that copies data from the file into
each field in your program.  

In other words, when compiling it looks at the input specs that it pulled
in from your external description, and creates a routine to copy the data
from those positions in the file into variables that are locally allocated
to your program (which it also defined from your external description.)
Perhaps the compiler gets tripped up when those local variables are 
based on a pointer?

My tests seem to indicate that the compiler cant properly handle that
situation.  Perhaps Hans or Barbara could shed some light on why?

An alternate approach would be to have the data structure in the service
program NOT be based on a pointer.  Instead, have the calling program 
base its data structure on a pointer.   Call the service program asking
to open the file, and have it pass back the address of the data structure.

For example:


----------------------------SERVICE PROGRAM----------------------------
     H NOMAIN

     FCUSTMAS   IF   E           K DISK    USROPN

     D OpenFile        PR            10I 0
     D   p_struct                      *

     D ReadNext        PR            10I 0
     D  p_struct                       *

     D CloseFile       PR            10I 0

     D dsData        E DS                  ExtName(CUSTMAS)


     P OpenFile        B                   export
     D OpenFile        PI            10I 0
     D   p_struct                      *
     c                   open      CUSTMAS                              10
     c   10              return    -1
     c                   eval      p_struct = %addr(dsData)
     c                   clear                   dsData
     c                   return    0
     P                 E


     P ReadNext        B                   export
     D ReadNext        PI            10I 0
     D   p_struct                      *
     c     cuCust        setgt     CUSTMAS
     c                   read      CUSTMAS                                10
     c   10              return    -1
     c                   return    0
     P                 E


     P CloseFile       B                   export
     D CloseFile       PI            10I 0
     c                   close     CUSTMAS                              10
     c   10              return    -1
     c                   return    0
     P                 E


----------------------------------CALLING PROGRAM-------------------------

     D OpenFile        PR            10I 0
     D   p_struct                      *

     D ReadNext        PR            10I 0
     D  p_struct                       *

     D CloseFile       PR            10I 0

     D p_struct        S               *
     D dsStuff       E DS                  ExtName(CUSTMAS) based(p_struct)

     c                   if        OpenFile(p_struct) < 0
     c                   eval      Msg = 'OpenFile() failed.'
     c                   dsply                   Msg              50
     c                   endif

     c                   dow       ReadNext(p_struct) >= 0
     c     cuCust        dsply
     c                   enddo

     c                   callp     CloseFile

     c                   eval      *inlr = *on



If you wanted to be more fancy about it, you could define dsData in
the service program as multiple occurance data structure.  Then, each
time OpenFile is called, add 1 to the occurance.  

Then your calling program could potentially define several data structures
and call OpenFile multiple times, essentially giving you "many copies" of
that file open...

Hope that helps...



On Thu, 11 May 2000, Stone, Brad V (TC) wrote:

> This is a tough one to explain, so bare with me.
> 
> Ok... 
> 
> I have PGMA.  It is using FILE1. 
> I have SRVPGMA that contains a procedure that passes me back the value of
> the field that I pass it.  For example, I say:
> 
> eval value = #RtvValue('FIELDNAME':Field@)
> 
> Field@ is a pointer to a data structure that is defined in PGMA as an
> external data structure using FILE1.  This is so they have the same field
> names and the data is loaded into the DS automatically when I read a record.
> 
> I do this so that I pass the service program the values in the file, the
> service program does a big SELECT statment, and returns the value of the
> 'FIELDNAME' parameter.
> 
> Now, in SRVPGM1, I accept the field name and the pointer to the DS that
> contains the value.  In SRVPGM1, I have another external DS defined from
> FILE1, same as in PGM1.
> 
> The DS is SRVPGM1 gets the data just fine, etc... etc...
> 
> Now the tricky part.
> 
> In SRVPGM1, I also have an option to retrieve the *NEXT value (like for a
> detail file.)  So, I do a SETGT on FILE1 in SRVPGM1 to position to the next
> record, then read.  The key list is made up of the fields in the DS.
> 
> Now, because the DS is created from FILE1, it has the same field names as
> the DS.  This is what I want.  So, when I read the file, the fields in the
> DS will automatically contain the "NExt" record.
> 
> But, after the read, the values do not change in the DS.  I watched the file
> pointer and everything moves fine, even does an IO on the read and is
> positioned on the RRN of the records I expect it to read.  But the data
> stays the same as when I passed it in with the pointer, and doesn't change
> to the values of the current record I read in the file.
> 
> Hard to follow, yes.  But, if anyone has any ideas why the values of the
> fields in the DS aren't changing, that would be great.
> 
> Brad

+---
| This is the RPG/400 Mailing List!
| To submit a new message, send your mail to RPG400-L@midrange.com.
| To subscribe to this list send email to RPG400-L-SUB@midrange.com.
| To unsubscribe from this list send email to RPG400-L-UNSUB@midrange.com.
| Questions should be directed to the list owner/operator: david@midrange.com
+---

As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:
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.