File: zroutinessp.h

package info (click to toggle)
fis-gtm 7.1-006-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 32,908 kB
  • sloc: ansic: 344,906; asm: 5,184; csh: 4,859; sh: 2,000; awk: 294; makefile: 73; sed: 13
file content (55 lines) | stat: -rwxr-xr-x 2,537 bytes parent folder | download | duplicates (6)
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
/****************************************************************
 *								*
 * Copyright (c) 2001-2015 Fidelity National Information 	*
 * Services, Inc. and/or its subsidiaries. All rights reserved.	*
 *								*
 *	This source code contains the intellectual property	*
 *	of its copyright holder(s), and is made available	*
 *	under a license.  If you do not know the terms of	*
 *	the license, please stop and do not read further.	*
 *								*
 ****************************************************************/

#ifndef ZROUTINESSP_H_INCLUDED
#define ZROUTINESSP_H_INCLUDED

/* Parse token types returned by zro_gettok() used when parsing $ZROUTINES values */
#define ZRO_EOL 		0	/* End of line */
#define ZRO_IDN 		1	/* Identifier/name - directory or file name */
#define ZRO_DEL 		' '	/* Delimiter (space) */
#define ZRO_LBR 		'('	/* Left parenthesis denoting source directory list start */
#define ZRO_RBR 		')'	/* Right parenthesis denoting source directory list end */
#define ZRO_ALF			'*'	/* Auto-relink flag/indicator */

/* Value to use in the count field of a zro_ent structure to mark a particular directory in $gtmroutines as autorelink-enabled for
 * subsequent traversal in MUPIP RUNDOWN -RELINKCTL. The value must be negative to be distinguishable from a real count.
 */
#define ZRO_DIR_ENABLE_AR	-1

/* zro_ent fields are interpreted based on entry type:
 * ZRO_TYPE_COUNT --> count indicates number of entries following
 *  	this entry representing a list of source or object directories.
 * ZRO_TYPE_OBJECT, ZRO_TYPE_SOURCE --> str stores the path of the appropriate
 * 	object/source directory.
 * ZRO_TYPE_OBJLIB --> str and shrlib store the shared library file name and
 * 	its handle respectively. (the shrsym field is used as a place holder
 * 	to keep dlsym() value available for incr_link during each $ZROUTINES search). */
typedef	struct zro_ent_type
{
	uint4		type;
	int4		count;
	mstr		str;			/* Path name */
	void_ptr_t	shrlib; 		/* Result of dlopen(), if a shared library */
	void_ptr_t	shrsym; 		/* Placeholder for result of fgn_getrtn(), which we pass from zro_search() to
						 * incr_link().
						 */
	void_ptr_t	relinkctl_sgmaddr;	/* Shared memory control structure associated with this $ZRO entry */
} zro_ent;

int zro_gettok(char **lp, char *top, mstr *tok);
void zro_search(mstr *objstr, zro_ent **objdir, mstr *srcstr, zro_ent **srcdir, boolean_t skip);
#ifdef AUTORELINK_SUPPORTED
zro_hist *zro_search_hist(char *objnamebuf, zro_ent **objdir);
#endif

#endif /* ZROUTINESSP_H_INCLUDED */