|
Scott, I thought about doing it something like this, but how do you know the Parm1 size before hand? Or does it matter? You are setting Parm1 up as 3072 bytes, how do you know it is this size? And does it matter? I thought that if I specified a parameter larger than my actual parameter I would get problems. For instance, say I had 2 parameters I was passing as length 5 strings. If I declared them as length 10 in my program, wouldn't I actually get both passed values in my first parameter? Perhaps this is a good time to use the VARYING length definition? Regards, Jim Langston Scott Klement wrote: > <SNIP> > As far as a "better way to do it", the way that I usually handle > triggers is that I make an externally defined data structure using > the description of the file that the trigger is to be added to. > Then, I base that data structure on a pointer, and I offset that > pointer to the location that the record is stored in "Parm1" > > Something like this: > > D Parm1 DS > D* Array, because I can't use pointer arthmetic at V3R2 > D Buffer 1 3072A DIM(3072) > D FileName 1 10 > D LibName 11 20 > D MemName 21 30 > D TrigEvent 31 31 > D TrigTime 32 32 > D CommLockLvl 33 33 > D Reserved01 34 36 > D CCSID 37 40B 0 > D Reserved02 41 48 > D OldOffset 49 52B 0 > D OldLength 53 56B 0 > D OldByteMapOff 57 60B 0 > D OldByteMapLen 61 64B 0 > D NewOffset 65 68B 0 > D NewLength 69 72B 0 > D NewByteMapOff 73 76B 0 > D NewByteMapLen 77 80B 0 > D Reserved03 81 96 > > D p_NewBuf S * > D dsRecord e ds EXTNAME(MYFILE) > D BASED(p_NewBuf) > > c eval p_NewBuf = %addr(Buffer(NewOffset+1)) > > If your release can use pointer arithmetic directly, you could > (instead of using the array) just add the "newoffset" to the > address of Parm1 to get p_NewBuf instead of using the array method > that I used above... <SNIP> +--- | 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 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.