|
Benjamin, I have attached two sample RPG programs. One (the larger) uses both the Virtual Terminal (VT) APIs and USRDFN datastreams. The second (VTATTN) works with the first in order to support the Attention key. Using these programs you basically operate your terminal in one job while your application is running in another. The samples do not manipulate the 5250 data stream, but rather just pass it through after timestamping the transaction. If you want to manipulate the datastream you will need to become extremely familiar with the 5250 datastream. Bruce Vining PS - I last used this code back in 1994 to test an idea so there may be a few "features" that I cannot recall at this late date. > >Hi! > >Is it possible to write 5250 data stream directly to a twinax attached >terminal? I think the DDS keyword USRDFN can be used for that purpose, but >I don't know how does it work. I want to manipulate the data flowing >between the application and the end user with VT APIs, but my client side >should be a real terminal. For that purpose I need to read/write directly >to the terminal. >Did anybody something similar? > >Regards, > > Benjamin Budai > H F* F* This is a sample program to demonstrate how to use Virtual F* Terminal API support. When called, this program brings the F* interactive caller into a virtual session, and then echoes F* all screen IO from the virtual session to the physical F* interactive session. When in the program, F23 can be used F* to exit the virtual session. This program has not been F* formally tested; and is provided on an as-is basis only. F* F* This program prereqs a *DSPF named RPGDSPF, with attributes F* similar to the following, to exist in *LIBL F* F* R FILLER F* DATA 4005 H F* R USRPUT USRDFN F* R USRREC INVITE F* PRINT F* USRDFN F* FRPGDSPF CF F 4005 WORKSTN UC F KPASS *NOIND F* F* Likewise, a *PF VTOUTFIL with these attributes is needed F* in *LIBL F* F* R VTOUTREC F* CODE 1 F* STAMP 63 F* F* The VTOUTPUT file is used to log timestamps of the interactive F* session and also to record unexpected Virtual Terminal F* sequences. There are 3 CODE values: F* 'A' = Timestamp prior to read from physical device F* 'B' = Timestamp after read from physical device F* 'E' = Error; an unexpected/unsupported sequence F* where 'A' - 'B' approximates response time F* and 'B' - 'A' approximates key/think time by the user F* FVTOUTFILO E DISK A F* F* And a *DTAQ must exist with these attributes: F* F* 1. Minimum length of 80 bytes F* 2. Not keyed F* 3. Has same name as interactive user F* 4. Resides in *LIBL F* F* If the *DTAQ is not found, this program will create it F* in QGPL F* E ARR 4000 1 IRPGDSPF NS I 14000 DS5250 IVTOP DS I 1 10 VTDATA I 1 1 READOP IINTS DS I I 0 B 1 40CCSID I I 0 B 5 80CODEPG I I 1 B 9 120WSTYPE I I 0 B 13 160QKEYLN I B 17 200READIN I B 21 240GOTIN I I 48 B 25 280OBJVSZ IERRCOD DS I I 15 B 1 40BYTPRV I B 5 80BYTAVL I 9 15 CPFID IDTAQ DS I 1 10 QNAME I I '*LIBL' 11 20 QLIB IROBJD DS I 39 48 OBJLIB I DS I I 'SETATNPGM VTATTN' 1 16 CLSET ICLCRT DS I I 'CRTDTAQ QGPL/' 1 13 CRT1 I 14 23 CRT2 I I ' MAXLEN(80)' 24 34 CRT3 ICLOVR DS I I 'OVRDSPF RPGDSPF - 1 21 OVR1 I 'DTAQ(' I 22 31 OVR2 I I ')' 32 32 OVR3 IUSRDTA DS I B 1 20PUT I I 4000 B 3 40GET I 5 5 FUNCT IDS5250 DS I 3 3 AIDKEY I 1 80 ARRDTA I 14000 ARR IQDATA DS I 1 10 VTQTYP I 11 12 VTQID I 13 28 VTQHAN I 29 80 VTFILL I X'00' C NULL I X'71' C PUTSCR I X'73' C PUTGET I X'BB' C GETOUT I X'0402' C SAVCMD I X'0462' C RSICMD I X'0472' C RMCMD I X'04520000' C RIMCMD I SDS I 254 263 USERID C/EJECT C EXSR INIT INIT VARS C* C* Just loop until F23 is pressed on any screen; and then exit C* C AIDKEY DOWNEGETOUT CF23 KEY? C LOOP TAG C* C* Wait on *DTAQ to determine next course of action C* C CALL 'QRCVDTAQ' C PARM QNAME *DTAQ name C PARM QLIB *DTAQ libr C PARM QLEN 50 Size of data C PARM QDATA Rcv variable C PARM -1 QWAIT 50 Wait forever C* C* If VT then get the 5250 data stream from the user application C* C VTQTYP IFEQ '*VRTTRM' VT entry? C VTQID ANDNE' 1' If not close C CALL 'QTVRDVT' C PARM HANDLE VT handle C PARM VTDATA VT ops C PARM DS5250 5250 orders C PARM 4000 READIN Rcv var size C PARM GOTIN Size back C PARM ERRCOD Error struct C BYTAVL IFNE 0 If error C DSPLY CPFID show msg C EXSR EOJ get out C END C* C* See what we got: C* C READOP IFEQ 'B' if message C READOP OREQ 'C' light then C GOTO LOOP NOOP C END C* C Z-ADDGOTIN PUT Set size C READOP IFEQ '2' Put? C MOVE PUTSCR FUNCT C ELSE Or C READOP IFEQ '3' Put/get? C MOVE PUTGET FUNCT C ELSE Or C READOP IFEQ '4' Save C MOVE PUTGET FUNCT Screen? C MOVELSAVCMD DS5250 C Z-ADD2 PUT C ELSE Or C READOP IFEQ '5' Restore C MOVE PUTGET FUNCT Screen? C ELSE Or C READOP IFEQ '6' Read C MOVE PUTGET FUNCT Immediate? C MOVELRMCMD DS5250 C Z-ADD2 PUT C ELSE Or C READOP IFEQ '8' Read Screen C MOVE PUTGET FUNCT Immediate? C MOVELRSICMD DS5250 C Z-ADD2 PUT C ELSE Or C READOP IFEQ '1' Invite? C MOVE PUTGET FUNCT C MOVELRIMCMD DS5250 C Z-ADD4 PUT C ELSE Or C READOP IFEQ 'A' Cancel C MOVE 'C' FUNCT Invite? C MOVEL'0A' WRTOP C Z-ADD0 READIN C EXSR VTWRT C ELSE C* C* If not any of the above, then log what was received and get C* out of here C* C DSPLY VTDATA C MOVE 'E' CODE C MOVELARRDTA STAMP C WRITEVTOUTREC C EXSR EOJ C END C END C END C END C END C END C END C END C FUNCT IFEQ PUTSCR No invite C EXCPTDSPP C ELSE C FUNCT IFEQ PUTGET With invite C EXCPTDSPF C END C END C FUNCT CABEQPUTSCR LOOP More to wrt? C* C* Now take timestamp 'A' C* C TIME STAMPN 120 C* C* and record it C* C MOVE 'A' CODE C MOVELSTAMPN STAMP C WRITEVTOUTREC C* C ELSE C* C* Is this an AID key from the physical workstation C* C VTQTYP IFEQ '*DSPF' DSPF Entry? C READ RPGDSPF 01Read DSPF C* C* Now take timestamp 'B' C* C TIME STAMPN C* C* and record it C* C MOVE 'B' CODE C MOVELSTAMPN STAMP C WRITEVTOUTREC C* C AIDKEY IFNE GETOUT CF23 ? C* C* Trim any trailing blanks from the received data stream C* C ' ' CHEKRDS5250 READIN C* C* and write response back to user application C* C MOVEL'0' WRTOP 2 C MOVE READOP WRTOP C EXSR VTWRT C END C ELSE C* C* Is this the Attention key C* C VTQTYP IFEQ 'ATTN' ATTN entry? C* C* Now take timestamp 'B' C* C TIME STAMPN C* C* record it C* C MOVE 'B' CODE C MOVELSTAMPN STAMP C WRITEVTOUTREC C* C* and write the Attention key to the application session C* C MOVEL'2 ' WRTOP C Z-ADD0 READIN C EXSR VTWRT C* C ELSE C* C* To get here, the program has received an unknown *DTAQ C* message OR the virtual terminal session is closing for some C* unknown reason. In either case, log the available data and C* get out. C* C MOVE 'E' CODE C MOVELQDATA STAMP C WRITEVTOUTREC Write log C EXSR EOJ End Session C END C END C END C END End F23 Loop C EXSR EOJ C* C* End of Mainline C* C/EJECT C INIT BEGSR C* C* Set the attention handler program C* C CALL 'QCMDEXC' C PARM CLSET Setatnpgm cl C PARM 16 CLSIZE 155 Size of cl C* C* Save the user name as the name of the *DTAQ C* C MOVE USERID QNAME C* C* For performance, since the *DTAQ APIs will cache resolved C* pointers if the *DTAQ name is library qualified, we will C* now determine the correct library from *LIBL C* C CALL 'QUSROBJD' C PARM ROBJD Rcv. var C PARM OBJVSZ Size of rcvr C PARM 'OBJD0100'OBJFMT 8 Format C PARM DTAQ Data queue C PARM '*DTAQ' OBJTYP 10 Object type C PARM ERRCOD Error struct C BYTAVL IFNE 0 If error C CPFID IFEQ 'CPF9801' C MOVELUSERID CRT2 C CALL 'QCMDEXC' C PARM CLCRT C PARM 34 CLSIZE 155 Size of cl C MOVEL'QGPL' OBJLIB C ELSE C DSPLY CPFID show msg C EXSR EOJ get out C END C END C* C* and save it back to the *DTAQ structure C* C MOVE OBJLIB QLIB C* C* The program will now clear the *DTAQ in anticipation of a new C* virtual terminal session C* C CALL 'QCLRDTAQ' Clear *DTAQ C PARM QNAME 10 Queue name C PARM QLIB 10 Queue libr C* C* Attach the *DTAQ to the *DSPF for I/O notification C* C MOVELUSERID OVR2 C CALL 'QCMDEXC' C PARM CLOVR Ovrdspf cl C PARM 32 CLSIZE 155 Size of cl C* C* open the *DSPF C* C OPEN RPGDSPF C* C* and allocate the new virtual terminal session C* C CALL 'QTVOPNVT' Open VT C PARM HANDLE 16 VT Handle C PARM KBDTYP 3 Keyboard typE C PARM CCSID Char set C PARM CODEPG Code page C PARM WSTYPE WS Type C PARM DTAQ Qual Q name C PARM QKEY 1 NOT USED C PARM QKEYLN NOT USED C PARM ERRCOD Error struct C BYTAVL IFNE 0 If error C DSPLY CPFID show msg C EXSR EOJ get out C END C* C* and return to the mainline C* C ENDSR C* C VTWRT BEGSR C* C* Write screen input to application session C* C CALL 'QTVWRTVT' C PARM HANDLE VT Handle C PARM WRTOP WRTBUF 10 Op code C PARM DS5250 5250 orders C PARM READIN size of DS C PARM ERRCOD Error struct C BYTAVL IFNE 0 If error C DSPLY CPFID show msg C MOVE 'E' CODE record 5250 C MOVELDS5250 STAMP data C WRITEVTOUTREC stream C* C* In this case, we end the job without closing the VT session C* as we do not know the state of the session C* C MOVE '1' *INLR C RETRN C END C ENDSR C* C EOJ BEGSR C* C* Close down the virtual terminal session and exit application C* C CALL 'QTVCLOVT' C PARM HANDLE VT Handle C PARM ERRCOD Error struct C MOVE '1' *INLR Get out no C RETRN matter what C ENDSR ORPGDSPF E DSPP O* Format for write with no invite O K6 'USRPUT' O USRDTA 5 O DS5250 4005 ORPGDSPF E DSPF O* Format for write with invite O K6 'USRREC' O USRDTA 5 O DS5250 4005 H F* F* This is a sample program which, when called, places an entry F* on a Data Queue. The Data Queue entry is 80 bytes long, with F* the first 4 bytes = ATTN. This program is used in conjunction F* with VTRPG2 in that the data queue entry is a signal to VTRPG2 F* to simulate the attention key to the virtual terminal session. F* This program has not been formally tested; and is provided on F* an as-is basis only. F* F* A *DTAQ must have been previously created with these F* attributes: F* F* 1. Minimum length of 80 bytes F* 2. Not keyed F* 3. Has same name as interactive user F* 4. Resides in *LIBL F* I SDS I 254 263 QNAME C* C* Send to *DTAQ message which indicates ATTN key used C* C MOVEL'ATTN' QDATA C CALL 'QSNDDTAQ' C PARM QNAME 10 C PARM '*LIBL' QLIB 10 C PARM 80 QLEN 50 C PARM QDATA 80 C MOVE '1' *INLR C RETRN +--- | This is the Midrange System Mailing List! | To submit a new message, send your mail to MIDRANGE-L@midrange.com. | To subscribe to this list send email to MIDRANGE-L-SUB@midrange.com. | To unsubscribe from this list send email to MIDRANGE-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.