VirtualBox

source: vbox/trunk/src/VBox/Additions/x11/VBoxClient/VBoxClient.h@ 57019

Last change on this file since 57019 was 55401, checked in by vboxsync, 10 years ago

added a couple of missing Id headers

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 3.3 KB
Line 
1/* $Id: VBoxClient.h 55401 2015-04-23 10:03:17Z vboxsync $ */
2/** @file
3 *
4 * VirtualBox additions user session daemon.
5 */
6
7/*
8 * Copyright (C) 2006-2011 Oracle Corporation
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
19#ifndef ___vboxclient_vboxclient_h
20# define ___vboxclient_vboxclient_h
21
22#include <VBox/log.h>
23#include <iprt/cpp/utils.h>
24#include <iprt/string.h>
25
26/** Exit with a fatal error. */
27#define VBClFatalError(format) \
28do { \
29 char *pszMessage = RTStrAPrintf2 format; \
30 LogRel(format); \
31 vbclFatalError(pszMessage); \
32} while(0)
33
34/** Exit with a fatal error. */
35extern DECLNORETURN(void) vbclFatalError(char *pszMessage);
36
37/** Call clean-up for the current service and exit. */
38extern void VBClCleanUp();
39
40/** A simple interface describing a service. VBoxClient will run exactly one
41 * service per invocation. */
42struct VBCLSERVICE
43{
44 /** Get the services default path to pidfile, relative to $HOME */
45 /** @todo Should this also have a component relative to the X server number?
46 */
47 const char *(*getPidFilePath)(void);
48 /** Special initialisation, if needed. @a pause and @a resume are
49 * guaranteed not to be called until after this returns. */
50 int (*init)(struct VBCLSERVICE **ppInterface);
51 /** Run the service main loop */
52 int (*run)(struct VBCLSERVICE **ppInterface, bool fDaemonised);
53 /** Pause the service loop. This is used to allow the service to disable
54 * itself when the X server is switched out. It must be safe to call on a
55 * different thread if the VT monitoring thread is used. */
56 int (*pause)(struct VBCLSERVICE **ppInterface);
57 /** Resume after pausing. The same applies here as for @a pause. */
58 int (*resume)(struct VBCLSERVICE **ppInterface);
59 /** Clean up any global resources before we shut down hard. The last calls
60 * to @a pause and @a resume are guaranteed to finish before this is called.
61 */
62 void (*cleanup)(struct VBCLSERVICE **ppInterface);
63};
64
65/** Default handler for various struct VBCLSERVICE member functions. */
66static int VBClServiceDefaultHandler(struct VBCLSERVICE **pSelf)
67{
68 return VINF_SUCCESS;
69}
70
71/** Default handler for the struct VBCLSERVICE clean-up member function.
72 * Usually used because the service is cleaned up automatically when the user
73 * process/X11 exits. */
74static void VBClServiceDefaultCleanup(struct VBCLSERVICE **ppInterface)
75{
76 NOREF(ppInterface);
77}
78
79union _XEvent; /* We do not want to pull in the X11 header files here. */
80extern void VBClCheckXOrgVT(union _XEvent *pEvent);
81extern int VBClStartVTMonitor();
82
83extern struct VBCLSERVICE **VBClGetClipboardService();
84extern struct VBCLSERVICE **VBClGetSeamlessService();
85extern struct VBCLSERVICE **VBClGetDisplayService();
86extern struct VBCLSERVICE **VBClGetHostVersionService();
87#ifdef VBOX_WITH_DRAG_AND_DROP
88extern struct VBCLSERVICE **VBClGetDragAndDropService();
89#endif /* VBOX_WITH_DRAG_AND_DROP */
90
91#endif /* !___vboxclient_vboxclient_h */
Note: See TracBrowser for help on using the repository browser.

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