× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



Joe Pluta wrote:
To use such a field you need free format code (unless you use the "loose fixed format" of eval+extended factor 2).

This implied that you considered extended factor two somehow "above and beyond" standard fixed format RPG IV. My point was that most of the things you included as benefits of /free are indeed available in fixed format RPG IV. The extended factor two is what makes /free so superfluous.

Ah. Yes, I can see where you are coming from. Like almost every argument, a lot of confusion comes about because of a lack of defining terms. People tend to make strong statements without really agreeing on what the terms mean that they are talking about. So let me define what I'm talking about (in case anyone is even reading this thread anymore):


In an earlier post I said:

If we stuck to what I'm going to call "true fixed format" then we would have:

<indicators> <factor 1> <operator> <factor 2> <result> <indicators>

The above is how I define fixed format. It is the syntax that RPG/36, RPG II, and RPG III use. With RPG IV we got a new syntax, something I called "loose fixed format" that consists of indicators, factor 1, opcode, and a new extended factor 2. This new extended factor 2 is really just a free format section of code within an otherwise fixed format syntax. In order to emphasize the fact that the extended factor 2 provides us with a free form style syntax I'm going to refer to this mixed syntax of RPG IV as "fixed-free". Fixed-free syntax looks like:

<indicators> <factor 1> <operator> <free format area>

This is the extended factor 2 syntax that we are familiar with as part of RPG IV. "True free format" syntax I'm going to define as syntax that has none of the fixed elements, i.e:

<free format area>

It seems a little pedantic to include that definition - but let's be complete. The interesting part to notice from this whole discussion is that we all primarily code in the free format area of fixed-free syntax. So much so that it seems wasteful to have to the fixed areas of fixed-free syntax. Following the suggestions of coding *EXTFACT2 in factor 1 would completely obviate the need for any code at all in the fixed area. So why have any fixed format at all?

With some definitions in place we can look at that question. One argument in favor of fixed format is that it is legible to RPG programmers. That argument is silly, since because true free format is just that, free format, you can format the code to look anyway you want, including making it looked like fixed-free code looks. If you think that the current fixed-free syntax of RPG IV is easy to read, then just keep indenting things that way.

Another argument against true free format code is the required uses of the /free precompiler directive. I agree that this kind of sucks. If a precompiler directive is necessary, I personally would have chosed to use /fixed to indicate areas the follow RPG IV's fixed-free syntax and defaulted to true free form syntax otherwise. But perhaps the best solution is to do what someone else mentioned a while ago and use the C in column 6 to indicate fixed-free vs. true free format code. Put a C in column 6 when you want fixed-free and leave it blank when you want true free format.

Another argument against true free format syntax is that the syntax checker doesn't work with it. This isn't really a problem with true free syntax or the compiler, but with the editor. Emacs, vi, and other editors can check true free format code, RPG editors should do the same. Perhaps SEU is not the editor to do that with, however.

Yet another argument against true free format syntax (YAAATFFS) is that following programmers will have a hard time with the indenting style chosen by the previous programmer. This is simply solved by code beautifiers such as those available for C. A standard beautifier such as the unix utility 'indent' could handle this without issue (indent also checks syntax - a nice bonus).

Now for the hairy stuff - addressing the MOVE issue. I'm afraid that this will never be resolved in a way that Joe likes because so many (myself included) don't like the MOVE opcode. The biggest uproar over this issue has been because some view MOVE as being removed from the language and others see it as simply not being moved forward into true free form syntax. Possibly the solution involving the C in column spec would pacify both camps, but I'm not counting on it.

I think those are the main arguments that have come up so far. But there has been an underlying argument that I don't think has been directly addressed: backward compatibility. I am interested by the statement "RPG is too backwards compatible". While argueing neither for nor against, I wonder what good or bad would come if RPG forked and a new, non-backwards compatible branch developed that contained many of the enhancements that have been asked for. RPG IV as it stands now would still be supported, but no longer evolve. Maybe call this new version something else, like FIR (FIR Isn't RPG - clever recursive acronym). It would have record level access, chain, external files, true free form, proper pointers, good SQL syntax, etc. but wouldn't support fixed-free or true fixed format at all.

Hopefully I've clearly stated the definitions and arguments. If there is anyone left reading this thread perhaps we'll understand each other better.

Yes, all day long.  But assuming I said something that was true, would
my background somehow make it false?


No, but the errors in your assumptions undermine the credibility of your
statements.

True. Happily I learned something new today about RPG.


James Rich


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.