Enhance the strings program so that it can display multibyte strings.

* strings.c (print_strings): Check for multibyte encodings.
	* binutils-all/strings-1.bin: New file.  Test binary for string decoding.
	* testsuite/binutils-all/strings.exp: New file.  Test the strings program.
	* testsuite/config/default.exp (STRINGS): Define if not provided
	by the environment.
	(STRINGSFLAGS): Likewise.
This commit is contained in:
Nick Clifton 2018-11-09 12:48:23 +00:00
parent 0d0b0a378e
commit 71f5e3f7b6
5 changed files with 97 additions and 2 deletions

View File

@ -1,3 +1,12 @@
2018-11-09 Mathias <m4tze@exitno.de>
* strings.c (print_strings): Check for multibyte encodings.
* binutils-all/strings-1.bin: New file. Test binary for string decoding.
* testsuite/binutils-all/strings.exp: New file. Test the strings program.
* testsuite/config/default.exp (STRINGS): Define if not provided
by the environment.
(STRINGSFLAGS): Likewise.
2018-11-07 Masatake Yamato <yamato@redhat.com>
* objdump.c (long_options): Have the --disassemble option take an

View File

@ -540,9 +540,48 @@ print_strings (const char *filename, FILE *stream, file_ptr address,
free (buf);
return;
}
if (! STRING_ISGRAPHIC (c))
/* Found a non-graphic. Try again starting with next char. */
goto tryline;
{
/* Found a non-graphic. Try again starting with next char. */
if (encoding_bytes > 1)
{
/* In case of multibyte encodings rewind using magic buffer. */
if (magiccount == 0)
{
/* If no magic buffer exists: use memory of c. */
switch (encoding)
{
default:
break;
case 'b':
c = c & 0xff;
magiccount += 1;
break;
case 'l':
case 'L':
c = c >> 8;
magiccount += (encoding_bytes -1);
break;
case 'B':
c = (( c & 0xff0000) >> 16) | ( c & 0xff00)
| (( c & 0xff) << 16);
magiccount += 3;
break;
}
magic = (char *) &c;
}
else
{
/* If magic buffer exists: rewind. */
magic = magic - (encoding_bytes -1);
}
address = address - (encoding_bytes -1);
}
goto tryline;
}
buf[i] = c;
}

Binary file not shown.

View File

@ -0,0 +1,41 @@
# Copyright (C) 2018 Free Software Foundation, Inc.
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
proc test_multibyte {testfile} {
global STRINGS
global STRINGSFLAGS
set testname "strings: decoding little-endian multibyte strings"
set got [binutils_run $STRINGS "$STRINGSFLAGS --encoding=l $testfile"]
set want "String1"
if ![regexp $want $got] then {
fail "$testname [String1]"
return
}
set want "tring2"
if ![regexp $want $got] then {
fail "$testname [tring2]"
return
}
pass $testname
}
test_multibyte $srcdir/$subdir/strings-1.bin

View File

@ -63,6 +63,12 @@ if ![info exists OBJCOPYFLAGS] then {
if ![info exists AR] then {
set AR [findfile $base_dir/ar]
}
if ![info exists STRINGS] then {
set STRINGS [findfile $base_dir/strings]
}
if ![info exists STRINGSFLAGS] then {
set STRINGSFLAGS ""
}
if ![info exists STRIP] then {
set STRIP [findfile $base_dir/strip-new $base_dir/strip-new [transform strip]]
}