mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-24 12:35:55 +08:00
a1f6a07c3d
This changes c_value_print to call common_val_print. This is more complicated than the usual sort of common_val_print change, due to the handling of RTTI. gdb/ChangeLog 2020-03-13 Tom Tromey <tom@tromey.com> * c-valprint.c (c_value_print): Use common_val_print. gdb/testsuite/ChangeLog 2020-03-13 Tom Tromey <tom@tromey.com> * gdb.base/printcmds.exp (test_print_strings): Add regression test. * gdb.base/printcmds.c (charptr): New typedef. (teststring2): New global.
259 lines
9.5 KiB
C
259 lines
9.5 KiB
C
/* This table is used as a source for every ascii character.
|
|
It is explicitly unsigned to avoid differences due to native characters
|
|
being either signed or unsigned. */
|
|
#include <stdlib.h>
|
|
unsigned char ctable1[256] = {
|
|
0000, 0001, 0002, 0003, 0004, 0005, 0006, 0007,
|
|
0010, 0011, 0012, 0013, 0014, 0015, 0016, 0017,
|
|
0020, 0021, 0022, 0023, 0024, 0025, 0026, 0027,
|
|
0030, 0031, 0032, 0033, 0034, 0035, 0036, 0037,
|
|
0040, 0041, 0042, 0043, 0044, 0045, 0046, 0047,
|
|
0050, 0051, 0052, 0053, 0054, 0055, 0056, 0057,
|
|
0060, 0061, 0062, 0063, 0064, 0065, 0066, 0067,
|
|
0070, 0071, 0072, 0073, 0074, 0075, 0076, 0077,
|
|
0100, 0101, 0102, 0103, 0104, 0105, 0106, 0107,
|
|
0110, 0111, 0112, 0113, 0114, 0115, 0116, 0117,
|
|
0120, 0121, 0122, 0123, 0124, 0125, 0126, 0127,
|
|
0130, 0131, 0132, 0133, 0134, 0135, 0136, 0137,
|
|
0140, 0141, 0142, 0143, 0144, 0145, 0146, 0147,
|
|
0150, 0151, 0152, 0153, 0154, 0155, 0156, 0157,
|
|
0160, 0161, 0162, 0163, 0164, 0165, 0166, 0167,
|
|
0170, 0171, 0172, 0173, 0174, 0175, 0176, 0177,
|
|
0200, 0201, 0202, 0203, 0204, 0205, 0206, 0207,
|
|
0210, 0211, 0212, 0213, 0214, 0215, 0216, 0217,
|
|
0220, 0221, 0222, 0223, 0224, 0225, 0226, 0227,
|
|
0230, 0231, 0232, 0233, 0234, 0235, 0236, 0237,
|
|
0240, 0241, 0242, 0243, 0244, 0245, 0246, 0247,
|
|
0250, 0251, 0252, 0253, 0254, 0255, 0256, 0257,
|
|
0260, 0261, 0262, 0263, 0264, 0265, 0266, 0267,
|
|
0270, 0271, 0272, 0273, 0274, 0275, 0276, 0277,
|
|
0300, 0301, 0302, 0303, 0304, 0305, 0306, 0307,
|
|
0310, 0311, 0312, 0313, 0314, 0315, 0316, 0317,
|
|
0320, 0321, 0322, 0323, 0324, 0325, 0326, 0327,
|
|
0330, 0331, 0332, 0333, 0334, 0335, 0336, 0337,
|
|
0340, 0341, 0342, 0343, 0344, 0345, 0346, 0347,
|
|
0350, 0351, 0352, 0353, 0354, 0355, 0356, 0357,
|
|
0360, 0361, 0362, 0363, 0364, 0365, 0366, 0367,
|
|
0370, 0371, 0372, 0373, 0374, 0375, 0376, 0377
|
|
};
|
|
|
|
unsigned char ctable2[] = {
|
|
'a','X','X','X','X','X','X','X','X','X','X','X','X','X','X','X',
|
|
'a','a','X','X','X','X','X','X','X','X','X','X','X','X','X','X',
|
|
'a','a','a','X','X','X','X','X','X','X','X','X','X','X','X','X',
|
|
'a','a','a','a','X','X','X','X','X','X','X','X','X','X','X','X',
|
|
'a','a','a','a','a','X','X','X','X','X','X','X','X','X','X','X',
|
|
'a','a','a','a','a','a','X','X','X','X','X','X','X','X','X','X',
|
|
'a','a','a','a','a','a','a','X','X','X','X','X','X','X','X','X',
|
|
'a','a','a','a','a','a','a','a','X','X','X','X','X','X','X','X',
|
|
'a','a','a','a','a','a','a','a','a','X','X','X','X','X','X','X',
|
|
'a','a','a','a','a','a','a','a','a','a','X','X','X','X','X','X',
|
|
'a','a','a','a','a','a','a','a','a','a','a','X','X','X','X','X',
|
|
'a','a','a','a','a','a','a','a','a','a','a','a','X','X','X','X',
|
|
'a','a','a','a','a','a','a','a','a','a','a','a','a','X','X','X',
|
|
'a','a','a','a','a','a','a','a','a','a','a','a','a','a','X','X',
|
|
'a','a','a','a','a','a','a','a','a','a','a','a','a','a','a','X',
|
|
'a','a','a','a','a','a','a','a','a','a','a','a','a','a','a','a', 0
|
|
};
|
|
|
|
/* Single and multidimensional arrays to test access and printing of array
|
|
members. */
|
|
|
|
typedef int ArrayInt [10];
|
|
ArrayInt a1 = {2,4,6,8,10,12,14,16,18,20};
|
|
|
|
typedef char ArrayChar [5];
|
|
ArrayChar a2 = {'a','b','c','d','\0'};
|
|
|
|
int int1dim[12] = {0,1,2,3,4,5,6,7,8,9,10,11};
|
|
int int2dim[3][4] = {{0,1,2,3},{4,5,6,7},{8,9,10,11}};
|
|
int int3dim[2][3][2] = {{{0,1},{2,3},{4,5}},{{6,7},{8,9},{10,11}}};
|
|
int int4dim[1][2][3][2] = {{{{0,1},{2,3},{4,5}},{{6,7},{8,9},{10,11}}}};
|
|
|
|
char *teststring = (char*)"teststring contents";
|
|
|
|
typedef char *charptr;
|
|
charptr teststring2 = "more contents";
|
|
|
|
/* Test printing of a struct containing character arrays. */
|
|
|
|
struct some_arrays {
|
|
unsigned char array1[4];
|
|
unsigned char array2[1];
|
|
unsigned char array3[1];
|
|
unsigned char array4[2];
|
|
unsigned char array5[4];
|
|
} arrays = {
|
|
{'a', 'b', 'c', '\0'},
|
|
{'d'},
|
|
{'e'},
|
|
{'f', 'g' },
|
|
{'h', 'i', 'j', '\0'}
|
|
};
|
|
|
|
struct some_arrays *parrays = &arrays;
|
|
|
|
enum some_volatile_enum { enumvolval1, enumvolval2 };
|
|
|
|
/* A volatile enum variable whose name is the same as the enumeration
|
|
name. See PR11827. */
|
|
volatile enum some_volatile_enum some_volatile_enum = enumvolval1;
|
|
|
|
/* An enum considered as a "flag enum". */
|
|
enum flag_enum
|
|
{
|
|
FE_NONE = 0x00,
|
|
FE_ONE = 0x01,
|
|
FE_TWO = 0x02,
|
|
FE_TWO_LEGACY = 0x02,
|
|
};
|
|
|
|
enum flag_enum three = FE_ONE | FE_TWO;
|
|
|
|
/* Another enum considered as a "flag enum", but with no enumerator with value
|
|
0. */
|
|
enum flag_enum_without_zero
|
|
{
|
|
FEWZ_ONE = 0x01,
|
|
FEWZ_TWO = 0x02,
|
|
};
|
|
|
|
enum flag_enum_without_zero flag_enum_without_zero = 0;
|
|
|
|
/* Not a flag enum, an enumerator value has multiple bits sets. */
|
|
enum not_flag_enum
|
|
{
|
|
NFE_ONE = 0x01,
|
|
NFE_TWO = 0x02,
|
|
NFE_F0 = 0xf0,
|
|
};
|
|
|
|
enum not_flag_enum three_not_flag = NFE_ONE | NFE_TWO;
|
|
|
|
/* A structure with an embedded array at an offset > 0. The array has
|
|
all elements with the same repeating value, which must not be the
|
|
same as the value of the preceding fields in the structure for the
|
|
test to be effective. This tests whether GDB uses the correct
|
|
element content offsets (relative to the complete `some_struct'
|
|
value) when counting value repetitions. */
|
|
struct some_struct
|
|
{
|
|
int a;
|
|
int b;
|
|
unsigned char array[20];
|
|
} some_struct = {
|
|
0x12345678,
|
|
0x87654321,
|
|
{
|
|
0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
|
|
0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
|
|
0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
|
|
0xaa, 0xaa, 0xaa, 0xaa, 0xaa
|
|
}
|
|
};
|
|
|
|
/* The following variables are used for testing byte repeat sequences.
|
|
The variable names are encoded: invalid_XYZ where:
|
|
X = start
|
|
Y = invalid
|
|
Z = end
|
|
|
|
Each of X and Z can be "E" (empty), "S" (single), "L" (long single),
|
|
or "R" (repeat).
|
|
|
|
Y can be either any of the above except "E" (otherwise there is nothing
|
|
to test). */
|
|
char invalid_ESE[] = "\240";
|
|
char invalid_SSE[] = "a\240";
|
|
char invalid_LSE[] = "abaabbaaabbb\240";
|
|
char invalid_RSE[] = "aaaaaaaaaaaaaaaaaaaa\240";
|
|
char invalid_ESS[] = "\240c";
|
|
char invalid_SSS[] = "a\240c";
|
|
char invalid_LSS[] = "abaabbaaabbb\240c";
|
|
char invalid_RSS[] = "aaaaaaaaaaaaaaaaaaaa\240c";
|
|
char invalid_ESL[] = "\240cdccddcccddd";
|
|
char invalid_SSL[] = "a\240cdccddcccddd";
|
|
char invalid_LSL[] = "abaabbaaabbb\240cdccddcccddd";
|
|
char invalid_RSL[] = "aaaaaaaaaaaaaaaaaaaa\240cdccddcccddd";
|
|
char invalid_ESR[] = "\240cccccccccccccccccccc";
|
|
char invalid_SSR[] = "a\240cccccccccccccccccccc";
|
|
char invalid_LSR[] = "abaabbaaabbb\240cccccccccccccccccccc";
|
|
char invalid_RSR[] = "aaaaaaaaaaaaaaaaaaaa\240cccccccccccccccccccc";
|
|
char invalid_ELE[] = "\240\240\240\240";
|
|
char invalid_SLE[] = "a\240\240\240\240";
|
|
char invalid_LLE[] = "abaabbaaabbb\240\240\240\240";
|
|
char invalid_RLE[] = "aaaaaaaaaaaaaaaaaaaa\240\240\240\240";
|
|
char invalid_ELS[] = "\240\240\240\240c";
|
|
char invalid_SLS[] = "a\240\240\240\240c";
|
|
char invalid_LLS[] = "abaabbaaabbb\240\240\240\240c";
|
|
char invalid_RLS[] = "aaaaaaaaaaaaaaaaaaaa\240\240\240\240c";
|
|
char invalid_ELL[] = "\240\240\240\240cdccddcccddd";
|
|
char invalid_SLL[] = "a\240\240\240\240cdccddcccddd";
|
|
char invalid_LLL[] = "abaabbaaabbb\240\240\240\240cdccddcccddd";
|
|
char invalid_RLL[] = "aaaaaaaaaaaaaaaaaaaa\240\240\240\240cdccddcccddd";
|
|
char invalid_ELR[] = "\240\240\240\240cccccccccccccccccccc";
|
|
char invalid_SLR[] = "a\240\240\240\240cccccccccccccccccccc";
|
|
char invalid_LLR[] = "abaabbaaabbb\240\240\240\240cccccccccccccccccccc";
|
|
char invalid_RLR[] = "aaaaaaaaaaaaaaaaaaaa\240\240\240\240cccccccccccccccccccc";
|
|
char invalid_ERE[] = ""
|
|
"\240\240\240\240\240\240\240\240\240\240"
|
|
"\240\240\240\240\240\240\240\240\240\240";
|
|
char invalid_LRE[] = "abaabbaaabbb"
|
|
"\240\240\240\240\240\240\240\240\240\240"
|
|
"\240\240\240\240\240\240\240\240\240\240";
|
|
char invalid_RRE[] = "aaaaaaaaaaaaaaaaaaaa"
|
|
"\240\240\240\240\240\240\240\240\240\240"
|
|
"\240\240\240\240\240\240\240\240\240\240";
|
|
char invalid_ERS[] = ""
|
|
"\240\240\240\240\240\240\240\240\240\240"
|
|
"\240\240\240\240\240\240\240\240\240\240c";
|
|
char invalid_ERL[] = ""
|
|
"\240\240\240\240\240\240\240\240\240\240"
|
|
"\240\240\240\240\240\240\240\240\240\240cdccddcccddd";
|
|
char invalid_ERR[] = ""
|
|
"\240\240\240\240\240\240\240\240\240\240"
|
|
"\240\240\240\240\240\240\240\240\240\240cccccccccccccccccccc";
|
|
char invalid_SRE[] = "a"
|
|
"\240\240\240\240\240\240\240\240\240\240"
|
|
"\240\240\240\240\240\240\240\240\240\240";
|
|
char invalid_SRS[] = "a"
|
|
"\240\240\240\240\240\240\240\240\240\240"
|
|
"\240\240\240\240\240\240\240\240\240\240c";
|
|
char invalid_SRL[] = "a"
|
|
"\240\240\240\240\240\240\240\240\240\240"
|
|
"\240\240\240\240\240\240\240\240\240\240cdccddcccddd";
|
|
char invalid_SRR[] = "a"
|
|
"\240\240\240\240\240\240\240\240\240\240"
|
|
"\240\240\240\240\240\240\240\240\240\240cccccccccccccccccccc";
|
|
char invalid_LRS[] = "abaabbaaabbb"
|
|
"\240\240\240\240\240\240\240\240\240\240"
|
|
"\240\240\240\240\240\240\240\240\240\240c";
|
|
char invalid_LRL[] = "abaabbaaabbb"
|
|
"\240\240\240\240\240\240\240\240\240\240"
|
|
"\240\240\240\240\240\240\240\240\240\240cdccddcccddd";
|
|
char invalid_LRR[] = "abaabbaaabbb"
|
|
"\240\240\240\240\240\240\240\240\240\240"
|
|
"\240\240\240\240\240\240\240\240\240\240cccccccccccccccccccc";
|
|
char invalid_RRS[] = "aaaaaaaaaaaaaaaaaaaa"
|
|
"\240\240\240\240\240\240\240\240\240\240"
|
|
"\240\240\240\240\240\240\240\240\240\240c";
|
|
char invalid_RRL[] = "aaaaaaaaaaaaaaaaaaaa"
|
|
"\240\240\240\240\240\240\240\240\240\240"
|
|
"\240\240\240\240\240\240\240\240\240\240cdccddcccddd";
|
|
char invalid_RRR[] = "aaaaaaaaaaaaaaaaaaaa"
|
|
"\240\240\240\240\240\240\240\240\240\240"
|
|
"\240\240\240\240\240\240\240\240\240\240cccccccccccccccccccc";
|
|
|
|
/* -- */
|
|
|
|
int main ()
|
|
{
|
|
void *p = malloc (1);
|
|
|
|
/* Prevent AIX linker from removing variables. */
|
|
return ctable1[0] + ctable2[0] + int1dim[0] + int2dim[0][0]
|
|
+ int3dim[0][0][0] + int4dim[0][0][0][0] + teststring[0] +
|
|
*parrays -> array1 + a1[0] + a2[0];
|
|
free (p);
|
|
}
|