diff options
author | Pedro Alves <palves@redhat.com> | 2018-11-30 17:49:49 +0000 |
---|---|---|
committer | Pedro Alves <palves@redhat.com> | 2018-11-30 17:49:49 +0000 |
commit | 66b4deae03e7a503f8c543aa198a8c010863135a (patch) | |
tree | 41030b08bd4b97e6d50004867b2a0bd20d0e9c73 /gdb/process-stratum-target.h | |
parent | 20a71194793bfa791b9090db2d47a67388650d93 (diff) | |
download | gdb-66b4deae03e7a503f8c543aa198a8c010863135a.zip gdb-66b4deae03e7a503f8c543aa198a8c010863135a.tar.gz gdb-66b4deae03e7a503f8c543aa198a8c010863135a.tar.bz2 |
target_ops::to_stratum -> target_ops::stratum() virtual method
Given that a target's stratum is a property of the type, and not of an
instance of the type, get rid of to_stratum data field and replace it
with a virtual method.
I.e., when we have e.g., 10 target remote instances active, there's no
need for each of the instances to have their own to_stratum copy.
gdb/ChangeLog:
2018-11-30 Pedro Alves <palves@redhat.com>
* aix-thread.c (aix_thread_target) <aix_thread_target>: Delete.
<stratum>: New override.
* bfd-target.c (aix_thread_target) <aix_thread_target>: Delete.
<stratum>: New override.
* bsd-uthread.c (bsd_uthread_target) <bsd_uthread_target>: Delete.
<stratum>: New override.
* exec.c (exec_target) <exec_target>: Delete.
<stratum>: New override.
* gdbarch-selftests.c (register_to_value_test): Adjust to use the
stratum method instead of the to_stratum field.
* linux-thread-db.c (thread_db_target) <thread_db_target>: Delete.
<stratum>: New override.
(thread_db_target::thread_db_target): Delete.
* make-target-delegates (print_class): Don't print a ctor
declaration. Print a stratum method override declaration.
* process-stratum-target.h (process_stratum_target)
<process_stratum_target>: Delete.
<stratum>: New override.
* ravenscar-thread.c (ravenscar_thread_target)
<ravenscar_thread_target>: Delete.
<stratum>: New override.
* record-btrace.c (record_btrace_target)
<record_btrace_target>: Delete.
<stratum>: New override.
* record-full.c (record_full_base_target)
<record_full_base_target>: Delete.
<stratum>: New override.
* record.c (record_disconnect, record_detach)
(record_mourn_inferior, record_kill): Adjust to use the stratum
method instead of the to_stratum field.
* regcache.c (cooked_read_test, cooked_write_test): Likewise.
* sol-thread.c (sol_thread_target)
<sol_thread_target>: Delete.
<stratum>: New override.
* spu-multiarch.c (spu_multiarch_target)
<spu_multiarch_target>: Delete.
<stratum>: New override.
* target-delegates.c: Regenerate.
* target.c (target_stack::push, target_stack::unpush)
(pop_all_targets_above, pop_all_targets_at_and_above)
(info_target_command, target_require_runnable)
(target_stack::find_beneath): Adjust to use the stratum method
instead of the to_stratum field.
(dummy_target::dummy_target): Delete.
(dummy_target::stratum): New.
(debug_target::debug_target): Delete.
(debug_target::stratum): New.
(maintenance_print_target_stack): Adjust to use the stratum method
instead of the to_stratum field.
* target.h (struct target_ops) <stratum>: New method.
<to_stratum>: Delete.
<is_pushed>: Adjust to use the stratum method
instead of the to_stratum field.
Diffstat (limited to 'gdb/process-stratum-target.h')
-rw-r--r-- | gdb/process-stratum-target.h | 7 |
1 files changed, 2 insertions, 5 deletions
diff --git a/gdb/process-stratum-target.h b/gdb/process-stratum-target.h index 74640aa..ce731eb 100644 --- a/gdb/process-stratum-target.h +++ b/gdb/process-stratum-target.h @@ -27,13 +27,10 @@ class process_stratum_target : public target_ops { public: - process_stratum_target () - { - to_stratum = process_stratum; - } - ~process_stratum_target () override = 0; + strata stratum () const override { return process_stratum; } + /* We must default these because they must be implemented by any target that can run. */ bool can_async_p () override { return false; } |