VirtualBox

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

Last change on this file since 12478 was 12469, checked in by vboxsync, 16 years ago

Debugger: qt4 copies of the stats impl.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.8 KB
Line 
1/* $Id: VBoxDbgGui.h 12469 2008-09-15 16:29:50Z vboxsync $ */
2/** @file
3 * VBox Debugger GUI - The Manager.
4 */
5
6/*
7 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
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 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
18 * Clara, CA 95054 USA or visit http://www.sun.com if you need
19 * additional information or have any questions.
20 */
21
22#ifndef ___Debugger_VBoxDbgGui_h
23#define ___Debugger_VBoxDbgGui_h
24
25// VirtualBox COM interfaces declarations (generated header)
26#ifdef VBOX_WITH_XPCOM
27# include <VirtualBox_XPCOM.h>
28#else
29# include <VirtualBox.h>
30#endif
31
32#ifdef VBOXDBG_USE_QT4
33# include "VBoxDbgStatsQt4.h"
34#else
35# include "VBoxDbgStats.h"
36#endif
37#include "VBoxDbgConsole.h"
38
39
40/**
41 * The Debugger GUI manager class.
42 *
43 * It's job is to provide a C callable external interface and manage the
44 * windows and bit making up the debugger GUI.
45 */
46class VBoxDbgGui : public QObject
47{
48 Q_OBJECT;
49
50public:
51 /**
52 * Create a default VBoxDbgGui object.
53 */
54 VBoxDbgGui();
55
56 /**
57 * Initializes a VBoxDbgGui object by ISession.
58 *
59 * @returns VBox status code.
60 * @param pSession VBox Session object.
61 */
62 int init(ISession *pSession);
63
64 /**
65 * Initializes a VBoxDbgGui object by VM handle.
66 *
67 * @returns VBox status code.
68 * @param pVM The VM handle.
69 */
70 int init(PVM pVM);
71
72 /**
73 * Destroys the VBoxDbgGui object.
74 */
75 virtual ~VBoxDbgGui();
76
77 /**
78 * Show the default statistics window, creating it if necessary.
79 *
80 * @returns VBox status code.
81 */
82 int showStatistics();
83
84 /**
85 * Repositions and resizes (optionally) the statistics to its defaults
86 *
87 * @param fResize If set (default) the size of window is also changed.
88 */
89 void repositionStatistics(bool fResize = true);
90
91 /**
92 * Show the console window (aka. command line), creating it if necessary.
93 *
94 * @returns VBox status code.
95 */
96 int showConsole();
97
98 /**
99 * Repositions and resizes (optionally) the console to its defaults
100 *
101 * @param fResize If set (default) the size of window is also changed.
102 */
103 void repositionConsole(bool fResize = true);
104
105 /**
106 * Update the desktop size.
107 * This is called whenever the reference window changes positition.
108 */
109 void updateDesktopSize();
110
111 /**
112 * Notifies the debugger GUI that the console window (or whatever) has changed
113 * size or position.
114 *
115 * @param x The x-coordinate of the window the debugger is relative to.
116 * @param y The y-coordinate of the window the debugger is relative to.
117 * @param cx The width of the window the debugger is relative to.
118 * @param cy The height of the window the debugger is relative to.
119 */
120 void adjustRelativePos(int x, int y, unsigned cx, unsigned cy);
121
122 /**
123 * Resizes a QWidget given the frame size.
124 *
125 * @param pWidget The widget to resize.
126 * @param cx The new frame height.
127 * @param cy The new frame width.
128 */
129 static void resizeWidget(QWidget *pWidget, unsigned cx, unsigned cy);
130
131protected slots:
132 /**
133 * Notify that a child object (i.e. a window is begin destroyed).
134 * @param pObj The object which is being destroyed.
135 */
136 void notifyChildDestroyed(QObject *pObj);
137
138protected:
139
140 /** The debugger statistics. */
141 VBoxDbgStats *m_pDbgStats;
142 /** The debugger console (aka. command line). */
143 VBoxDbgConsole *m_pDbgConsole;
144
145 /** The Virtual Box session. */
146 ISession *m_pSession;
147 /** The Virtual Box console. */
148 IConsole *m_pConsole;
149 /** The Virtual Box Machine Debugger. */
150 IMachineDebugger *m_pMachineDebugger;
151 /** The Virtual Box Machine. */
152 IMachine *m_pMachine;
153 /** The VM instance. */
154 PVM m_pVM;
155
156 /** The x-coordinate of the window we're relative to. */
157 int m_x;
158 /** The y-coordinate of the window we're relative to. */
159 int m_y;
160 /** The width of the window we're relative to. */
161 unsigned m_cx;
162 /** The height of the window we're relative to. */
163 unsigned m_cy;
164 /** The x-coordianate of the desktop. */
165 int m_xDesktop;
166 /** The y-coordianate of the desktop. */
167 int m_yDesktop;
168 /** The size of the desktop. */
169 unsigned m_cxDesktop;
170 /** The size of the desktop. */
171 unsigned m_cyDesktop;
172};
173
174
175#endif
176
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