unistd.h
来自「基于组件方式开发操作系统的OSKIT源代码」· C头文件 代码 · 共 163 行
H
163 行
/* $NetBSD: unistd.h,v 1.18 1999/09/27 16:24:41 kleink Exp $ *//* * Copyright (c) 1989, 1993 * The Regents of the University of California. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. All advertising materials mentioning features or use of this software * must display the following acknowledgement: * This product includes software developed by the University of * California, Berkeley and its contributors. * 4. Neither the name of the University nor the names of its contributors * may be used to endorse or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * @(#)unistd.h 8.2 (Berkeley) 1/7/94 */#ifndef _SYS_UNISTD_H_#define _SYS_UNISTD_H_#include <sys/featuretest.h>/* compile-time symbolic constants */#define _POSIX_JOB_CONTROL /* implementation supports job control *//* * According to POSIX 1003.1: * "The saved set-user-ID capability allows a program to regain the * effective user ID established at the last exec call." * However, the setuid/setgid function as specified by POSIX 1003.1 does * not allow changing the effective ID from the super-user without also * changed the saved ID, so it is impossible to get super-user privileges * back later. Instead we provide this feature independent of the current * effective ID through the seteuid/setegid function. In addition, we do * not use the saved ID as specified by POSIX 1003.1 in setuid/setgid, * because this would make it impossible for a set-user-ID executable * owned by a user other than the super-user to permanently revoke its * extra privileges. */#ifdef _NOT_AVAILABLE#define _POSIX_SAVED_IDS /* saved set-user-ID and set-group-ID */#endif#define _POSIX_VERSION 199009L#define _POSIX2_VERSION 199212L/* execution-time symbolic constants */ /* chown requires appropriate privileges */#define _POSIX_CHOWN_RESTRICTED 1 /* too-long path components generate errors */#define _POSIX_NO_TRUNC 1 /* may disable terminal special characters */#define _POSIX_VDISABLE ((unsigned char)'\377') /* file synchronization is available */#define _POSIX_FSYNC 1 /* synchronized I/O is available */#define _POSIX_SYNCHRONIZED_IO 1 /* memory mapped files */#define _POSIX_MAPPED_FILES 1 /* memory locking of whole address space */#define _POSIX_MEMLOCK 1 /* memory locking address ranges */#define _POSIX_MEMLOCK_RANGE 1 /* memory access protections */#define _POSIX_MEMORY_PROTECTION 1/* access function */#define F_OK 0 /* test for existence of file */#define X_OK 0x01 /* test for execute or search permission */#define W_OK 0x02 /* test for write permission */#define R_OK 0x04 /* test for read permission *//* whence values for lseek(2) */#define SEEK_SET 0 /* set file offset to offset */#define SEEK_CUR 1 /* set file offset to current plus offset */#define SEEK_END 2 /* set file offset to EOF plus offset */#if !defined(_POSIX_C_SOURCE) && !defined(_XOPEN_SOURCE)/* whence values for lseek(2); renamed by POSIX 1003.1 */#define L_SET SEEK_SET#define L_INCR SEEK_CUR#define L_XTND SEEK_END#endif/* configurable pathname variables */#define _PC_LINK_MAX 1#define _PC_MAX_CANON 2#define _PC_MAX_INPUT 3#define _PC_NAME_MAX 4#define _PC_PATH_MAX 5#define _PC_PIPE_BUF 6#define _PC_CHOWN_RESTRICTED 7#define _PC_NO_TRUNC 8#define _PC_VDISABLE 9#define _PC_SYNC_IO 10#define _PC_FILESIZEBITS 11/* configurable system variables */#define _SC_ARG_MAX 1#define _SC_CHILD_MAX 2#define _SC_CLK_TCK 3#define _SC_NGROUPS_MAX 4#define _SC_OPEN_MAX 5#define _SC_JOB_CONTROL 6#define _SC_SAVED_IDS 7#define _SC_VERSION 8#define _SC_BC_BASE_MAX 9#define _SC_BC_DIM_MAX 10#define _SC_BC_SCALE_MAX 11#define _SC_BC_STRING_MAX 12#define _SC_COLL_WEIGHTS_MAX 13#define _SC_EXPR_NEST_MAX 14#define _SC_LINE_MAX 15#define _SC_RE_DUP_MAX 16#define _SC_2_VERSION 17#define _SC_2_C_BIND 18#define _SC_2_C_DEV 19#define _SC_2_CHAR_TERM 20#define _SC_2_FORT_DEV 21#define _SC_2_FORT_RUN 22#define _SC_2_LOCALEDEF 23#define _SC_2_SW_DEV 24#define _SC_2_UPE 25#define _SC_STREAM_MAX 26#define _SC_TZNAME_MAX 27#define _SC_PAGESIZE 28#define _SC_PAGE_SIZE _SC_PAGESIZE /* 1170 compatibility */#define _SC_FSYNC 29#define _SC_XOPEN_SHM 30#define _SC_SYNCHRONIZED_IO 31#define _SC_IOV_MAX 32#define _SC_MAPPED_FILES 33#define _SC_MEMLOCK 34#define _SC_MEMLOCK_RANGE 35#define _SC_MEMORY_PROTECTION 36#define _SC_LOGIN_NAME_MAX 37/* configurable system strings */#define _CS_PATH 1#endif /* !_SYS_UNISTD_H_ */
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?