VirtualBox

source: vbox/trunk/src/VBox/Debugger/VBoxDbgGui.h@ 76882

Last change on this file since 76882 was 76564, checked in by vboxsync, 6 years ago

Debugger: Use DEBUGGER_INCLUDED_SRC_ as header guard prefix with scm.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.1 KB
Line 
1/* $Id: VBoxDbgGui.h 76564 2019-01-01 03:57:14Z vboxsync $ */
2/** @file
3 * VBox Debugger GUI - The Manager.
4 */
5
6/*
7 * Copyright (C) 2006-2019 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17
18#ifndef DEBUGGER_INCLUDED_SRC_VBoxDbgGui_h
19#define DEBUGGER_INCLUDED_SRC_VBoxDbgGui_h
20#ifndef RT_WITHOUT_PRAGMA_ONCE
21# pragma once
22#endif
23
24// VirtualBox COM interfaces declarations (generated header)
25#ifdef VBOX_WITH_XPCOM
26# include <VirtualBox_XPCOM.h>
27#else
28# include <VirtualBox.h>
29#endif
30
31#include "VBoxDbgStatsQt.h"
32#include "VBoxDbgConsole.h"
33
34
35/**
36 * The Debugger GUI manager class.
37 *
38 * It's job is to provide a C callable external interface and manage the
39 * windows and bit making up the debugger GUI.
40 */
41class VBoxDbgGui : public QObject
42{
43 Q_OBJECT;
44
45public:
46 /**
47 * Create a default VBoxDbgGui object.
48 */
49 VBoxDbgGui();
50
51 /**
52 * Initializes a VBoxDbgGui object by ISession.
53 *
54 * @returns VBox status code.
55 * @param pSession VBox Session object.
56 */
57 int init(ISession *pSession);
58
59 /**
60 * Initializes a VBoxDbgGui object by VM handle.
61 *
62 * @returns VBox status code.
63 * @param pUVM The user mode VM handle. The caller's reference will be
64 * consumed on success.
65 */
66 int init(PUVM pUVM);
67
68 /**
69 * Destroys the VBoxDbgGui object.
70 */
71 virtual ~VBoxDbgGui();
72
73 /**
74 * Sets the parent widget.
75 *
76 * @param pParent New parent widget.
77 * @remarks This only affects new windows.
78 */
79 void setParent(QWidget *pParent);
80
81 /**
82 * Sets the menu object.
83 *
84 * @param pMenu New menu object.
85 * @remarks This only affects new menu additions.
86 */
87 void setMenu(QMenu *pMenu);
88
89 /**
90 * Show the default statistics window, creating it if necessary.
91 *
92 * @returns VBox status code.
93 */
94 int showStatistics();
95
96 /**
97 * Repositions and resizes (optionally) the statistics to its defaults
98 *
99 * @param fResize If set (default) the size of window is also changed.
100 */
101 void repositionStatistics(bool fResize = true);
102
103 /**
104 * Show the console window (aka. command line), creating it if necessary.
105 *
106 * @returns VBox status code.
107 */
108 int showConsole();
109
110 /**
111 * Repositions and resizes (optionally) the console to its defaults
112 *
113 * @param fResize If set (default) the size of window is also changed.
114 */
115 void repositionConsole(bool fResize = true);
116
117 /**
118 * Update the desktop size.
119 * This is called whenever the reference window changes position.
120 */
121 void updateDesktopSize();
122
123 /**
124 * Notifies the debugger GUI that the console window (or whatever) has changed
125 * size or position.
126 *
127 * @param x The x-coordinate of the window the debugger is relative to.
128 * @param y The y-coordinate of the window the debugger is relative to.
129 * @param cx The width of the window the debugger is relative to.
130 * @param cy The height of the window the debugger is relative to.
131 */
132 void adjustRelativePos(int x, int y, unsigned cx, unsigned cy);
133
134 /**
135 * Gets the user mode VM handle.
136 * @returns The UVM handle.
137 */
138 PUVM getUvmHandle() const
139 {
140 return m_pUVM;
141 }
142
143
144protected slots:
145 /**
146 * Notify that a child object (i.e. a window is begin destroyed).
147 * @param pObj The object which is being destroyed.
148 */
149 void notifyChildDestroyed(QObject *pObj);
150
151protected:
152
153 /** The debugger statistics. */
154 VBoxDbgStats *m_pDbgStats;
155 /** The debugger console (aka. command line). */
156 VBoxDbgConsole *m_pDbgConsole;
157
158 /** The VirtualBox session. */
159 ISession *m_pSession;
160 /** The VirtualBox console. */
161 IConsole *m_pConsole;
162 /** The VirtualBox Machine Debugger. */
163 IMachineDebugger *m_pMachineDebugger;
164 /** The VirtualBox Machine. */
165 IMachine *m_pMachine;
166 /** The VM instance. */
167 PVM m_pVM;
168 /** The user mode VM handle. */
169 PUVM m_pUVM;
170
171 /** The parent widget. */
172 QWidget *m_pParent;
173 /** The menu object for the 'debug' menu. */
174 QMenu *m_pMenu;
175
176 /** The x-coordinate of the window we're relative to. */
177 int m_x;
178 /** The y-coordinate of the window we're relative to. */
179 int m_y;
180 /** The width of the window we're relative to. */
181 unsigned m_cx;
182 /** The height of the window we're relative to. */
183 unsigned m_cy;
184 /** The x-coordinate of the desktop. */
185 int m_xDesktop;
186 /** The y-coordinate of the desktop. */
187 int m_yDesktop;
188 /** The size of the desktop. */
189 unsigned m_cxDesktop;
190 /** The size of the desktop. */
191 unsigned m_cyDesktop;
192};
193
194
195#endif /* !DEBUGGER_INCLUDED_SRC_VBoxDbgGui_h */
196
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette