View previous topic :: View next topic
|
Author |
Message |
Nainesh A Jadwani
New User
Joined: 15 Jan 2013 Posts: 6 Location: India
|
|
|
|
Hi,
Is it possible to access parms across procs within the same jcl. Say JOB1 has the below calls:
Code: |
//RSTART EXEC RSTART,JOBDET=123456
//STEP010 EXEC MAINPROC |
I need to pass the value of JOBDET to a program within MAINPROC. To give some background. This is a job invoked from CICS and the JOBDET value is passed down by the CICS program. This is a key to a file containing user details which I need to access from within MAINPROC.
Please let me know if any additional information is needed. Thanks in advance.
Regards,
Nainesh A Jadwani |
|
Back to top |
|
|
prino
Senior Member
Joined: 07 Feb 2009 Posts: 1316 Location: Vilnius, Lithuania
|
|
|
|
Of course it's possible, if you go through all the control blocks.
Why not pass the flucking parm also to "mainproc" and the required program in that proc?
Ever heard of KISS: "Keep It Simple, Stupid!" |
|
Back to top |
|
|
Nainesh A Jadwani
New User
Joined: 15 Jan 2013 Posts: 6 Location: India
|
|
|
|
Hi Robert,
The thing is, CICS dynamically sends the key 123456 into JOBDET. In fact, the entire RSTART step is added by the CICS process (in the source of the proc, we can only see MAINPROC (this is the only step I can modify).
If I add something like...
Code: |
//STEP010 EXEC MAINPROC,JOBDET='' |
...and run the job, it still remains blank. I guess this is because the JOBDET in RSTART and the JOBDET in MAINPROC are treated as two separate entities.
What I want is to, somehow, be able to access the RSTART JOBDET and use it within MAINPROC.
Regards,
Nainesh A Jadwani |
|
Back to top |
|
|
daveporcelan
Active Member
Joined: 01 Dec 2006 Posts: 792 Location: Pennsylvania
|
|
|
|
Try this on for size:
Code: |
//SYMBOLIC SET JOBDET=123456
//RSTART EXEC RSTART,JOBDET=&JOBDET
//STEP010 EXEC MAINPROC,JOBDET=&JOBDET |
The question still remains, is JOBDET used within MAINPROC?
I assume it is YES. But we all know what happens when you assume. |
|
Back to top |
|
|
Nainesh A Jadwani
New User
Joined: 15 Jan 2013 Posts: 6 Location: India
|
|
|
|
Hi Dave,
Actually, I meant to show 123456 as an arbitrary key. It has a different value each time the job runs (because CICS sends a different key value each time). Hence, I wouldn't be able to use...
Code: |
//SYMBOLIC SET JOBDET=123456 |
Also, I can't make any changes to the RSTART step. This step is added by the CICS process.
Quote: |
The question still remains, is JOBDET used within MAINPROC? |
Yes. There is a program, say PROG1, which needs the value of JOBDET. This key is used to retrieve the correct record for obtaining the user details from a VSAM file. This is basically a report generation process in CICS that triggers a job in batch.
Regards,
Nainesh A Jadwani |
|
Back to top |
|
|
daveporcelan
Active Member
Joined: 01 Dec 2006 Posts: 792 Location: Pennsylvania
|
|
|
|
What can you change?
This is not going to happen just because you want it to.
This Job you speak of exists some where. You need to change that.
You also need to change the CICS process to populate the value of JOBDET into either the SYMBOLIC SET statement or directly into JOBDET= on the EXEC MAINPROC statement.
If you say 'I can not change....' then I am fresh out of ideas.
Maybe chase control blocks as prino stated above. Good luck with that. |
|
Back to top |
|
|
Nainesh A Jadwani
New User
Joined: 15 Jan 2013 Posts: 6 Location: India
|
|
|
|
Hi Dave/prino,
This is a generic CICS process (for users to submit reports from online) that dynamically creates a jcl and invokes different procs depending on the choice made by the user. It adds the RSTART to each proc and passes JOBDET as the key refering back to the details of the user and the request made by that user. I only want to refer to the key for the one new report that I have added to this process. Changing the CICS process and the RSTART step would impact the entire process and cause a lot of regression testing. Hence, I mentioned that I cannot change that.
What I basically wanted with the key was to obtain the email address of the submittor so that a mail could be sent back once the job completes. I guess a work around I might have to use is define a distribution list and hard code that into the job.
But just out of curiosity...would it have been possible to access the parms of an adjacent proc within a jcl using Control Blocks? How can this be done?
Regards,
Nainesh A Jadwani |
|
Back to top |
|
|
daveporcelan
Active Member
Joined: 01 Dec 2006 Posts: 792 Location: Pennsylvania
|
|
|
|
Quote: |
would it have been possible to access the parms of an adjacent proc within a jcl using Control Blocks? |
It may be possible.
Quote: |
How can this be done?
|
I do not know. Working with control blocks is not an easy thing. Maybe you or Prino or someone else can spend the time to satisfy your curiosity.
I do think however it would be easier and a better idea to:
Quote: |
Changing the CICS process and the RSTART step would impact the entire process and cause a lot of regression testing. |
I have a hard time understanding not doing something like this because 'it is too much work'. |
|
Back to top |
|
|
prino
Senior Member
Joined: 07 Feb 2009 Posts: 1316 Location: Vilnius, Lithuania
|
|
|
|
daveporcelan wrote: |
I do think however it would be easier and a better idea to:
Quote: |
Changing the CICS process and the RSTART step would impact the entire process and cause a lot of regression testing. |
I have a hard time understanding not doing something like this because 'it is too much work'. |
This is an Indian outsourcer, doing something like this would hurt their bottom line... |
|
Back to top |
|
|
|