From 938c69a11897acea85275b93b5bb376b589564fa Mon Sep 17 00:00:00 2001 From: Simon Marchi Date: Thu, 9 Jul 2015 11:19:25 -0400 Subject: [PATCH] Factor out memberptr printing code from c_val_print gdb/ChangeLog: * c-valprint.c (c_val_print): Factor out memberptr printing code from c_val_print to ... (c_val_print_memberptr): ... this new function. --- gdb/ChangeLog | 6 ++++++ gdb/c-valprint.c | 29 +++++++++++++++++++++++------ 2 files changed, 29 insertions(+), 6 deletions(-) diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 8a6a2ace13e..b5b80a39cc6 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,9 @@ +2015-07-09 Simon Marchi + + * c-valprint.c (c_val_print): Factor out memberptr printing code + from c_val_print to ... + (c_val_print_memberptr): ... this new function. + 2015-07-09 Simon Marchi * c-valprint.c (c_val_print): Factor out int printing code to ... diff --git a/gdb/c-valprint.c b/gdb/c-valprint.c index 0a61d7a6151..d76a206e25f 100644 --- a/gdb/c-valprint.c +++ b/gdb/c-valprint.c @@ -456,6 +456,26 @@ c_val_print_int (struct type *type, struct type *unresolved_type, } } +/* c_val_print helper for TYPE_CODE_MEMBERPTR. */ + +static void +c_val_print_memberptr (struct type *type, const gdb_byte *valaddr, + int embedded_offset, CORE_ADDR address, + struct ui_file *stream, int recurse, + const struct value *original_value, + const struct value_print_options *options) +{ + if (!options->format) + { + cp_print_class_member (valaddr + embedded_offset, type, stream, "&"); + } + else + { + generic_val_print (type, valaddr, embedded_offset, address, stream, + recurse, original_value, options, &c_decorations); + } +} + /* See val_print for a description of the various parameters of this function; they are identical. */ @@ -501,12 +521,9 @@ c_val_print (struct type *type, const gdb_byte *valaddr, break; case TYPE_CODE_MEMBERPTR: - if (!options->format) - { - cp_print_class_member (valaddr + embedded_offset, type, stream, "&"); - break; - } - /* FALLTHROUGH */ + c_val_print_memberptr (type, valaddr, embedded_offset, address, stream, + recurse, original_value, options); + break; case TYPE_CODE_REF: case TYPE_CODE_ENUM: