Jump to content

REXX Tips & Tricks:Additional Software for REXX: Difference between revisions

From EDM2
Ak120 (talk | contribs)
No edit summary
Line 1: Line 1:
 
=Development & Debugging Tools=
'''Development & Debugging Tools'''
 
This sections contains information about additional usefuls tools for developing REXX programs.  
This sections contains information about additional usefuls tools for developing REXX programs.  


==Samples & skeletons==
==Samples & skeletons==
 
===Skeleton - a REXX program skeleton===
====Skeleton - a REXX program skeleton====
  Name [[SKELETON]]
  Name [[SKELETON]]
  Version 1.0, 03.08.1995
  Version 1.0, 03.08.1995
Line 27: Line 24:


==Preprocessors & Formating tools==
==Preprocessors & Formating tools==
 
===PPWIZARD - a pre-processor===
====PPWIZARD - a pre-processor====
:Name [[PPWizard|PPWIZARD]] - a generic pre-processor
Name [[PPWIZARD]] - a generic pre-processor
:Version 03.059
Version 03.059
:Author [[Dennis Bareis]]
Author [[Dennis Bareis]]
:(see EMail Addresses)
(see EMail Addresses)
:Distrib. Freeware
Distrib. Freeware
:Type EXE
Type EXE
:Price -
Price -
:Source The home page of the author
Source The home page of the author
:(see Internet - Web Pages)
(see Internet - Web Pages)
:Name: ppwos2.*
Name: ppwos2.*


Description from the author:
Description from the author:
Line 52: Line 48:
The html capability of this program is the basis of a series of e-Zine! articles (3 so far). Its use for rexx development would have to be at least as important. AWE def files are being developed using PPWIZARD macros and I generate PPWIZARD itself plus the extensive PPWIZARD INF and HTML documentation using PPWIZARD macros."  
The html capability of this program is the basis of a series of e-Zine! articles (3 so far). Its use for rexx development would have to be at least as important. AWE def files are being developed using PPWIZARD macros and I generate PPWIZARD itself plus the extensive PPWIZARD INF and HTML documentation using PPWIZARD macros."  


====MakeREXX - a pre-processor for REXX====
===MakeREXX - a pre-processor for REXX===
  Name [[MAKEREXX]] - pre-processor for REXX
  Name [[MAKEREXX]] - pre-processor for REXX
  Version 10/92
  Version 10/92
Line 68: Line 64:
"MAKEREXX is a utility that allows a REXX programmer to create a library of generic routines. Those routines are maintained in a subdirectory named 'XXX' and must have a file suffix of '.XXX'. The REXX code produced by MAKEREXX is placed in a subdirectory of '.CMD' and will have a suffix of either '.CMD' or '.ERX'. '.CMD' files are OS/2 REXX routines while the '.ERX' files are EPM editor REXX routines. Mainline REXX routines are maintained in a subdirectory named 'REX' and must have a file suffix of either '.REX' or '.EPM'. '.REX' routines will be expanded into '.CMD' routines while '.EPM' routines will be expanded into '.ERX' routines."  
"MAKEREXX is a utility that allows a REXX programmer to create a library of generic routines. Those routines are maintained in a subdirectory named 'XXX' and must have a file suffix of '.XXX'. The REXX code produced by MAKEREXX is placed in a subdirectory of '.CMD' and will have a suffix of either '.CMD' or '.ERX'. '.CMD' files are OS/2 REXX routines while the '.ERX' files are EPM editor REXX routines. Mainline REXX routines are maintained in a subdirectory named 'REX' and must have a file suffix of either '.REX' or '.EPM'. '.REX' routines will be expanded into '.CMD' routines while '.EPM' routines will be expanded into '.ERX' routines."  


====PrepProc - pre-processor for REXX====
===PrepProc - pre-processor for REXX===
  Name PREPPROC - pre-processor for REXX
  Name PREPPROC - pre-processor for REXX
  Version v2.00
  Version v2.00
Line 81: Line 77:
PrepProc is a simple pre-processor for REXX programs written in REXX. Supported directives in this version are #define, #ifdef, #ifndef and #include.  
PrepProc is a simple pre-processor for REXX programs written in REXX. Supported directives in this version are #define, #ifdef, #ifndef and #include.  


====RxPrep - REXX pre-processor====
===RxPrep - REXX pre-processor===
  Name RXPREP
  Name RXPREP
  Version 1.8, 24.11.1993
  Version 1.8, 24.11.1993
Line 95: Line 91:
RXPREP is only available for DAP members.  
RXPREP is only available for DAP members.  


====REXX Toolbox and pre-processor ($)====
===REXX Toolbox and pre-processor ($)===
  Name REXX Toolbox and Preprozessor
  Name REXX Toolbox and Preprozessor
  Version V1.1 1995
  Version V1.1 1995
