• The Four Hundred
  • Subscribe
  • Media Kit
  • Contributors
  • About Us
  • Contact
Menu
  • The Four Hundred
  • Subscribe
  • Media Kit
  • Contributors
  • About Us
  • Contact
  • String Parameters of Various Lengths

    May 29, 2002 Timothy Prickett Morgan

    Hey, Ted:

    I have an RPG IV subprocedure that I call from several different programs. I use what I call the QCMDEXC method to pass a character string to it. That is, I pass two parameters–the character string and the length of the character string. I would like to eliminate the second parameter.

    ASC

    The subprocedure would have to determine the length of the character string that is passed to it. Is that possible?

    — Karen

    Yes, it’s possible. Your subprocedure needs the operational descriptor of the parameter. Here’s what you need to do.

    Add the OPDESC keyword to the parameter definition in the prototype, as follows:

    D MyProc          PR                  Opdesc                  
    D   String                   32767    Const Options(*Varsize)
    

    I recommend you put the prototype in a source member of its own in a source physical file for copybooks. In this example, I’ll call the subprocedure MYPROC and assume prototypes are in a file called COPYSRC.

    The subprocedure must call the CEEDOD API to retrieve the operational descriptor. Here’s the prototype for CEEDOD:

    * Retrieve Operational Descriptors API              
    D CEEDOD          PR                                 
    D ParmNum                       10I 0 Const          
    D DescType                      10I 0                
    D DataType                      10I 0                
    D DescInfo1                     10I 0                
    D DescInfo2                     10I 0                
    D DataLen                       10I 0                
    D Feedback                      12A   Options(*Omit) 
    

    Here are the essentials of the subprocedure:

    H nomain                                                      
                                                                  
     /copy copysrc,myproc                                         
     /copy copysrc,ceedod                                         
                                                                  
    P MyProc          B                   Export                  
     * Procedure Interface                                        
    D                 PI                  Opdesc                  
    D   String                   32767    Const Options(*Varsize) 
                                                                  
     * Variables for the CEEDOD API                               
    D DescType        s             10I 0                         
    D DataType        s             10I 0                         
    D DescInfo1       s             10I 0                         
    D DescInfo2       s             10I 0                         
    D DataLen         s             10I 0                         
                                                                  
     * Retrieve the length of the string parameter                
    C                   Callp     CEEDOD(1: DescType:        
    C                                DataType : DescInfo1:   
    C                                DescInfo2 : DataLen :   
    C                                *OMIT)                  
                                                             
     * DataLen now contains the length of the input string   
                                                             
     * Do whatever needs to be done                          
                                                             
    C                   Return                               
    P                 e                                      
    

    The first parameter of CEEDOD is the number of the positional parameter whose descriptor is to be retrieved. In this example, the constant 1 indicates that I want the operational descriptor of the first parameter.

    The length of the string variable is returned in binary format in the sixth parameter (DataLen).

    — Ted

    Sponsored By
    ADVANCED SYSTEMS CONCEPTS

    SEQUEL meets all your iSeries and AS/400 data access needs in a single, integrated solution:

    • Windows, Web or host user interfaces

  • Convert AS/400 data into PC file formats
  • E-mail or FTP query results, reports and spool files
  • Run-time prompted queries and reports for end users
  • IF-THEN-ELSE logic in queries and reports
  • Report, form and label formatting second to none
  • Easily convert date fields, character-to-numeric, numeric-to-character and other data manipulation
  • SORT or JOIN using a calculated field
  • Quick summarization of data with Tabling function
  • Run multiple SEQUEL requests as one with the SEQUEL Scripting function
  • OLAP Business Intelligence at a fraction of the cost of comparable solutions
  • Take 6 minutes to
    view a SEQUEL ViewPoint ScreenCam movie to see how simple Windows-based
    AS/400 and iSeries data access can be! In just a few short minutes, you
    can find out ways to make your job easier and improve data access throughout
    your organization. Download
    the ViewPoint movie here
    .

    For more information or a FREE trial of SEQUEL,
    call 847/605-1311 or visit Advanced Systems Concepts .

    Share this:

    • Reddit
    • Facebook
    • LinkedIn
    • Twitter
    • Email

    Tags: Tags: mgo_rc, Volume 2, Number 41 -- May 29, 2002

    Sponsored by
    ARCAD Software

    Unlock Application Knowledge with DISCOVER: From Code to Data Lineage

    In today’s fast-paced IT landscape, organizations face a critical challenge: understanding the complexity of their existing applications while preparing for modernization. DISCOVER addresses this challenge by providing a powerful, AI-assisted knowledge base that makes application intelligence accessible to everyone.

    Join Alan Ashley, Solution Architect at ARCAD Software, as he demonstrates how DISCOVER empowers teams to:

    • Visualize and explore application metadata, code, and dependencies
    • Gain clear insights into data lineage to maximize the value of enterprise data
    • Document and explain applications in natural language
    • Boost productivity and autonomy across technical and business users

    Whether you are modernizing legacy systems, leveraging data for new business initiatives, or simply striving to recover lost application knowledge, DISCOVER is your key to bridging the gap between code and actionable intelligence.

    Register Now!

    Share this:

    • Reddit
    • Facebook
    • LinkedIn
    • Twitter
    • Email

    TFH Flashback: Let Them Eat Gates, February 1995 A Better Way to Get Query/400 Definitions?

    Leave a Reply Cancel reply

MGO Volume: 2 Issue: 41

This Issue Sponsored By

    Table of Contents

    • Reader Feedback and Insights: Suggestions for a Temporary Library
    • String Parameters of Various Lengths
    • Prevent Someone Else from Peeking at Your Window 2000/XP System

    Content archive

    • The Four Hundred
    • Four Hundred Stuff
    • Four Hundred Guru

    Recent Posts

    • Stacking Up Power11 Entry Server Performance To Older Iron
    • Big Blue Boosts IBM i Support In Instana, Adds Tracing
    • It Is Time To Tell Us What You Are Thinking And Doing
    • IBM i PTF Guide, Volume 27, Number 40
    • The GenAI Boom Is Only Slightly Louder Than The Dot Com Boom
    • Talking Training And Skills With System i Developer
    • Maybe Stopgap Your Legacy Data Issues And Wait for What’s Next?
    • Stelo Touts Data Replication For IBM i In Azure Cloud
    • IBM i PTF Guide, Volume 27, Number 39
    • And Then There Were Two: Big Blue Withdraws IBM i 7.4

    Subscribe

    To get news from IT Jungle sent to your inbox every week, subscribe to our newsletter.

    Pages

    • About Us
    • Contact
    • Contributors
    • Four Hundred Monitor
    • IBM i PTF Guide
    • Media Kit
    • Subscribe

    Search

    Copyright © 2025 IT Jungle