mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2024-11-27 03:51:15 +08:00
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:
parent
0d0b0a378e
commit
71f5e3f7b6
@ -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
|
||||
|
@ -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;
|
||||
}
|
||||
|
||||
|
BIN
binutils/testsuite/binutils-all/strings-1.bin
Executable file
BIN
binutils/testsuite/binutils-all/strings-1.bin
Executable file
Binary file not shown.
41
binutils/testsuite/binutils-all/strings.exp
Normal file
41
binutils/testsuite/binutils-all/strings.exp
Normal 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
|
||||
|
||||
|
@ -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]]
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user