|
Thanks. Yes batch jobs, different parameter list. Sure I can say what I am working on. A week or so ago someone wanted to know about Socket programs and some else wanted to know about calling a program from VB. I was interested in both of those so I started looking into it. I had a book (TCP something from midrange computing) with a good example of a sockets program and even how to use it with visual basic. But it requires you to write a second sockets program for every program you want to run. So If I want to get the serial number of the AS/400 I have to copy and paste into a program the socket logic then add the logic to get the serial number and pass it back. Then if some other time I want the description of the user profile, another copy and paste socket program. It get worse when you already have a program to do what you want on the AS/400 (say pass an item number in and get description, quantity on hand and quantity on order) that is called from an AS/400 program and now you want to call it from a PC program. Now you have to copy paste socket program to call the already written program and pass the parameter values back to the PC program. I would just like a way to write the one socket program and pass it in the program the parms and then send pack the parms. Even if on the PC I had to format it like call iteminfo Parm('Item1' ' ' ' ' ' ') which looks like it would work with qcmdexec but no parms back from QCMDEXEC. I am willing to put the x'00000f' in on the PC for numeric packed fields. I guess I am willing to even dig through the joblog if qcmdexec (or something else) would write out the out parms there. Hope that was not to long and gives you an ideal of what I want to do. Thanks John Ross At 02:26 PM 7/3/01 -0400, you wrote: > >Is there any way I can call a program from a program > >without knowing what the second (called) programs > >name or parameters are at the time I write the > >first (calling) program. I need to get any parameters > >back from the second program into the first program. > >That's a tall order! I looked quickly at %paddr/procptr but that only works >for bound procedures, not external program calls. > > >What I am trying to do is write one sockets program > >that will run on the AS/400 and run a program that was > >passed to it from a PC and then pass the results to > >the PC. The pc will format the call and strip out the > >returned parameters. > >So these are batch programs you're wanting to call? And they can have >variable number/type of parameters that you need to send to the PC? How >nice it would be if these programs did output to stdout and you could simply >pipe the results... This won't be a simple matter in RPG. There's always >brute force: > >eval pgmName inpPgmName >call pgmName >parm parm1 >trap "wrong parameter list" error >if error > call pgmName > parm parm1 > parm parm2 >endif >... >then you get to have fun assembling all the returned parameters to pass on >to the PC. > >Of course, you could "cache" the program/library/parameter type information >in a file. Try the "normal" CALL; if it fails, run the "discover >parameters" routine and store the results. Then use those results as the >next "normal" CALL. > >Perhaps there's another way around your particular business problem than >trying to directly call the 400 program. Can you disclose what you're >working on? > >Buck Calabro >Commsoft; Albany, NY >Visit the Midrange archives and FAQ at http://www.midrange.com >"Where so many hours have been spent convincing myself that I am right, > is there not some reason to fear that I may be wrong?" -- Jane Austen +--- | This is the RPG/400 Mailing List! | To submit a new message, send your mail to RPG400-L@midrange.com. | To subscribe to this list send email to RPG400-L-SUB@midrange.com. | To unsubscribe from this list send email to RPG400-L-UNSUB@midrange.com. | Questions should be directed to the list owner/operator: david@midrange.com +---
As an Amazon Associate we earn from qualifying purchases.
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.