Blame include/glibtop/proclist.h

Packit Service 407539
/* Copyright (C) 1998-99 Martin Baulig
Packit Service 407539
   This file is part of LibGTop 1.0.
Packit Service 407539
Packit Service 407539
   Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
Packit Service 407539
Packit Service 407539
   LibGTop is free software; you can redistribute it and/or modify it
Packit Service 407539
   under the terms of the GNU General Public License as published by
Packit Service 407539
   the Free Software Foundation; either version 2 of the License,
Packit Service 407539
   or (at your option) any later version.
Packit Service 407539
Packit Service 407539
   LibGTop is distributed in the hope that it will be useful, but WITHOUT
Packit Service 407539
   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
Packit Service 407539
   FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
Packit Service 407539
   for more details.
Packit Service 407539
Packit Service 407539
   You should have received a copy of the GNU General Public License
Packit Service 407539
   along with LibGTop; see the file COPYING. If not, write to the
Packit Service 407539
   Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Packit Service 407539
   Boston, MA 02110-1301, USA.
Packit Service 407539
*/
Packit Service 407539
Packit Service 407539
#ifndef __GLIBTOP_PROCLIST_H__
Packit Service 407539
#define __GLIBTOP_PROCLIST_H__
Packit Service 407539
Packit Service 407539
#include <glibtop.h>
Packit Service 407539
#include <glibtop/global.h>
Packit Service 407539
Packit Service 407539
G_BEGIN_DECLS
Packit Service 407539
Packit Service 407539
#define GLIBTOP_PROCLIST_NUMBER	0
Packit Service 407539
#define GLIBTOP_PROCLIST_TOTAL	1
Packit Service 407539
#define GLIBTOP_PROCLIST_SIZE	2
Packit Service 407539
Packit Service 407539
#define GLIBTOP_MAX_PROCLIST	3
Packit Service 407539
Packit Service 407539
/* You can use the folowing constants as the `which' member of
Packit Service 407539
 * glibtop_get_proclist () to specify which processes to fetch. */
Packit Service 407539
Packit Service 407539
/**
Packit Service 407539
 * GLIBTOP_KERN_PROC_ALL:
Packit Service 407539
 *
Packit Service 407539
 * Return information about all processes
Packit Service 407539
 **/
Packit Service 407539
#define GLIBTOP_KERN_PROC_ALL		0
Packit Service 407539
Packit Service 407539
/**
Packit Service 407539
 * GLIBTOP_KERN_PROC_PID:
Packit Service 407539
 *
Packit Service 407539
 * Return all processes with the pid which is passed in @arg. You can use this to find out whether some process still exists.
Packit Service 407539
 **/
Packit Service 407539
#define GLIBTOP_KERN_PROC_PID		1
Packit Service 407539
Packit Service 407539
/**
Packit Service 407539
 * GLIBTOP_KERN_PROC_PGRP:
Packit Service 407539
 *
Packit Service 407539
 * Return all processes in the process group passed in @arg. 
Packit Service 407539
 **/
Packit Service 407539
#define GLIBTOP_KERN_PROC_PGRP		2
Packit Service 407539
Packit Service 407539
/**
Packit Service 407539
 * GLIBTOP_KERN_PROC_SESSION:
Packit Service 407539
 *
Packit Service 407539
 * Return all processes in the session passed in @arg. 
Packit Service 407539
 **/
Packit Service 407539
#define GLIBTOP_KERN_PROC_SESSION	3
Packit Service 407539
Packit Service 407539
/**
Packit Service 407539
 * GLIBTOP_KERN_PROC_TTY:
Packit Service 407539
 *
Packit Service 407539
 * Return all processes which have the controlling tty passed in @arg
Packit Service 407539
 * (which is interpreted as the device number). 
Packit Service 407539
 **/
Packit Service 407539
#define GLIBTOP_KERN_PROC_TTY		4
Packit Service 407539
Packit Service 407539
/**
Packit Service 407539
 * GLIBTOP_KERN_PROC_UID:
Packit Service 407539
 *
Packit Service 407539
 * Return all processes with the effective uid passed in @arg. 
Packit Service 407539
 **/
Packit Service 407539
#define GLIBTOP_KERN_PROC_UID		5
Packit Service 407539
Packit Service 407539
/**
Packit Service 407539
 * GLIBTOP_KERN_PROC_RUID:
Packit Service 407539
 *
Packit Service 407539
 * Return all processes with the real uid passed in @arg. 
Packit Service 407539
 **/
Packit Service 407539
#define GLIBTOP_KERN_PROC_RUID		6
Packit Service 407539
Packit Service 407539
#define GLIBTOP_KERN_PROC_MASK		15
Packit Service 407539
Packit Service 407539
Packit Service 407539
/**
Packit Service 407539
 * GLIBTOP_EXCLUDE_IDLE:
Packit Service 407539
 *
Packit Service 407539
 * Exclude idle processes. 
Packit Service 407539
 **/
Packit Service 407539
#define GLIBTOP_EXCLUDE_IDLE		0x1000
Packit Service 407539
Packit Service 407539
/**
Packit Service 407539
 * GLIBTOP_EXCLUDE_SYSTEM:
Packit Service 407539
 *
Packit Service 407539
 * Exclude system (on most UNIXes root's) processes.
Packit Service 407539
 **/
