1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
3 * The contents of this file are subject to the Mozilla Public
4 * License Version 1.1 (the "License"); you may not use this file
5 * except in compliance with the License. You may obtain a copy of
6 * the License at http://www.mozilla.org/MPL/
8 * Software distributed under the License is distributed on an "AS
9 * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
10 * implied. See the License for the specific language governing
11 * rights and limitations under the License.
13 * The Original Code is the Netscape Portable Runtime (NSPR).
15 * The Initial Developer of the Original Code is Netscape
16 * Communications Corporation. Portions created by Netscape are
17 * Copyright (C) 1999-2000 Netscape Communications Corporation. All
22 * Alternatively, the contents of this file may be used under the
23 * terms of the GNU General Public License Version 2 or later (the
24 * "GPL"), in which case the provisions of the GPL are applicable
25 * instead of those above. If you wish to allow use of your
26 * version of this file only under the terms of the GPL and not to
27 * allow others to use your version of this file under the MPL,
28 * indicate your decision by deleting the provisions above and
29 * replace them with the notice and other provisions required by
30 * the GPL. If you do not delete the provisions above, a recipient
31 * may use your version of this file under either the MPL or the
45 * THIS API IS A PRELIMINARY VERSION IN NSPR 4.0 AND IS SUBJECT TO
51 typedef struct PRJobIoDesc
{
54 PRIntervalTime timeout
;
57 typedef struct PRThreadPool PRThreadPool
;
58 typedef struct PRJob PRJob
;
59 typedef void (PR_CALLBACK
*PRJobFn
) (void *arg
);
61 /* Create thread pool */
62 NSPR_API(PRThreadPool
*)
63 PR_CreateThreadPool(PRInt32 initial_threads
, PRInt32 max_threads
,
68 PR_QueueJob(PRThreadPool
*tpool
, PRJobFn fn
, void *arg
, PRBool joinable
);
70 /* queue a job, when a socket is readable */
72 PR_QueueJob_Read(PRThreadPool
*tpool
, PRJobIoDesc
*iod
,
73 PRJobFn fn
, void * arg
, PRBool joinable
);
75 /* queue a job, when a socket is writeable */
77 PR_QueueJob_Write(PRThreadPool
*tpool
, PRJobIoDesc
*iod
,
78 PRJobFn fn
, void * arg
, PRBool joinable
);
80 /* queue a job, when a socket has a pending connection */
82 PR_QueueJob_Accept(PRThreadPool
*tpool
, PRJobIoDesc
*iod
,
83 PRJobFn fn
, void * arg
, PRBool joinable
);
85 /* queue a job, when the socket connection to addr succeeds or fails */
87 PR_QueueJob_Connect(PRThreadPool
*tpool
, PRJobIoDesc
*iod
,
88 const PRNetAddr
*addr
, PRJobFn fn
, void * arg
, PRBool joinable
);
90 /* queue a job, when a timer exipres */
92 PR_QueueJob_Timer(PRThreadPool
*tpool
, PRIntervalTime timeout
,
93 PRJobFn fn
, void * arg
, PRBool joinable
);
96 PR_CancelJob(PRJob
*job
);
100 PR_JoinJob(PRJob
*job
);
104 PR_ShutdownThreadPool(PRThreadPool
*tpool
);
106 /* join pool, wait for exit of all threads */
108 PR_JoinThreadPool(PRThreadPool
*tpool
);
112 #endif /* prtpool_h___ */