1
0
mirror of https://github.com/gryf/wmaker.git synced 2025-12-21 05:18:06 +01:00

Introduce OS-dependent stuff

- move GetCommandForPid() into a separate file
- slightly rewrite it to be more readable along the way
This commit is contained in:
Tamas TEVESZ
2010-03-19 14:09:48 +01:00
committed by Carlos R. Mafra
parent eee6551aff
commit 294ea56d84
3 changed files with 66 additions and 45 deletions

View File

@@ -45,6 +45,7 @@ wmaker_SOURCES = \
menu.c \ menu.c \
menu.h \ menu.h \
misc.c \ misc.c \
osdep/linux.c \
monitor.c \ monitor.c \
motif.c \ motif.c \
motif.h \ motif.h \

View File

@@ -1073,51 +1073,6 @@ char *StrConcatDot(char *a, char *b)
return str; return str;
} }
#define MAX_CMD_SIZE 4096
Bool GetCommandForPid(int pid, char ***argv, int *argc)
{
static char buf[MAX_CMD_SIZE];
FILE *fPtr;
int count, i, j;
Bool ok = False;
sprintf(buf, "/proc/%d/cmdline", pid);
fPtr = fopen(buf, "r");
if (fPtr) {
count = read(fileno(fPtr), buf, MAX_CMD_SIZE);
if (count > 0) {
buf[count - 1] = 0;
for (i = 0, *argc = 0; i < count; i++) {
if (buf[i] == 0) {
(*argc)++;
}
}
if ((*argc) == 0) {
*argv = NULL;
ok = False;
} else {
*argv = (char **)wmalloc(sizeof(char *) * (*argc));
(*argv)[0] = buf;
for (i = 0, j = 1; i < count; i++) {
if (buf[i] != 0)
continue;
if (i < count - 1) {
(*argv)[j++] = &buf[i + 1];
}
if (j == *argc) {
break;
}
}
ok = True;
}
}
fclose(fPtr);
}
return ok;
}
static char *getCommandForWindow(Window win, int elements) static char *getCommandForWindow(Window win, int elements)
{ {
char **argv, *command = NULL; char **argv, *command = NULL;

65
src/osdep/linux.c Normal file
View File

@@ -0,0 +1,65 @@
#include <sys/types.h>
#include <sys/stat.h>
#include <errno.h>
#include <fcntl.h>
#include <limits.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <WINGs/WUtil.h>
#include "../wconfig.h"
/*
* copy argc and argv for an existing process identified by `pid'
* into suitable storage given in ***argv and *argc.
*
* returns 0 for failure, in which case argc := 0 and arv := NULL
* returns 1 for success
*/
Bool GetCommandForPid(int pid, char ***argv, int *argc)
{
static char buf[_POSIX_ARG_MAX];
int fd, i, j;
ssize_t count;
*argv = NULL;
*argc = 0;
/* cmdline is a flattened series of null-terminated strings */
snprintf(buf, sizeof(buf), "/proc/%d/cmdline", pid);
if ((fd = open(buf, O_RDONLY)) == -1)
return False;
/* XXX: read/close errors */
if ((count = read(fd, buf, sizeof(buf))) == -1) {
close(fd);
return False;
}
close(fd);
for (i = 0; i < count; i++)
if (buf[i] == '\0')
(*argc)++;
if (*argc == 0)
return False;
*argv = (char **)wmalloc(sizeof(char *) * *argc);
(*argv)[0] = buf;
/* go through buf, set argv[$next] to the beginning of each string */
for (i = 0, j = 1; i < count; i++) {
if (buf[i] != '\0')
continue;
if (i < count - 1)
(*argv)[j++] = &buf[i + 1];
if (j == *argc)
break;
}
return True;
}