Packit Service 407539
#define GLIBTOP_EXCLUDE_SYSTEM		0x2000
Packit Service 407539
Packit Service 407539
/**
Packit Service 407539
 * GLIBTOP_EXCLUDE_NOTTY:
Packit Service 407539
 *
Packit Service 407539
 * Exclude processes without a controlling terminal.
Packit Service 407539
 **/
Packit Service 407539
#define GLIBTOP_EXCLUDE_NOTTY		0x4000
Packit Service 407539
Packit Service 407539
typedef struct _glibtop_proclist	glibtop_proclist;
Packit Service 407539
Packit Service 407539
/**
Packit Service 407539
 * glibtop_proclist:
Packit Service 407539
 * @number: Number of entries in the returned list.
Packit Service 407539
 * @total: Total size of the returned list (this equals @number * @size).
Packit Service 407539
 * @size: Size of a single entry in the returned list 
Packit Service 407539
 * (this equals <type>sizeof(unsigned)</type>).
Packit Service 407539
 */
Packit Service 407539
struct _glibtop_proclist
Packit Service 407539
{
Packit Service 407539
	guint64	flags;
Packit Service 407539
	guint64 number;			/* GLIBTOP_PROCLIST_NUMBER	*/
Packit Service 407539
	guint64 total;			/* GLIBTOP_PROCLIST_TOTAL	*/
Packit Service 407539
	guint64 size;			/* GLIBTOP_PROCLIST_SIZE	*/
Packit Service 407539
};
Packit Service 407539
Packit Service 407539
/**
Packit Service 407539
 * glibtop_get_proclist:
Packit Service 407539
 * @buf: a #glibtop_proclist
Packit Service 407539
 * @which: a #GLIBTOP_* constant specifying process type
Packit Service 407539
 * @arg: an argument specific for the process type
Packit Service 407539
 *
Packit Service 407539
 * Returns: (array zero-terminated=1) (transfer none): an array of process
Packit Service 407539
 *     ids
Packit Service 407539
 */
Packit Service 407539
pid_t*
Packit Service 407539
glibtop_get_proclist(glibtop_proclist *buf, gint64 which, gint64 arg);
Packit Service 407539
Packit Service 407539
#if GLIBTOP_SUID_PROCLIST
Packit Service 407539
#define glibtop_get_proclist_r		glibtop_get_proclist_p
Packit Service 407539
#else
Packit Service 407539
#define glibtop_get_proclist_r		glibtop_get_proclist_s
Packit Service 407539
#endif
Packit Service 407539
Packit Service 407539
/**
Packit Service 407539
 * glibtop_get_proclist_l:
Packit Service 407539
 * @server: a #glibtop server
Packit Service 407539
 * @buf: a #glibtop_proclist
Packit Service 407539
 * @which: a #GLIBTOP_* constant specifying process type
Packit Service 407539
 * @arg: an argument specific for the process type
Packit Service 407539
 *
Packit Service 407539
 * Returns: (array zero-terminated=1) (transfer none): an array of process
Packit Service 407539
 *     ids
Packit Service 407539
 */
Packit Service 407539
pid_t*
Packit Service 407539
glibtop_get_proclist_l (glibtop *server, glibtop_proclist *buf,
Packit Service 407539
			gint64 which, gint64 arg);
Packit Service 407539
Packit Service 407539
#if GLIBTOP_SUID_PROCLIST
Packit Service 407539
void _glibtop_init_proclist_p (glibtop *server);
Packit Service 407539
Packit Service 407539
/**
Packit Service 407539
 * glibtop_get_proclist_p:
Packit Service 407539
 * @server: a #glibtop server
Packit Service 407539
 * @buf: a #glibtop_proclist
Packit Service 407539
 * @which: a #GLIBTOP_* constant specifying process type
Packit Service 407539
 * @arg: an argument specific for the process type
Packit Service 407539
 *
Packit Service 407539
 * Returns: (array zero-terminated=1) (transfer none): an array of process
Packit Service 407539
 *     ids
Packit Service 407539
 */
Packit Service 407539
pid_t*
Packit Service 407539
glibtop_get_proclist_p (glibtop *server, glibtop_proclist *buf,
Packit Service 407539
			gint64 which, gint64 arg);
Packit Service 407539
#else
Packit Service 407539
void _glibtop_init_proclist_s (glibtop *server);
Packit Service 407539
Packit Service 407539
/**
Packit Service 407539
 * glibtop_get_proclist_s:
Packit Service 407539
 * @server: a #glibtop server
Packit Service 407539
 * @buf: a #glibtop_proclist
Packit Service 407539
 * @which: a #GLIBTOP_* constant specifying process type
Packit Service 407539
 * @arg: an argument specific for the process type
Packit Service 407539
 *
Packit Service 407539
 * Returns: (array zero-terminated=1) (transfer none): an array of process
Packit Service 407539
 *     ids
Packit Service 407539
 */
Packit Service 407539
pid_t*
Packit Service 407539
glibtop_get_proclist_s (glibtop *server, glibtop_proclist *buf,
Packit Service 407539
			gint64 which, gint64 arg);
Packit Service 407539
#endif
Packit Service 407539
Packit Service 407539
Packit Service 407539
G_END_DECLS
Packit Service 407539
Packit Service 407539
#endif