Line 111: Line 107:
FASTREXX is mainly a pre-processor for REXX programs. Also included are various REXX procedures.  
FASTREXX is mainly a pre-processor for REXX programs. Also included are various REXX procedures.  


====RCF - REXX Code Formatter/2 ($)====
===RCF - REXX Code Formatter/2 ($)===
  Name RCF - REXX Code Formatter/2
  Name RCF - REXX Code Formatter/2
  Version Release 1.2.9
  Version Release 1.2.9
Line 133: Line 129:


Using this product, users may, for example:
Using this product, users may, for example:
* Define the indentation to be used in general plus the amount for:
* Define the indentation to be used in general plus the amount for:
**Program statements subordinate to DO and SELECT,
**Program statements subordinate to DO and SELECT,
**Statements that begin with THEN/ELSE, and
**Statements that begin with THEN/ELSE, and
**Continued statements.  
**Continued statements.  
 
* Specify whether:
Specify whether:
** Lines are to be split at semicolons,
* Lines are to be split at semicolons,
** Redundant spaces are to be removed from program statements,
* Redundant spaces are to be removed from program statements,
** New lines are to start before or after THEN/ELSE keywords, and
* New lines are to start before or after THEN/ELSE keywords, and
** END statements are to be indented to align with the corresponding DO/SELECT subordinate statements.  
* END statements are to be indented to align with the corresponding DO/SELECT subordinate statements.  
*Specify the formatting for:
 
** REXX keyword Instructions,
Specify the formatting for:
** REXX keywords besides those that begin a REXX keyword instruction,
* REXX keyword Instructions,
** Variables names,
* REXX keywords besides those that begin a REXX keyword instruction,
** Function names, and
* Variables names,
** Labels.
* Function names, and
* Labels.
* Define special formatting for selected function names.
* Define special formatting for selected function names.
* Check for duplicate labels and insure all labels start on a new line.
* Check for duplicate labels and insure all labels start on a new line.
Line 177: Line 170:
* Use of WARP 4 notebook format for configuration settings when using OS/2 WARP 4.
* Use of WARP 4 notebook format for configuration settings when using OS/2 WARP 4.


====RexxComm====
===RexxComm===
Name RexxComm - Formats comments in REXX
Name RexxComm - Formats comments in REXX program files
program files
Version 2000-07-16
Version 2000-07-16
Author Marcus C. de Geus
Author Marcus C. de Geus
(see EMail Addresses)
(see EMail Addresses)
Distrib. Freeware
Distrib. Freeware
Type REXX program
Type REXX program
Price -
Price -
Source Internet
Source Internet
Name: rexxcomm.*
Name: rexxcomm.*


This program formats comments in REXX program files according to a user-defined option and reports any uncommented program lines.  
This program formats comments in REXX program files according to a user-defined option and reports any uncommented program lines.  


==Syntax check programs==
==Syntax check programs==
 
===RXCALLLST - show the CALL structure of a program===
====RXCALLLST - show the CALL structure of a program====
  Name RXCALLST
  Name RXCALLST
  Version 05/01/2003
  Version 05/01/2003
Line 209: Line 200:
(see also Checkfunc - Function analysis of a REXX program and Codeanalizer)
(see also Checkfunc - Function analysis of a REXX program and Codeanalizer)


====Checkfunc - Function analysis of a REXX program====
===Checkfunc - Function analysis of a REXX program===
  Name CheckFunc
  Name CheckFunc
  Version 1.02
  Version 1.02
Line 234: Line 225:
(see also RXCALLLST - show the CALL structure of a program and Codeanalizer)   
(see also RXCALLLST - show the CALL structure of a program and Codeanalizer)   


====Codeanalizer====
===Codeanalizer===
  Name CheckFunc
  Name CheckFunc
  Version 1.02
  Version 1.02
Line 252: Line 243:


==Debugger==
==Debugger==
 
===RXD - Rexx Debugger===
====RXD - Rexx Debugger====
  Name RXD
  Name RXD
  Version V1.4
  Version V1.4
Line 269: Line 259:


=="Compiler" & Translator==
=="Compiler" & Translator==
 
===Rexx/Wrapper===
 
====Rexx/Wrapper====
  Name REXX/Wrapper
  Name REXX/Wrapper
  Version 1.4
  Version 1.4
Line 288: Line 276:


To use Rexx/Wrapper you need two extra bits of software:
To use Rexx/Wrapper you need two extra bits of software:
1) A supported Rexx interpreter
#A supported Rexx interpreter
2) A supported C compiler
#A supported C compiler


