Talk:Rexx
This is the talk page for discussing improvements to the Rexx article. This is not a forum for general discussion of the article's subject. |
Article policies
|
Find sources: Google (books · news · scholar · free images · WP refs) · FENS · JSTOR · TWL |
Archives: 1 |
This article is rated C-class on Wikipedia's content assessment scale. It is of interest to the following WikiProjects: | |||||||||||||||||
|
Recent edit
[edit]A recent edit changed case insensitive variables to typeless variables. There were two problems with that:
- The article already listed dynamic data typing (no declarations)
- No replacement text was provided for case independence.
I am reverting the change and then replacing case insensitive variables with case independent tokens, including variable names.
In the same edit I'm including VM and TSO/E as bundled with REXX and I'm mentioning that there are potential surprises for PL/I programmers. Shmuel (Seymour J.) Metz Username:Chatul (talk) 00:36, 12 September 2010 (UTC)
Rexx is not Object Rexx
[edit]The infobox shows Rexx as object oriented, which it is not. There is a separate article on Object REXX, where that paradign does apply. Shmuel (Seymour J.) Metz Username:Chatul (talk) 14:33, 31 December 2010 (UTC)
NPOV: NOVALUE
[edit]The reference to NOVALUE violates WP:NPOV; quoting feature is totally out of bounds and the disdain for allowing bare words to default to their upper case names is hardly universal. The text should be rewritten in a neutral fashion, although it is certainly appropriate for the text to describe the controversy between the convenience and safety camps. Shmuel (Seymour J.) Metz Username:Chatul (talk) 15:23, 31 December 2010 (UTC)
- Addressed. RossPatterson (talk) 02:01, 11 June 2014 (UTC)
- The article still contains the sentence Virtually all serious Rexx programs contain signal on novalue or a similar statement., which violates WP:NPOV. Shmuel (Seymour J.) Metz Username:Chatul (talk) 14:57, 12 June 2014 (UTC)
- Feel free to change it. RossPatterson (talk) 22:17, 12 June 2014 (UTC)
- Reworded without "many" WP:WEASEL. –2A03:2267:0:0:452A:FA00:6D62:CEE8 (talk) 11:35, 10 January 2017 (UTC)
- Feel free to change it. RossPatterson (talk) 22:17, 12 June 2014 (UTC)
- The article still contains the sentence Virtually all serious Rexx programs contain signal on novalue or a similar statement., which violates WP:NPOV. Shmuel (Seymour J.) Metz Username:Chatul (talk) 14:57, 12 June 2014 (UTC)
First line
[edit]The first line of a Rexx script does not identify the operating system; it identifies the compiler or interpreter. There are several different uses of a special first line.
- The presence of a comment normally identifies the script as Rexx
- In TSO, a Rexx script loaded from SYSPROC must start with
/* REXX */
to distinguish it from a clist - In Unix the first line may be a shebang to identify the language processor
- In OS/2 the first line may be EXTPROC to identify the language processor; normally that is not necessary as an initial comment will let the script run with the default Rexx.
Shmuel (Seymour J.) Metz Username:Chatul (talk) 20:54, 10 November 2011 (UTC)
Community development
[edit]I think that many IBM people would say that REXX's design was highly developed by a community of IBM personnel and customers I think. This was before the internet was in use but PROFS provided email capability at the time. The fact that it was a community-designed language is noteworthy but I cannot find a reference. I hope an IBM person can. Sam Tomato (talk) 17:40, 9 June 2014 (UTC)
- I don't know of any community development of Rexx per se, but here was massive community development of function packages and Rexx-aware commands to support applications written in Rexx, to say nothing of such development tools as VX-REXX and VisPro REXX. Shmuel (Seymour J.) Metz Username:Chatul (talk) 18:12, 10 June 2014 (UTC)
I would assume Sam Tomato is referring to the process Mike Cowlishaw used for having the REXX user community inside IBM vett new features and substantive changes. He has spoken of this many times, and remarked on how valuable it was for developing the language. See, for example, p. 334 in Mike's 1984 IBM Systems Journal article The design of the REXX language:
The most important factor in the development of REXX began to take effect when the first interpreter was distributed over the IBM communication network known as VNET. (This network links over 1400 mainframe computers in forty countries.) From the beginning, many hundreds of people were using the language. All these users, from temporary staff to professional programmers, were able to provide immediate feedback to the designer on their preferences, needs, and suggestions for change. An informal language committee then appeared spontaneously and communicated among themselves and with the designer entirely electronically. The discussions of the committee grew to be hundreds of thousands of lines, and these and the similar quantity of mail from the users were all kept for later review.
As time passed, it became clear that changes in the language were necessary. Using the network, the designer could interactively explain and discuss the changes that were required, some of which were incompatible with the then-current version of the language. The decision to make an incompatible change was never taken lightly, but-because changes could be made relatively easily and explained to users in detail-the language was able to evolve much further than would have been the case if upward compatibility only were considered. Several other important concepts guided the process of enhancing the language.
RossPatterson (talk) 22:47, 10 June 2014 (UTC)
- It's a wiki, just add the info where it fits to the article, I think I could add a TRL reference, or just use the link shown above, or a link to this document archived on Mike's web site. VX-REXX was 15 (?) years later, that's something different. –Be..anyone (talk) 14:32, 13 January 2015 (UTC)
Strange remark
[edit]To me 'able to fully recover following a fatal error' is contradictory: if a full recovery is possible then the error was not fatal. — Preceding unsigned comment added by 86.185.216.95 (talk) 21:30, 4 November 2014 (UTC)
- It seems clear in context that here fatal means that it would terminated execution if not intercepted. If you believe that it is clearer, you could change it to following an otherwise fatal error, but I believe that it is clear as is. Shmuel (Seymour J.) Metz Username:Chatul (talk) 15:47, 6 November 2014 (UTC)
- Ten years later... I agree. It's nonsense to talk about recovering from a fatal error. Fatal error has a (generally accepted) meaning: an error from which there is no recovering! I plan to change to "... an otherwise fatal error" Stevebroshar (talk) 18:26, 12 January 2025 (UTC)
Missing key concepts
[edit]It is difficult to appreciate the flavor of Rexx as a scripting language without an understanding of the Rexx variable pool and the environment[1], especially the definition of function packages related to a particular environment. Shmuel (Seymour J.) Metz Username:Chatul (talk) 17:41, 23 February 2015 (UTC)
- ^ Not related to the Unix environment
- References and notes on talk pages are gross.
- REXX is dead, only very old folks like you and me recall what it was and still use it, everybody else uses Python or Lua.
- IIRC SHVENV is no official part of the language, maybe the stack would come first as missing concept.
- But when you add this, that, or both it's of course your decision, one of the few nice features on a wiki.
- –Be..anyone (talk) 05:12, 24 February 2015 (UTC)
- (Restored my comment as it was, adding tags below what your replies were about: Feel free to remove that, but keep my list together, please. –Be..anyone (talk) 06:37, 25 February 2015 (UTC))
- ad 1
-
- You're entitled to your opinion; I find the information useful when present. Shmuel (Seymour J.) Metz Username:Chatul (talk) 23:30, 24 February 2015 (UTC)
- ad 2
-
- The corpse is under active development. Shmuel (Seymour J.) Metz Username:Chatul (talk) 23:30, 24 February 2015 (UTC)
- ad 3
-
- From ANSI® X3J18-199X American National Standard for Information Systems – Programming Language REXX
Shmuel (Seymour J.) Metz Username:Chatul (talk) 23:30, 24 February 2015 (UTC)5.13 Variable pool
The variable pool interface consists of functions which the configuration shall provide to manipulate the variables and to obtain some characteristics of a REXX program.These functions can be called from programs not written in REXX — commands and external routines invoked from a REXX program, or traps invoked from the language processor.
- It's a wiki, as long as it passes WP:42 with a reference just do what you like. Claiming to speak for be..anyone: 2A03:2267:0:0:452A:FA00:6D62:CEE8 (talk) 11:42, 10 January 2017 (UTC)
File extionsions - types
[edit]The term file extension is problematical
- Rex is based on the older, cognate, concept of file type, used in, e.g. CMS, TSO.
- Rex also uses file types to identify Rex macros in Rex-aware applications, e.g., XEDIT. Note that this usage carries over to PC-based operating systems, e.,g., PC-DOS, Linux.
Shmuel (Seymour J.) Metz Username:Chatul (talk) 17:06, 8 July 2015 (UTC)
- For the purposes of enwiki we just need a
.rex
=> REXX as noted on .rex, the fine print of "type" vs. "extension" should be handled elsewhere, it's no REXX-issue. PC DOS used.bat
for the scripts and.rx
for its REXXUTIL-subset, Regina also uses.rexx
and.cmd
, the latter is slightly confusing on Windows, ooRexx might know.orx
and certainly supports.rexg
(GUI) and.rexp
(CLI+pause), and I find these details while looking at thePATHEXT
environment value on my Windows box. –2A03:2267:0:0:452A:FA00:6D62:CEE8 (talk) 11:58, 10 January 2017 (UTC)
Degree of use?
[edit]A recent edit challenged the claim that Rexx is widely used. It is ubiquitous on IBM mainframes, and there are open source interpreters for the Intel world, so the claim is plausible. Does anybody have any hard data on the usage prevalence of, e.g., OOREXX, Regina, in *bsd, Linux or windows? Shmuel (Seymour J.) Metz Username:Chatul (talk) 23:31, 6 February 2017 (UTC)
- From 2005 " Rexx's worldwide user community numbers in the hundreds of thousands" [1] Peter Flass (talk) 03:22, 7 February 2017 (UTC)
Appropriate chronology for citations?
[edit]@Polluks: A recent edit added a citation[1] to "VM/SP R3" that is for VM/ESA V2 R4.0. Wouldn't it be more appropriate to cite either the manual for the most recent[2] z/VM version or for the original[3] VM/SP R3 version? Should "TSO/E V2" also have a citation?[4] Also, do the citations belong in the infobox or should they be in the article proper? -- Shmuel (Seymour J.) Metz Username:Chatul (talk) 11:24, 26 May 2023 (UTC)
- Indeed. Polluks ★ 16:47, 28 May 2023 (UTC)
- @Polluks: Move citations out of infobox, use citations for original releases, or both? -- Shmuel (Seymour J.) Metz Username:Chatul (talk) 12:58, 29 May 2023 (UTC)
- I've update the infobox to use the oldest sources I could find for VM, TSO and SAA REXX. The most recent VM sources can be found at z/VM Library Overview.
References
- ^ http://www.manmrk.net/tutorials/rexx/rexxvmref.pdf
- ^ z/VM - 7.3 - REXX/VM Reference (PDF). z/VM Library Overview. 2022-08-31. SC24-6314-73. Retrieved May 26, 2023. -- from https://www.vm.ibm.com/library/index.html
- ^ Virtual Machine/ System Product - System Product - Interpreter Reference - Release 3 (PDF) (First ed.). September 1983. SC24-5239-0. Retrieved May 26, 2023.
- ^ TSO Extensions Version 2 - Procedures Language MVS/REXX Reference (PDF) (Fifth ed.). August 1991. SC28-1883-4. Retrieved May 26, 2023.
promotional edits for RexxUtil
[edit]Using "best known", etc., is promotional editing rather than following the Wikipedia guidelines WP:NPOV TEDickey (talk) 10:13, 15 October 2023 (UTC)
- I don't agree that it is promotional, but I also don't believe that popularity ratings of packages or language features, even if cited, are helpful in general, so unless there is some reason that the reader would care ... -- Shmuel (Seymour J.) Metz Username:Chatul (talk) 15:35, 16 October 2023 (UTC)
- "Best known" may not be promotional, but it is subjective, disputable, opinion ... which I think is what WP guidelines mean by point of view. I often remove such language but if I leave it in I add wiggle phrases like some contend or think or arguably ... Stevebroshar (talk) 10:41, 14 January 2025 (UTC)
RexxInfo external link removed by user Tedicky
[edit]@Tedicky I do not agree that adding an external link to rexxinf.org violates anything in WP:EL. I think a referral to a wikipedia rule alone does not sufficiently justify a revert of my addition. The linked to website is an important resource for any Rexx user; more so, for example, than the link to OpenHub above it. Please revert your revert. René Vincent Jansen (talk) 11:11, 21 April 2024 (UTC)
Ok, looking at it now, I agree. René Vincent Jansen (talk) 10:14, 22 April 2024 (UTC)
A programming language that can be interpreted or compiled
[edit]WRT "is a programming language that can be interpreted or compiled." Adds no value. All languages can be interpreted or compiled! A language defines syntax and semantics; not how the source code gets translated into a runnable form. Some languages are typically compiled (C++) and some are typically interpreted (Python) but C++ is not inherently characterized as being compiled nor is Python inherently interpreted. We could write a compiler for python and an interpreter for C++. That no one has is interesting but does not change the nature of the languages. Some languages are typically compiled to byte code (c#, java). But is it really compilation if it's not to machine code? IDK. What about a translator that converts Ada to C++? Is that a compiler? IDK. Thing is, it doesn't matter. Languages (just) specify syntax and semantics. Translators allow a language to be useful. Stevebroshar (talk) 18:53, 12 January 2025 (UTC)
Typeless? or no?
[edit]WRT "Variables are typeless ... Thus a variable's type can vary with its use in the program" is contradictory. Either they have type or not. Some languages provide automatic typing. Like if you assign like "v=3" then it's a number, but if you assign like "s='asdf'" then it's a string. Is Rexx like that? Or are all variables typeless? or are they strings? Stevebroshar (talk) 12:40, 14 January 2025 (UTC)
Notes
[edit]I did convert some info formatted as notes into normal body text. IMO notes should only be used in very rare cases. Normally, they make the info harder to read and harder to maintain. Further, if the info is not important enough to be in the body of the text, then it's probably not important enough to be in the article at all (even as a note). If the reason for using a note is bc organizing information is challenging; hard to make it flow/readable, then the solution is to figure out how to write it so the info does flow. It's a writing thing. Stevebroshar (talk) 14:30, 14 January 2025 (UTC)
Clarification of EXEC versus EXEC2
[edit]In z/VM, a script name foo EXEC bar[a] may be in one of three different languages, EXEC,[b] EXEC 2[c] or REXX.[d]
If the first line contains a REXX comment, then the script is REXX.[1]
If the first line is an &TRACE statement then the script is EXEC2.[2]
Otherwise the script is EXEC.
How much of this, if any, belongs in the article? -- Shmuel (Seymour J.) Metz Username:Chatul (talk) 17:17, 14 January 2025 (UTC)
- Good question. Without citation it appears to be OR, but if it's correct I think we let someone else deal with citation. I trust that you know what you are saying ;o) But, my wife tells me I'm overly trusting. So there's that.
- I think the detail is good and relevant. But, please avoid notes. They make info harder to read and to maintain. ... I don't agree with everything I learned in college, but I do think my writing professor was right about this point of style: If it's not important enough to include in the body of the text, it's probably not important enough to include as a note. Either put the info in the body of the text or drop it.
- Going further, this article has lots of good info in it. But, I edited it extensively since it was poorly written. It seemed to target folks that already know the topic; or at least skilled programmers. I firmly believe that a WP article can have great content and be written well, that technical info is hard to write about, that all writing is hard. So, good luck. You can write about a highly technical topic in a way that the general public can consume. Stevebroshar (talk) 13:08, 15 January 2025 (UTC)
Notes
References
- ^ "The CMS EXEC Processor - Invoking EXECs" (PDF). Virtual Machine/System Product - CMS User's Guide - Release 5 (PDF) (Fifth ed.). December 1986. p. 224. SC19-6210-4. Retrieved January 13, 2025.
When an EXEC file is invoked, CMS examines the first statement of the EXEC file to determine which EXEC processor must handle it. If the first line contains /* a comment * /, then the System Product Interpreter is called. If the first statement of the EXEC is &TRACE, CMS calls the EXEC 2 processor to handle it. If the first statement is not &TRACE or /* a comment */, CMS calls the EXEC processor to handle it.
- ^ "Appendix C Exec 2 in CMS - Identifying EXEC 2 Files" (PDF). IBM Virtual Machine/System Product: - EXEC 2 Reference - Program Number 5664-167 - Release 2 (PDF) (Second ed.). April 1982. p. 56. SC24-5219-1. Retrieved January 13, 2025.
Since both CMS EXEC and EXEC 2 files are called in the same way, CMS examines the first statement of the EXEC 2 file to determine which EXEC interpreter must handle it. If the first statement of the EXEC file is &TRACE, CMS calls the EXEC 2 interpreter to handle it. If the first statement is not &TRACE, CMS calls the CMS EXEC interpreter o handle it.
Types of statement
[edit]When new content is added to an article I ask myself: is this a valuable addition? ... I wasn't wondering how many types of statements rexx has, and I don't think knowing there are three is interesting. That is my opinion of course.
I do wonder whether this section is OR. Are there really three according to the language? Can we find a citation?
But... if we are going to add this, I'd say that each needs an example (even though examples are OR). Saying that a language supports assignment statement without an example assumes the reader knows that an assignment statement looks like. You know, I know, but does the non-programmer? the high school student? WP is not only for programmers.
Further, please limit use of comments in code examples. I'd say that is a programmer talking to a programmer. Minimize code! If you need to note something, put that in the text instead of a code comment. Stevebroshar (talk) 13:22, 15 January 2025 (UTC)
- I can certainly find a citation, but if anybody knows of a secondary source that would be better, at least in the wiki context. Should the citation include
|quote=
[1]? - Are you suggesting an example of each type? -- Shmuel (Seymour J.) Metz Username:Chatul (talk) 14:31, 15 January 2025 (UTC)
References
- ^ Cowlishaw, Michael (1990). The REXX Language - A Practical Approach to Programming (Second ed.). Prentice Hall. p. 31. ISBN 0137806515. LCCN 89071130.
An instruction consists of one or more clauses that describe some course of action to be taken by the language processor. Instructions may be either Assignments, Keyword Instructions, or Commands:
Case of keywords
[edit]I changed many of the language keywords that were in upper case to lower. Before my change, it was a mixed bag; many upper and many lower. I was trying to apply some consistency. I thought it odd that they were lower case in the example code (somewhat consistently) but upper case elsewhere (sometimes). But, some are still upper after my changes. I left NOP and the conditions as upper ... since I lacked confidence that changing them was a good idea. I think I made a good change and I think maybe the rest should be lower cased to match.
FWIW, I think maybe the keywords were in upper case to highlight them for the rest of the text. This might have been a common style a long time ago that has hung on for this context since it comes from along time ago. But, with markup (<code>) we can highlight without resorting to upper case. Stevebroshar (talk) 13:34, 15 January 2025 (UTC)
- I lowercased nop and the conditions. Stevebroshar (talk) 13:56, 15 January 2025 (UTC)
No reserved keywords?
[edit]WRT "No reserved keywords" Seems that it has lots of them: do, end, while, until, index, forever, if, then, else...
Or can you define a variable with any of these words? If so, that should be noted (since it seems important and a horrible idea for a language!) Stevebroshar (talk) 13:55, 15 January 2025 (UTC)
What does numeric do?
[edit]The numeric section currently just shows examples. But I don't know what the examples tell me. What does numeric do? Stevebroshar (talk) 14:07, 15 January 2025 (UTC)
Organization
[edit]Most of the material in § Syntax relates to semantics rather than to syntax. I propose something like
- Syntax
- Clauses
- Null clause
- Labels
- Instructions
- Assignments
- Keyword Instructions
- Commands:
- Clauses
- Assignments and variables
- Expressions
- Assignment clauses
- Keyword instruction clauses
- Commands to external environments
- Address instruction
- Command clauses
The actual headings should match the terms in the documentation adjusted to avoid duplicate anchors.
Is there guidance on synthetic examples versus exaamples copied from sources, to what extent fair uses allows copying examples, and how to properly attribute copied examples? -- Shmuel (Seymour J.) Metz Username:Chatul (talk) 15:01, 15 January 2025 (UTC)
- C-Class Computing articles
- Low-importance Computing articles
- C-Class software articles
- Low-importance software articles
- C-Class software articles of Low-importance
- All Software articles
- C-Class Free and open-source software articles
- Low-importance Free and open-source software articles
- C-Class Free and open-source software articles of Low-importance
- All Free and open-source software articles
- All Computing articles