⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sys2.h

📁 代码检索工具GLOBAL源码。可用来浏览分析LINUX源码。
💻 H
字号:
/* WARNING -- this file is temporary.  It is shared between the   sh-utils, fileutils, and textutils packages.  Once I find a little   more time, I'll merge the remaining things in system.h and everything   in this file will go back there. */#ifndef RETSIGTYPE# define RETSIGTYPE void#endif#ifndef __GNUC__# ifdef HAVE_ALLOCA_H#  include <alloca.h># else#  ifdef _AIX #  pragma alloca#  else#   ifdef _WIN32#    include <malloc.h>#    include <io.h>#   else#    ifndef allocachar *alloca ();#    endif#   endif#  endif# endif#endif#ifdef __DJGPP__  /* We need the declaration of setmode.  */# include <io.h>  /* We need the declaration of __djgpp_set_ctrl_c.  */# include <sys/exceptn.h>#endif#include <ctype.h>/* Jim Meyering writes:   "... Some ctype macros are valid only for character codes that   isascii says are ASCII (SGI's IRIX-4.0.5 is one such system --when   using /bin/cc or gcc but without giving an ansi option).  So, all   ctype uses should be through macros like ISPRINT...  If   STDC_HEADERS is defined, then autoconf has verified that the ctype   macros don't need to be guarded with references to isascii. ...   Defining isascii to 1 should let any compiler worth its salt   eliminate the && through constant folding."   Bruno Haible adds:   "... Furthermore, isupper(c) etc. have an undefined result if c is   outside the range -1 <= c <= 255. One is tempted to write isupper(c)   with c being of type `char', but this is wrong if c is an 8-bit   character >= 128 which gets sign-extended to a negative value.   The macro ISUPPER protects against this as well."  */#if STDC_HEADERS || (!defined (isascii) && !HAVE_ISASCII)# define IN_CTYPE_DOMAIN(c) 1#else# define IN_CTYPE_DOMAIN(c) isascii(c)#endif#ifdef isblank# define ISBLANK(c) (IN_CTYPE_DOMAIN (c) && isblank (c))#else# define ISBLANK(c) ((c) == ' ' || (c) == '\t')#endif#ifdef isgraph# define ISGRAPH(c) (IN_CTYPE_DOMAIN (c) && isgraph (c))#else# define ISGRAPH(c) (IN_CTYPE_DOMAIN (c) && isprint (c) && !isspace (c))#endif#define ISPRINT(c) (IN_CTYPE_DOMAIN (c) && isprint (c))#define ISALNUM(c) (IN_CTYPE_DOMAIN (c) && isalnum (c))#define ISALPHA(c) (IN_CTYPE_DOMAIN (c) && isalpha (c))#define ISCNTRL(c) (IN_CTYPE_DOMAIN (c) && iscntrl (c))#define ISLOWER(c) (IN_CTYPE_DOMAIN (c) && islower (c))#define ISPUNCT(c) (IN_CTYPE_DOMAIN (c) && ispunct (c))#define ISSPACE(c) (IN_CTYPE_DOMAIN (c) && isspace (c))#define ISUPPER(c) (IN_CTYPE_DOMAIN (c) && isupper (c))#define ISXDIGIT(c) (IN_CTYPE_DOMAIN (c) && isxdigit (c))#define ISDIGIT_LOCALE(c) (IN_CTYPE_DOMAIN (c) && isdigit (c))#if STDC_HEADERS# define TOLOWER(Ch) tolower (Ch)# define TOUPPER(Ch) toupper (Ch)#else# define TOLOWER(Ch) (ISUPPER (Ch) ? tolower (Ch) : (Ch))# define TOUPPER(Ch) (ISLOWER (Ch) ? toupper (Ch) : (Ch))#endif/* ISDIGIT differs from ISDIGIT_LOCALE, as follows:   - Its arg may be any int or unsigned int; it need not be an unsigned char.   - It's guaranteed to evaluate its argument exactly once.   - It's typically faster.   Posix 1003.2-1992 section 2.5.2.1 page 50 lines 1556-1558 says that   only '0' through '9' are digits.  Prefer ISDIGIT to ISDIGIT_LOCALE unless   it's important to use the locale's definition of `digit' even when the   host does not conform to Posix.  */#define ISDIGIT(c) ((unsigned) (c) - '0' <= 9)#ifndef PARAMS# if PROTOTYPES#  define PARAMS(Args) Args# else#  define PARAMS(Args) ()# endif#endif/* Take care of NLS matters.  */#if HAVE_LOCALE_H# include <locale.h>#endif#if !HAVE_SETLOCALE# define setlocale(Category, Locale) /* empty */#endif#if ENABLE_NLS# include <libintl.h># define _(Text) gettext (Text)#else# undef bindtextdomain# define bindtextdomain(Domain, Directory) /* empty */# undef textdomain# define textdomain(Domain) /* empty */# define _(Text) Text#endif#define N_(Text) Text#define STREQ(a, b) (strcmp ((a), (b)) == 0)#if !HAVE_DECL_FREEvoid free ();#endif#if !HAVE_DECL_MALLOCchar *malloc ();#endif#if !HAVE_DECL_MEMCHRchar *memchr ();#endif#if !HAVE_DECL_REALLOCchar *realloc ();#endif#if !HAVE_DECL_STPCPY# ifndef stpcpychar *stpcpy ();# endif#endif#if !HAVE_DECL_STRSTRchar *strstr ();#endif#if !HAVE_DECL_GETENVchar *getenv ();#endif#if !HAVE_DECL_LSEEKoff_t lseek ();#endif#include "xalloc.h"#if ! defined HAVE_MEMPCPY && ! defined mempcpy/* Be CAREFUL that there are no side effects in N.  */# define mempcpy(D, S, N) ((void *) ((char *) memcpy (D, S, N) + (N)))#endif/* These are wrappers for functions/macros from GNU libc.   The standard I/O functions are thread-safe.  These *_unlocked ones   are more efficient but not thread-safe.  That they're not thread-safe   is fine since all these applications are single threaded.  */#ifdef HAVE_CLEARERR_UNLOCKED# undef clearerr# define clearerr(S) clearerr_unlocked (S)#endif#ifdef HAVE_FEOF_UNLOCKED# undef feof# define feof(S) feof_unlocked (S)#endif#ifdef HAVE_FERROR_UNLOCKED# undef ferror# define ferror(S) ferror_unlocked (S)#endif#ifdef HAVE_FFLUSH_UNLOCKED# undef fflush# define fflush(S) fflush_unlocked (S)#endif#ifdef HAVE_FPUTC_UNLOCKED# undef fputc# define fputc(C, S) fputc_unlocked (C, S)#endif#ifdef HAVE_FREAD_UNLOCKED# undef fread# define fread(P, Z, N, S) fread_unlocked (P, Z, N, S)#endif#ifdef HAVE_FWRITE_UNLOCKED# undef fwrite# define fwrite(P, Z, N, S) fwrite_unlocked (P, Z, N, S)#endif#ifdef HAVE_GETC_UNLOCKED# undef getc# define getc(S) getc_unlocked (S)#endif#ifdef HAVE_GETCHAR_UNLOCKED# undef getchar# define getchar(S) getchar_unlocked (S)#endif#ifdef HAVE_PUTC_UNLOCKED# undef putc# define putc(C, S) putc_unlocked (C, S)#endif#ifdef HAVE_PUTCHAR_UNLOCKED# undef putchar# define putchar(C) putchar_unlocked (C)#endif#define SAME_INODE(Stat_buf_1, Stat_buf_2) \  ((Stat_buf_1).st_ino == (Stat_buf_2).st_ino \   && (Stat_buf_1).st_dev == (Stat_buf_2).st_dev)#define DOT_OR_DOTDOT(Basename) \  (Basename[0] == '.' && (Basename[1] == '\0' \			  || (Basename[1] == '.' && Basename[2] == '\0')))#if SETVBUF_REVERSED# define SETVBUF(Stream, Buffer, Type, Size) \    setvbuf (Stream, Type, Buffer, Size)#else# define SETVBUF(Stream, Buffer, Type, Size) \    setvbuf (Stream, Buffer, Type, Size)#endifchar *base_name PARAMS ((char const *));/* Factor out some of the common --help and --version processing code.  */#define GETOPT_HELP_CHAR 250#define GETOPT_VERSION_CHAR 251#define GETOPT_HELP_OPTION_DECL \  "help", no_argument, 0, GETOPT_HELP_CHAR#define GETOPT_VERSION_OPTION_DECL \  "version", no_argument, 0, GETOPT_VERSION_CHAR#define case_GETOPT_HELP_CHAR			\  case GETOPT_HELP_CHAR:			\    usage (EXIT_SUCCESS);			\    break;#include "closeout.h"#include "version-etc.h"#define case_GETOPT_VERSION_CHAR(Program_name, Authors)			\  case GETOPT_VERSION_CHAR:						\    version_etc (stdout, Program_name, GNU_PACKAGE, VERSION, Authors);	\    close_stdout ();							\    exit (EXIT_SUCCESS);						\    break;#ifndef MAX# define MAX(a, b) ((a) > (b) ? (a) : (b))#endif#ifndef MIN# define MIN(a,b) (((a) < (b)) ? (a) : (b))#endif#ifndef CHAR_BIT# define CHAR_BIT 8#endif/* The extra casts work around common compiler bugs.  */#define TYPE_SIGNED(t) (! ((t) 0 < (t) -1))/* The outer cast is needed to work around a bug in Cray C 5.0.3.0.   It is necessary at least when t == time_t.  */#define TYPE_MINIMUM(t) ((t) (TYPE_SIGNED (t) \			      ? ~ (t) 0 << (sizeof (t) * CHAR_BIT - 1) : (t) 0))#define TYPE_MAXIMUM(t) ((t) (~ (t) 0 - TYPE_MINIMUM (t)))#ifndef CHAR_MIN# define CHAR_MIN TYPE_MINIMUM (char)#endif#ifndef CHAR_MAX# define CHAR_MAX TYPE_MAXIMUM (char)#endif#ifndef SCHAR_MIN# define SCHAR_MIN (-1 - SCHAR_MAX)#endif#ifndef SCHAR_MAX# define SCHAR_MAX (CHAR_MAX == UCHAR_MAX ? CHAR_MAX / 2 : CHAR_MAX)#endif#ifndef UCHAR_MAX# define UCHAR_MAX TYPE_MAXIMUM (unsigned char)#endif#ifndef SHRT_MIN# define SHRT_MIN TYPE_MINIMUM (short int)#endif#ifndef SHRT_MAX# define SHRT_MAX TYPE_MAXIMUM (short int)#endif#ifndef INT_MAX# define INT_MAX TYPE_MAXIMUM (int)#endif#ifndef UINT_MAX# define UINT_MAX TYPE_MAXIMUM (unsigned int)#endif#ifndef LONG_MAX# define LONG_MAX TYPE_MAXIMUM (long)#endif#ifndef ULONG_MAX# define ULONG_MAX TYPE_MAXIMUM (unsigned long)#endif#ifndef UID_T_MAX# define UID_T_MAX TYPE_MAXIMUM (uid_t)#endif#ifndef GID_T_MAX# define GID_T_MAX TYPE_MAXIMUM (gid_t)#endif#ifndef PID_T_MAX# define PID_T_MAX TYPE_MAXIMUM (pid_t)#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -