|
A couple of months ago I emailed the patch below to Mike & he said he'd look it over when he got a chance, but I guess TurboLinux is keeping him *really* busy :-) The patch is for 0.17.1 but 0.16.0pre2 appears to have the same bugs. This patch is for the following bugs in TN5250: 1. In DFU, the cursor positions to the Format field (1st input-capable field), instead of the RECNBR field. 2. In DFU (or any field-exit-required field), when FieldExit is pressed, the last character is removed. 3. Minor misspelling in curses_terminal_getkey(). The DFU cursor problem occurs because DFU sends the screen in 3 WTD commands (using TN5250_RECORD_OPCODE_OUTPUT_ONLY). The 1st WTD has an IC order (to the RECNBR field) but the keyboard isn't unlocked til the 3rd WTD. The old code was setting the cursor on each WTD (when the keyboard is locked). The new code sets it only on a "Lock-to-Unlock transition", as mentioned in RFC 1205 section 5.2. However, the cursor fix caused cursor-positioning to break when the screen is restored after switching to a new job with System Request option 1, or to a group job with the Attention key. It appears that neither the Restore Screen opcode nor the Restore Screen command are sent by the system unless you put a Restore Screen command (x'12') in the screen you send to the system on Save Screen, so I put one in (in tn5250_wtd_context_convert_nosrc()). This allows tn5250_write_to_display() to check for TN5250_RECORD_OPCODE_RESTORE_SCR. --Dave Here's the patch: Index: cursesterm.c =================================================================== RCS file: /tn5250/tn5250/src/cursesterm.c,v retrieving revision 1.28 diff -r1.28 cursesterm.c 1056c1056 < TN5250_LOG(("curses_getch: recevied 0x%02X.\n", ch)); --- > TN5250_LOG(("curses_getch: received 0x%02X.\n", ch)); Index: display.c =================================================================== RCS file: /tn5250/tn5250/src/display.c,v retrieving revision 1.36 diff -r1.36 display.c 532c532 < if (This->pending_insert) --- > if (This->pending_insert) { 534c534,535 < else { --- > This->pending_insert = 0; > } else { 872a874,875 > int pre_FER_clear = 0; > 900c903 < tn5250_display_indicator_clear (This, TN5250_DISPLAY_IND_FER); --- > pre_FER_clear = 1; 1022a1026,1028 > } > if (pre_FER_clear) { > tn5250_display_indicator_clear (This, TN5250_DISPLAY_IND_FER); Index: session.c =================================================================== RCS file: /tn5250/tn5250/src/session.c,v retrieving revision 1.51 diff -r1.51 session.c 534c534 < tn5250_display_clear_pending_insert (This->display); --- > 579d578 < tn5250_session_clear_unit(This); 758a758,759 > int will_be_unlocked; > int cur_opcode; 850a852,854 > will_be_unlocked = ((CC2 & TN5250_SESSION_CTL_UNLOCK) != 0); > cur_opcode = tn5250_record_opcode(This->record); > 853c857,858 < else if(is_x_system) { --- > else if((is_x_system && will_be_unlocked) || > cur_opcode == TN5250_RECORD_OPCODE_RESTORE_SCR) { Index: wtd.c =================================================================== RCS file: /tn5250/tn5250/src/wtd.c,v retrieving revision 1.10 diff -r1.10 wtd.c 148a149,151 > tn5250_wtd_context_putc (This, ESC); > tn5250_wtd_context_putc (This, CMD_RESTORE_SCREEN); > Jason Felice wrote: <snip> > Side note: Last call for bugs in 0.16.0pre1 - (yes, I've been ignoring > the list a little > lately - it's this work thing *sigh* - I don't think I missed any bugs, > tho). If I'm being > a dunce and there are bugs, let me know - I'd like to wrap up 0.16.0 > next week. <snip> +--- | This is the LINUX5250 Mailing List! | To submit a new message, send your mail to LINUX5250@midrange.com. | To subscribe to this list send email to LINUX5250-SUB@midrange.com. | To unsubscribe from this list send email to LINUX5250-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.