xref: /openbsd-src/gnu/usr.bin/binutils/gdb/wrapper.c (revision b725ae7711052a2233e31a66fefb8a752c388d7a)
1*b725ae77Skettenis /* Longjump free calls to gdb internal routines.
2*b725ae77Skettenis    Copyright 1999, 2000 Free Software Foundation, Inc.
3*b725ae77Skettenis 
4*b725ae77Skettenis    This program is free software; you can redistribute it and/or modify
5*b725ae77Skettenis    it under the terms of the GNU General Public License as published by
6*b725ae77Skettenis    the Free Software Foundation; either version 2 of the License, or
7*b725ae77Skettenis    (at your option) any later version.
8*b725ae77Skettenis 
9*b725ae77Skettenis    This program is distributed in the hope that it will be useful,
10*b725ae77Skettenis    but WITHOUT ANY WARRANTY; without even the implied warranty of
11*b725ae77Skettenis    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12*b725ae77Skettenis    GNU General Public License for more details.
13*b725ae77Skettenis 
14*b725ae77Skettenis    You should have received a copy of the GNU General Public License
15*b725ae77Skettenis    along with this program; if not, write to the Free Software
16*b725ae77Skettenis    Foundation, Inc., 59 Temple Place - Suite 330,
17*b725ae77Skettenis    Boston, MA 02111-1307, USA.  */
18*b725ae77Skettenis 
19*b725ae77Skettenis #include "defs.h"
20*b725ae77Skettenis #include "value.h"
21*b725ae77Skettenis #include "wrapper.h"
22*b725ae77Skettenis 
23*b725ae77Skettenis /* Use this struct to pass arguments to wrapper routines. We assume
24*b725ae77Skettenis    (arbitrarily) that no gdb function takes more than ten arguments. */
25*b725ae77Skettenis struct gdb_wrapper_arguments
26*b725ae77Skettenis   {
27*b725ae77Skettenis 
28*b725ae77Skettenis     /* Pointer to some result from the gdb function call, if any */
29*b725ae77Skettenis     union wrapper_results
30*b725ae77Skettenis       {
31*b725ae77Skettenis 	int   integer;
32*b725ae77Skettenis 	void *pointer;
33*b725ae77Skettenis       } result;
34*b725ae77Skettenis 
35*b725ae77Skettenis 
36*b725ae77Skettenis     /* The list of arguments. */
37*b725ae77Skettenis     union wrapper_args
38*b725ae77Skettenis       {
39*b725ae77Skettenis 	int   integer;
40*b725ae77Skettenis 	void *pointer;
41*b725ae77Skettenis       } args[10];
42*b725ae77Skettenis   };
43*b725ae77Skettenis 
44*b725ae77Skettenis struct captured_value_struct_elt_args
45*b725ae77Skettenis {
46*b725ae77Skettenis   struct value **argp;
47*b725ae77Skettenis   struct value **args;
48*b725ae77Skettenis   char *name;
49*b725ae77Skettenis   int *static_memfuncp;
50*b725ae77Skettenis   char *err;
51*b725ae77Skettenis   struct value **result_ptr;
52*b725ae77Skettenis };
53*b725ae77Skettenis 
54*b725ae77Skettenis static int wrap_parse_exp_1 (char *);
55*b725ae77Skettenis 
56*b725ae77Skettenis static int wrap_evaluate_expression (char *);
57*b725ae77Skettenis 
58*b725ae77Skettenis static int wrap_value_fetch_lazy (char *);
59*b725ae77Skettenis 
60*b725ae77Skettenis static int wrap_value_equal (char *);
61*b725ae77Skettenis 
62*b725ae77Skettenis static int wrap_value_assign (char *);
63*b725ae77Skettenis 
64*b725ae77Skettenis static int wrap_value_subscript (char *);
65*b725ae77Skettenis 
66*b725ae77Skettenis static int wrap_value_ind (char *opaque_arg);
67*b725ae77Skettenis 
68*b725ae77Skettenis static int do_captured_value_struct_elt (struct ui_out *uiout, void *data);
69*b725ae77Skettenis 
70*b725ae77Skettenis static int wrap_parse_and_eval_type (char *);
71*b725ae77Skettenis 
72*b725ae77Skettenis int
gdb_parse_exp_1(char ** stringptr,struct block * block,int comma,struct expression ** expression)73*b725ae77Skettenis gdb_parse_exp_1 (char **stringptr, struct block *block, int comma,
74*b725ae77Skettenis 		 struct expression **expression)
75*b725ae77Skettenis {
76*b725ae77Skettenis   struct gdb_wrapper_arguments args;
77*b725ae77Skettenis   args.args[0].pointer = stringptr;
78*b725ae77Skettenis   args.args[1].pointer = block;
79*b725ae77Skettenis   args.args[2].integer = comma;
80*b725ae77Skettenis 
81*b725ae77Skettenis   if (!catch_errors ((catch_errors_ftype *) wrap_parse_exp_1, &args,
82*b725ae77Skettenis 		     "", RETURN_MASK_ERROR))
83*b725ae77Skettenis     {
84*b725ae77Skettenis       /* An error occurred */
85*b725ae77Skettenis       return 0;
86*b725ae77Skettenis     }
87*b725ae77Skettenis 
88*b725ae77Skettenis   *expression = (struct expression *) args.result.pointer;
89*b725ae77Skettenis   return 1;
90*b725ae77Skettenis 
91*b725ae77Skettenis }
92*b725ae77Skettenis 
93*b725ae77Skettenis static int
wrap_parse_exp_1(char * argptr)94*b725ae77Skettenis wrap_parse_exp_1 (char *argptr)
95*b725ae77Skettenis {
96*b725ae77Skettenis   struct gdb_wrapper_arguments *args
97*b725ae77Skettenis     = (struct gdb_wrapper_arguments *) argptr;
98*b725ae77Skettenis   args->result.pointer = parse_exp_1((char **) args->args[0].pointer,
99*b725ae77Skettenis 				     (struct block *) args->args[1].pointer,
100*b725ae77Skettenis 				     args->args[2].integer);
101*b725ae77Skettenis   return 1;
102*b725ae77Skettenis }
103*b725ae77Skettenis 
104*b725ae77Skettenis int
gdb_evaluate_expression(struct expression * exp,struct value ** value)105*b725ae77Skettenis gdb_evaluate_expression (struct expression *exp, struct value **value)
106*b725ae77Skettenis {
107*b725ae77Skettenis   struct gdb_wrapper_arguments args;
108*b725ae77Skettenis   args.args[0].pointer = exp;
109*b725ae77Skettenis 
110*b725ae77Skettenis   if (!catch_errors ((catch_errors_ftype *) wrap_evaluate_expression, &args,
111*b725ae77Skettenis 		     "", RETURN_MASK_ERROR))
112*b725ae77Skettenis     {
113*b725ae77Skettenis       /* An error occurred */
114*b725ae77Skettenis       return 0;
115*b725ae77Skettenis     }
116*b725ae77Skettenis 
117*b725ae77Skettenis   *value = (struct value *) args.result.pointer;
118*b725ae77Skettenis   return 1;
119*b725ae77Skettenis }
120*b725ae77Skettenis 
121*b725ae77Skettenis static int
wrap_evaluate_expression(char * a)122*b725ae77Skettenis wrap_evaluate_expression (char *a)
123*b725ae77Skettenis {
124*b725ae77Skettenis   struct gdb_wrapper_arguments *args = (struct gdb_wrapper_arguments *) a;
125*b725ae77Skettenis 
126*b725ae77Skettenis   (args)->result.pointer =
127*b725ae77Skettenis     (char *) evaluate_expression ((struct expression *) args->args[0].pointer);
128*b725ae77Skettenis   return 1;
129*b725ae77Skettenis }
130*b725ae77Skettenis 
131*b725ae77Skettenis int
gdb_value_fetch_lazy(struct value * value)132*b725ae77Skettenis gdb_value_fetch_lazy (struct value *value)
133*b725ae77Skettenis {
134*b725ae77Skettenis   struct gdb_wrapper_arguments args;
135*b725ae77Skettenis 
136*b725ae77Skettenis   args.args[0].pointer = value;
137*b725ae77Skettenis   return catch_errors ((catch_errors_ftype *) wrap_value_fetch_lazy, &args,
138*b725ae77Skettenis 		       "", RETURN_MASK_ERROR);
139*b725ae77Skettenis }
140*b725ae77Skettenis 
141*b725ae77Skettenis static int
wrap_value_fetch_lazy(char * a)142*b725ae77Skettenis wrap_value_fetch_lazy (char *a)
143*b725ae77Skettenis {
144*b725ae77Skettenis   struct gdb_wrapper_arguments *args = (struct gdb_wrapper_arguments *) a;
145*b725ae77Skettenis 
146*b725ae77Skettenis   value_fetch_lazy ((struct value *) (args)->args[0].pointer);
147*b725ae77Skettenis   return 1;
148*b725ae77Skettenis }
149*b725ae77Skettenis 
150*b725ae77Skettenis int
gdb_value_equal(struct value * val1,struct value * val2,int * result)151*b725ae77Skettenis gdb_value_equal (struct value *val1, struct value *val2, int *result)
152*b725ae77Skettenis {
153*b725ae77Skettenis   struct gdb_wrapper_arguments args;
154*b725ae77Skettenis 
155*b725ae77Skettenis   args.args[0].pointer = val1;
156*b725ae77Skettenis   args.args[1].pointer = val2;
157*b725ae77Skettenis 
158*b725ae77Skettenis   if (!catch_errors ((catch_errors_ftype *) wrap_value_equal, &args,
159*b725ae77Skettenis 		     "", RETURN_MASK_ERROR))
160*b725ae77Skettenis     {
161*b725ae77Skettenis       /* An error occurred */
162*b725ae77Skettenis       return 0;
163*b725ae77Skettenis     }
164*b725ae77Skettenis 
165*b725ae77Skettenis   *result = args.result.integer;
166*b725ae77Skettenis   return 1;
167*b725ae77Skettenis }
168*b725ae77Skettenis 
169*b725ae77Skettenis static int
wrap_value_equal(char * a)170*b725ae77Skettenis wrap_value_equal (char *a)
171*b725ae77Skettenis {
172*b725ae77Skettenis   struct gdb_wrapper_arguments *args = (struct gdb_wrapper_arguments *) a;
173*b725ae77Skettenis   struct value *val1;
174*b725ae77Skettenis   struct value *val2;
175*b725ae77Skettenis 
176*b725ae77Skettenis   val1 = (struct value *) (args)->args[0].pointer;
177*b725ae77Skettenis   val2 = (struct value *) (args)->args[1].pointer;
178*b725ae77Skettenis 
179*b725ae77Skettenis   (args)->result.integer = value_equal (val1, val2);
180*b725ae77Skettenis   return 1;
181*b725ae77Skettenis }
182*b725ae77Skettenis 
183*b725ae77Skettenis int
gdb_value_assign(struct value * val1,struct value * val2,struct value ** result)184*b725ae77Skettenis gdb_value_assign (struct value *val1, struct value *val2, struct value **result)
185*b725ae77Skettenis {
186*b725ae77Skettenis   struct gdb_wrapper_arguments args;
187*b725ae77Skettenis 
188*b725ae77Skettenis   args.args[0].pointer = val1;
189*b725ae77Skettenis   args.args[1].pointer = val2;
190*b725ae77Skettenis 
191*b725ae77Skettenis   if (!catch_errors ((catch_errors_ftype *) wrap_value_assign, &args,
192*b725ae77Skettenis 		     "", RETURN_MASK_ERROR))
193*b725ae77Skettenis     {
194*b725ae77Skettenis       /* An error occurred */
195*b725ae77Skettenis       return 0;
196*b725ae77Skettenis     }
197*b725ae77Skettenis 
198*b725ae77Skettenis   *result = (struct value *) args.result.pointer;
199*b725ae77Skettenis   return 1;
200*b725ae77Skettenis }
201*b725ae77Skettenis 
202*b725ae77Skettenis static int
wrap_value_assign(char * a)203*b725ae77Skettenis wrap_value_assign (char *a)
204*b725ae77Skettenis {
205*b725ae77Skettenis   struct gdb_wrapper_arguments *args = (struct gdb_wrapper_arguments *) a;
206*b725ae77Skettenis   struct value *val1;
207*b725ae77Skettenis   struct value *val2;
208*b725ae77Skettenis 
209*b725ae77Skettenis   val1 = (struct value *) (args)->args[0].pointer;
210*b725ae77Skettenis   val2 = (struct value *) (args)->args[1].pointer;
211*b725ae77Skettenis 
212*b725ae77Skettenis   (args)->result.pointer = value_assign (val1, val2);
213*b725ae77Skettenis   return 1;
214*b725ae77Skettenis }
215*b725ae77Skettenis 
216*b725ae77Skettenis int
gdb_value_subscript(struct value * val1,struct value * val2,struct value ** rval)217*b725ae77Skettenis gdb_value_subscript (struct value *val1, struct value *val2, struct value **rval)
218*b725ae77Skettenis {
219*b725ae77Skettenis   struct gdb_wrapper_arguments args;
220*b725ae77Skettenis 
221*b725ae77Skettenis   args.args[0].pointer = val1;
222*b725ae77Skettenis   args.args[1].pointer = val2;
223*b725ae77Skettenis 
224*b725ae77Skettenis   if (!catch_errors ((catch_errors_ftype *) wrap_value_subscript, &args,
225*b725ae77Skettenis 		     "", RETURN_MASK_ERROR))
226*b725ae77Skettenis     {
227*b725ae77Skettenis       /* An error occurred */
228*b725ae77Skettenis       return 0;
229*b725ae77Skettenis     }
230*b725ae77Skettenis 
231*b725ae77Skettenis   *rval = (struct value *) args.result.pointer;
232*b725ae77Skettenis   return 1;
233*b725ae77Skettenis }
234*b725ae77Skettenis 
235*b725ae77Skettenis static int
wrap_value_subscript(char * a)236*b725ae77Skettenis wrap_value_subscript (char *a)
237*b725ae77Skettenis {
238*b725ae77Skettenis   struct gdb_wrapper_arguments *args = (struct gdb_wrapper_arguments *) a;
239*b725ae77Skettenis   struct value *val1;
240*b725ae77Skettenis   struct value *val2;
241*b725ae77Skettenis 
242*b725ae77Skettenis   val1 = (struct value *) (args)->args[0].pointer;
243*b725ae77Skettenis   val2 = (struct value *) (args)->args[1].pointer;
244*b725ae77Skettenis 
245*b725ae77Skettenis   (args)->result.pointer = value_subscript (val1, val2);
246*b725ae77Skettenis   return 1;
247*b725ae77Skettenis }
248*b725ae77Skettenis 
249*b725ae77Skettenis int
gdb_value_ind(struct value * val,struct value ** rval)250*b725ae77Skettenis gdb_value_ind (struct value *val, struct value **rval)
251*b725ae77Skettenis {
252*b725ae77Skettenis   struct gdb_wrapper_arguments args;
253*b725ae77Skettenis 
254*b725ae77Skettenis   args.args[0].pointer = val;
255*b725ae77Skettenis 
256*b725ae77Skettenis   if (!catch_errors ((catch_errors_ftype *) wrap_value_ind, &args,
257*b725ae77Skettenis 		     "", RETURN_MASK_ERROR))
258*b725ae77Skettenis     {
259*b725ae77Skettenis       /* An error occurred */
260*b725ae77Skettenis       return 0;
261*b725ae77Skettenis     }
262*b725ae77Skettenis 
263*b725ae77Skettenis   *rval = (struct value *) args.result.pointer;
264*b725ae77Skettenis   return 1;
265*b725ae77Skettenis }
266*b725ae77Skettenis 
267*b725ae77Skettenis static int
wrap_value_ind(char * opaque_arg)268*b725ae77Skettenis wrap_value_ind (char *opaque_arg)
269*b725ae77Skettenis {
270*b725ae77Skettenis   struct gdb_wrapper_arguments *args = (struct gdb_wrapper_arguments *) opaque_arg;
271*b725ae77Skettenis   struct value *val;
272*b725ae77Skettenis 
273*b725ae77Skettenis   val = (struct value *) (args)->args[0].pointer;
274*b725ae77Skettenis   (args)->result.pointer = value_ind (val);
275*b725ae77Skettenis   return 1;
276*b725ae77Skettenis }
277*b725ae77Skettenis 
278*b725ae77Skettenis int
gdb_parse_and_eval_type(char * p,int length,struct type ** type)279*b725ae77Skettenis gdb_parse_and_eval_type (char *p, int length, struct type **type)
280*b725ae77Skettenis {
281*b725ae77Skettenis   struct gdb_wrapper_arguments args;
282*b725ae77Skettenis   args.args[0].pointer = p;
283*b725ae77Skettenis   args.args[1].integer = length;
284*b725ae77Skettenis 
285*b725ae77Skettenis   if (!catch_errors ((catch_errors_ftype *) wrap_parse_and_eval_type, &args,
286*b725ae77Skettenis 		     "", RETURN_MASK_ALL))
287*b725ae77Skettenis     {
288*b725ae77Skettenis       /* An error occurred */
289*b725ae77Skettenis       return 0;
290*b725ae77Skettenis     }
291*b725ae77Skettenis 
292*b725ae77Skettenis   *type = (struct type *) args.result.pointer;
293*b725ae77Skettenis   return 1;
294*b725ae77Skettenis }
295*b725ae77Skettenis 
296*b725ae77Skettenis static int
wrap_parse_and_eval_type(char * a)297*b725ae77Skettenis wrap_parse_and_eval_type (char *a)
298*b725ae77Skettenis {
299*b725ae77Skettenis   struct gdb_wrapper_arguments *args = (struct gdb_wrapper_arguments *) a;
300*b725ae77Skettenis 
301*b725ae77Skettenis   char *p = (char *) args->args[0].pointer;
302*b725ae77Skettenis   int length = args->args[1].integer;
303*b725ae77Skettenis 
304*b725ae77Skettenis   args->result.pointer = (char *) parse_and_eval_type (p, length);
305*b725ae77Skettenis 
306*b725ae77Skettenis   return 1;
307*b725ae77Skettenis }
308*b725ae77Skettenis 
309*b725ae77Skettenis enum gdb_rc
gdb_value_struct_elt(struct ui_out * uiout,struct value ** result,struct value ** argp,struct value ** args,char * name,int * static_memfuncp,char * err)310*b725ae77Skettenis gdb_value_struct_elt (struct ui_out *uiout, struct value **result, struct value **argp,
311*b725ae77Skettenis 		      struct value **args, char *name, int *static_memfuncp,
312*b725ae77Skettenis 		      char *err)
313*b725ae77Skettenis {
314*b725ae77Skettenis   struct captured_value_struct_elt_args cargs;
315*b725ae77Skettenis   cargs.argp = argp;
316*b725ae77Skettenis   cargs.args = args;
317*b725ae77Skettenis   cargs.name = name;
318*b725ae77Skettenis   cargs.static_memfuncp = static_memfuncp;
319*b725ae77Skettenis   cargs.err = err;
320*b725ae77Skettenis   cargs.result_ptr = result;
321*b725ae77Skettenis   return catch_exceptions (uiout, do_captured_value_struct_elt, &cargs,
322*b725ae77Skettenis 			   NULL, RETURN_MASK_ALL);
323*b725ae77Skettenis }
324*b725ae77Skettenis 
325*b725ae77Skettenis static int
do_captured_value_struct_elt(struct ui_out * uiout,void * data)326*b725ae77Skettenis do_captured_value_struct_elt (struct ui_out *uiout, void *data)
327*b725ae77Skettenis {
328*b725ae77Skettenis   struct captured_value_struct_elt_args *cargs = data;
329*b725ae77Skettenis   *cargs->result_ptr = value_struct_elt (cargs->argp, cargs->args, cargs->name,
330*b725ae77Skettenis 			     cargs->static_memfuncp, cargs->err);
331*b725ae77Skettenis   return GDB_RC_OK;
332*b725ae77Skettenis }
333*b725ae77Skettenis 
334