xcall GETJTB, job-table-variable
There are innumerable subroutines which have been written in order to return the current PPN, terminal name, job name, and so on. Although many of the more common subroutines are implemented in A-Shell, it is clearly not possible to cater to all possibilities. A-Shell therefore also contains this subroutine, GETJTB (and its counterpart SETJTB), to return into a structure, everything that is likely to be needed from the job control block, within an application.
The structure of the job-table-variable is:
MAP1 JOB'TABLE ! 130+ byte area
MAP2 JOBNAM,s,6 ! Job name
MAP2 JOBNO,f,6 ! Entry in job table
MAP2 JOBDEV,s,5 ! Current device
MAP2 JOB'FIL1,x,1
MAP2 PPN ! Current PPN
MAP3 P,b,1 ! Project number
MAP3 PN,b,1 ! Programmer number
MAP2 JOBPRV,f,6 ! Job privilege word
MAP2 JOBPRG,s,6 ! Current program name
MAP2 USRNAM,s,20,"" ! Current user name
MAP2 TRMNAM,s,6 ! Terminal name
MAP2 DRVNAM,s,6 ! Terminal driver name
MAP2 TRMBAUD,f,6 ! Terminal baud rate
MAP2 JOBDFP,x,6 ! Default file protection
MAP2 JOBLVL,f,6 ! Class of user (level)
MAP2 JOBEXP,f,6 ! Experience of user
MAP2 SYSDOS,s,14 ! Operating system name
MAP2 JOBATT,s,6 ! Parent job name
MAP2 SYSVER,s,4 ! Operating sys. version (to 9.9N)
MAP2 JOBSTS,f,6 ! Job status word
MAP2 PRJ'STR,s,3 ! Project no. string
MAP2 PRG'STR,s,3 ! Programmer no. string
MAP2 JOBTYP,f,6 ! Job type
Comments
By calling GETJTB once at the start of each program, all the information likely to be required is readily available, without the need to call a hotchpotch of routines later on.
The operating system field, sysdos, contains the name of the host operating system on which A-Shell is running, for example Windows/32 or AIX. If A-Shell is running in demonstration mode, then an asterisk is appended to the name, e.g. AIX*.
The user name field, usrnam, returns the current logon user name.
The jobnam parameter will be returned with the trailing spaces removed, but the program name (jobprg) will be padded with trailing spaces to a length of 6.
The p and pn fields, being only one byte each, are only capable of handling up to 377,377 (octal). Since A-Shell supports decimal PPNs update to 999,999, you should use the prj’str and prg’str fields instead.