]>
Commit | Line | Data |
---|---|---|
c17a9e46 HZ |
1 | /* Python interface to inferior continue events. |
2 | ||
d01e8234 | 3 | Copyright (C) 2009-2025 Free Software Foundation, Inc. |
c17a9e46 HZ |
4 | |
5 | This file is part of GDB. | |
6 | ||
7 | This program is free software; you can redistribute it and/or modify | |
8 | it under the terms of the GNU General Public License as published by | |
9 | the Free Software Foundation; either version 3 of the License, or | |
10 | (at your option) any later version. | |
11 | ||
12 | This program is distributed in the hope that it will be useful, | |
13 | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
14 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
15 | GNU General Public License for more details. | |
16 | ||
17 | You should have received a copy of the GNU General Public License | |
18 | along with this program. If not, see <http://www.gnu.org/licenses/>. */ | |
19 | ||
20 | #include "py-event.h" | |
da3c8738 PA |
21 | #include "gdbthread.h" |
22 | ||
23 | /* Create a gdb.ContinueEvent event. gdb.ContinueEvent is-a | |
24 | gdb.ThreadEvent, and thread events can either be thread specific or | |
25 | process wide. If gdb is running in non-stop mode then the event is | |
26 | thread specific (in which case the PTID thread is included in the | |
27 | event), otherwise it is process wide (in which case PTID is | |
28 | ignored). In either case a new reference is returned. */ | |
c17a9e46 | 29 | |
35c61a1d | 30 | static gdbpy_ref<> |
da3c8738 | 31 | create_continue_event_object (ptid_t ptid) |
c17a9e46 | 32 | { |
db1337cc | 33 | gdbpy_ref<> py_thr = py_get_event_thread (ptid); |
da3c8738 PA |
34 | |
35 | if (py_thr == nullptr) | |
36 | return nullptr; | |
37 | ||
db1337cc TT |
38 | return create_thread_event_object (&continue_event_object_type, |
39 | py_thr.get ()); | |
c17a9e46 HZ |
40 | } |
41 | ||
42 | /* Callback function which notifies observers when a continue event occurs. | |
43 | This function will create a new Python continue event object. | |
44 | Return -1 if emit fails. */ | |
45 | ||
46 | int | |
47 | emit_continue_event (ptid_t ptid) | |
48 | { | |
c17a9e46 HZ |
49 | if (evregpy_no_listeners_p (gdb_py_events.cont)) |
50 | return 0; | |
51 | ||
d98fc15b | 52 | gdbpy_ref<> event = create_continue_event_object (ptid); |
abf5651e TT |
53 | if (event != NULL) |
54 | return evpy_emit_event (event.get (), gdb_py_events.cont); | |
c17a9e46 HZ |
55 | return -1; |
56 | } |