I've recently participated in a number of discussions that appear on various forums discussing RPG, its future, and value. Frequently these discussions are led by highly skilled professional programmers who utilize the latest features and facilities of RPG and write good structured modular code leveraging procedures, service programs and advanced features of ILE.
I absolutely agree that the most current version of the RPG language has the capabilities of being a superb procedural language and can offer the best structure and results that one could expect from a procedural language.
After thinking about this and looking the realities of most IBM i shops, the simple reality is that most shops do not have programmers of the quality of the folks that write these arguments favoring RPG. In a weird tribute to RPG, it is a language that can be learned, used, and implemented by people with very little training and a virtually no background in computers, technology, or systems.
In fact the vast majority of RPG programmers were blue collar workers without college degrees or training who learned RPG in in-house IBM sponsored training classes, Junior college courses, or 3rd party taught classes.
The vast majority of programmers have never written an RPG program from scratch (i.e. an empty SEU or RDp file) but rather copy and modify existing programs, sample programs obtained from IBM redbooks,or articles in various books, magazines, and publications. Few of these sample programs were examples of good code.
Over the years (and many of you have programs that were originally written 40 to 50 years ago and modified numerous times over the years written by people with all sorts of skills.
Cleaning or replacing this code base is the challenge faced by most IBM i customers. Some vendors including IBM advocate code conversion to EGL (enterprise generation language) or Java. There are many vendors who offer conversion to other language including various Windows technologies.
Straight conversion can cost as much as $1 per line of code resulting in project prices of several million dollars. Conversion projects are extremely risky as the vendor will convert your code from RPG to another language, but they are not responsible for testing or insuring that the new language based system still works and performs well.
Most companies have hundreds of thousands of lines of redundant code, code that is never executed, or should otherwise be cleaned up and improved before any conversion is undertaken.
Some vendors (including IBM) advocate using their conversion tools to convert 5250 green screen applications to web based applications. They argue that you can enhance the web presentation after the conversion.
Vendors like IBM or the many others have superbly skilled programmers and architects. They have no experience with corporate systems built and modified over 40 to 50 years and really have no idea what a company's system portfolio contains. They would be shocked and horrified at that 12,000 line monster that drives one of your critical business applications with the User Interface, business rules, and database access as well as control logic all embedded somewhere in the beast (along with commented out code from previous generations and code that can never be executed).
I recommend use of tools like Databorough's X-Analysis along with a rigorous methodology that mandates restructuring and modernization of each program as current projects require the program to be modified. I also advocate a rigorous program of peer review carefully organized to insure that your very best programmers are reviewing others code.
If you don't want to invest in X-Analysis, then use Hawkeye or at a minimum use DSPPGMREF to an outfile and write some programs to produce reports on the structure of your systems.
Once again, it is only a matter of time until IBM drops support for IBM i and therefore RPG (which only runs on the IBM i operating system). You have time to modernize and replace your RPG based systems but you need to start now. When IBM does drop support for IBM i they will generally support it for 3 years after they announce that the product is discontinued. Even then you can still run your systems and tools as long as you don't need to upgrade your machine or operating system.
The key is to realize that IBM i and RPG will eventually be withdrawn and support discontinued by IBM. They are offering their own tools to convert to Java and modernize now. You need to take the path that makes most sense for you, but you need to move on this.
No comments:
Post a Comment