Files
Arquivotheca.Solaris-2.5/uts/common/sys/pathname.h
seta75D 7c4988eac0 Init
2021-10-11 19:38:01 -03:00

111 lines
3.6 KiB
C
Executable File

/* Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T */
/* All Rights Reserved */
/* THIS IS UNPUBLISHED PROPRIETARY SOURCE CODE OF AT&T */
/* The copyright notice above does not evidence any */
/* actual or intended publication of such source code. */
/*
* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
* PROPRIETARY NOTICE (Combined)
*
* This source code is unpublished proprietary information
* constituting, or derived under license from AT&T's UNIX(r) System V.
* In addition, portions of such source code were derived from Berkeley
* 4.3 BSD under license from the Regents of the University of
* California.
*
*
*
* Copyright Notice
*
* Notice of copyright on this source code product does not indicate
* publication.
*
* (c) 1986,1987,1988,1989 Sun Microsystems, Inc
* (c) 1983,1984,1985,1986,1987,1988,1989 AT&T.
* All rights reserved.
*
*/
#ifndef _SYS_PATHNAME_H
#define _SYS_PATHNAME_H
#pragma ident "@(#)pathname.h 1.13 94/10/27 SMI" /* from SVR4.0 1.7 */
#include <sys/vnode.h>
#include <sys/cred.h>
#include <sys/uio.h>
#ifdef __cplusplus
extern "C" {
#endif
/*
* Pathname structure.
* System calls that operate on path names gather the path name
* from the system call into this structure and reduce it by
* peeling off translated components. If a symbolic link is
* encountered the new path name to be translated is also
* assembled in this structure.
*
* By convention pn_buf is not changed once it's been set to point
* to the underlying storage; routines which manipulate the pathname
* do so by changing pn_path and pn_pathlen. pn_pathlen is redundant
* since the path name is null-terminated, but is provided to make
* some computations faster.
*/
typedef struct pathname {
char *pn_buf; /* underlying storage */
char *pn_path; /* remaining pathname */
u_int pn_pathlen; /* remaining length */
u_int pn_bufsize; /* total size of pn_buf */
} pathname_t;
#define pn_peekchar(pnp) ((pnp)->pn_pathlen > 0 ? *((pnp)->pn_path) : 0)
#define pn_pathleft(pnp) ((pnp)->pn_pathlen)
#ifdef __STDC__
extern void pn_alloc(struct pathname *);
extern int pn_get(char *, enum uio_seg, struct pathname *);
extern int pn_set(struct pathname *, char *);
extern int pn_insert(struct pathname *, struct pathname *);
extern int pn_getsymlink(vnode_t *, struct pathname *, cred_t *);
extern int pn_getcomponent(struct pathname *, char *);
extern void pn_setlast(struct pathname *);
extern void pn_skipslash(struct pathname *);
extern void pn_fixslash(struct pathname *);
extern void pn_free(struct pathname *);
extern int lookupname(char *, enum uio_seg, enum symfollow, vnode_t **,
vnode_t **);
extern int lookuppn(struct pathname *, enum symfollow, vnode_t **,
vnode_t **);
extern int traverse(vnode_t **);
#else
extern void pn_alloc(); /* allocate buffer for pathname */
extern int pn_get(); /* allocate buffer, copy path into it */
extern int pn_set(); /* set pathname to string */
extern int pn_insert(); /* combine two pathnames (symlink) */
extern int pn_getsymlink(); /* get symlink into pathname */
extern int pn_getcomponent(); /* get next component of pathname */
extern void pn_setlast(); /* set pathname to last component */
extern void pn_skipslash(); /* skip over slashes */
extern void pn_fixslash(); /* eliminate trailing slashes */
extern void pn_free(); /* free pathname buffer */
extern int lookupname(); /* convert name to vnode */
extern int lookuppn(); /* convert pathname buffer to vnode */
extern int traverse(); /* traverse a mount point */
#endif /* __STDC__ */
#ifdef __cplusplus
}
#endif
#endif /* _SYS_PATHNAME_H */