The Rexx interpreter that is linked with the executable must be capable of executing an "instore" Rexx macro via the SAA API.
The Rexx interpreter that is linked with the executable must be capable of executing an "instore" Rexx macro via the SAA API.
Line 307: Line 295:
see also RxCLS - a REXX 'compiler' ($), REXXCC - a REXX "compiler" and REXX2EXE a REXX "compiler"  
see also RxCLS - a REXX 'compiler' ($), REXXCC - a REXX "compiler" and REXX2EXE a REXX "compiler"  


====REXXCC - a REXX "compiler"====
===REXXCC - a REXX "compiler"===
  Name REXXCC - a REXX "compiler"
  Name REXXCC - a REXX "compiler"
  Version v3.22
  Version v3.22
Line 337: Line 325:
see also Rexx/Wrapper, RxCLS - a REXX 'compiler' ($) and REXX2EXE a REXX "compiler"  
see also Rexx/Wrapper, RxCLS - a REXX 'compiler' ($) and REXX2EXE a REXX "compiler"  


====RxCLS - a REXX 'compiler' ($)====
===RxCLS - a REXX 'compiler' ($)===
  Name RXCLS - a REXX 'compiler'
  Name RXCLS - a REXX 'compiler'
  (quotes added by /bs - see below)
  (quotes added by /bs - see below)
Line 365: Line 353:
see also Rexx/Wrapper, REXXCC - a REXX "compiler" and REXX2EXE a REXX "compiler"  
see also Rexx/Wrapper, REXXCC - a REXX "compiler" and REXX2EXE a REXX "compiler"  


====REXX2EXE - a REXX "compiler"====
===REXX2EXE - a REXX "compiler"===
  Name REXX2EXE - a REXX "compiler"
  Name REXX2EXE - a REXX "compiler"
  Version 98.349
  Version 98.349
Line 382: Line 370:
see also Rexx/Wrapper, RxCLS - a REXX 'compiler' ($) and REXXCC - a REXX "compiler"  
see also Rexx/Wrapper, RxCLS - a REXX 'compiler' ($) and REXXCC - a REXX "compiler"  


