|
Scott; I completely agree with everyting you said. Altho I am supprised not to hear you, or anyone else, having a problem with the 80 character limit to /Free lines. I would love to see the limit for /Free lines and (in my fanticy world) the P and D specs to the length of the file. I often code into the "comment" section of the /Free line and get bit by the compiler. I have been working on a RPG Java interface for my company and it would be a great if I didn't have to have 3 or 4 lines to describe the CLASS of an object. The other reason for using the file length as the limit, is that my RPG source file's record lengths are 127, this allows me, in SEU, to see the full date and have 35 characters on the right for comments. Duane Christen > -----Original Message----- > From: Scott Klement [mailto:rpg400-l@xxxxxxxxxxxxxxxx] > Sent: Friday, October 29, 2004 11:31 AM > To: RPG programming on the AS400 / iSeries > Subject: Re: RPGIII to get a facelift? > > > > Hi, > > > How about the opcode extensions that _only_ work in /Free > and the probability > > that more of these will appear in the future. > > For me, the biggest reason for /FREE is the extra space it provides me > with. With the "extended factor 2" syntax, I was FOREVER > running out of > space on a line, and then was faced with the problem "how I > can break this > line of code up and have it still look elegant?" > > I do like being able to indent. And once in a blue moon, the > new op-codes > are useful for something. But the #1 reason is the extra space on the > line. > > For example, in free-form I can do this: > > trackRequest = > '<?xml version="1.0"?>' + CRLF + > '<TrackRequest xml:lang="en-US">' + CRLF + > '<Request>' + CRLF + > '<TransactionReference>' + CRLF + > '<CustomerContext>Example 1</CustomerContext>' + CRLF + > '<XpciVersion>1.0001</XpciVersion>' + CRLF + > '</TransactionReference>' + CRLF + > '<RequestAction>Track</RequestAction>' + CRLF + > '<RequestOption>activity</RequestOption>' + CRLF + > '</Request>' + CRLF + > '<TrackingNumber>' + TrackingNo + '</TrackingNumber>'+ CRLF + > '</TrackRequest>' + CRLF ; > > In fixed, it looks like this: > c eval data = > c '<?xml version="1.0"?>' + CRLF + > c '<TrackRequest > xml:lang="en-US">' + CRLF+ > c '<Request>' + CRLF + > c '<TransactionReference>' + CRLF + > c '<CustomerContext>Example 1</Customer'+ > c 'Context>' + CRLF + > c > '<XpciVersion>1.0001</XpciVersion>'+CRLF+ > c '</TransactionReference>' + > c '<RequestAction>Track</RequestAction>'+ > c CRLF + > c '<RequestOption>activity</Request' + > c 'Option>' + CRLF + > c '</Request>' + CRLF + > c '<TrackingNumber>' + > c %trim(tracknum) + '</TrackingNumber>'+ > c CRLF + '</TrackRequest>' + CRLF > > > Or, maybe you want to run a CL command: > > Command = 'CRTTAPF FILE(QTEMP/TAPEDATA) ' > + ' DEV(' + %trim(peDevice) + ') ' > + ' VOL(' + %trim(peVolume) + ') ' > + ' REELS(*SL 1) ' > + ' SEQNBR(' + %trim(%editc(peSeqNbr:'Z')) +') ' > + ' LABEL(' + %trim(peLabel) + ') ' > + ' FILETYPE(*DATA) ' > + ' RCDLEN(*CALC) ' > + ' BLKLEN(8200) ' > + ' RCDBLKFMT(*V) ' > + ' DENSITY(' + %trim(peDensity) + ') ' > + ' ENDOPT(' + %trim(peEndOpt) + ') ' > + ' CODE(*EBCDIC) ' > + ' COMPACT(' + %trim(peCompact) + ') ' > + ' REPLACE(*YES)' ; > > QCMDEXC(Command: %len(Command)); > > Instead of: > > c eval Command = 'CRTTAPF > FILE(QTEMP/TAPEDATA) '+ > c + 'DEV(' + > %trim(peDevice) + > c ') VOL(' + > %trim(peVolume) + > c ') REELS(*SL 1) ' + > c ') SEQNBR( ' + > c > %Trim(%editc(peSeqNbr:'Z')) + > c ') LABEL(' + > %trim(peLabel) + > c ') FILETYPE(*DATA) ' + > c 'RCDLEN(*CALC) ' + > c 'BLKLEN(8200) ' + > c 'RCDBLKFMT(*V) ' + > c 'DENSITY(' + > %trim(peDensity) + > c ') ENDOPT(' + > %trim(peEndOpt) + > c ') CODE(*EBCDIC) ' + > c 'COMPACT(' + > %trim(peCompact) + > c ') REPLACE(*YES)' > c callp QCMDEXC(Command: %len(Command)) > > Every day I do SOMETHING like this... sometimes it's a > subprocedure that > has long parameters (such as a URL or IFS pathname) other > days its a CL > command or a text document or an XML document... Most days it's MANY > things like this. > > It just seems like such a horrible waste for half of each > source record to > be taken up by 'C' followed by a bunch of useless spaces when I'm > struggling with how to make things fit all the time. > > My opinion of the other concerns people have raised: > > a) Semi-colons aren't a big deal to me. I'm used to having to > specify them > differently in RPG vs C vs Java vs Perl... it's nothing new. > > b) Missing op-codes? I hear this complaint ALL THE TIME on > this list, yet > never once I have I had to switch back to fixed to do > something. NOT EVEN > ONCE. > > c) Typing /free and /end-free? Yeah, that can be a little bit of a > nuisance. But, weigh the alternatives! It's not nearly as > bad as typing > 'C' followed by 300 spaces. It's not even close to as bad as > wrapping my > code every 30 characters or so. > > d) Not having free-form H, F, D, I, O, P specs? It really > doesn't matter > to me. H-specs are more or less free form anyway, and have > been since RPG > IV debuted. F-specs... I've never had the desire to indent > an f-spec, and > I almost never run out of space. I & O specs I hardly ever > use. D-specs > MIGHT be nice to have free-form, since I could use the extra space for > CLASS(), EXTPROC(), OPTIONS(), etc keywords.but this usually > isn't a big > problem. It's almost universally C-specs where I need /FREE. > > I'd MUCH rather have the RPG team work on giving us more functionality > than reinventing H,F,D,I,O,P specs! > > -- > 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. > NOTICE: This electronic mail transmission may contain confidential information and is intended only for the person(s) named. Any use, copying or disclosure by any other person is strictly prohibited. If you have received this transmission in error, please notify the sender via e-mail.
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.