File: groups.h

package info (click to toggle)
spread 3.17.4-2
  • links: PTS
  • area: main
  • in suites: lenny, squeeze
  • size: 1,800 kB
  • ctags: 2,322
  • sloc: ansic: 15,666; sh: 2,611; java: 2,291; perl: 556; yacc: 523; makefile: 255; lex: 204; xml: 77
file content (67 lines) | stat: -rw-r--r-- 2,405 bytes parent folder | download | duplicates (3)
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
/*
 * The Spread Toolkit.
 *     
 * The contents of this file are subject to the Spread Open-Source
 * License, Version 1.0 (the ``License''); you may not use
 * this file except in compliance with the License.  You may obtain a
 * copy of the License at:
 *
 * http://www.spread.org/license/
 *
 * or in the file ``license.txt'' found in this distribution.
 *
 * Software distributed under the License is distributed on an AS IS basis, 
 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License 
 * for the specific language governing rights and limitations under the 
 * License.
 *
 * The Creators of Spread are:
 *  Yair Amir, Michal Miskin-Amir, Jonathan Stanton.
 *
 *  Copyright (C) 1993-2004 Spread Concepts LLC <spread@spreadconcepts.com>
 *
 *  All Rights Reserved.
 *
 * Major Contributor(s):
 * ---------------
 *    Cristina Nita-Rotaru crisn@cs.purdue.edu - group communication security.
 *    Theo Schlossnagle    jesus@omniti.com - Perl, skiplists, autoconf.
 *    Dan Schoenblum       dansch@cnds.jhu.edu - Java interface.
 *    John Schultz         jschultz@cnds.jhu.edu - contribution to process group membership.
 *
 */


#ifndef	INC_GROUPS
#define	INC_GROUPS

#include "session.h"

#define		GOP	1
#define		GTRANS	2
#define		GGATHER	3
#define		GGT	4

#define GROUPS_BUF_SIZE 100000
#define MAX_LOCAL_GROUP_MEMBERS ( GROUPS_BUF_SIZE -                           \
                                ( sizeof( membership_id ) + MAX_GROUP_NAME +  \
                                  sizeof( group_id ) + sizeof( int16 ) ) ) /  \
                                MAX_GROUP_NAME

void	G_init(void);

void	G_handle_reg_memb( configuration reg_memb, membership_id reg_memb_id );
void	G_handle_trans_memb( configuration trans_memb,
                             membership_id trans_memb_id );
void	G_handle_join( char *private_group_name, char *group_name );
void	G_handle_leave( char *private_group_name, char *group_name );
void	G_handle_kill( char *private_group_name );
void	G_handle_groups( message_link *mess_link );

int	G_analize_groups( int num_groups, char target_groups[][MAX_GROUP_NAME], int target_sessions[] );
void    G_set_mask( int num_groups, char target_groups[][MAX_GROUP_NAME], int32u *grp_mask );

int	G_private_to_names( char *private_group_name, char *private_name, char *proc_name );
int     G_get_num_local( char *group_name );
 
#endif	/* INC_GROUPS */