× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



Use copybooks. 

Look at the testbed code. We use standard names for the QMHSNDPM parameters
defined in a copybook. We call the API by including the approprate copybook
in line, then you have the correct procedure, and within a few statements
the correct statement sent with the message, all with one line of code in
the source "/Include QRpgCbSrc,CQMhSndPm".

>From a previous email on a user condition handler.

These are the copybooks:
http://code.midrange.com/index.php?id=0c09a304c2 DQUSEC
http://code.midrange.com/index.php?id=a40b9b3f86 DQMHRCVPM
http://code.midrange.com/index.php?id=1b5d8cb4e1 DQMHSNDPM
http://code.midrange.com/index.php?id=a9565df204 DUSERCH
http://code.midrange.com/index.php?id=bd240da5b8 ZQMHRCVPM
http://code.midrange.com/index.php?id=31cc85e3a2 ZQMHSNDPM
http://code.midrange.com/index.php?id=2898ff8b5e ZQUSEC
http://code.midrange.com/index.php?id=b8c579c977 ZUSERCH


This is the user condition handler code
http://code.midrange.com/index.php?id=867b3820e8 PVRM999900

This is the example procedure.
http://code.midrange.com/index.php?id=02310231c4 TESTBED

Duane Christen


-----Original Message-----
From: Hewitt, Rory [mailto:rory.hewitt@xxxxxx]
Sent: Wednesday, July 27, 2005 6:30 PM
To: rpg400-l@xxxxxxxxxxxx
Subject: Trials and tribulations of QMHSNDPM (Was: No Subroutines...)


John, Bob, et.al,

>> And yes.. yes... I understand that QMHSNDPM can be wrapped in a
>> sub-procedure. I've done it and have one in my toolkit. But I don't use
it
>> often because in most cases I want the message to contain the correct
>> originating procedure/module name. As soon as you wrap QMHSNDPM in a
service
>> pgm subprocedure, you lose that information.


What's the problem with wrapping QMHSNDPM in a procedure which takes the
name of the current procedure (and possibly a callstack level above it) as
parameters, and using those to send the message.

The module and owning program/srvpgm name can be retrieved from the PSDS
(assuming you've coded it in your module) and that's all you really need. If
you haven't coded it in your module, here is an example of mine that Scott
put in his newsletter in January:

http://code.midrange.com/index.php?id=9c259a573f

The only downside is that there is no easy way to retrieve the name of the
current procedure from within a procedure. I tend to create a constant in
each procedure (always called THISPROC) which contains the name of the
current procedure. Anyone got a better way to retrieve the name of the
current procedure ,aside from having a SUBROUTINE to call QMHSNDPM/QMHRCVPM
to get it using one of the more esoteric formats)?

This is my SndPgmMsg() wrapper procedure for QMHSNDPM. Call it with e.g.:

Eval rc = sndpgmmsg( 'CPF9999' : THISPROC : 2 )

http://code.midrange.com/index.php?id=931ee5ee06


Rory




NOTICE: This electronic mail transmission may contain confidential
information and is intended only for the person(s) named.  Any use, copying
or disclosure by any other person is strictly prohibited. If you have
received this transmission in error, please notify the sender via e-mail.




As an Amazon Associate we earn from qualifying purchases.

This thread ...


Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.