|
Thnaks everyone for replying to my question ref 'variable variable' names One reply (Bruce Guetzkow) mentioned the possibility of using REXX. Is this something that we would do by a call from RPG. I must admit I know little about REXX. Paul -----Message d'origine----- De : rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-bounces@xxxxxxxxxxxx] De la part de rpg400-l-request@xxxxxxxxxxxx Envoyé : vendredi 18 mars 2005 21:18 À : rpg400-l@xxxxxxxxxxxx Objet : RPG400-L Digest, Vol 4, Issue 313 Send RPG400-L mailing list submissions to rpg400-l@xxxxxxxxxxxx To subscribe or unsubscribe via the World Wide Web, visit http://lists.midrange.com/mailman/listinfo/rpg400-l or, via email, send a message with subject or body 'help' to rpg400-l-request@xxxxxxxxxxxx You can reach the person managing the list at rpg400-l-owner@xxxxxxxxxxxx When replying, please edit your Subject line so it is more specific than "Re: Contents of RPG400-L digest..." Today's Topics: 1. Re: Conversion Error Help (Peter Dow) 2. using record to build a screen (Keith Fischer) 3. Re: Conversion Error Help (Brian Parkins) 4. RE: Variable Variable names (Holden Tommy) 5. RE: Conversion Error Help (Brian Piotrowski) 6. Re: Variable Variable names (Rich Duzenbury) 7. RE: Variable Variable names (Bruce Guetzkow) ---------------------------------------------------------------------- message: 1 date: Fri, 18 Mar 2005 10:52:35 -0800 from: "Peter Dow" <maillist@xxxxxxxxxxxxxxx> subject: Re: Conversion Error Help Hi Brian, Try FLDQTY = %DEC(%SUBST(FLD5:2) : 6 : 0) if you're on v5r2 or higher. Peter Dow Dow Software Services, Inc. 909 793-9050 voice 909 793-4480 fax 951 522-3214 cell ----- Original Message ----- From: "Brian Piotrowski" <bpiotrowski@xxxxxxxxxxxxxxx> To: "RPG programming on the AS400 / iSeries" <rpg400-l@xxxxxxxxxxxx> Sent: Friday, March 18, 2005 10:22 AM Subject: Conversion Error Help Hi All, I'm having a bit of a problem with a data evaluation / conversion, and I'm wondering if you veterans can help (Yes, I am still fairly new to RPG)? In my code, I have this statement: /FREE CHAIN KEYPB SSM05A11; IF %FOUND(SSM05A11); FLDQTY = %SUBST(FLD5:2:%LEN(FLD5)); GTBOXQTY = (%INT(FLDQTY) > PNBQTY); ENDIF; /END-FREE KEYPB is a key that contains a part number FLD5 is a 9A field PNBQTY is a 6S field for box quantity -- No virus found in this outgoing message. Checked by AVG Anti-Virus. Version: 7.0.308 / Virus Database: 266.7.3 - Release Date: 3/15/2005 ------------------------------ message: 2 date: Fri, 18 Mar 2005 14:10:46 -0500 from: "Keith Fischer" <keithf@xxxxxxxxxxxxxxxx> subject: using record to build a screen I have a file from a third party that has 2 record types. The first record type has field name and description. There are 30 different field names. The second record type has the list of values for the field name. Most of the record types are for future fields and when the fields are to be used a new file will be sent. The question I have is is there a way to have a field description for a screen get updated from a file. Also, can the list of values be updated for a screen from a file. Thanks Keith ------------------------------ message: 3 date: Fri, 18 Mar 2005 19:18:49 +0000 from: Brian Parkins <parkib@xxxxxxxxxx> subject: Re: Conversion Error Help The following seems to work OK: D FLD5 S 9A Inz('Q901') D FLDQTY S Like(Fld5) D PNBQTY S 6S 0 D GTBOXQTY S N /Free Dsply 'Enter Value for PNBQTY' '*REQUESTER' PNBQTY; FLDQTY = %SUBST(FLD5:2:(%Len(%TrimR(FLD5))-1)); GTBOXQTY = (%INT(FLDQTY) > PNBQTY); Dsply GTBOXQTY '*REQUESTER'; *InLR = *On; /End-Free Brian Parkins ------------------------------ message: 4 date: Fri, 18 Mar 2005 13:36:02 -0600 from: Holden Tommy <Tommy.Holden@xxxxxxxxxxxxxxxxx> subject: RE: Variable Variable names There are only 2 ways that I know of to do this. One is to write a code generator program, the other is via embedded SQL. Here is a sample of the embedded SQL. Hope this helps!!! Thanks, Tommy Holden -----Original Message----- From: rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-bounces@xxxxxxxxxxxx]On Behalf Of Lim Hock-Chai Sent: Friday, March 18, 2005 10:45 AM To: RPG programming on the AS400 / iSeries Subject: RE: Variable Variable names Clarify. Datastructure mentioned below should be an external datastructure. -----Original Message----- From: rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-bounces@xxxxxxxxxxxx]On Behalf Of Lim Hock-Chai Sent: Friday, March 18, 2005 10:26 AM To: RPG programming on the AS400 / iSeries Subject: RE: Variable Variable names There is no such bif in RPG. It is possible if all those variables are in a datastrucure. You can use an api to get a list of field location of the datastructure and then use %subst to get the value. -----Original Message----- From: rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-bounces@xxxxxxxxxxxx]On Behalf Of PAPWORTH Paul Sent: Friday, March 18, 2005 9:28 AM To: rpg400-l@xxxxxxxxxxxx Cc: GAZIN Florence; DEVILLE Jacques Subject: Variable Variable names Does any one know if it is possible in RPG (or any other i_series) language to do the following Ws_work_zone = %pgmvar(var) %pgmvar would be a function which would allow you to get the contents of a variable , whose name is contained in a variable. Eg if in my imaginary function var contains the name of a field 'FRED' , and FRED contains 'ABC' , I would end up with 'ABC' in ws_work_zone Many thanks in advance -- This is the RPG programming on the AS400 / iSeries (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. -- This is the RPG programming on the AS400 / iSeries (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. -- This is the RPG programming on the AS400 / iSeries (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. -------------- next part -------------- H DFTACTGRP(*NO) H OPTION(*SRCSTMT: *NODEBUGIO: *NOSHOWCPY) /copy prodkr/qcopysrc,clcmdexec /copy prodkr/qcopysrc,getcurdb * SQLDA Descriptor Area D SQLDA DS D SQLDAID 1 8A D SQLDABC 9 12B 0 D SQLN 13 14B 0 D SQLD 15 16B 0 D SQL_VAR 80A DIM(400) D SQL_Data_Type 17 18B 0 D SQL_Var_Len 19 20B 0 D SQL_Resrvd 21 32A D SQL_Data_Pntr 33 48* D SQL_Null_Ind 49 64* D SQL_Name_Len 65 66B 0 D SQL_Col_Name 67 96A * SQLDA Variable Data D SQLVAR DS D SQLTYPE 1 2B 0 D SQLLEN 3 4B 0 D SQLRES 5 16A D SQLDATA 17 32* D SQLIND 33 48* D SQLNAMELEN 49 50B 0 D SQLNAME 51 80A * SQLDA Variable Data (Extended) D SQLVAR2 DS D SQLLONGL 1 4B 0 D SQLRSVDL 5 32A D SQLDATAL 33 48* D SQLTNAMELN 49 50B 0 D SQLTNAME 51 80A * Work Variables D File s 10a D Lib s 10a D TempFile s 10a D TempLib s 10a Drowcountx s 10I 0 DOrdinal s 10I 0 DColName s 10a DDataType s 8a DLength s 10i 0 DScale s 10i 0 Dn1 s 4b 0 DPuNo s 6a DDatabaseName s 100a D XLSPath s 100a D SQLSelect s 5000a Varying DColumnNumber s 10i 0 D RecordData s 32766a DElement s 10i 0 * Parameter Entry C *Entry PList C Parm FileName 20 C Parm TemplateFile 20 C Parm XLSPath * SQL Error Trapping c/exec sql c+ Whenever SQLError Continue c/end-exec /free //* Extract The Input File Name //* & Load The Output Path If Not Specified If XLSPath=*Blanks; XLSPath='/tmp/xl.xls'; EndIf; File=%Subst(FileName:1:10); Lib=%Subst(FileName:11:10); TempFile=%Subst(TemplateFile:1:10); TempLib=%Subst(TemplateFile:11:10); //* Override The Database File Being Processed CmdStr='OVRDBF '+%Trim(File)+' '+ %Trim(Lib)+'/'+%Trim(File)+ ' Share(*Yes)'; CmdStrSize=%Len(%Trim(CmdStr)); monitor; Run(CmdStr:CmdStrSize); on-error; endmon; //* Build The Dynamic Excel Generation Program ExSR SQLSelectBuild; /end-free c/exec sql c+ Prepare SQLExtract From :SQLSelect c/end-exec c Eval SqlN=1 C/exec sql c+ Describe SQLExtract Into :SQLDA c/end-exec c Eval SqlN=SqlD c Eval SQLABC=SqlN*%Len(SqlVar)+16 c/exec sql c+ Describe SQLExtract Into :SQLDA c/end-exec c/exec sql c+ Declare SQL_Extract Cursor For SQLExtract c/end-exec c/exec sql c+ open SQL_Extract Using Descriptor :SQLDA c/end-exec c DoU SqlCod=100 c/exec sql c+ Fetch SQL_Extract Into Descriptor :SQLDA c/end-exec c If SqlCod=100 c/exec sql c+ Close SQL_Extract c/end-exec c Leave c EndIf c ExSR ExtractData c EndDo /free //* Terminate *inlr = *on; BegSR ExtractData; For Element = 1 By 1 To SqlD; SQLVAR=SQL_VAR(Element); EndFor; EndSR; /end-free * * Build SQL Select Statement From Template File C SQLSelectBuildBegSR C Eval SQLSelect='Select ' * Declare The SQL Cursor c/exec sql c+ Declare StringBuild Cursor c+ For Select Column_Name,Data_Type,Length,Numeric_Scale, c+ Ordinal_Position From SYSCOLUMNS c+ Where System_Table_Name= :TempFile And c+ System_Table_Schema = :TempLib c+ Order By Ordinal_Position c/end-exec * Open The SQL Cursor c/exec sql c+ Open StringBuild c/end-exec * Error Occurred On Open c If SQLCod<0 c LeaveSR c EndIf * Load The Source Code For All Fields In the File c Eval rowcountx=4 c DoU SQLCod=100 c/exec sql c+ Fetch StringBuild Into :ColName,:DataType,:Length, c+ :Scale:n1,:Ordinal c/end-exec * End Of Records c If SQLCod=100 c Leave c EndIf * Error On Fetch c If SQLCod<0 c Iter c EndIf c Eval SQLSelect=%Trim(SQLSelect)+' '+ c %Trim(ColName)+',' c EndDo c Eval Length=%Len(%Trim(SQLSelect)) c Eval SQLSelect=%Subst(SQLSelect:1:Length-1) c Eval SQLSelect=%Trim(SQLSelect)+ c ' From '+%Trim(Lib)+'/' c +%Trim(File) c EndSR ------------------------------ message: 5 date: Fri, 18 Mar 2005 15:03:44 -0500 from: "Brian Piotrowski" <bpiotrowski@xxxxxxxxxxxxxxx> subject: RE: Conversion Error Help Hi All, Thanks for the great responses. I gave all of them a try, and I still get the conversion error. Could it be something with the way I'm defining the fields? Thanks, Brian. -----Original Message----- From: Peter Dow [mailto:maillist@xxxxxxxxxxxxxxx] Sent: Friday, March 18, 2005 1:53 PM To: RPG programming on the AS400 / iSeries Subject: Re: Conversion Error Help Hi Brian, Try FLDQTY = %DEC(%SUBST(FLD5:2) : 6 : 0) if you're on v5r2 or higher. Peter Dow Dow Software Services, Inc. 909 793-9050 voice 909 793-4480 fax 951 522-3214 cell ----- Original Message ----- From: "Brian Piotrowski" <bpiotrowski@xxxxxxxxxxxxxxx> To: "RPG programming on the AS400 / iSeries" <rpg400-l@xxxxxxxxxxxx> Sent: Friday, March 18, 2005 10:22 AM Subject: Conversion Error Help Hi All, I'm having a bit of a problem with a data evaluation / conversion, and I'm wondering if you veterans can help (Yes, I am still fairly new to RPG)? In my code, I have this statement: /FREE CHAIN KEYPB SSM05A11; IF %FOUND(SSM05A11); FLDQTY = %SUBST(FLD5:2:%LEN(FLD5)); GTBOXQTY = (%INT(FLDQTY) > PNBQTY); ENDIF; /END-FREE KEYPB is a key that contains a part number FLD5 is a 9A field PNBQTY is a 6S field for box quantity -- No virus found in this outgoing message. Checked by AVG Anti-Virus. Version: 7.0.308 / Virus Database: 266.7.3 - Release Date: 3/15/2005 -- This is the RPG programming on the AS400 / iSeries (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. ------------------------------ message: 6 date: Fri, 18 Mar 2005 14:04:10 -0600 from: Rich Duzenbury <rduz-midrange@xxxxxxxxxxxxxxxxxxx> subject: Re: Variable Variable names On Fri, 2005-03-18 at 16:27 +0100, PAPWORTH Paul wrote: > Does any one know if it is possible in RPG (or any other i_series) > language to do the following > > > > Ws_work_zone = %pgmvar(var) About fifteen years ago, we needed to write a program where the user could define rules that edited fields in a set of records. They needed to be able to edit against the contents of any field (in a defined list of several hundred) to see if it was blank, or zero, or matched a list, or matched one of the other fields in the list. There were ranges, and all sorts of requirements. We thought about various methods, including writing a program generator, but at the time, it would have been too slow to have the user generate and compile some kind of program every time they changed the ruleset, which was frequently. Finally, someone not really connected to the project said - As soon as the data is in memory, why not just copy each field into an array element? At first we dismissed the idea out of hand, because it wasn't 'real' softcoding, which we thought we were after. However, after a bit of thought, it became clear that the only 'hardcoding' in the project would be the bit of code to copy each field into it's array element. Once that was done, the user could write a rule like "if account type is 111 and end_date is 0, reject the record". Since we knew account type was in (say) field 15, and end date was in field (say) 38, we could easily, at run time, parse the rule(s), and then compare fields(15) with 111 and fields(38) with 0. HTH -- Regards, Rich Current Conditions in Des Moines, IA Overcast Temp 46.4F Winds out of the Southwest at 15mph Moderate Rain ------------------------------ message: 7 date: Fri, 18 Mar 2005 14:17:08 -0600 from: "Bruce Guetzkow" <bruceg@xxxxxxxxxxxxxxxxxxxxxxx> subject: RE: Variable Variable names Paul: <snip> Does any one know if it is possible in RPG (or any other i_series) language to do the following Ws_work_zone = %pgmvar(var) </snip> The only language that I know of that allows this is REXX. Using the VALUE function you can do the following... data = 'Some Value' var = 'data' say value(var) The "value(var)" can be translated into English as "give me the contents (or value) of the variable specified in the variable name var". Having said this, REXX is somewhat limited in processing data directly, although you can do an OVRDBF to file STDIN and read data from a single file, or execute SQL statements in REXX (which is much more powerful). Hope that helps, --Bruce Guetzkow ------------------------------ -- This is the RPG programming on the AS400 / iSeries (RPG400-L) digest 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. End of RPG400-L Digest, Vol 4, Issue 313 ****************************************
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.