os: split off internal definitions from client.h

The client.h file is part of the public module API, but it also contains
definitions that aren't useful for being used in modules. Splitting them
out into their own client_priv.h file, which isn't part of the API.

Signed-off-by: Enrico Weigelt, metux IT consult <info@metux.net>
This commit is contained in:
Enrico Weigelt, metux IT consult 2024-02-08 16:03:56 +01:00 committed by Povilas Kanapickas
parent a917f6a8a8
commit 7ac7a2d6de
8 changed files with 43 additions and 22 deletions

View File

@ -4,26 +4,26 @@
#include <dix-config.h>
#include <assert.h>
#include <stdio.h>
#include <string.h>
#include <X11/X.h>
#include <X11/Xproto.h>
#include <assert.h>
#include <X11/extensions/XResproto.h>
#include "dix/registry_priv.h"
#include "os/client_priv.h"
#include "misc.h"
#include "os.h"
#include "dixstruct.h"
#include "extnsionst.h"
#include "swaprep.h"
#include <X11/extensions/XResproto.h>
#include "pixmapstr.h"
#include "windowstr.h"
#include "gcstruct.h"
#include "extinit_priv.h"
#include "protocol-versions.h"
#include "client.h"
#include "list.h"
#include "misc.h"
#include <string.h>

View File

@ -33,6 +33,7 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
#include <X11/Xfuncproto.h>
#include "dix/registry_priv.h"
#include "os/client_priv.h"
#include "selection.h"
#include "inputstr.h"
@ -41,7 +42,6 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
#include "propertyst.h"
#include "extnsionst.h"
#include "xacestr.h"
#include "client.h"
#define _XSELINUX_NEED_FLASK_MAP
#include "xselinuxint.h"

View File

@ -112,6 +112,7 @@ Equipment Corporation.
#include "dix/screenint_priv.h"
#include "include/resource.h"
#include "os/auth.h"
#include "os/client_priv.h"
#include "os/ddx_priv.h"
#include "os/osdep.h"
#include "os/screensaver.h"
@ -133,7 +134,6 @@ Equipment Corporation.
#include "xace.h"
#include "inputstr.h"
#include "xkbsrv.h"
#include "client.h"
#include "xfixesint.h"
#include "dixstruct_priv.h"

View File

@ -92,6 +92,7 @@ Equipment Corporation.
#include "dix/registry_priv.h"
#include "os/audit.h"
#include "os/auth.h"
#include "os/client_priv.h"
#include "os/cmdline.h"
#include "os/ddx_priv.h"
#include "os/osdep.h"
@ -114,7 +115,6 @@ Equipment Corporation.
#include "dixfont.h"
#include "extnsionst.h"
#include "privates.h"
#include "client.h"
#include "exevents.h"
#ifdef PANORAMIX
#include "panoramiXsrv.h"

View File

@ -29,22 +29,12 @@
#ifdef HAVE_DIX_CONFIG_H
#include <dix-config.h>
#endif /* HAVE_DIX_CONFIG_H */
#include <X11/Xfuncproto.h>
#include <sys/types.h>
/* Client IDs. Use GetClientPid, GetClientCmdName and GetClientCmdArgs
* instead of accessing the fields directly. */
typedef struct {
pid_t pid; /* process ID, -1 if not available */
const char *cmdname; /* process name, NULL if not available */
const char *cmdargs; /* process arguments, NULL if not available */
} ClientIdRec, *ClientIdPtr;
#include <sys/types.h>
#include <X11/Xfuncproto.h>
struct _Client;
/* Initialize and clean up. */
void ReserveClientIds(struct _Client *client);
void ReleaseClientIds(struct _Client *client);
typedef struct _ClientId *ClientIdPtr;
/* Determine client IDs for caching. Exported on purpose for
* extensions such as SELinux. */

View File

@ -73,6 +73,8 @@ typedef struct _saveSet {
#define SaveSetAssignToRoot(ss,tr) ((ss).toRoot = (tr))
#define SaveSetAssignMap(ss,m) ((ss).map = (m))
struct _ClientId;
typedef struct _Client {
void *requestBuffer;
void *osPrivate; /* for OS layer, including scheduler */
@ -109,7 +111,7 @@ typedef struct _Client {
int smart_stop_tick;
DeviceIntPtr clientPtr;
ClientIdPtr clientIds;
struct _ClientId *clientIds;
int req_fds;
} ClientRec;

View File

@ -50,12 +50,14 @@
*
* Author: Rami Ylimäki <rami.ylimaki@vincit.fi>
*/
#include <dix-config.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include "client.h"
#include "os/client_priv.h"
#include "os.h"
#include "dixstruct.h"
@ -452,7 +454,7 @@ ReserveClientIds(struct _Client *client)
return;
assert(!client->clientIds);
client->clientIds = calloc(1, sizeof(ClientIdRec));
client->clientIds = calloc(1, sizeof(struct _ClientId));
if (!client->clientIds)
return;

27
os/client_priv.h Normal file
View File

@ -0,0 +1,27 @@
/* SPDX-License-Identifier: MIT OR X11
*
* Copyright © 2024 Enrico Weigelt, metux IT consult <info@metux.net>
* Copyright © 2010 Nokia Corporation and/or its subsidiary(-ies).
*/
#ifndef _XSERVER_DIX_CLIENT_PRIV_H
#define _XSERVER_DIX_CLIENT_PRIV_H
#include <sys/types.h>
#include "client.h"
/* Client IDs. Use GetClientPid, GetClientCmdName and GetClientCmdArgs
* instead of accessing the fields directly. */
struct _ClientId {
pid_t pid; /* process ID, -1 if not available */
const char *cmdname; /* process name, NULL if not available */
const char *cmdargs; /* process arguments, NULL if not available */
};
struct _Client;
/* Initialize and clean up. */
void ReserveClientIds(struct _Client *client);
void ReleaseClientIds(struct _Client *client);
#endif /* _XSERVER_DIX_CLIENT_PRIV_H */