|  | /* 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 = (enum flag_enum) (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 = (enum 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 = (enum not_flag_enum) (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); | 
|  | } |