*** empty log message ***
[deliverable/binutils-gdb.git] / gdb / value.h
CommitLineData
c906108c 1/* Definitions for values of C expressions, for GDB.
dea7f9ba 2
6aba47ca 3 Copyright (C) 1986, 1987, 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995,
9b254dd1 4 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007,
0fb0cc75 5 2008, 2009 Free Software Foundation, Inc.
c906108c 6
c5aa993b 7 This file is part of GDB.
c906108c 8
c5aa993b
JM
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
a9762ec7 11 the Free Software Foundation; either version 3 of the License, or
c5aa993b 12 (at your option) any later version.
c906108c 13
c5aa993b
JM
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
c906108c 18
c5aa993b 19 You should have received a copy of the GNU General Public License
a9762ec7 20 along with this program. If not, see <http://www.gnu.org/licenses/>. */
c906108c
SS
21
22#if !defined (VALUE_H)
23#define VALUE_H 1
24
dea7f9ba 25#include "doublest.h"
1df6926e 26#include "frame.h" /* For struct frame_id. */
dea7f9ba
MK
27
28struct block;
da3331ec 29struct expression;
dea7f9ba 30struct regcache;
da3331ec
AC
31struct symbol;
32struct type;
dea7f9ba 33struct ui_file;
d8ca156b 34struct language_defn;
79a45b7d 35struct value_print_options;
d16aafd8 36
dea7f9ba
MK
37/* The structure which defines the type of a value. It should never
38 be possible for a program lval value to survive over a call to the
39 inferior (i.e. to be put into the history list or an internal
40 variable). */
c906108c 41
91294c83 42struct value;
c906108c 43
a08702d6
TJB
44/* Needed if another module needs to maintain its own list of values. */
45
46void value_prepend_to_list (struct value **head, struct value *val);
47void value_remove_from_list (struct value **head, struct value *val);
48
17cf0ecd 49/* Values are stored in a chain, so that they can be deleted easily
a08702d6
TJB
50 over calls to the inferior. Values assigned to internal variables,
51 put into the value history or exposed to Python are taken off this
52 list. */
91294c83 53
17cf0ecd
AC
54struct value *value_next (struct value *);
55
91294c83
AC
56/* Type of the value. */
57
df407dfe 58extern struct type *value_type (struct value *);
91294c83 59
04624583
AC
60/* This is being used to change the type of an existing value, that
61 code should instead be creating a new value with the changed type
62 (but possibly shared content). */
91294c83 63
04624583
AC
64extern void deprecated_set_value_type (struct value *value,
65 struct type *type);
91294c83
AC
66
67/* Only used for bitfields; number of bits contained in them. */
68
df407dfe 69extern int value_bitsize (struct value *);
9bbda503 70extern void set_value_bitsize (struct value *, int bit);
91294c83
AC
71
72/* Only used for bitfields; position of start of field. For
32c9a795
MD
73 gdbarch_bits_big_endian=0 targets, it is the position of the LSB. For
74 gdbarch_bits_big_endian=1 targets, it is the position of the MSB. */
91294c83 75
df407dfe 76extern int value_bitpos (struct value *);
9bbda503 77extern void set_value_bitpos (struct value *, int bit);
f5cf64a7 78
91294c83
AC
79/* Describes offset of a value within lval of a structure in bytes.
80 If lval == lval_memory, this is an offset to the address. If lval
81 == lval_register, this is a further offset from location.address
82 within the registers structure. Note also the member
83 embedded_offset below. */
84
df407dfe 85extern int value_offset (struct value *);
f5cf64a7 86extern void set_value_offset (struct value *, int offset);
df407dfe 87
88e3b34b
AC
88/* The comment from "struct value" reads: ``Is it modifiable? Only
89 relevant if lval != not_lval.''. Shouldn't the value instead be
90 not_lval and be done with it? */
91294c83 91
88e3b34b
AC
92extern int deprecated_value_modifiable (struct value *value);
93extern void deprecated_set_value_modifiable (struct value *value,
94 int modifiable);
95
91294c83
AC
96/* If a value represents a C++ object, then the `type' field gives the
97 object's compile-time type. If the object actually belongs to some
98 class derived from `type', perhaps with other base classes and
99 additional members, then `type' is just a subobject of the real
100 thing, and the full object is probably larger than `type' would
101 suggest.
102
103 If `type' is a dynamic class (i.e. one with a vtable), then GDB can
104 actually determine the object's run-time type by looking at the
105 run-time type information in the vtable. When this information is
106 available, we may elect to read in the entire object, for several
107 reasons:
108
109 - When printing the value, the user would probably rather see the
110 full object, not just the limited portion apparent from the
111 compile-time type.
112
113 - If `type' has virtual base classes, then even printing `type'
114 alone may require reaching outside the `type' portion of the
115 object to wherever the virtual base class has been stored.
116
117 When we store the entire object, `enclosing_type' is the run-time
118 type -- the complete object -- and `embedded_offset' is the offset
119 of `type' within that larger type, in bytes. The value_contents()
120 macro takes `embedded_offset' into account, so most GDB code
121 continues to see the `type' portion of the value, just as the
122 inferior would.
123
124 If `type' is a pointer to an object, then `enclosing_type' is a
125 pointer to the object's run-time type, and `pointed_to_offset' is
126 the offset in bytes from the full object to the pointed-to object
127 -- that is, the value `embedded_offset' would have if we followed
128 the pointer and fetched the complete object. (I don't really see
129 the point. Why not just determine the run-time type when you
130 indirect, and avoid the special case? The contents don't matter
131 until you indirect anyway.)
132
133 If we're not doing anything fancy, `enclosing_type' is equal to
134 `type', and `embedded_offset' is zero, so everything works
135 normally. */
136
4754a64e 137extern struct type *value_enclosing_type (struct value *);
91294c83
AC
138extern struct value *value_change_enclosing_type (struct value *val,
139 struct type *new_type);
140extern int value_pointed_to_offset (struct value *value);
141extern void set_value_pointed_to_offset (struct value *value, int val);
142extern int value_embedded_offset (struct value *value);
143extern void set_value_embedded_offset (struct value *value, int val);
144
5f5233d4
PA
145/* For lval_computed values, this structure holds functions used to
146 retrieve and set the value (or portions of the value).
147
148 For each function, 'V' is the 'this' pointer: an lval_funcs
149 function F may always assume that the V it receives is an
150 lval_computed value, and has F in the appropriate slot of its
151 lval_funcs structure. */
152
153struct lval_funcs
154{
155 /* Fill in VALUE's contents. This is used to "un-lazy" values. If
156 a problem arises in obtaining VALUE's bits, this function should
157 call 'error'. */
158 void (*read) (struct value *v);
159
160 /* Handle an assignment TOVAL = FROMVAL by writing the value of
161 FROMVAL to TOVAL's location. The contents of TOVAL have not yet
162 been updated. If a problem arises in doing so, this function
163 should call 'error'. */
164 void (*write) (struct value *toval, struct value *fromval);
165
166 /* Return a duplicate of VALUE's closure, for use in a new value.
167 This may simply return the same closure, if VALUE's is
168 reference-counted or statically allocated.
169
170 This may be NULL, in which case VALUE's closure is re-used in the
171 new value. */
172 void *(*copy_closure) (struct value *v);
173
174 /* Drop VALUE's reference to its closure. Maybe this frees the
175 closure; maybe this decrements a reference count; maybe the
176 closure is statically allocated and this does nothing.
177
178 This may be NULL, in which case no action is taken to free
179 VALUE's closure. */
180 void (*free_closure) (struct value *v);
181};
182
183/* Create a computed lvalue, with type TYPE, function pointers FUNCS,
184 and closure CLOSURE. */
185
186extern struct value *allocate_computed_value (struct type *type,
187 struct lval_funcs *funcs,
188 void *closure);
189
190/* If VALUE is lval_computed, return its lval_funcs structure. */
191
192extern struct lval_funcs *value_computed_funcs (struct value *value);
193
194/* If VALUE is lval_computed, return its closure. The meaning of the
195 returned value depends on the functions VALUE uses. */
196
197extern void *value_computed_closure (struct value *value);
198
91294c83 199/* If zero, contents of this value are in the contents field. If
9214ee5f
DJ
200 nonzero, contents are in inferior. If the lval field is lval_memory,
201 the contents are in inferior memory at location.address plus offset.
202 The lval field may also be lval_register.
91294c83
AC
203
204 WARNING: This field is used by the code which handles watchpoints
205 (see breakpoint.c) to decide whether a particular value can be
206 watched by hardware watchpoints. If the lazy flag is set for some
207 member of a value chain, it is assumed that this member of the
208 chain doesn't need to be watched as part of watching the value
209 itself. This is how GDB avoids watching the entire struct or array
210 when the user wants to watch a single struct member or array
211 element. If you ever change the way lazy flag is set and reset, be
212 sure to consider this use as well! */
213
d69fe07e 214extern int value_lazy (struct value *);
dfa52d88 215extern void set_value_lazy (struct value *value, int val);
dea7f9ba 216
0fd88904
AC
217/* value_contents() and value_contents_raw() both return the address
218 of the gdb buffer used to hold a copy of the contents of the lval.
219 value_contents() is used when the contents of the buffer are needed
dea7f9ba 220 -- it uses value_fetch_lazy() to load the buffer from the process
0fd88904
AC
221 being debugged if it hasn't already been loaded
222 (value_contents_writeable() is used when a writeable but fetched
223 buffer is required).. value_contents_raw() is used when data is
224 being stored into the buffer, or when it is certain that the
225 contents of the buffer are valid.
dea7f9ba 226
c906108c
SS
227 Note: The contents pointer is adjusted by the offset required to
228 get to the real subobject, if the value happens to represent
dea7f9ba 229 something embedded in a larger run-time object. */
c906108c 230
fc1a4b47 231extern gdb_byte *value_contents_raw (struct value *);
91294c83
AC
232
233/* Actual contents of the value. For use of this value; setting it
234 uses the stuff above. Not valid if lazy is nonzero. Target
235 byte-order. We force it to be aligned properly for any possible
236 value. Note that a value therefore extends beyond what is
237 declared here. */
238
fc1a4b47
AC
239extern const gdb_byte *value_contents (struct value *);
240extern gdb_byte *value_contents_writeable (struct value *);
c906108c
SS
241
242/* The ALL variants of the above two macros do not adjust the returned
dea7f9ba 243 pointer by the embedded_offset value. */
c5aa993b 244
fc1a4b47
AC
245extern gdb_byte *value_contents_all_raw (struct value *);
246extern const gdb_byte *value_contents_all (struct value *);
c5aa993b 247
f23631e4 248extern int value_fetch_lazy (struct value *val);
a6c442d8 249extern int value_contents_equal (struct value *val1, struct value *val2);
c906108c 250
91294c83
AC
251/* If nonzero, this is the value of a variable which does not actually
252 exist in the program. */
feb13ab0
AC
253extern int value_optimized_out (struct value *value);
254extern void set_value_optimized_out (struct value *value, int val);
c906108c 255
f372da99
CT
256/* Set or return field indicating whether a variable is initialized or
257 not, based on debugging information supplied by the compiler.
258 1 = initialized; 0 = uninitialized. */
259extern int value_initialized (struct value *);
260extern void set_value_initialized (struct value *, int);
261
74bcbdf3
PA
262/* Set COMPONENT's location as appropriate for a component of WHOLE
263 --- regardless of what kind of lvalue WHOLE is. */
264extern void set_value_component_location (struct value *component,
265 struct value *whole);
266
13bb5560
AC
267/* While the following fields are per- VALUE .CONTENT .PIECE (i.e., a
268 single value might have multiple LVALs), this hacked interface is
269 limited to just the first PIECE. Expect further change. */
91294c83
AC
270/* Type of value; either not an lval, or one of the various different
271 possible kinds of lval. */
13bb5560
AC
272extern enum lval_type *deprecated_value_lval_hack (struct value *);
273#define VALUE_LVAL(val) (*deprecated_value_lval_hack (val))
91294c83 274
42ae5230
TT
275/* If lval == lval_memory, return the address in the inferior. If
276 lval == lval_register, return the byte offset into the registers
277 structure. Otherwise, return 0. The returned address
278 includes the offset, if any. */
279extern CORE_ADDR value_address (struct value *);
280
281/* Like value_address, except the result does not include value's
282 offset. */
283extern CORE_ADDR value_raw_address (struct value *);
284
285/* Set the address of a value. */
286extern void set_value_address (struct value *, CORE_ADDR);
91294c83
AC
287
288/* Pointer to internal variable. */
13bb5560
AC
289extern struct internalvar **deprecated_value_internalvar_hack (struct value *);
290#define VALUE_INTERNALVAR(val) (*deprecated_value_internalvar_hack (val))
91294c83
AC
291
292/* Frame register value is relative to. This will be described in the
293 lval enum above as "lval_register". */
13bb5560
AC
294extern struct frame_id *deprecated_value_frame_id_hack (struct value *);
295#define VALUE_FRAME_ID(val) (*deprecated_value_frame_id_hack (val))
91294c83
AC
296
297/* Register number if the value is from a register. */
13bb5560
AC
298extern short *deprecated_value_regnum_hack (struct value *);
299#define VALUE_REGNUM(val) (*deprecated_value_regnum_hack (val))
300
dea7f9ba 301/* Convert a REF to the object referenced. */
c906108c 302
994b9211 303extern struct value *coerce_ref (struct value *value);
c906108c
SS
304
305/* If ARG is an array, convert it to a pointer.
c906108c
SS
306 If ARG is a function, convert it to a function pointer.
307
308 References are dereferenced. */
309
994b9211 310extern struct value *coerce_array (struct value *value);
c906108c 311
c906108c 312\f
c5aa993b 313
c906108c
SS
314#include "symtab.h"
315#include "gdbtypes.h"
316#include "expression.h"
317
c906108c
SS
318struct frame_info;
319struct fn_field;
c906108c 320
d9fcf2fb 321extern void print_address_demangle (CORE_ADDR, struct ui_file *, int);
c906108c 322
f23631e4 323extern LONGEST value_as_long (struct value *val);
f23631e4 324extern DOUBLEST value_as_double (struct value *val);
f23631e4 325extern CORE_ADDR value_as_address (struct value *val);
c906108c 326
fc1a4b47
AC
327extern LONGEST unpack_long (struct type *type, const gdb_byte *valaddr);
328extern DOUBLEST unpack_double (struct type *type, const gdb_byte *valaddr,
66140c26 329 int *invp);
fc1a4b47 330extern CORE_ADDR unpack_pointer (struct type *type, const gdb_byte *valaddr);
8929e59d 331extern LONGEST unpack_field_as_long (struct type *type,
fc1a4b47 332 const gdb_byte *valaddr,
a14ed312 333 int fieldno);
c906108c 334
14d06750
DJ
335extern void pack_long (gdb_byte *buf, struct type *type, LONGEST num);
336
f23631e4 337extern struct value *value_from_longest (struct type *type, LONGEST num);
f23631e4 338extern struct value *value_from_pointer (struct type *type, CORE_ADDR addr);
f23631e4 339extern struct value *value_from_double (struct type *type, DOUBLEST num);
4ef30785
TJB
340extern struct value *value_from_decfloat (struct type *type,
341 const gdb_byte *decbytes);
0f71a2f6 342
00a4c844
AC
343extern struct value *value_at (struct type *type, CORE_ADDR addr);
344extern struct value *value_at_lazy (struct type *type, CORE_ADDR addr);
c906108c 345
8acb6b92
TT
346extern struct value *value_from_contents_and_address (struct type *,
347 const gdb_byte *,
348 CORE_ADDR);
349
9acbedc0
UW
350extern struct value *default_value_from_register (struct type *type,
351 int regnum,
352 struct frame_info *frame);
353
f23631e4
AC
354extern struct value *value_from_register (struct type *type, int regnum,
355 struct frame_info *frame);
c906108c 356
0b2b0195
UW
357extern CORE_ADDR address_from_register (struct type *type, int regnum,
358 struct frame_info *frame);
359
f23631e4 360extern struct value *value_of_variable (struct symbol *var, struct block *b);
c906108c 361
61212c0f
UW
362extern struct value *address_of_variable (struct symbol *var, struct block *b);
363
89f5065b 364extern struct value *value_of_register (int regnum, struct frame_info *frame);
c906108c 365
9214ee5f
DJ
366struct value *value_of_register_lazy (struct frame_info *frame, int regnum);
367
a14ed312 368extern int symbol_read_needs_frame (struct symbol *);
c906108c 369
f23631e4
AC
370extern struct value *read_var_value (struct symbol *var,
371 struct frame_info *frame);
c906108c 372
f23631e4 373extern struct value *allocate_value (struct type *type);
3e3d7139
JG
374extern struct value *allocate_value_lazy (struct type *type);
375extern void allocate_value_contents (struct value *value);
c906108c 376
f23631e4 377extern struct value *allocate_repeat_value (struct type *type, int count);
c906108c 378
f23631e4 379extern struct value *value_mark (void);
c906108c 380
f23631e4 381extern void value_free_to_mark (struct value *mark);
c906108c 382
3b7538c0
UW
383extern struct value *value_cstring (char *ptr, int len,
384 struct type *char_type);
385extern struct value *value_string (char *ptr, int len,
386 struct type *char_type);
f23631e4 387extern struct value *value_bitstring (char *ptr, int len);
c906108c 388
f23631e4 389extern struct value *value_array (int lowbound, int highbound,
89f5065b 390 struct value **elemvec);
c906108c 391
f23631e4 392extern struct value *value_concat (struct value *arg1, struct value *arg2);
c906108c 393
f23631e4
AC
394extern struct value *value_binop (struct value *arg1, struct value *arg2,
395 enum exp_opcode op);
c906108c 396
89eef114 397extern struct value *value_ptradd (struct value *arg1, struct value *arg2);
c906108c 398
89eef114
UW
399extern struct value *value_ptrsub (struct value *arg1, struct value *arg2);
400
401extern LONGEST value_ptrdiff (struct value *arg1, struct value *arg2);
c906108c 402
63092375
DJ
403extern int value_must_coerce_to_target (struct value *arg1);
404
405extern struct value *value_coerce_to_target (struct value *arg1);
406
f23631e4 407extern struct value *value_coerce_array (struct value *arg1);
c906108c 408
f23631e4 409extern struct value *value_coerce_function (struct value *arg1);
c906108c 410
f23631e4 411extern struct value *value_ind (struct value *arg1);
c906108c 412
f23631e4 413extern struct value *value_addr (struct value *arg1);
c906108c 414
fb933624
DJ
415extern struct value *value_ref (struct value *arg1);
416
89f5065b
AC
417extern struct value *value_assign (struct value *toval,
418 struct value *fromval);
c906108c 419
36e9969c
NS
420extern struct value *value_pos (struct value *arg1);
421
f23631e4 422extern struct value *value_neg (struct value *arg1);
c906108c 423
f23631e4 424extern struct value *value_complement (struct value *arg1);
c906108c 425
f23631e4
AC
426extern struct value *value_struct_elt (struct value **argp,
427 struct value **args,
428 char *name, int *static_memfuncp,
429 char *err);
c906108c 430
79c2c32d 431extern struct value *value_aggregate_elt (struct type *curtype,
0d5de010
DJ
432 char *name,
433 int want_address,
434 enum noside noside);
c906108c 435
f23631e4 436extern struct value *value_static_field (struct type *type, int fieldno);
c906108c 437
f23631e4 438extern struct fn_field *value_find_oload_method_list (struct value **, char *,
4a1970e4 439 int, int *,
a14ed312 440 struct type **, int *);
7a292a7a 441
a14ed312
KB
442extern int find_overload_match (struct type **arg_types, int nargs,
443 char *name, int method, int lax,
7f8c9282 444 struct value **objp, struct symbol *fsym,
f23631e4 445 struct value **valp, struct symbol **symp,
a14ed312 446 int *staticp);
c906108c 447
f23631e4 448extern struct value *value_field (struct value *arg1, int fieldno);
c906108c 449
f23631e4
AC
450extern struct value *value_primitive_field (struct value *arg1, int offset,
451 int fieldno,
452 struct type *arg_type);
c906108c 453
c906108c 454
f23631e4
AC
455extern struct type *value_rtti_target_type (struct value *, int *, int *,
456 int *);
c906108c 457
f23631e4
AC
458extern struct value *value_full_object (struct value *, struct type *, int,
459 int, int);
c906108c 460
fb933624
DJ
461extern struct value *value_cast_pointers (struct type *, struct value *);
462
f23631e4 463extern struct value *value_cast (struct type *type, struct value *arg2);
c906108c 464
f23631e4 465extern struct value *value_zero (struct type *type, enum lval_type lv);
c906108c 466
301f0ecf
DE
467extern struct value *value_one (struct type *type, enum lval_type lv);
468
f23631e4 469extern struct value *value_repeat (struct value *arg1, int count);
c906108c 470
f23631e4 471extern struct value *value_subscript (struct value *array, struct value *idx);
c906108c 472
afc05acb
UW
473extern struct value *value_bitstring_subscript (struct type *type,
474 struct value *bitstring,
475 struct value *idx);
476
5fe830e4
AC
477extern struct value *register_value_being_returned (struct type *valtype,
478 struct regcache *retbuf);
c906108c 479
fbb06eb1 480extern int value_in (struct value *element, struct value *set);
c906108c 481
fc1a4b47 482extern int value_bit_index (struct type *type, const gdb_byte *addr,
c84141d6 483 int index);
c906108c 484
d80b854b
UW
485extern int using_struct_return (struct gdbarch *gdbarch,
486 struct type *func_type,
c055b101 487 struct type *value_type);
c906108c 488
f23631e4 489extern struct value *evaluate_expression (struct expression *exp);
c906108c 490
f23631e4 491extern struct value *evaluate_type (struct expression *exp);
c906108c 492
4b27a620
JB
493extern struct value *evaluate_subexp (struct type *expect_type,
494 struct expression *exp,
495 int *pos, enum noside noside);
496
65d12d83
TT
497extern struct value *evaluate_subexpression_type (struct expression *exp,
498 int subexp);
499
500extern char *extract_field_op (struct expression *exp, int *subexp);
501
f23631e4
AC
502extern struct value *evaluate_subexp_with_coercion (struct expression *,
503 int *, enum noside);
c906108c 504
f23631e4 505extern struct value *parse_and_eval (char *exp);
c906108c 506
f23631e4 507extern struct value *parse_to_comma_and_eval (char **expp);
c906108c 508
a14ed312 509extern struct type *parse_and_eval_type (char *p, int length);
c906108c 510
a14ed312 511extern CORE_ADDR parse_and_eval_address (char *exp);
c906108c 512
a14ed312 513extern CORE_ADDR parse_and_eval_address_1 (char **expptr);
c906108c 514
bb518678
DT
515extern LONGEST parse_and_eval_long (char *exp);
516
4066e646
UW
517extern void unop_promote (const struct language_defn *language,
518 struct gdbarch *gdbarch,
519 struct value **arg1);
520
521extern void binop_promote (const struct language_defn *language,
522 struct gdbarch *gdbarch,
523 struct value **arg1, struct value **arg2);
524
f23631e4 525extern struct value *access_value_history (int num);
c906108c 526
f23631e4 527extern struct value *value_of_internalvar (struct internalvar *var);
c906108c 528
4fa62494
UW
529extern int get_internalvar_integer (struct internalvar *var, LONGEST *l);
530
f23631e4 531extern void set_internalvar (struct internalvar *var, struct value *val);
c906108c 532
4fa62494
UW
533extern void set_internalvar_integer (struct internalvar *var, LONGEST l);
534
535extern void clear_internalvar (struct internalvar *var);
536
a14ed312
KB
537extern void set_internalvar_component (struct internalvar *var,
538 int offset,
539 int bitpos, int bitsize,
f23631e4 540 struct value *newvalue);
c906108c 541
bc3b79fd 542extern struct internalvar *lookup_only_internalvar (const char *name);
c4a3d09a 543
bc3b79fd 544extern struct internalvar *create_internalvar (const char *name);
c4a3d09a 545
4fa62494
UW
546typedef struct value * (*internalvar_make_value) (struct internalvar *);
547
4aa995e1
PA
548extern struct internalvar *
549 create_internalvar_type_lazy (char *name, internalvar_make_value fun);
550
bc3b79fd 551extern struct internalvar *lookup_internalvar (const char *name);
c906108c 552
f23631e4 553extern int value_equal (struct value *arg1, struct value *arg2);
c906108c 554
f23631e4 555extern int value_less (struct value *arg1, struct value *arg2);
c906108c 556
f23631e4 557extern int value_logical_not (struct value *arg1);
c906108c
SS
558
559/* C++ */
560
f23631e4 561extern struct value *value_of_this (int complain);
c906108c 562
f23631e4
AC
563extern struct value *value_x_binop (struct value *arg1, struct value *arg2,
564 enum exp_opcode op,
565 enum exp_opcode otherop,
566 enum noside noside);
c906108c 567
f23631e4
AC
568extern struct value *value_x_unop (struct value *arg1, enum exp_opcode op,
569 enum noside noside);
c906108c 570
89f5065b 571extern struct value *value_fn_field (struct value **arg1p, struct fn_field *f,
f23631e4 572 int j, struct type *type, int offset);
c906108c 573
f23631e4
AC
574extern int binop_user_defined_p (enum exp_opcode op, struct value *arg1,
575 struct value *arg2);
c906108c 576
f23631e4 577extern int unop_user_defined_p (enum exp_opcode op, struct value *arg1);
c906108c 578
a14ed312 579extern int destructor_name_p (const char *name, const struct type *type);
c906108c 580
3e3d7139 581extern void value_free (struct value *val);
c906108c 582
a14ed312 583extern void free_all_values (void);
c906108c 584
f23631e4 585extern void release_value (struct value *val);
c906108c 586
f23631e4 587extern int record_latest_value (struct value *val);
c906108c 588
fc1a4b47 589extern void modify_field (gdb_byte *addr, LONGEST fieldval, int bitpos,
570b8f7c 590 int bitsize);
c906108c 591
89f5065b
AC
592extern void type_print (struct type *type, char *varstring,
593 struct ui_file *stream, int show);
c906108c 594
ae6a3a4c
TJB
595extern char *type_to_string (struct type *type);
596
fc1a4b47
AC
597extern gdb_byte *baseclass_addr (struct type *type, int index,
598 gdb_byte *valaddr,
8929e59d 599 struct value **valuep, int *errp);
c906108c 600
89f5065b 601extern void print_longest (struct ui_file *stream, int format,
d9fcf2fb 602 int use_local, LONGEST val);
c906108c 603
fc1a4b47 604extern void print_floating (const gdb_byte *valaddr, struct type *type,
89f5065b 605 struct ui_file *stream);
c906108c 606
7678ef8f
TJB
607extern void print_decimal_floating (const gdb_byte *valaddr, struct type *type,
608 struct ui_file *stream);
609
79a45b7d
TT
610extern int value_print (struct value *val, struct ui_file *stream,
611 const struct value_print_options *options);
c906108c 612
f23631e4
AC
613extern void value_print_array_elements (struct value *val,
614 struct ui_file *stream, int format,
d9fcf2fb 615 enum val_prettyprint pretty);
c906108c 616
f23631e4 617extern struct value *value_release_to_mark (struct value *mark);
c906108c 618
fc1a4b47 619extern int val_print (struct type *type, const gdb_byte *valaddr,
d9fcf2fb 620 int embedded_offset, CORE_ADDR address,
79a45b7d
TT
621 struct ui_file *stream, int recurse,
622 const struct value_print_options *options,
d8ca156b 623 const struct language_defn *language);
c906108c 624
806048c6 625extern int common_val_print (struct value *val,
79a45b7d
TT
626 struct ui_file *stream, int recurse,
627 const struct value_print_options *options,
d8ca156b 628 const struct language_defn *language);
806048c6 629
6c7a06a3 630extern int val_print_string (struct type *elttype, CORE_ADDR addr, int len,
79a45b7d
TT
631 struct ui_file *stream,
632 const struct value_print_options *options);
c906108c 633
aad95b57
TT
634extern void print_variable_and_value (const char *name,
635 struct symbol *var,
636 struct frame_info *frame,
637 struct ui_file *stream,
638 int indent);
c906108c 639
2b2d9e11 640extern int check_field (struct type *, const char *);
c906108c 641
89f5065b
AC
642extern void typedef_print (struct type *type, struct symbol *news,
643 struct ui_file *stream);
c906108c 644
a14ed312 645extern char *internalvar_name (struct internalvar *var);
c906108c 646
ae5a43e0 647extern void preserve_values (struct objfile *);
c906108c
SS
648
649/* From values.c */
650
f23631e4 651extern struct value *value_copy (struct value *);
c906108c 652
c906108c
SS
653/* From valops.c */
654
f23631e4 655extern struct value *varying_to_slice (struct value *);
c906108c 656
f23631e4 657extern struct value *value_slice (struct value *, int, int);
c906108c 658
f23631e4
AC
659extern struct value *value_literal_complex (struct value *, struct value *,
660 struct type *);
c906108c 661
3e3b026f
UW
662extern struct value *find_function_in_inferior (const char *,
663 struct objfile **);
c906108c 664
f23631e4 665extern struct value *value_allocate_space_in_inferior (int);
c906108c 666
d069f99d
AF
667extern struct value *value_of_local (const char *name, int complain);
668
9eec4d1e 669extern struct value * value_subscripted_rvalue (struct value *array, struct value *idx, int lowerbound);
bc3b79fd
TJB
670
671/* User function handler. */
672
673typedef struct value *(*internal_function_fn) (void *cookie,
674 int argc,
675 struct value **argv);
676
677void add_internal_function (const char *name, const char *doc,
678 internal_function_fn handler,
679 void *cookie);
680
681struct value *call_internal_function (struct value *function,
682 int argc, struct value **argv);
683
684char *value_internal_function_name (struct value *);
685
c5aa993b 686#endif /* !defined (VALUE_H) */
This page took 0.896976 seconds and 4 git commands to generate.