====Arc====
===Arc===
  Name ARC (Alexander's REXX Cruncher)
  Name ARC (Alexander's REXX Cruncher)
  Version 2.00
  Version 2.00
Line 395: Line 383:
This is a REXX program to "crunch" (remove all not necessary parts) REXX programs  
This is a REXX program to "crunch" (remove all not necessary parts) REXX programs  


====Rexx2Nrx====
===Rexx2Nrx===
  Name Rexx2Nrx - REXX to NetREXX converter
  Name Rexx2Nrx - REXX to NetREXX converter
  Version 2.23
  Version 2.23
Line 408: Line 396:


==EXE & DLL tools==
==EXE & DLL tools==
 
===ExeHdr===
====ExeHdr====
  Name ExeHdr
  Name ExeHdr
  Version -
  Version -
Line 418: Line 405:
  Source Internet
  Source Internet
  Name: EXEHDR.*
  Name: EXEHDR.*
  An ExeHdr tool is also included in
   
the OS/2 Developers Toolkit and in
An ExeHdr tool is also included in the OS/2 Developers Toolkit and in nearly all C/C++ Compiler packages.
nearly all C/C++ Compiler packages.


An ExeHdr-Tools shows the names of the functions exported by a DLL. This is useful to get the propper spellings for functions exported by a REXX DLL if the DLL was linked in a case-sensitive manner (see DLL loading failed).  
An ExeHdr-Tools shows the names of the functions exported by a DLL. This is useful to get the propper spellings for functions exported by a REXX DLL if the DLL was linked in a case-sensitive manner (see DLL loading failed).  


====PMDLL====
===PMDLL===
Description from the author:
Description from the author:


Line 433: Line 419:
There is also a command line tool named ckkdll32.exe from IBM for this purpose.
There is also a command line tool named ckkdll32.exe from IBM for this purpose.


====LX lite - a compressor for OS/2 executables====
===LX lite - a compressor for OS/2 executables===
  Name LX lite - a compressor for OS/2 executables
  Name LX lite - a compressor for OS/2 executables
  Version 1.3.2
  Version 1.3.2
Line 463: Line 449:
So, this is just an temporary workaround, you have better to reboot after doing all neccesary things on former locked files. The command-line format of unLock is much like lxLite's, except that it have much less options :-)"   
So, this is just an temporary workaround, you have better to reboot after doing all neccesary things on former locked files. The command-line format of unLock is much like lxLite's, except that it have much less options :-)"   


====lsof - list open files====
===lsof - list open files===
  Name lsof - list open files
  Name lsof - list open files
  Version 07/2000
  Version 07/2000
Line 477: Line 463:
You can also use the program psfiles.exe to get a list of open files (available in Warp 4 Fixpack 13) - but it's not as comfortable as lsof.  
You can also use the program psfiles.exe to get a list of open files (available in Warp 4 Fixpack 13) - but it's not as comfortable as lsof.  


====XWorkplace====
===XWorkplace===
  Name XWorkplace
  Name XWorkplace
  Version 1.0.0
  Version 1.0.0
  Author Ulrich Moeller
  Author [[Ulrich Möller|Ulrich Moeller]]
  (see EMail Addresses)
  (see EMail Addresses)
  Distrib. GPL (freeware)
  Distrib. GPL (freeware)
Line 495: Line 481:
XWorplace is a must have for OS/2 users and developers.  
XWorplace is a must have for OS/2 users and developers.  


====XRay - a PM window peeker====
===XRay - a PM window peeker===
  Name XRay - a window peeker
  Name XRay - a window peeker
  Version 1.0  
  Version 1.0  
Line 512: Line 498:
You can use this tool to get the IDs neccessary for the new setup string MENUITEMSELECTED in WARP 4.  
You can use this tool to get the IDs neccessary for the new setup string MENUITEMSELECTED in WARP 4.  


====PSPM====
===PSPM===
  Name psPM - Process Status Presentation Manager
  Name psPM - Process Status Presentation Manager
  Version v5.20
  Version v5.20
Line 527: Line 513:


PSPM (or a similar tool) is necessary if a program using VREXX crashes without calling VEXIT. In this case you must delete the invisible process created by VREXX manually before you can use VREXX in other REXX programs.  
PSPM (or a similar tool) is necessary if a program using VREXX crashes without calling VEXIT. In this case you must delete the invisible process created by VREXX manually before you can use VREXX in other REXX programs.  


==Misc. develop tools==
==Misc. develop tools==
 
===ConfigTool===
====ConfigTool====
  Name Configtool
  Name Configtool
  Version
  Version

Revision as of 10:54, 5 September 2016

Development & Debugging Tools

This sections contains information about additional usefuls tools for developing REXX programs.

Samples & skeletons

Skeleton - a REXX program skeleton

Name SKELETON
Version 1.0, 03.08.1995
Author Bob Rice
Empirical Heuristics
P.O. Box 189
West Hurley, NY 12491
(see EMail Addresses)
Distrib. Shareware, $0 fee
Type REXX programs
Price -
Source Internet
Name: SKELETON.*

Description from the author:

"Extremely simple to use, the REXX Skeleton provides: display or extraction of embedded help code, automatic external function registration, automatic initialization of useful "global" variables, automatic trapping of REXX execution time events and errors with dump file generation containing variables and queues, and debug assistance. Needs only the standard OS/2 REXX but has more function with REXXLIB. Great for beginning REXX programmers as well as more advanced programmers. This is Zero-cost Shareware uploaded by the author, Bob Rice."

Note: see also Template for a REXX program

Preprocessors & Formating tools

PPWIZARD - a pre-processor

Name PPWIZARD - a generic pre-processor
Version 03.059
Author Dennis Bareis
(see EMail Addresses)
Distrib. Freeware
Type EXE
Price -
Source The home page of the author
(see Internet - Web Pages)
Name: ppwos2.*

Description from the author:

"This is a generic processor (for any text files) with specific support built in for rexx and html files.

When used with the "/rexx" switch it will by default remove comments and pack rexx code and then perform a syntax check.

You have access to instructions such as #define, #evaluate, #include, #if and #ifdef. You can develop macros that take both optional and manditory parameters and the macros can conditionally generate output.

The program is extendable through rexx. Commands such as #if tests can be very complex, for example it would be relatively simple to compare environment variables or contents of files etc.

The html capability of this program is the basis of a series of e-Zine! articles (3 so far). Its use for rexx development would have to be at least as important. AWE def files are being developed using PPWIZARD macros and I generate PPWIZARD itself plus the extensive PPWIZARD INF and HTML documentation using PPWIZARD macros."

MakeREXX - a pre-processor for REXX

Name MAKEREXX - pre-processor for REXX
Version 10/92
Author Tony Thigpen
115 West York Court
Longwood, FL 32779
Distrib. Freeware
Type REXX program
Price -
Source Internet
Name: MAKEREXX.*

Description from the author:

"MAKEREXX is a utility that allows a REXX programmer to create a library of generic routines. Those routines are maintained in a subdirectory named 'XXX' and must have a file suffix of '.XXX'. The REXX code produced by MAKEREXX is placed in a subdirectory of '.CMD' and will have a suffix of either '.CMD' or '.ERX'. '.CMD' files are OS/2 REXX routines while the '.ERX' files are EPM editor REXX routines. Mainline REXX routines are maintained in a subdirectory named 'REX' and must have a file suffix of either '.REX' or '.EPM'. '.REX' routines will be expanded into '.CMD' routines while '.EPM' routines will be expanded into '.ERX' routines."

PrepProc - pre-processor for REXX

Name PREPPROC - pre-processor for REXX
Version v2.00
Author Hilbert Computing
Gary Murphy
Distrib. Freeware
Type REXX program
Price -
Source Internet
Name: PREPRC.*

PrepProc is a simple pre-processor for REXX programs written in REXX. Supported directives in this version are #define, #ifdef, #ifndef and #include.

RxPrep - REXX pre-processor

Name RXPREP
Version 1.8, 24.11.1993
Author Richard Moore
Distrib. Freeware, DAP Software
Type REXX program
Price -
Source Internet
Name: RxPREP.*

This is another pre-processor for REXX programs written in REXX.

RXPREP is only available for DAP members.

REXX Toolbox and pre-processor ($)

Name REXX Toolbox and Preprozessor
Version V1.1 1995
Author Joerg Burdorf
Im Leuters 12
53567 Asbach Germscheid
Germany
Distrib. Shareware
Type REXX DLL
Price 20,- DM
Source Internet
Name: FASTREXX.*
Note All docs are in German!

FASTREXX is mainly a pre-processor for REXX programs. Also included are various REXX procedures.

RCF - REXX Code Formatter/2 ($)

Name RCF - REXX Code Formatter/2
Version Release 1.2.9
Author RKE Consulting, Inc.
P.O. Box 11569
Spring, TX 77391-1569
USA
Distrib. Shareware
Type VisPro REXX Executable
Price $15
Source Internet
Name: rcf2102j.*

Description from the author:

REXX Code Formatter/2 Description

The REXX Code Formatter/2 (RCF/2) is an OS/2(*) REXX application written using VisPro/REXX(**) and VisPro/Reports(**). It is designed to allow a REXX programmer to format a program in a particular style, insuring that the format of each element of the REXX program conforms to that style.

Features of REXX Code Formatter/2

Using this product, users may, for example:

  • Define the indentation to be used in general plus the amount for:
    • Program statements subordinate to DO and SELECT,
    • Statements that begin with THEN/ELSE, and
    • Continued statements.
  • Specify whether:
    • Lines are to be split at semicolons,
    • Redundant spaces are to be removed from program statements,
    • New lines are to start before or after THEN/ELSE keywords, and
    • END statements are to be indented to align with the corresponding DO/SELECT subordinate statements.
  • Specify the formatting for:
    • REXX keyword Instructions,
    • REXX keywords besides those that begin a REXX keyword instruction,
    • Variables names,
    • Function names, and
    • Labels.
  • Define special formatting for selected function names.
  • Check for duplicate labels and insure all labels start on a new line.
  • Have RCF/2 create a file of label names as they appear in the program
  • so that all references to them in the program (and even other programs) will reflect this same format.
  • Align full-line, left-hand, and right-hand comments.
  • Generate a listing of the formatted program.

In addition, while RCF/2 is not a syntax-checker or code debugger, it does provide some assistance in program development. It can, for example:

  • Identify DO and SELECT instructions missing a corresponding END clause,
  • Flag comments that are not started but not closed, and
  • Highlight literal strings with a missing quote.

New features in Release 1.2.0 are:

  • A cross reference facility for labels, variables, and function names.
  • Optional formatting notes if undefined function names are found.
  • The ability to add "Commented line numbers" to statements.
  • Landscape printing formats.
  • Right-hand alignment of full-line comments with extension and truncation to allow for "boxing" of comments.
  • Specification of file name and directory for generated associated label files.
  • Maintenance of multiple generated associated label file data in a single file.
  • Separate formatting specification for the standard REXX built-in functions.
  • The specification of the file to be edited as a parameter at RCF invocation.
  • The extension of the allowable indentation values to be up to 999.
  • Placement of the print specification in a separate page to facilitate changing of printer specifications.
  • Use of WARP 4 notebook format for configuration settings when using OS/2 WARP 4.

RexxComm

Name RexxComm - Formats comments in REXX program files
Version 2000-07-16
Author Marcus C. de Geus
(see EMail Addresses)
Distrib. Freeware
Type REXX program
Price -
Source Internet
Name: rexxcomm.*

This program formats comments in REXX program files according to a user-defined option and reports any uncommented program lines.

Syntax check programs

RXCALLLST - show the CALL structure of a program

Name RXCALLST
Version 05/01/2003
Author Wilfried Eike
Distrib. Freeware
Type VisPro REXX EXE
Price -
Source Internet
Name: RXCALLST.*

RXCALLST is a tool to show the CALL structure of REXX programs.

RXCALLLST shows the call structure of a REXX program in a TOP-DOWN-view and a BOTTOM-UP view. It can also detect rescursive code and dead code.

(see also Checkfunc - Function analysis of a REXX program and Codeanalizer)

Checkfunc - Function analysis of a REXX program

Name CheckFunc
Version 1.02
Author Toby Thurston
(see EMail Addresses)
Distrib. Freeware
Type REXX CMD
Price -
Source Internet
Name: checkfunc102.*

Checkfunc is a handy routine to help you develop correct and portable REXX code. It contains a mini-parser for REXX that finds all the function calls in a program and lists them out for you to see. The output listing shows

  • BIFs Used
  • Internal functions
  • Duplicate (and therefore unreachable) labels
  • Rexxutil common functions
  • Rexxutil OS/2 only functions
  • Rexxutil Windows only functions
  • Rexxutil Version 2 functions
  • External functions
  • External commands

(see also RXCALLLST - show the CALL structure of a program and Codeanalizer)

Codeanalizer

Name CheckFunc
Version 1.02
Author Doug Rickman
Distrib. Freeware
Type REXX CMD
Price -
Source Internet
Name: codeanalyzer###.*
### is the version number, e.g. 005

Description from the author:

"CodeAnalyzer is a generic engine for analyzing and formatting REXX code. This is a tool for the REXX programmer who works with large complex programs."

(see also Checkfunc - Function analysis of a REXX program and RXCALLLST - show the CALL structure of a program)

Debugger

RXD - Rexx Debugger

Name RXD
Version V1.4
Author Patrick J. Mueller
IBM
Distrib. Freeware, IBM EWS
Type REXX Debugger (PM)
Price -
Source Internet
Name: RXD.*

RxD is a very useful debugger for OS/2 REXX programs. RxD supports Breakpoints, single stepping and watch variables. RxD is a PM program.

Note that RXD is an older 16-bit app and, according to the author, there may be some errors or unexpected conditions using it on 32-bit OS/2 (like WARP).

"Compiler" & Translator

Rexx/Wrapper

Name REXX/Wrapper
Version 1.4
Author Mark Hessling
(see EMail Addresses)
Distrib. GPL (GNU)
Type REXX cmd & more
Price -
Source Internet
Name: rxwrap14.*

Description from the author:

"Rexx/Wrapper is a tool that wraps a Rexx source file, or tokenised code into an executable program. The Rexx source code can be optionally compressed and encoded to ensure that the original Rexx code cannot be viewed (unless you have the original encryption key).

To use Rexx/Wrapper you need two extra bits of software:

  1. A supported Rexx interpreter
  2. A supported C compiler

The Rexx interpreter that is linked with the executable must be capable of executing an "instore" Rexx macro via the SAA API. The Rexx interpreter used to build the executable wrapper can be different to the interpreter used to run the executable program. If wrapping tokenised code, then the Rexx interpreter that creates the tokenised code, MUST be the same interpreter that runs the tokenised code.

All suppliers of Rexx interpreters provide access to their interpreter via a shared or dynamic library. This means that it is not possible to build a completely stand-alone executable; you will always have to include the shared or dynamic library with the executable built with Rexx/Wrapper.

There is one exception to this rule; Regina. Regina also provides a static library, which means you can link your program with Regina's static library, and you will get a completely stand-alone executable.

There is a catch however with using the Regina static library :-(. The Rexx program that you wrap, cannot dynamically load an external function package. This is because the Regina static library does not (and cannot) support the dynamic loading of external functions. External functions, by their very nature, require the presence of a dynamic or shared library to operate.

Rexx/Wrapper supports all C compilers that support ANSI prototypes. Rexx/Wrapper will not work with older K&R C Compilers.

For a list of the supported C compilers for the current platform, run rexxwrap.cmd with the '-help' switch and see the list below."

see also RxCLS - a REXX 'compiler' ($), REXXCC - a REXX "compiler" and REXX2EXE a REXX "compiler"

REXXCC - a REXX "compiler"

Name REXXCC - a REXX "compiler"
Version v3.22
Author Bernd Schemmer
Distrib. Freeware
Type "compiled" REXX
program
Price -
Source Internet
Name: RCnnn.*
where nnn is the
version number

REXXCC "compiles" an OS/2 REXX program by substituting the source code with any text. This is possible because the OS/2 REXX interpreter stores a tokenized copy of each executed REXX program in the EAs of the program. If you execute an OS/2 REXX program, the OS/2 REXX interpreter first checks, if the tokenized copy in the EAs is still valid and, if so, executes the tokenized copy and ignores the source code.

Beginning with version 3.00 REXXCC can also compress REXX programs (this means: delete all leading and trailing whitespaces, all linefeeds and all comments).

Beginning with version 3.10 REXXCC also contains a REXX program to unpack packed or compressed REXX files.

Beginning with version 3.20 REXXCC also contains a REXX program to use the macro space for creating token images of REXX programs.

REXXCC is a command line program. But there is also a PM front-end for REXXCC called REXXCC/2 in the archive. REXXCC/2 uses Rexx Dialog for the PM interface.

The current version of REXXCC is always available at Hobbes in the same library as RXT&T (see Distribution)

Note: The format of the token image for REXX programs is the same since OS/2 version 2.1. So you can use a REXX program "compiled" with REXXCC on any OS/2 version since 2.1. But: You can't use a "compiled" REXX program with the new Object-Oriented REXX (see also "Compiling" REXX programs).

see also Rexx/Wrapper, RxCLS - a REXX 'compiler' ($) and REXX2EXE a REXX "compiler"

RxCLS - a REXX 'compiler' ($)

Name RXCLS - a REXX 'compiler'
(quotes added by /bs - see below)
Version 1.0, 1/1996
Author Steven Higgins
41 Victoria Drive
Aston, PA 19014
USA
Distrib. Shareware
Type EXE
Price registered version: $10
Source Internet
Name: RXCLS.*

Description from the author:

"RXCLS is a shareware program which compiles a REXX programs into a stand alone executable. RXCLS is a 32bit program designed to run on OS/2* version 2.x or greater."

Well, the author did not say all: RXCLS does NOT compile REXX programs into machine readable code like other compilers. The only thing it does is: Create the token image of the REXX program and bind it with a little stub together to an EXE file. If called, the stub of the EXE calls the REXX interpreter to execute the included token image.

To verify this you may set the environment variable TRACE to ON and call an EXE 'compiled' by RXCLS.

But nevertheless RXCLS is fine done and useful if you want to hide your REXX source code. And this method does not have any compatibility problems through converting the REXX code, of course.

The advantage of the method used by RXCLS compared to my free REXX "compiler" REXXCC: It avoids the 64 K limit and you don't have problems with the EAs.

see also Rexx/Wrapper, REXXCC - a REXX "compiler" and REXX2EXE a REXX "compiler"

REXX2EXE - a REXX "compiler"

Name REXX2EXE - a REXX "compiler"
Version 98.349
Author Dennis Bareis
Distrib. Freeware
Type EXE
Price -
Source The home page of the author
(see Internet - Web Pages)
Name: REXX2EXE.*

Description from the author:

"This program will "compile" a rexx program in 2 main ways. It will tokenise the rexx (no 64K limit) or will simply wrap up the source (the default). The default action is to encrypt and compress the resultant image and attach it to an EXE stub. There are all sorts of options to control the stub, for example you can have a runtime DLL or standalone EXE. You can choose to have a compact EXE which will run in Warp onwards or a larger one which will also run in 2.0+. You can generate the stub as a PM program eliminating all the hassle of using 'RxMsgBox'."

see also Rexx/Wrapper, RxCLS - a REXX 'compiler' ($) and REXXCC - a REXX "compiler"

Arc

Name ARC (Alexander's REXX Cruncher)
Version 2.00
Author Alexander Mai
(see EMail Addresses)
Distrib. Freeware
Type REXX cmd
Price -
Source Internet
Name: arc.*

This is a REXX program to "crunch" (remove all not necessary parts) REXX programs

Rexx2Nrx

Name Rexx2Nrx - REXX to NetREXX converter
Version 2.23
Author Thomas Schneider
Distrib. Freeware
Type java program
Price -
Source Internet
Name: rexx2nrx.*

This program converts Classic REXX programs to NetRexx.

EXE & DLL tools

ExeHdr

Name ExeHdr
Version -
Author misc.
Distrib. -
Type EXE program
Price -
Source Internet
Name: EXEHDR.*

An ExeHdr tool is also included in the OS/2 Developers Toolkit and in nearly all C/C++ Compiler packages.

An ExeHdr-Tools shows the names of the functions exported by a DLL. This is useful to get the propper spellings for functions exported by a REXX DLL if the DLL was linked in a case-sensitive manner (see DLL loading failed).

PMDLL

Description from the author:

"PMDLL is an OS/2 presentation manager program that shows you the complete tree of DLLs loaded by an OS/2 executable file or by a DLL (both 16 and 32 bit formats are supported). Sometimes it's uncertain why a program won't start (correctly) or behaves strange when running. When this program is using DLLs one of the causes can be that DLLs can't be found or that DLLs are loaded from unexpected directories which contain an incorrect version of the DLL. PMDLL gives you an easy way to detect these kind of problems."

PMDLL is a very useful tool to detect the further DLLs needed by a REXX dll (see DLL loading failed).

There is also a command line tool named ckkdll32.exe from IBM for this purpose.

LX lite - a compressor for OS/2 executables

Name LX lite - a compressor for OS/2 executables
Version 1.3.2
Author Andrew Zabolotny
(see EMail Addresses)
Distrib. Freeware
Type EXE program
Price -
Source Internet
Name: LXLT132.*

This is a fantastic program to pack OS/2 executables in Linear Executable (LX) format. OS/2 uses the LX format for .EXE, .DLL, .PDR, .QPR, .DRV, .FON and .SYS files. Virtual Device Drivers (VDDs) for DOS sessions are also in LX format. You can even compress the OS/2 kernel (os2krnl)! LX compresses the files in the same way as LINK386 does. The decompression algorithm is part of the OS/2 WARP program loader. So files compressed with LX are "simple" OS/2 executables. There's no additional stub program necessary to uncompress the compressed files.

The only drawback of this tool:

You cannot execute compressed executables under OS/2 prior to WARP because the decompression code was first introduced in WARP. But that's no great problem because LxLite can also decompress compressed files again.

Conclusion:

LxLite is one of the most useful tools for OS/2 I've seen so far.

(see Using REXX if booted from diskette for one use of LxLite)

Another useful tool contained in this package is UNLOCK.EXE:

"unLock is a simple utility which allows to 'unlock' application executables which are currently in use. Normally when an executable is loaded by OS/2 its file is open with a deny-write sharing mode. This is done because LX format structure is designed not to swap out unused pages in executables each time when they aren't needed anymore, but rather to discard them. When a discarded page is needed OS/2 simply reads it again from the executable. However, there is still a way to replace executables 'on-the-fly' even if they are currently running. There is an so-called 'well-known-undocumented' function (which in fact means that it won't be neccesarily supported in future versions of OS/2) which allow to disable sharing protection on such files. Before doing that OS/2 reads entire executable in swap file, then page swapping is done as with usual memory. If you'll 'unlock' many running executables at the same time you can notice an increase in swap file size. So, this is just an temporary workaround, you have better to reboot after doing all neccesary things on former locked files. The command-line format of unLock is much like lxLite's, except that it have much less options :-)"

lsof - list open files

Name lsof - list open files
Version 07/2000
Author Shaun Tancheff
Distrib. Freeware (?)
Type EXE program (w/ source)
Price -
Source Internet
Name: lsof.*

You can use lsof to find out if your REXX program opens files without closing them.

You can also use the program psfiles.exe to get a list of open files (available in Warp 4 Fixpack 13) - but it's not as comfortable as lsof.

XWorkplace

Name XWorkplace
Version 1.0.0
Author Ulrich Moeller
(see EMail Addresses)
Distrib. GPL (freeware)
Type WPS Extension (DLL)
Price -
Source Internet
Name: xwp.n.m.r.*
where n is the major version; n is
the minor version and r is the revision
(see Internet - Web Pages)

XWorkplace (or its predecessor XFolder) is not only the best WPS enhancer for OS/2 - it's also a very good tool to examine the internals of the WPS.

XWorplace is a must have for OS/2 users and developers.

XRay - a PM window peeker

Name XRay - a window peeker
Version 1.0 
Author CodeSmith Software, RR 1, S-2, C-23
Fernie, BC,
Canada V0B 1M0
(see EMail Addresses)
Distrib. Freeware
Type EXE program (w/ source)
Price -
Source Internet
Name: XRAY.*

Xray is an utility to display window info of window under the mouse pointer.

You can use this tool to get the IDs neccessary for the new setup string MENUITEMSELECTED in WARP 4.

PSPM

Name psPM - Process Status Presentation Manager
Version v5.20
Author Seth A. Eilbott
Distrib. Freeware
Type PM program
Price -
Source Internet
Name: PSPM.*

Description from the author:

"PSPM graphically displays the status of all processes running in OS/2. PSPM allows you to display information about any process, including thread information, to terminate a process or an entire process tree, or to switch to a running process."

PSPM (or a similar tool) is necessary if a program using VREXX crashes without calling VEXIT. In this case you must delete the invisible process created by VREXX manually before you can use VREXX in other REXX programs.

Misc. develop tools

ConfigTool

Name Configtool
Version
Author Program: Goran Ivankovic
(see EMail Addresses)
Database: Klaus Staedtler
(see EMail Addresses)
Distrib. Freeware
Type Database/INF file
Price -
Source Internet
Name: cfgtool.*

ConfigTool is AFAIK the best database with various information about the CONFIG.SYS of OS/2. It includes also a tool to check and optimize the CONFIG.SYS.