1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
|
/* -*- mode: c++ -*-
*/
/*
GIFT, a flexible content based image retrieval system.
Copyright (C) 1998, 1999, 2000, 2001, 2002, CUI University of Geneva
Copyright (C) 2003, 2004 Bayreuth University
2005 Bamberg University
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
// -*- mode: c++ -*-
/**
Author of this file:
Wolfgang Mller
*/
#ifndef _CREAPER
#define _CREAPER
#include <unistd.h>
#include <iostream>
#include <cstdio>
#include <sys/types.h>
#include <sys/wait.h>
#include <sys/socket.h>
#include <cstring>
#include <cerrno>
#include <csignal>
#include <map>
#include <vector>
/**
This file is what Wall et al. call REAPER
in the perlipc manpage. It class knows which
PID it's waiting for. When the time has come
the reaper distributor will call reap() on this.
@author: Wolfgang Mueller
@see: CReaperDistributor, man perlipc
*/
class CReaper{
protected:
/** the ID of the process to which the reaper belongs */
int mPID;
public:
/** the PID for which this reaper
is responsible */
CReaper(int inPID);
/** react to a sigchild signal */
virtual void reap()=0;
/**
get the PID of this reaper
*/
int getPID()const;
};
#endif
|