Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/tests/lib/libcurses Fix false positive for mvscanw tests on ...



details:   https://anonhg.NetBSD.org/src/rev/23005ba7449c
branches:  trunk
changeset: 1011141:23005ba7449c
user:      rin <rin%NetBSD.org@localhost>
date:      Sat Jun 20 07:50:16 2020 +0000

description:
Fix false positive for mvscanw tests on big endian machines.

When conversion specifier is not a derivative form of "%s", retrieve
input as 32bit integer, and then convert to string literal. Then we
can avoid interpretation from ASCII code to integer, which is
apparently byte-order depended.

diffstat:

 tests/lib/libcurses/slave/curses_commands.c |  12 +++++++++---
 tests/lib/libcurses/tests/mvscanw           |   7 ++++---
 2 files changed, 13 insertions(+), 6 deletions(-)

diffs (52 lines):

diff -r ab4cd678ad96 -r 23005ba7449c tests/lib/libcurses/slave/curses_commands.c
--- a/tests/lib/libcurses/slave/curses_commands.c       Sat Jun 20 07:30:09 2020 +0000
+++ b/tests/lib/libcurses/slave/curses_commands.c       Sat Jun 20 07:50:16 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: curses_commands.c,v 1.9 2019/05/26 07:47:37 blymn Exp $        */
+/*     $NetBSD: curses_commands.c,v 1.10 2020/06/20 07:50:16 rin Exp $ */
 
 /*-
  * Copyright 2009 Brett Lymn <blymn%NetBSD.org@localhost>
@@ -3061,7 +3061,7 @@
 void
 cmd_mvscanw(int nargs, char **args)
 {
-       int y, x;
+       int y, x, val;
        char string[256];
 
        if (check_arg_count(nargs, 3) == 1)
@@ -3081,7 +3081,13 @@
 
        /* XXX - call2 */
        report_count(2);
-       report_return(mvscanw(y, x, args[2], &string));
+       if (strchr(args[2], 's') != NULL)
+               report_return(mvscanw(y, x, args[2], &string));
+       else {
+               /* XXX assume 32bit integer */
+               report_return(mvscanw(y, x, args[2], &val));
+               snprintf(string, sizeof(string), args[2], val);
+       }
        report_status(string);
 }
 
diff -r ab4cd678ad96 -r 23005ba7449c tests/lib/libcurses/tests/mvscanw
--- a/tests/lib/libcurses/tests/mvscanw Sat Jun 20 07:30:09 2020 +0000
+++ b/tests/lib/libcurses/tests/mvscanw Sat Jun 20 07:50:16 2020 +0000
@@ -1,11 +1,12 @@
+# XXX For this test, only one string or 32bit integer are supported as
+# conversion specifiers at the moment.
 include start
 input "testing 1 2 3\n"
 call2 OK "testing" mvscanw 3 5 "%s"
 input "testing 1 2 3\n"
 call2 OK "test" mvscanw 3 5 "%4s"
-# 50 will translate into number 2 in ascii
 input "50 12\n"
-call2 OK "2" mvscanw 3 5 "%d"
+call2 OK "50" mvscanw 3 5 "%d"
 input "aa bb 50 12\n"
 # expect ERR because input has alpha and scanw wants integer
-call2 ERR "2" mvscanw 3 5 "%d"
+call2 ERR "50" mvscanw 3 5 "%d"



Home | Main Index | Thread Index | Old Index