aboutsummaryrefslogtreecommitdiff
path: root/gdb/valops.c
diff options
context:
space:
mode:
authorDaniel Jacobowitz <drow@false.org>2002-01-04 17:51:38 +0000
committerDaniel Jacobowitz <drow@false.org>2002-01-04 17:51:38 +0000
commit7f8c9282581cbc3f7e13d8c5a6f20e086bf2ad7b (patch)
tree608b223fb0e33b72cf730ca953d5fc135a59f7e3 /gdb/valops.c
parenta3aa38ee6cb3da7e2759d852e1d4afccd9ca9aa3 (diff)
downloadgdb-7f8c9282581cbc3f7e13d8c5a6f20e086bf2ad7b.zip
gdb-7f8c9282581cbc3f7e13d8c5a6f20e086bf2ad7b.tar.gz
gdb-7f8c9282581cbc3f7e13d8c5a6f20e086bf2ad7b.tar.bz2
2002-01-04 Daniel Jacobowitz <drow@mvista.com>
* valops.c (find_overload_match): Accept obj as a reference parameter. Update it before returning. * value.h (find_overload_match): Update prototype. * eval.c (evaluate_subexp_standard): Pass object to find_overload_match by reference.
Diffstat (limited to 'gdb/valops.c')
-rw-r--r--gdb/valops.c12
1 files changed, 11 insertions, 1 deletions
diff --git a/gdb/valops.c b/gdb/valops.c
index cfc6937..dfef113 100644
--- a/gdb/valops.c
+++ b/gdb/valops.c
@@ -2636,12 +2636,13 @@ value_find_oload_method_list (struct value **argp, char *method, int offset,
int
find_overload_match (struct type **arg_types, int nargs, char *name, int method,
- int lax, struct value *obj, struct symbol *fsym,
+ int lax, struct value **objp, struct symbol *fsym,
struct value **valp, struct symbol **symp, int *staticp)
{
int nparms;
struct type **parm_types;
int champ_nparms = 0;
+ struct value *obj = (objp ? *objp : NULL);
short oload_champ = -1; /* Index of best overloaded function */
short oload_ambiguous = 0; /* Current ambiguity state for overload resolution */
@@ -2865,6 +2866,15 @@ find_overload_match (struct type **arg_types, int nargs, char *name, int method,
xfree (func_name);
}
+ if (objp)
+ {
+ if (TYPE_CODE (VALUE_TYPE (temp)) != TYPE_CODE_PTR
+ && TYPE_CODE (VALUE_TYPE (*objp)) == TYPE_CODE_PTR)
+ {
+ temp = value_addr (temp);
+ }
+ *objp = temp;
+ }
return oload_incompatible ? 100 : (oload_non_standard ? 10 : 0);
}