File: runlater.H

package info (click to toggle)
cone 0.75-1
  • links: PTS, VCS
  • area: main
  • in suites: lenny
  • size: 31,040 kB
  • ctags: 13,930
  • sloc: ansic: 90,648; cpp: 79,781; sh: 18,355; perl: 3,218; makefile: 1,611; yacc: 289; sed: 16
file content (47 lines) | stat: -rw-r--r-- 1,109 bytes parent folder | download | duplicates (2)
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
/* $Id: runlater.H,v 1.2 2004/04/06 02:06:37 mrsam Exp $
**
** Copyright 2002, Double Precision Inc.
**
** See COPYING for distribution information.
*/
#ifndef libmail_runlater_H
#define libmail_runlater_H

#include "libmail_config.h"
#include "objectmonitor.H"

#include <queue>

/*
** Local mail drivers are immediate - they implement the request and invoke
** the callback function without delay.  Some requests iterate over an entire
** message set (such as mail::copyMessages).  Each callback function
** iterates to the next message.  With large message sets the stack could
** grow quite big.  The solution is the mail::runLater interface.  After
** calling RunLater(), the caller MUST immediately terminate.  The stack
** will unwind back to mail::account::process(), which then invokes the
** checkRunLater() method.
*/

LIBMAIL_START

class runLater;

class runLater : public mail::obj {
public:
	runLater();
	~runLater();

	static std::queue<mail::ptr<runLater> > runningLater;

	void RunLater();

	virtual void RunningLater()=0;

	static void checkRunLater(int &timeout);
};

LIBMAIL_END

#endif