VirtualBox

source: vbox/trunk/src/VBox/Frontends/VBoxManage/VBoxManage.h@ 20554

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

VBoxManage: convert all disk-related subcommands to double-dash parameters and exclusively using RTGetOpt. Updated the documentation to reflect this. Additionally the testing revealed a few bugs which are fixed now.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 7.1 KB
Line 
1/* $Id: VBoxManage.h 18703 2009-04-03 16:19:40Z vboxsync $ */
2/** @file
3 * VBoxManage - VirtualBox command-line interface, internal header file.
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 ___H_VBOXMANAGE
23#define ___H_VBOXMANAGE
24
25#ifndef VBOX_ONLY_DOCS
26#include <VBox/com/com.h>
27#include <VBox/com/ptr.h>
28#include <VBox/com/VirtualBox.h>
29#include <VBox/com/EventQueue.h>
30#include <VBox/com/string.h>
31#endif /* !VBOX_ONLY_DOCS */
32
33#include <iprt/types.h>
34
35#if defined(VBOX_WITH_XPCOM) && !defined(RT_OS_DARWIN) && !defined(RT_OS_OS2)
36# define USE_XPCOM_QUEUE
37#endif
38
39////////////////////////////////////////////////////////////////////////////////
40//
41// definitions
42//
43////////////////////////////////////////////////////////////////////////////////
44
45/** @name Syntax diagram category.
46 * @{ */
47#define USAGE_DUMPOPTS 0
48#define USAGE_LIST RT_BIT_64(0)
49#define USAGE_SHOWVMINFO RT_BIT_64(1)
50#define USAGE_REGISTERVM RT_BIT_64(2)
51#define USAGE_UNREGISTERVM RT_BIT_64(3)
52#define USAGE_CREATEVM RT_BIT_64(4)
53#define USAGE_MODIFYVM RT_BIT_64(5)
54#define USAGE_STARTVM RT_BIT_64(6)
55#define USAGE_CONTROLVM RT_BIT_64(7)
56#define USAGE_DISCARDSTATE RT_BIT_64(8)
57#define USAGE_SNAPSHOT RT_BIT_64(9)
58#define USAGE_OPENMEDIUM RT_BIT_64(10)
59#define USAGE_CLOSEMEDIUM RT_BIT_64(11)
60#define USAGE_SHOWHDINFO RT_BIT_64(12)
61#define USAGE_CREATEHD RT_BIT_64(13)
62#define USAGE_MODIFYHD RT_BIT_64(14)
63#define USAGE_CLONEHD RT_BIT_64(15)
64#define USAGE_ADDISCSIDISK RT_BIT_64(16)
65#define USAGE_CREATEHOSTIF RT_BIT_64(17)
66#define USAGE_REMOVEHOSTIF RT_BIT_64(18)
67#define USAGE_GETEXTRADATA RT_BIT_64(19)
68#define USAGE_SETEXTRADATA RT_BIT_64(20)
69#define USAGE_SETPROPERTY RT_BIT_64(21)
70#define USAGE_USBFILTER (RT_BIT_64(22) | RT_BIT_64(23) | RT_BIT_64(24))
71#define USAGE_USBFILTER_ADD RT_BIT_64(22)
72#define USAGE_USBFILTER_MODIFY RT_BIT_64(23)
73#define USAGE_USBFILTER_REMOVE RT_BIT_64(24)
74#define USAGE_SHAREDFOLDER (RT_BIT_64(25) | RT_BIT_64(26))
75#define USAGE_SHAREDFOLDER_ADD RT_BIT_64(25)
76#define USAGE_SHAREDFOLDER_REMOVE RT_BIT_64(26)
77#define USAGE_LOADSYMS RT_BIT_64(29)
78#define USAGE_UNLOADSYMS RT_BIT_64(30)
79#define USAGE_SETHDUUID RT_BIT_64(31)
80#define USAGE_CONVERTFROMRAW RT_BIT_64(32)
81#define USAGE_LISTPARTITIONS RT_BIT_64(33)
82#define USAGE_CREATERAWVMDK RT_BIT_64(34)
83#define USAGE_VM_STATISTICS RT_BIT_64(35)
84#define USAGE_ADOPTSTATE RT_BIT_64(36)
85#define USAGE_MODINSTALL RT_BIT_64(37)
86#define USAGE_MODUNINSTALL RT_BIT_64(38)
87#define USAGE_RENAMEVMDK RT_BIT_64(39)
88#ifdef VBOX_WITH_GUEST_PROPS
89#define USAGE_GUESTPROPERTY RT_BIT_64(40)
90#endif /* VBOX_WITH_GUEST_PROPS defined */
91#define USAGE_CONVERTTORAW RT_BIT_64(41)
92#define USAGE_METRICS RT_BIT_64(42)
93#define USAGE_CONVERTHD RT_BIT_64(43)
94#define USAGE_IMPORTAPPLIANCE RT_BIT_64(44)
95#define USAGE_EXPORTAPPLIANCE RT_BIT_64(45)
96#define USAGE_HOSTONLYIFS RT_BIT_64(46)
97#define USAGE_DHCPSERVER RT_BIT_64(47)
98#define USAGE_ALL (~(uint64_t)0)
99/** @} */
100
101typedef uint64_t USAGECATEGORY;
102
103/** command handler argument */
104struct HandlerArg
105{
106 int argc;
107 char **argv;
108
109#ifdef USE_XPCOM_QUEUE
110 nsCOMPtr<nsIEventQueue> eventQ;
111#endif
112#ifndef VBOX_ONLY_DOCS
113 ComPtr<IVirtualBox> virtualBox;
114 ComPtr<ISession> session;
115#endif
116};
117
118/** flag whether we're in internal mode */
119extern bool g_fInternalMode;
120
121/** showVMInfo details */
122typedef enum
123{
124 VMINFO_NONE = 0,
125 VMINFO_STANDARD = 1, /**< standard details */
126 VMINFO_STATISTICS = 2, /**< guest statistics */
127 VMINFO_FULL = 3, /**< both */
128 VMINFO_MACHINEREADABLE = 4, /**< both, and make it machine readable */
129 VMINFO_COMPACT = 5
130} VMINFO_DETAILS;
131
132////////////////////////////////////////////////////////////////////////////////
133//
134// global variables
135//
136////////////////////////////////////////////////////////////////////////////////
137
138extern bool g_fDetailedProgress; // in VBoxManage.cpp
139
140////////////////////////////////////////////////////////////////////////////////
141//
142// prototypes
143//
144////////////////////////////////////////////////////////////////////////////////
145
146/* VBoxManageHelp.cpp */
147void printUsage(USAGECATEGORY u64Cmd);
148int errorSyntax(USAGECATEGORY u64Cmd, const char *pszFormat, ...);
149int errorArgument(const char *pszFormat, ...);
150
151void printUsageInternal(USAGECATEGORY u64Cmd);
152
153#ifndef VBOX_ONLY_DOCS
154void showProgress(ComPtr<IProgress> progress);
155#endif
156
157/* VBoxManage.cpp */
158void showLogo(void);
159
160#ifndef VBOX_ONLY_DOCS
161int handleInternalCommands(HandlerArg *a);
162
163unsigned parseNum(const char *psz, unsigned cMaxNum, const char *name);
164#endif /* !VBOX_ONLY_DOCS */
165
166/* VBoxManageModifyVM.cpp */
167int handleModifyVM(HandlerArg *a);
168
169/* VBoxManageGuestProp.cpp */
170extern void usageGuestProperty(void);
171#ifndef VBOX_ONLY_DOCS
172extern int handleGuestProperty(HandlerArg *a);
173
174/* VBoxManageVMInfo.cpp */
175void showSnapshots(ComPtr<ISnapshot> rootSnapshot, VMINFO_DETAILS details, const com::Bstr &prefix = "", int level = 0);
176int handleShowVMInfo(HandlerArg *a);
177HRESULT showVMInfo(ComPtr<IVirtualBox> virtualBox,
178 ComPtr<IMachine> machine,
179 VMINFO_DETAILS details = VMINFO_NONE,
180 ComPtr <IConsole> console = ComPtr<IConsole>());
181
182/* VBoxManageList.cpp */
183int handleList(HandlerArg *a);
184
185/* VBoxManageMetrics.cpp */
186int handleMetrics(HandlerArg *a);
187
188/* VBoxManageDisk.cpp */
189int handleCreateHardDisk(HandlerArg *a);
190int handleModifyHardDisk(HandlerArg *a);
191int handleCloneHardDisk(HandlerArg *a);
192int handleConvertFromRaw(int argc, char *argv[]);
193int handleAddiSCSIDisk(HandlerArg *a);
194int handleShowHardDiskInfo(HandlerArg *a);
195int handleOpenMedium(HandlerArg *a);
196int handleCloseMedium(HandlerArg *a);
197
198// VBoxManageImport.cpp
199int handleImportAppliance(HandlerArg *a);
200int handleExportAppliance(HandlerArg *a);
201
202// VBoxManageSnapshot.cpp
203int handleSnapshot(HandlerArg *a);
204
205/* VBoxManageUSB.cpp */
206int handleUSBFilter(HandlerArg *a);
207
208/* VBoxManageHostonly.cpp */
209int handleHostonlyIf(HandlerArg *a);
210
211/* VBoxManageHostonly.cpp */
212int handleDHCPServer(HandlerArg *a);
213
214#endif /* !VBOX_ONLY_DOCS */
215unsigned long VBoxSVNRev();
216
217#endif /* !___H_VBOXMANAGE */
218
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