VirtualBox

source: vbox/trunk/src/VBox/Frontends/VirtualBox4/include/VBoxGlobal.h@ 14442

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

FE/Qt4: Cumulative patch for defects (2928, 2883, 2405) : (1) Required video memory for VM Settings & New VM Wizard now feat integer megabytes number; (2) New VM Wizard updated with blocking 'Next' button when user assigns more than 50% of system memory to this vm; (3) New VM Wizard updated with silent calculation of video memory size required for fullscreen/seamless modes and selects the larger size between this and the recommended by os type; (4) OS Type Selector updated with 'recently selected os' storing mechanism used to switch to last chosen os type when switching os families; (5) 'Other' os family moved to the last position as the 'Other/Unknown' os type.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 35.6 KB
Line 
1/** @file
2 *
3 * VBox frontends: Qt GUI ("VirtualBox"):
4 * VBoxGlobal class declaration
5 */
6
7/*
8 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
9 *
10 * This file is part of VirtualBox Open Source Edition (OSE), as
11 * available from http://www.virtualbox.org. This file is free software;
12 * you can redistribute it and/or modify it under the terms of the GNU
13 * General Public License (GPL) as published by the Free Software
14 * Foundation, in version 2 as it comes in the "COPYING" file of the
15 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
16 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
17 *
18 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
19 * Clara, CA 95054 USA or visit http://www.sun.com if you need
20 * additional information or have any questions.
21 */
22
23#ifndef __VBoxGlobal_h__
24#define __VBoxGlobal_h__
25
26#include "COMDefs.h"
27
28#include "VBoxGlobalSettings.h"
29
30/* Qt includes */
31#include <QApplication>
32#include <QLayout>
33#include <QHash>
34#include <QPixmap>
35#include <QMenu>
36#include <QStyle>
37#include <QProcess>
38#include <QLinkedList>
39
40class QAction;
41class QLabel;
42class QToolButton;
43
44// Auxiliary types
45////////////////////////////////////////////////////////////////////////////////
46
47/**
48 * Media descriptor for the GUI.
49 *
50 * Maintains the results of the last state (accessibility) check and precomposes
51 * string parameters such as location, size which can be used in various GUI
52 * controls.
53 *
54 * Many getter methods take the boolean @a aNoDiffs argument. Unless explicitly
55 * stated otherwise, this argument, when set to @c true, will cause the
56 * corresponding property of this object's root medium to be returned instead of
57 * its own one. This is useful when hard disk media is represented in the
58 * user-friendly "don't show diffs" mode. For non-hard disk media, the value of
59 * this argument is irrelevant because the root object for such medium is
60 * the medium itself.
61 *
62 * Note that this class "abuses" the KMediaState_NotCreated state value to
63 * indicate that the accessibility check of the given medium (see
64 * #blockAndQueryState()) has not been done yet and therefore some parameters
65 * such as #size() are meaningless because they can be read only from the
66 * accessible medium. The real KMediaState_NotCreated state is not necessary
67 * because this class is only used with created (existing) media.
68 */
69class VBoxMedium
70{
71public:
72
73 /**
74 * Creates a null medium descriptor which is not associated with any medium.
75 * The state field is set to KMediaState_NotCreated.
76 */
77 VBoxMedium()
78 : mType (VBoxDefs::MediaType_Invalid)
79 , mState (KMediaState_NotCreated)
80 , mIsReadOnly (false), mIsUsedInSnapshots (false)
81 , mParent (NULL) {}
82
83 /**
84 * Creates a media descriptor associated with the given medium.
85 *
86 * The state field remain KMediaState_NotCreated until #blockAndQueryState()
87 * is called. All precomposed strings are filled up by implicitly calling
88 * #refresh(), see the #refresh() details for more info.
89 *
90 * One of the hardDisk, dvdImage, or floppyImage members is assigned from
91 * aMedium according to aType. @a aParent must be always NULL for non-hard
92 * disk media.
93 */
94 VBoxMedium (const CMedium &aMedium, VBoxDefs::MediaType aType,
95 VBoxMedium *aParent = NULL)
96 : mMedium (aMedium), mType (aType)
97 , mState (KMediaState_NotCreated)
98 , mIsReadOnly (false), mIsUsedInSnapshots (false)
99 , mParent (aParent) { init(); }
100
101 /**
102 * Similar to the other non-null constructor but sets the media state to
103 * @a aState. Suitable when the media state is known such as right after
104 * creation.
105 */
106 VBoxMedium (const CMedium &aMedium, VBoxDefs::MediaType aType,
107 KMediaState aState)
108 : mMedium (aMedium), mType (aType)
109 , mState (aState)
110 , mIsReadOnly (false), mIsUsedInSnapshots (false)
111 , mParent (NULL) { init(); }
112
113 void blockAndQueryState();
114 void refresh();
115
116 const CMedium &medium() const { return mMedium; };
117
118 VBoxDefs::MediaType type() const { return mType; }
119
120 /**
121 * Media state. In "don't show diffs" mode, this is the worst state (in
122 * terms of inaccessibility) detected on the given hard disk chain.
123 *
124 * @param aNoDiffs @c true to enable user-friendly "don't show diffs" mode.
125 */
126 KMediaState state (bool aNoDiffs = false) const
127 {
128 unconst (this)->checkNoDiffs (aNoDiffs);
129 return aNoDiffs ? mNoDiffs.state : mState;
130 }
131
132 QString lastAccessError() const { return mLastAccessError; }
133
134 /**
135 * Result of the last blockAndQueryState() call. Will indicate an error and
136 * contain a proper error info if the last state check fails. In "don't show
137 * diffs" mode, this is the worst result (in terms of inaccessibility)
138 * detected on the given hard disk chain.
139 *
140 * @param aNoDiffs @c true to enable user-friendly "don't show diffs" mode.
141 */
142 const COMResult &result (bool aNoDiffs = false) const
143 {
144 unconst (this)->checkNoDiffs (aNoDiffs);
145 return aNoDiffs ? mNoDiffs.result : mResult;
146 }
147
148 const CHardDisk2 &hardDisk() const { return mHardDisk; }
149 const CDVDImage2 &dvdImage() const { return mDVDImage; }
150 const CFloppyImage2 &floppyImage() const { return mFloppyImage; }
151
152 QUuid id() const { return mId; }
153
154 QString location (bool aNoDiffs = false) const
155 { return aNoDiffs ? root().mLocation : mLocation; }
156 QString name (bool aNoDiffs = false) const
157 { return aNoDiffs ? root().mName : mName; }
158
159 QString size (bool aNoDiffs = false) const
160 { return aNoDiffs ? root().mSize : mSize; }
161
162 QString hardDiskFormat (bool aNoDiffs = false) const
163 { return aNoDiffs ? root().mHardDiskFormat : mHardDiskFormat; }
164 QString hardDiskType (bool aNoDiffs = false) const
165 { return aNoDiffs ? root().mHardDiskType : mHardDiskType; }
166 QString logicalSize (bool aNoDiffs = false) const
167 { return aNoDiffs ? root().mLogicalSize : mLogicalSize; }
168
169 QString usage (bool aNoDiffs = false) const
170 { return aNoDiffs ? root().mUsage : mUsage; }
171
172 /**
173 * Returns @c true if this medium is read-only (either because it is
174 * Immutable or because it has child hard disks). Read-only media can only
175 * be attached indirectly.
176 */
177 bool isReadOnly() const { return mIsReadOnly; }
178
179 /**
180 * Returns @c true if this medium is attached to any VM (in the current
181 * state or in a snapshot) in which case #usage() will contain a string with
182 * comma-sparated VM names (with snapshot names, if any, in parenthesis).
183 */
184 bool isUsed() const { return !mUsage.isNull(); }
185
186 /**
187 * Returns @c true if this medium is attached to any VM in any snapshot.
188 * which case #usage() will contain a string with comma-sparated VM names.
189 */
190 bool isUsedInSnapshots() const { return mIsUsedInSnapshots; }
191
192 /**
193 * Returns @c true if this medium is attached to the given machine in the
194 * current state.
195 */
196 bool isAttachedInCurStateTo (const QUuid &aMachineId) const
197 { return mCurStateMachineIds.indexOf (aMachineId) >= 0; }
198
199 /**
200 * Returns a vector of IDs of all machines this medium is attached
201 * to in their current state (i.e. excluding snapshots).
202 */
203 const QList <QUuid> &curStateMachineIds() const
204 { return mCurStateMachineIds; }
205
206 /**
207 * Returns a parent medium. For non-hard disk media, this is always NULL.
208 */
209 VBoxMedium *parent() const { return mParent; }
210
211 VBoxMedium &root() const;
212
213 QString toolTip(bool aNoDiffs = false, bool aCheckRO = false) const;
214 QPixmap icon (bool aNoDiffs = false, bool aCheckRO = false) const;
215
216 /** Shortcut to <tt>#toolTip (aNoDiffs, true)</tt>. */
217 QString toolTipCheckRO (bool aNoDiffs = false) const
218 { return toolTip (aNoDiffs, true); }
219
220 /** Shortcut to <tt>#icon (aNoDiffs, true)</tt>. */
221 QPixmap iconCheckRO (bool aNoDiffs = false) const
222 { return icon (aNoDiffs, true); }
223
224 QString details (bool aNoDiffs = false, bool aPredictDiff = false,
225 bool aUseHTML = false) const;
226
227 /** Shortcut to <tt>#details (aNoDiffs, aPredictDiff, true)</tt>. */
228 QString detailsHTML (bool aNoDiffs = false, bool aPredictDiff = false) const
229 { return details (aNoDiffs, aPredictDiff, true); }
230
231 /** Returns @c true if this media descriptor is a null object. */
232 bool isNull() const { return mMedium.isNull(); }
233
234private:
235
236 void init();
237
238 void checkNoDiffs (bool aNoDiffs);
239
240 CMedium mMedium;
241
242 VBoxDefs::MediaType mType;
243
244 KMediaState mState;
245 QString mLastAccessError;
246 COMResult mResult;
247
248 CHardDisk2 mHardDisk;
249 CDVDImage2 mDVDImage;
250 CFloppyImage2 mFloppyImage;
251
252 QUuid mId;
253 QString mLocation;
254 QString mName;
255 QString mSize;
256
257 QString mHardDiskFormat;
258 QString mHardDiskType;
259 QString mLogicalSize;
260
261 QString mUsage;
262 QString mToolTip;
263
264 bool mIsReadOnly : 1;
265 bool mIsUsedInSnapshots : 1;
266
267 QList <QUuid> mCurStateMachineIds;
268
269 VBoxMedium *mParent;
270
271 /**
272 * Used to override some attributes in the user-friendly "don't show diffs"
273 * mode.
274 */
275 struct NoDiffs
276 {
277 NoDiffs() : isSet (false), state (KMediaState_NotCreated) {}
278
279 bool isSet : 1;
280
281 KMediaState state;
282 COMResult result;
283 QString toolTip;
284 }
285 mNoDiffs;
286};
287
288typedef QLinkedList <VBoxMedium> VBoxMediaList;
289
290// VirtualBox callback events
291////////////////////////////////////////////////////////////////////////////////
292
293class VBoxMachineStateChangeEvent : public QEvent
294{
295public:
296 VBoxMachineStateChangeEvent (const QUuid &aId, KMachineState aState)
297 : QEvent ((QEvent::Type) VBoxDefs::MachineStateChangeEventType)
298 , id (aId), state (aState)
299 {}
300
301 const QUuid id;
302 const KMachineState state;
303};
304
305class VBoxMachineDataChangeEvent : public QEvent
306{
307public:
308 VBoxMachineDataChangeEvent (const QUuid &aId)
309 : QEvent ((QEvent::Type) VBoxDefs::MachineDataChangeEventType)
310 , id (aId)
311 {}
312
313 const QUuid id;
314};
315
316class VBoxMachineRegisteredEvent : public QEvent
317{
318public:
319 VBoxMachineRegisteredEvent (const QUuid &aId, bool aRegistered)
320 : QEvent ((QEvent::Type) VBoxDefs::MachineRegisteredEventType)
321 , id (aId), registered (aRegistered)
322 {}
323
324 const QUuid id;
325 const bool registered;
326};
327
328class VBoxSessionStateChangeEvent : public QEvent
329{
330public:
331 VBoxSessionStateChangeEvent (const QUuid &aId, KSessionState aState)
332 : QEvent ((QEvent::Type) VBoxDefs::SessionStateChangeEventType)
333 , id (aId), state (aState)
334 {}
335
336 const QUuid id;
337 const KSessionState state;
338};
339
340class VBoxSnapshotEvent : public QEvent
341{
342public:
343
344 enum What { Taken, Discarded, Changed };
345
346 VBoxSnapshotEvent (const QUuid &aMachineId, const QUuid &aSnapshotId,
347 What aWhat)
348 : QEvent ((QEvent::Type) VBoxDefs::SnapshotEventType)
349 , what (aWhat)
350 , machineId (aMachineId), snapshotId (aSnapshotId)
351 {}
352
353 const What what;
354
355 const QUuid machineId;
356 const QUuid snapshotId;
357};
358
359class VBoxCanShowRegDlgEvent : public QEvent
360{
361public:
362 VBoxCanShowRegDlgEvent (bool aCanShow)
363 : QEvent ((QEvent::Type) VBoxDefs::CanShowRegDlgEventType)
364 , mCanShow (aCanShow)
365 {}
366
367 const bool mCanShow;
368};
369
370class VBoxCanShowUpdDlgEvent : public QEvent
371{
372public:
373 VBoxCanShowUpdDlgEvent (bool aCanShow)
374 : QEvent ((QEvent::Type) VBoxDefs::CanShowUpdDlgEventType)
375 , mCanShow (aCanShow)
376 {}
377
378 const bool mCanShow;
379};
380
381class VBoxChangeGUILanguageEvent : public QEvent
382{
383public:
384 VBoxChangeGUILanguageEvent (QString aLangId)
385 : QEvent ((QEvent::Type) VBoxDefs::ChangeGUILanguageEventType)
386 , mLangId (aLangId)
387 {}
388
389 const QString mLangId;
390};
391
392class Process : public QProcess
393{
394 Q_OBJECT;
395
396public:
397
398 static QByteArray singleShot (const QString &aProcessName,
399 int aTimeout = 5000
400 /* wait for data maximum 5 seconds */)
401 {
402 /* Why is it really needed is because of Qt4.3 bug with QProcess.
403 * This bug is about QProcess sometimes (~70%) do not receive
404 * notification about process was finished, so this makes
405 * 'bool QProcess::waitForFinished (int)' block the GUI thread and
406 * never dismissed with 'true' result even if process was really
407 * started&finished. So we just waiting for some information
408 * on process output and destroy the process with force. Due to
409 * QProcess::~QProcess() has the same 'waitForFinished (int)' blocker
410 * we have to change process state to QProcess::NotRunning. */
411
412 QByteArray result;
413 Process process;
414 process.start (aProcessName);
415 bool firstShotReady = process.waitForReadyRead (aTimeout);
416 if (firstShotReady)
417 result = process.readAllStandardOutput();
418 process.setProcessState (QProcess::NotRunning);
419 return result;
420 }
421
422protected:
423
424 Process (QWidget *aParent = 0) : QProcess (aParent) {}
425};
426
427// VBoxGlobal class
428////////////////////////////////////////////////////////////////////////////////
429
430class VBoxSelectorWnd;
431class VBoxConsoleWnd;
432class VBoxRegistrationDlg;
433class VBoxUpdateDlg;
434
435class VBoxGlobal : public QObject
436{
437 Q_OBJECT
438
439public:
440
441 static VBoxGlobal &instance();
442
443 bool isValid() { return mValid; }
444
445 QString versionString() { return verString; }
446
447 CVirtualBox virtualBox() const { return mVBox; }
448
449 const VBoxGlobalSettings &settings() const { return gset; }
450 bool setSettings (const VBoxGlobalSettings &gs);
451
452 VBoxSelectorWnd &selectorWnd();
453 VBoxConsoleWnd &consoleWnd();
454
455 /* main window handle storage */
456 void setMainWindow (QWidget *aMainWindow) { mMainWindow = aMainWindow; }
457 QWidget *mainWindow() const { return mMainWindow; }
458
459
460 bool isVMConsoleProcess() const { return !vmUuid.isNull(); }
461 QUuid managedVMUuid() const { return vmUuid; }
462
463 VBoxDefs::RenderMode vmRenderMode() const { return vm_render_mode; }
464 const char *vmRenderModeStr() const { return vm_render_mode_str; }
465
466#ifdef VBOX_WITH_DEBUGGER_GUI
467 bool isDebuggerEnabled() const { return mDbgEnabled; }
468 bool isDebuggerAutoShowEnabled() const { return mDbgAutoShow; }
469 RTLDRMOD getDebuggerModule() const { return mhVBoxDbg; }
470#else
471 bool isDebuggerAutoShowEnabled() const { return false; }
472#endif
473
474 /* VBox enum to/from string/icon/color convertors */
475
476 QList <CGuestOSType> vmGuestOSFamilyList() const;
477 QList <CGuestOSType> vmGuestOSTypeList (const QString &aFamilyId) const;
478 QPixmap vmGuestOSTypeIcon (const QString &aTypeId) const;
479 CGuestOSType vmGuestOSType (const QString &aTypeId,
480 const QString &aFamilyId = QString::null) const;
481 QString vmGuestOSTypeDescription (const QString &aTypeId) const;
482
483 QPixmap toIcon (KMachineState s) const
484 {
485 QPixmap *pm = mStateIcons.value (s);
486 AssertMsg (pm, ("Icon for VM state %d must be defined", s));
487 return pm ? *pm : QPixmap();
488 }
489
490 const QColor &toColor (KMachineState s) const
491 {
492 static const QColor none;
493 AssertMsg (vm_state_color.value (s), ("No color for %d", s));
494 return vm_state_color.value (s) ? *vm_state_color.value(s) : none;
495 }
496
497 QString toString (KMachineState s) const
498 {
499 AssertMsg (!machineStates.value (s).isNull(), ("No text for %d", s));
500 return machineStates.value (s);
501 }
502
503 QString toString (KSessionState s) const
504 {
505 AssertMsg (!sessionStates.value (s).isNull(), ("No text for %d", s));
506 return sessionStates.value (s);
507 }
508
509 /**
510 * Returns a string representation of the given KStorageBus enum value.
511 * Complementary to #toStorageBusType (const QString &) const.
512 */
513 QString toString (KStorageBus aBus) const
514 {
515 AssertMsg (!storageBuses.value (aBus).isNull(), ("No text for %d", aBus));
516 return storageBuses [aBus];
517 }
518
519 /**
520 * Returns a KStorageBus enum value corresponding to the given string
521 * representation. Complementary to #toString (KStorageBus) const.
522 */
523 KStorageBus toStorageBusType (const QString &aBus) const
524 {
525 QStringVector::const_iterator it =
526 qFind (storageBuses.begin(), storageBuses.end(), aBus);
527 AssertMsg (it != storageBuses.end(), ("No value for {%s}", aBus.toLatin1().constData()));
528 return KStorageBus (it - storageBuses.begin());
529 }
530
531 QString toString (KStorageBus aBus, LONG aChannel) const;
532 LONG toStorageChannel (KStorageBus aBus, const QString &aChannel) const;
533
534 QString toString (KStorageBus aBus, LONG aChannel, LONG aDevice) const;
535 LONG toStorageDevice (KStorageBus aBus, LONG aChannel, const QString &aDevice) const;
536
537 QString toFullString (KStorageBus aBus, LONG aChannel, LONG aDevice) const;
538
539 QString toString (KHardDiskType t) const
540 {
541 AssertMsg (!diskTypes.value (t).isNull(), ("No text for %d", t));
542 return diskTypes.value (t);
543 }
544
545 /**
546 * Similar to toString (KHardDiskType), but returns 'Differencing' for
547 * normal hard disks that have a parent.
548 */
549 QString hardDiskTypeString (const CHardDisk2 &aHD) const
550 {
551 if (!aHD.GetParent().isNull())
552 {
553 Assert (aHD.GetType() == KHardDiskType_Normal);
554 return diskTypes_Differencing;
555 }
556 return toString (aHD.GetType());
557 }
558
559 QString toString (KVRDPAuthType t) const
560 {
561 AssertMsg (!vrdpAuthTypes.value (t).isNull(), ("No text for %d", t));
562 return vrdpAuthTypes.value (t);
563 }
564
565 QString toString (KPortMode t) const
566 {
567 AssertMsg (!portModeTypes.value (t).isNull(), ("No text for %d", t));
568 return portModeTypes.value (t);
569 }
570
571 QString toString (KUSBDeviceFilterAction t) const
572 {
573 AssertMsg (!usbFilterActionTypes.value (t).isNull(), ("No text for %d", t));
574 return usbFilterActionTypes.value (t);
575 }
576
577 QString toString (KClipboardMode t) const
578 {
579 AssertMsg (!clipboardTypes.value (t).isNull(), ("No text for %d", t));
580 return clipboardTypes.value (t);
581 }
582
583 KClipboardMode toClipboardModeType (const QString &s) const
584 {
585 QStringVector::const_iterator it =
586 qFind (clipboardTypes.begin(), clipboardTypes.end(), s);
587 AssertMsg (it != clipboardTypes.end(), ("No value for {%s}", s.toLatin1().constData()));
588 return KClipboardMode (it - clipboardTypes.begin());
589 }
590
591 QString toString (KIDEControllerType t) const
592 {
593 AssertMsg (!ideControllerTypes.value (t).isNull(), ("No text for %d", t));
594 return ideControllerTypes.value (t);
595 }
596
597 KIDEControllerType toIDEControllerType (const QString &s) const
598 {
599 QStringVector::const_iterator it =
600 qFind (ideControllerTypes.begin(), ideControllerTypes.end(), s);
601 AssertMsg (it != ideControllerTypes.end(), ("No value for {%s}", s.toLatin1().constData()));
602 return KIDEControllerType (it - ideControllerTypes.begin());
603 }
604
605 KVRDPAuthType toVRDPAuthType (const QString &s) const
606 {
607 QStringVector::const_iterator it =
608 qFind (vrdpAuthTypes.begin(), vrdpAuthTypes.end(), s);
609 AssertMsg (it != vrdpAuthTypes.end(), ("No value for {%s}", s.toLatin1().constData()));
610 return KVRDPAuthType (it - vrdpAuthTypes.begin());
611 }
612
613 KPortMode toPortMode (const QString &s) const
614 {
615 QStringVector::const_iterator it =
616 qFind (portModeTypes.begin(), portModeTypes.end(), s);
617 AssertMsg (it != portModeTypes.end(), ("No value for {%s}", s.toLatin1().constData()));
618 return KPortMode (it - portModeTypes.begin());
619 }
620
621 KUSBDeviceFilterAction toUSBDevFilterAction (const QString &s) const
622 {
623 QStringVector::const_iterator it =
624 qFind (usbFilterActionTypes.begin(), usbFilterActionTypes.end(), s);
625 AssertMsg (it != usbFilterActionTypes.end(), ("No value for {%s}", s.toLatin1().constData()));
626 return KUSBDeviceFilterAction (it - usbFilterActionTypes.begin());
627 }
628
629 QString toString (KDeviceType t) const
630 {
631 AssertMsg (!deviceTypes.value (t).isNull(), ("No text for %d", t));
632 return deviceTypes.value (t);
633 }
634
635 KDeviceType toDeviceType (const QString &s) const
636 {
637 QStringVector::const_iterator it =
638 qFind (deviceTypes.begin(), deviceTypes.end(), s);
639 AssertMsg (it != deviceTypes.end(), ("No value for {%s}", s.toLatin1().constData()));
640 return KDeviceType (it - deviceTypes.begin());
641 }
642
643 QStringList deviceTypeStrings() const;
644
645 QString toString (KAudioDriverType t) const
646 {
647 AssertMsg (!audioDriverTypes.value (t).isNull(), ("No text for %d", t));
648 return audioDriverTypes.value (t);
649 }
650
651 KAudioDriverType toAudioDriverType (const QString &s) const
652 {
653 QStringVector::const_iterator it =
654 qFind (audioDriverTypes.begin(), audioDriverTypes.end(), s);
655 AssertMsg (it != audioDriverTypes.end(), ("No value for {%s}", s.toLatin1().constData()));
656 return KAudioDriverType (it - audioDriverTypes.begin());
657 }
658
659 QString toString (KAudioControllerType t) const
660 {
661 AssertMsg (!audioControllerTypes.value (t).isNull(), ("No text for %d", t));
662 return audioControllerTypes.value (t);
663 }
664
665 KAudioControllerType toAudioControllerType (const QString &s) const
666 {
667 QStringVector::const_iterator it =
668 qFind (audioControllerTypes.begin(), audioControllerTypes.end(), s);
669 AssertMsg (it != audioControllerTypes.end(), ("No value for {%s}", s.toLatin1().constData()));
670 return KAudioControllerType (it - audioControllerTypes.begin());
671 }
672
673 QString toString (KNetworkAdapterType t) const
674 {
675 AssertMsg (!networkAdapterTypes.value (t).isNull(), ("No text for %d", t));
676 return networkAdapterTypes.value (t);
677 }
678
679 KNetworkAdapterType toNetworkAdapterType (const QString &s) const
680 {
681 QStringVector::const_iterator it =
682 qFind (networkAdapterTypes.begin(), networkAdapterTypes.end(), s);
683 AssertMsg (it != networkAdapterTypes.end(), ("No value for {%s}", s.toLatin1().constData()));
684 return KNetworkAdapterType (it - networkAdapterTypes.begin());
685 }
686
687 QString toString (KNetworkAttachmentType t) const
688 {
689 AssertMsg (!networkAttachmentTypes.value (t).isNull(), ("No text for %d", t));
690 return networkAttachmentTypes.value (t);
691 }
692
693 KNetworkAttachmentType toNetworkAttachmentType (const QString &s) const
694 {
695 QStringVector::const_iterator it =
696 qFind (networkAttachmentTypes.begin(), networkAttachmentTypes.end(), s);
697 AssertMsg (it != networkAttachmentTypes.end(), ("No value for {%s}", s.toLatin1().constData()));
698 return KNetworkAttachmentType (it - networkAttachmentTypes.begin());
699 }
700
701 QString toString (KUSBDeviceState aState) const
702 {
703 AssertMsg (!USBDeviceStates.value (aState).isNull(), ("No text for %d", aState));
704 return USBDeviceStates.value (aState);
705 }
706
707 QStringList COMPortNames() const;
708 QString toCOMPortName (ulong aIRQ, ulong aIOBase) const;
709 bool toCOMPortNumbers (const QString &aName, ulong &aIRQ, ulong &aIOBase) const;
710
711 QStringList LPTPortNames() const;
712 QString toLPTPortName (ulong aIRQ, ulong aIOBase) const;
713 bool toLPTPortNumbers (const QString &aName, ulong &aIRQ, ulong &aIOBase) const;
714
715 QPixmap snapshotIcon (bool online) const
716 {
717 return online ? mOnlineSnapshotIcon : mOfflineSnapshotIcon;
718 }
719
720 QPixmap warningIcon() const { return mWarningIcon; }
721 QPixmap errorIcon() const { return mErrorIcon; }
722
723 /* details generators */
724
725 QString details (const CHardDisk2 &aHD, bool aPredictDiff);
726
727 QString details (const CUSBDevice &aDevice) const;
728 QString toolTip (const CUSBDevice &aDevice) const;
729 QString toolTip (const CUSBDeviceFilter &aFilter) const;
730
731 QString detailsReport (const CMachine &aMachine, bool aIsNewVM,
732 bool aWithLinks);
733
734 QString platformInfo();
735
736 /* VirtualBox helpers */
737
738#if defined(Q_WS_X11) && !defined(VBOX_OSE)
739 double findLicenseFile (const QStringList &aFilesList, QRegExp aPattern, QString &aLicenseFile) const;
740 bool showVirtualBoxLicense();
741#endif
742
743 bool checkForAutoConvertedSettings (bool aAfterRefresh = false);
744
745 void checkForAutoConvertedSettingsAfterRefresh()
746 { checkForAutoConvertedSettings (true); }
747
748 CSession openSession (const QUuid &aId, bool aExisting = false);
749
750 /** Shortcut to openSession (aId, true). */
751 CSession openExistingSession (const QUuid &aId) { return openSession (aId, true); }
752
753 bool startMachine (const QUuid &id);
754
755 void startEnumeratingMedia();
756
757 /**
758 * Returns a list of all currently registered media. This list is used to
759 * globally track the accessiblity state of all media on a dedicated thread.
760 *
761 * Note that the media list is initially empty (i.e. before the enumeration
762 * process is started for the first time using #startEnumeratingMedia()).
763 * See #startEnumeratingMedia() for more information about how meida are
764 * sorted in the returned list.
765 */
766 const VBoxMediaList &currentMediaList() const { return mMediaList; }
767
768 /** Returns true if the media enumeration is in progress. */
769 bool isMediaEnumerationStarted() const { return mMediaEnumThread != NULL; }
770
771 void addMedium (const VBoxMedium &);
772 void updateMedium (const VBoxMedium &);
773 void removeMedium (VBoxDefs::MediaType, const QUuid &);
774
775 bool findMedium (const CMedium &, VBoxMedium &) const;
776
777 /** Compact version of #findMediumTo(). Asserts if not found. */
778 VBoxMedium getMedium (const CMedium &aObj) const
779 {
780 VBoxMedium medium;
781 if (!findMedium (aObj, medium))
782 AssertFailed();
783 return medium;
784 }
785
786 /* various helpers */
787
788 QString languageName() const;
789 QString languageCountry() const;
790 QString languageNameEnglish() const;
791 QString languageCountryEnglish() const;
792 QString languageTranslators() const;
793
794 void retranslateUi();
795
796 /** @internal made public for internal purposes */
797 void cleanup();
798
799 /* public static stuff */
800
801 static bool isDOSType (const QString &aOSTypeId);
802
803 static void adoptLabelPixmap (QLabel *);
804
805 static QString languageId();
806 static void loadLanguage (const QString &aLangId = QString::null);
807 QString helpFile() const;
808
809 static QIcon iconSet (const char *aNormal,
810 const char *aDisabled = NULL,
811 const char *aActive = NULL);
812 static QIcon iconSetFull (const QSize &aNormalSize, const QSize &aSmallSize,
813 const char *aNormal, const char *aSmallNormal,
814 const char *aDisabled = NULL,
815 const char *aSmallDisabled = NULL,
816 const char *aActive = NULL,
817 const char *aSmallActive = NULL);
818
819 static QIcon standardIcon (QStyle::StandardPixmap aStandard, QWidget *aWidget = NULL);
820
821 static void setTextLabel (QToolButton *aToolButton, const QString &aTextLabel);
822
823 static QRect normalizeGeometry (const QRect &aRect, const QRect &aBoundRect,
824 bool aCanResize = true);
825
826 static void centerWidget (QWidget *aWidget, QWidget *aRelative,
827 bool aCanResize = true);
828
829 static QChar decimalSep();
830 static QString sizeRegexp();
831
832 static quint64 parseSize (const QString &);
833 static QString formatSize (quint64, int aMode = 0);
834
835 static quint64 requiredVideoMemory (CMachine *aMachine = 0);
836
837 static QString locationForHTML (const QString &aFileName);
838
839 static QString highlight (const QString &aStr, bool aToolTip = false);
840
841 static QString systemLanguageId();
842
843 static QString getExistingDirectory (const QString &aDir, QWidget *aParent,
844 const QString &aCaption = QString::null,
845 bool aDirOnly = TRUE,
846 bool resolveSymlinks = TRUE);
847
848 static QString getOpenFileName (const QString &aStartWith, const QString &aFilters, QWidget *aParent,
849 const QString &aCaption, QString *aSelectedFilter = NULL,
850 bool aResolveSymLinks = true);
851
852 static QStringList getOpenFileNames (const QString &aStartWith, const QString &aFilters, QWidget *aParent,
853 const QString &aCaption, QString *aSelectedFilter = NULL,
854 bool aResolveSymLinks = true,
855 bool aSingleFile = false);
856
857 static QString getFirstExistingDir (const QString &);
858
859 static bool activateWindow (WId aWId, bool aSwitchDesktop = true);
860
861 static QString removeAccelMark (const QString &aText);
862
863 static QString insertKeyToActionText (const QString &aText, const QString &aKey);
864 static QString extractKeyFromActionText (const QString &aText);
865
866 static QPixmap joinPixmaps (const QPixmap &aPM1, const QPixmap &aPM2);
867
868 static QWidget *findWidget (QWidget *aParent, const char *aName,
869 const char *aClassName = NULL,
870 bool aRecursive = false);
871
872 static QList <QPair <QString, QString> > HDDBackends();
873
874 /* Qt 4.2.0 support function */
875 static inline void setLayoutMargin (QLayout *aLayout, int aMargin)
876 {
877#if QT_VERSION < 0x040300
878 /* Deprecated since > 4.2 */
879 aLayout->setMargin (aMargin);
880#else
881 /* New since > 4.2 */
882 aLayout->setContentsMargins (aMargin, aMargin, aMargin, aMargin);
883#endif
884 }
885
886signals:
887
888 /**
889 * Emitted at the beginning of the enumeration process started by
890 * #startEnumeratingMedia().
891 */
892 void mediumEnumStarted();
893
894 /**
895 * Emitted when a new medium item from the list has updated its
896 * accessibility state.
897 */
898 void mediumEnumerated (const VBoxMedium &aMedum);
899
900 /**
901 * Emitted at the end of the enumeration process started by
902 * #startEnumeratingMedia(). The @a aList argument is passed for
903 * convenience, it is exactly the same as returned by #currentMediaList().
904 */
905 void mediumEnumFinished (const VBoxMediaList &aList);
906
907 /** Emitted when a new media is added using #addMedia(). */
908 void mediumAdded (const VBoxMedium &);
909
910 /** Emitted when the media is updated using #updateMedia(). */
911 void mediumUpdated (const VBoxMedium &);
912
913 /** Emitted when the media is removed using #removeMedia(). */
914 void mediumRemoved (VBoxDefs::MediaType, const QUuid &);
915
916 /* signals emitted when the VirtualBox callback is called by the server
917 * (not that currently these signals are emitted only when the application
918 * is the in the VM selector mode) */
919
920 void machineStateChanged (const VBoxMachineStateChangeEvent &e);
921 void machineDataChanged (const VBoxMachineDataChangeEvent &e);
922 void machineRegistered (const VBoxMachineRegisteredEvent &e);
923 void sessionStateChanged (const VBoxSessionStateChangeEvent &e);
924 void snapshotChanged (const VBoxSnapshotEvent &e);
925
926 void canShowRegDlg (bool aCanShow);
927 void canShowUpdDlg (bool aCanShow);
928
929public slots:
930
931 bool openURL (const QString &aURL);
932
933 void showRegistrationDialog (bool aForce = true);
934 void showUpdateDialog (bool aForce = true);
935
936protected:
937
938 bool event (QEvent *e);
939 bool eventFilter (QObject *, QEvent *);
940
941private:
942
943 VBoxGlobal();
944 ~VBoxGlobal();
945
946 void init();
947
948 bool mValid;
949
950 CVirtualBox mVBox;
951
952 VBoxGlobalSettings gset;
953
954 VBoxSelectorWnd *mSelectorWnd;
955 VBoxConsoleWnd *mConsoleWnd;
956 QWidget* mMainWindow;
957
958#ifdef VBOX_WITH_REGISTRATION
959 VBoxRegistrationDlg *mRegDlg;
960#endif
961 VBoxUpdateDlg *mUpdDlg;
962
963 QUuid vmUuid;
964
965 QThread *mMediaEnumThread;
966 VBoxMediaList mMediaList;
967
968 VBoxDefs::RenderMode vm_render_mode;
969 const char * vm_render_mode_str;
970
971#ifdef VBOX_WITH_DEBUGGER_GUI
972 /** Whether the debugger should be accessible or not.
973 * Use --dbg, the env.var. VBOX_GUI_DBG_ENABLED, --debug or the env.var.
974 * VBOX_GUI_DBG_AUTO_SHOW to enable. */
975 bool mDbgEnabled;
976 /** Whether to show the debugger automatically with the console.
977 * Use --debug or the env.var. VBOX_GUI_DBG_AUTO_SHOW to enable. */
978 bool mDbgAutoShow;
979 /** VBoxDbg module handle. */
980 RTLDRMOD mhVBoxDbg;
981#endif
982
983#if defined (Q_WS_WIN32)
984 DWORD dwHTMLHelpCookie;
985#endif
986
987 CVirtualBoxCallback callback;
988
989 typedef QVector <QString> QStringVector;
990
991 QString verString;
992
993 QList <QString> mFamilyIDs;
994 QList <QList <CGuestOSType> > mTypes;
995 QHash <QString, QPixmap *> mOsTypeIcons;
996 QVector <QColor *> vm_state_color;
997
998 QHash <long int, QPixmap *> mStateIcons;
999 QPixmap mOfflineSnapshotIcon, mOnlineSnapshotIcon;
1000
1001 QStringVector machineStates;
1002 QStringVector sessionStates;
1003 QStringVector deviceTypes;
1004
1005 QStringVector storageBuses;
1006 QStringVector storageBusDevices;
1007 QStringVector storageBusChannels;
1008
1009 QStringVector diskTypes;
1010 QString diskTypes_Differencing;
1011
1012 QStringVector vrdpAuthTypes;
1013 QStringVector portModeTypes;
1014 QStringVector usbFilterActionTypes;
1015 QStringVector audioDriverTypes;
1016 QStringVector audioControllerTypes;
1017 QStringVector networkAdapterTypes;
1018 QStringVector networkAttachmentTypes;
1019 QStringVector clipboardTypes;
1020 QStringVector ideControllerTypes;
1021 QStringVector USBDeviceStates;
1022
1023 QString mUserDefinedPortName;
1024
1025 QPixmap mWarningIcon, mErrorIcon;
1026
1027 mutable bool detailReportTemplatesReady;
1028
1029 friend VBoxGlobal &vboxGlobal();
1030 friend class VBoxCallback;
1031};
1032
1033inline VBoxGlobal &vboxGlobal() { return VBoxGlobal::instance(); }
1034
1035// Helper classes
1036////////////////////////////////////////////////////////////////////////////////
1037
1038/**
1039 * Generic asyncronous event.
1040 *
1041 * This abstract class is intended to provide a conveinent way to execute
1042 * code on the main GUI thread asynchronously to the calling party. This is
1043 * done by putting necessary actions to the #handle() function in a subclass
1044 * and then posting an instance of the subclass using #post(). The instance
1045 * must be allocated on the heap using the <tt>new</tt> operation and will be
1046 * automatically deleted after processing. Note that if you don't call #post()
1047 * on the created instance, you have to delete it yourself.
1048 */
1049class VBoxAsyncEvent : public QEvent
1050{
1051public:
1052
1053 VBoxAsyncEvent() : QEvent ((QEvent::Type) VBoxDefs::AsyncEventType) {}
1054
1055 /**
1056 * Worker function. Gets executed on the GUI thread when the posted event
1057 * is processed by the main event loop.
1058 */
1059 virtual void handle() = 0;
1060
1061 /**
1062 * Posts this event to the main event loop.
1063 * The caller loses ownership of this object after this method returns
1064 * and must not delete the object.
1065 */
1066 void post()
1067 {
1068 QApplication::postEvent (&vboxGlobal(), this);
1069 }
1070};
1071
1072/**
1073 * USB Popup Menu class.
1074 * This class provides the list of USB devices attached to the host.
1075 */
1076class VBoxUSBMenu : public QMenu
1077{
1078 Q_OBJECT
1079
1080public:
1081
1082 VBoxUSBMenu (QWidget *);
1083
1084 const CUSBDevice& getUSB (QAction *aAction);
1085
1086 void setConsole (const CConsole &);
1087
1088private slots:
1089
1090 void processAboutToShow();
1091
1092private:
1093 bool event(QEvent *aEvent);
1094
1095 QMap <QAction *, CUSBDevice> mUSBDevicesMap;
1096 CConsole mConsole;
1097};
1098
1099/**
1100 * Enable/Disable Menu class.
1101 * This class provides enable/disable menu items.
1102 */
1103class VBoxSwitchMenu : public QMenu
1104{
1105 Q_OBJECT
1106
1107public:
1108
1109 VBoxSwitchMenu (QWidget *, QAction *, bool aInverted = false);
1110
1111 void setToolTip (const QString &);
1112
1113private slots:
1114
1115 void processAboutToShow();
1116
1117private:
1118
1119 QAction *mAction;
1120 bool mInverted;
1121};
1122
1123#endif /* __VBoxGlobal_h__ */
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