Tips and Techniques: C Language Procedures

RPG
Typography
  • Smaller Small Medium Big Bigger
  • Default Helvetica Segoe Georgia Times

It is relatively easy to take advantage of some of the useful procedures provided to you for free. The procedures I'm talking about are the routines in the C language runtime library available to RPG IV programmers.

There are only two things you need to do to call any C language procedure.

1. Specify BNDDIR('QC2LE') on the header specification of the source member that will be calling the C language procedure.

2. Prototype the C language procedure.

The more difficult part is, of course, correctly prototyping the procedure. To illustrate how this is done, I've prototyped and illustrated two C language procedures for you.

The first is atoll(). This is the ASCII to long, long procedure. The term "long, long" is the C language's way of saying an 8-byte binary value (20I0 in RPG IV-speak). The "ASCII" isn't really ASCII, but rather character. The procedure converts a numeric value that happens to be stored in a character variable to a numeric value.

While this capability is built into RPG IV in OS/400 V5R2 in the %DEC and %INT built-in functions, few people are currently running that release.

Below is the RPG IV prototype needed to call the atoll() procedure. Simply cut/paste this code into your RPG source member, and you have access to its functionality. It works on all releases of OS/400 V3R7 and later.

D atoll           PR            20I 0 ExtProc('atoll')
D  szCharIn                       *   Value Options(*STRING)

To use this procedure, just specify it on an eval statement, as illustrated below:

H BNDDIR('QC2LE')

D szPastDue       S             15A   inz('65')
D nDaysOverDue                   5P 0
C                   eval      nDaysOverDue = atoll(szPastDue)

The downside to this procedure is that it only works with whole numbers. Decimal values aren't supported. Note that this procedure works with up-to-19-digit numbers.

The second C language procedure that is nice to have access to is the system() procedure. This procedure essentially replaces QCMDEXC in that it runs OS/400 CL commands. But unlike QCMDEXC, system() does not require you to know the length of the command string being passed to it. It figures that out on its own, making for much nicer syntax.

Below is the RPG IV prototype needed to call the system() procedure. Simply cut/paste this code into your RPG source member, and you have access to its functionality. It works on all releases of OS/400 V3R7 and later.

D system          PR            10I 0 ExtProc( 'system' )
D  szCmd                          *   Value Options( *String )

The system() is used by calling it with the CALLP opcode. For example:

H BNDDIR('QC2LE')

C                   callp     system('ADDLIBLE TOOLKIT')

You can also call it with the eval opcode, as follows:

H BNDDIR('QC2LE')

D nRtnCode        S             10I 0
C                   eval      nRtnCode = system('ADDLIBLE TOOLKIT')

When eval is used, the system() procedure returns a return code that can be tested for a value of something other than zero. If it is not zero, an error occurred. To make it compatible with OS/400 errors, IBM also provides an exported field for you to view the CPF error message. To access this field, declare it as an import value, as follows:

H BNDDIR('QC2LE')

D CPFMSGID        S              7A   Import'_EXCP_MSGID' )

Now, the field CPFMSGID contains the CPF message ID (if any) that is produced when an error is generated by the command processed by the system() function.

Bob Cozzi has been programming in RPG since 1978. Since then, he has written many articles and several books, including The Modern RPG Language --the most widely used RPG reference manual in the world. Bob is also a very popular speaker at industry events such as RPG World and is the author of his own Web site and of the RPG ToolKit, an add-on library for RPG IV programmers.

BOB COZZI

Bob Cozzi is a programmer/consultant, writer/author, and software developer. His popular RPG xTools add-on subprocedure library for RPG IV is fast becoming a standard with RPG developers. His book The Modern RPG Language has been the most widely used RPG programming book for more than a decade. He, along with others, speaks at and produces the highly popular RPG World conference for RPG programmers.


MC Press books written by Robert Cozzi available now on the MC Press Bookstore.

RPG TnT RPG TnT
Get this jam-packed resource of quick, easy-to-implement RPG tips!
List Price $65.00

Now On Sale

The Modern RPG IV Language The Modern RPG IV Language
Cozzi on everything RPG! What more could you want?
List Price $99.95

Now On Sale

BLOG COMMENTS POWERED BY DISQUS

LATEST COMMENTS

Support MC Press Online

$

Book Reviews

Resource Center

  •  

  • LANSA Business users want new applications now. Market and regulatory pressures require faster application updates and delivery into production. Your IBM i developers may be approaching retirement, and you see no sure way to fill their positions with experienced developers. In addition, you may be caught between maintaining your existing applications and the uncertainty of moving to something new.

  • The MC Resource Centers bring you the widest selection of white papers, trial software, and on-demand webcasts for you to choose from. >> Review the list of White Papers, Trial Software or On-Demand Webcast at the MC Press Resource Center. >> Add the items to yru Cart and complet he checkout process and submit

  • SB Profound WC 5536Join us for this hour-long webcast that will explore:

  • Fortra IT managers hoping to find new IBM i talent are discovering that the pool of experienced RPG programmers and operators or administrators with intimate knowledge of the operating system and the applications that run on it is small. This begs the question: How will you manage the platform that supports such a big part of your business? This guide offers strategies and software suggestions to help you plan IT staffing and resources and smooth the transition after your AS/400 talent retires. Read on to learn: