亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? system.c

?? MC Linux/Unix 終端下文件管理器
?? C
字號:
/*    Unix SMB/Netbios implementation.   Version 1.9.   Samba system utilities   Copyright (C) Andrew Tridgell 1992-1998      This program is free software; you can redistribute it and/or modify   it under the terms of the GNU General Public License as published by   the Free Software Foundation; either version 2 of the License, or   (at your option) any later version.      This program is distributed in the hope that it will be useful,   but WITHOUT ANY WARRANTY; without even the implied warranty of   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the   GNU General Public License for more details.      You should have received a copy of the GNU General Public License   along with this program; if not, write to the Free Software   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.*/#include "includes.h"extern int DEBUGLEVEL;/*   The idea is that this file will eventually have wrappers around all   important system calls in samba. The aims are:   - to enable easier porting by putting OS dependent stuff in here   - to allow for hooks into other "pseudo-filesystems"   - to allow easier integration of things like the japanese extensions   - to support the philosophy of Samba to expose the features of     the OS within the SMB model. In general whatever file/printer/variable     expansions/etc make sense to the OS should be acceptable to Samba.*//*******************************************************************this replaces the normal select() system callreturn if some data has arrived on one of the file descriptorsreturn -1 means error********************************************************************/#ifndef HAVE_SELECTstatic int pollfd(int fd){  int     r=0;#ifdef HAS_RDCHK  r = rdchk(fd);#elif defined(TCRDCHK)  (void)ioctl(fd, TCRDCHK, &r);#else  (void)ioctl(fd, FIONREAD, &r);#endif  return(r);}int sys_select(int maxfd, fd_set *fds,struct timeval *tval){  fd_set fds2;  int counter=0;  int found=0;  FD_ZERO(&fds2);  while (1)   {    int i;    for (i=0;i<maxfd;i++) {      if (FD_ISSET(i,fds) && pollfd(i)>0) {        found++;        FD_SET(i,&fds2);      }    }    if (found) {      memcpy((void *)fds,(void *)&fds2,sizeof(fds2));      return(found);    }          if (tval && tval->tv_sec < counter) return(0);      sleep(1);      counter++;  }}#else /* !NO_SELECT */int sys_select(int maxfd, fd_set *fds,struct timeval *tval){#ifdef USE_POLL  struct pollfd pfd[256];  int i;  int maxpoll;  int timeout;  int pollrtn;  maxpoll = 0;  for( i = 0; i < maxfd; i++) {    if(FD_ISSET(i,fds)) {      struct pollfd *pfdp = &pfd[maxpoll++];      pfdp->fd = i;      pfdp->events = POLLIN;      pfdp->revents = 0;    }  }  timeout = (tval != NULL) ? (tval->tv_sec * 1000) + (tval->tv_usec/1000) :                -1;  errno = 0;  do {    pollrtn = poll( &pfd[0], maxpoll, timeout);  } while (pollrtn<0 && errno == EINTR);  FD_ZERO(fds);  for( i = 0; i < maxpoll; i++)    if( pfd[i].revents & POLLIN )      FD_SET(pfd[i].fd,fds);  return pollrtn;#else /* USE_POLL */  struct timeval t2;  int selrtn;  do {    if (tval) memcpy((void *)&t2,(void *)tval,sizeof(t2));    errno = 0;    selrtn = select(maxfd,SELECT_CAST fds,NULL,NULL,tval?&t2:NULL);  } while (selrtn<0 && errno == EINTR);  return(selrtn);}#endif /* USE_POLL */#endif /* NO_SELECT *//******************************************************************* A wrapper for usleep in case we don't have one.********************************************************************/int sys_usleep(long usecs){#ifndef HAVE_USLEEP  struct timeval tval;#endif  /*   * We need this braindamage as the glibc usleep   * is not SPEC1170 complient... grumble... JRA.   */  if(usecs < 0 || usecs > 1000000) {    errno = EINVAL;    return -1;  }#if HAVE_USLEEP  usleep(usecs);  return 0;#else /* HAVE_USLEEP */  /*   * Fake it with select...   */  tval.tv_sec = 0;  tval.tv_usec = usecs/1000;  select(0,NULL,NULL,NULL,&tval);  return 0;#endif /* HAVE_USLEEP */}/*******************************************************************A stat() wrapper that will deal with 64 bit filesizes.********************************************************************/int sys_stat(const char *fname,SMB_STRUCT_STAT *sbuf){  return stat(fname, sbuf);}/******************************************************************* An fstat() wrapper that will deal with 64 bit filesizes.********************************************************************/int sys_fstat(int fd,SMB_STRUCT_STAT *sbuf){  return fstat(fd, sbuf);}/******************************************************************* An lstat() wrapper that will deal with 64 bit filesizes.********************************************************************/int sys_lstat(const char *fname,SMB_STRUCT_STAT *sbuf){  return lstat(fname, sbuf);}/******************************************************************* An ftruncate() wrapper that will deal with 64 bit filesizes.********************************************************************/#if 0int sys_ftruncate(int fd, SMB_OFF_T offset){  return ftruncate(fd, offset);}#endif/******************************************************************* An lseek() wrapper that will deal with 64 bit filesizes.********************************************************************/SMB_OFF_T sys_lseek(int fd, SMB_OFF_T offset, int whence){  return lseek(fd, offset, whence);}/******************************************************************* An fseek() wrapper that will deal with 64 bit filesizes.********************************************************************/int sys_fseek(FILE *fp, SMB_OFF_T offset, int whence){  return fseek(fp, offset, whence);}/******************************************************************* An ftell() wrapper that will deal with 64 bit filesizes.********************************************************************/SMB_OFF_T sys_ftell(FILE *fp){  return (SMB_OFF_T)ftell(fp);}/******************************************************************* A creat() wrapper that will deal with 64 bit filesizes.********************************************************************/int sys_creat(const char *path, mode_t mode){  return sys_open(path, O_WRONLY | O_CREAT | O_TRUNC, mode);}/******************************************************************* An open() wrapper that will deal with 64 bit filesizes.********************************************************************/int sys_open(const char *path, int oflag, mode_t mode){  return open(path, oflag, mode);}/******************************************************************* An fopen() wrapper that will deal with 64 bit filesizes.********************************************************************/FILE *sys_fopen(const char *path, const char *type){  return fopen(path, type);}#if defined(HAVE_MMAP)/******************************************************************* An mmap() wrapper that will deal with 64 bit filesizes.********************************************************************/void *sys_mmap(void *addr, size_t len, int prot, int flags, int fd, SMB_OFF_T offset){  return mmap(addr, len, prot, flags, fd, offset);}#endif /* HAVE_MMAP *//******************************************************************* A readdir wrapper that will deal with 64 bit filesizes.********************************************************************/SMB_STRUCT_DIRENT *sys_readdir(DIR *dirp){  return readdir(dirp);}/*******************************************************************The wait() calls vary between systems********************************************************************/#if 0int sys_waitpid(pid_t pid,int *status,int options){#ifdef HAVE_WAITPID  return waitpid(pid,status,options);#else /* HAVE_WAITPID */  return wait4(pid, status, options, NULL);#endif /* HAVE_WAITPID */}#endif/*******************************************************************system wrapper for getwd********************************************************************/char *sys_getwd(char *s){    char *wd;#ifdef HAVE_GETCWD    wd = (char *)getcwd(s, sizeof (pstring));#else    wd = (char *)getwd(s);#endif    return wd;}/*******************************************************************chown isn't used much but OS/2 doesn't have it********************************************************************/int sys_chown(const char *fname,uid_t uid,gid_t gid){#ifndef HAVE_CHOWN	static int done;	if (!done) {		DEBUG(1,("WARNING: no chown!\n"));		done=1;	}#else	return(chown(fname,uid,gid));#endif}/**************************************************************************A wrapper for gethostbyname() that tries avoids looking up hostnames in the root domain, which can cause dial-on-demand links to come up for noapparent reason.****************************************************************************/struct hostent *sys_gethostbyname(const char *name){#ifdef REDUCE_ROOT_DNS_LOOKUPS  char query[256], hostname[256];  char *domain;  /* Does this name have any dots in it? If so, make no change */  if (strchr(name, '.'))    return(gethostbyname(name));  /* Get my hostname, which should have domain name      attached. If not, just do the gethostname on the     original string.   */  gethostname(hostname, sizeof(hostname) - 1);  hostname[sizeof(hostname) - 1] = 0;  if ((domain = strchr(hostname, '.')) == NULL)    return(gethostbyname(name));  /* Attach domain name to query and do modified query.     If names too large, just do gethostname on the     original string.  */  if((strlen(name) + strlen(domain)) >= sizeof(query))    return(gethostbyname(name));  slprintf(query, sizeof(query)-1, "%s%s", name, domain);  return(gethostbyname(query));#else /* REDUCE_ROOT_DNS_LOOKUPS */  return(gethostbyname(name));#endif /* REDUCE_ROOT_DNS_LOOKUPS */}/************************************************************************** Try and abstract process capabilities (for systems that have them).****************************************************************************/BOOL set_process_capability( uint32 cap_flag, BOOL enable ){#if defined(HAVE_IRIX_SPECIFIC_CAPABILITIES)  if(cap_flag == KERNEL_OPLOCK_CAPABILITY)  {    cap_t cap = cap_get_proc();    if (cap == NULL) {      DEBUG(0,("set_process_capability: cap_get_proc failed. Error was %s\n",            strerror(errno)));      return False;    }    if(enable)      cap->cap_effective |= CAP_NETWORK_MGT;    else      cap->cap_effective &= ~CAP_NETWORK_MGT;    if (cap_set_proc(cap) == -1) {      DEBUG(0,("set_process_capability: cap_set_proc failed. Error was %s\n",            strerror(errno)));      cap_free(cap);      return False;    }    cap_free(cap);    DEBUG(10,("set_process_capability: Set KERNEL_OPLOCK_CAPABILITY.\n"));  }#endif  return True;}/************************************************************************** Try and abstract inherited process capabilities (for systems that have them).****************************************************************************/BOOL set_inherited_process_capability( uint32 cap_flag, BOOL enable ){#if defined(HAVE_IRIX_SPECIFIC_CAPABILITIES)  if(cap_flag == KERNEL_OPLOCK_CAPABILITY)  {    cap_t cap = cap_get_proc();    if (cap == NULL) {      DEBUG(0,("set_inherited_process_capability: cap_get_proc failed. Error was %s\n",            strerror(errno)));      return False;    }    if(enable)      cap->cap_inheritable |= CAP_NETWORK_MGT;    else      cap->cap_inheritable &= ~CAP_NETWORK_MGT;    if (cap_set_proc(cap) == -1) {      DEBUG(0,("set_inherited_process_capability: cap_set_proc failed. Error was %s\n",             strerror(errno)));      cap_free(cap);      return False;    }    cap_free(cap);    DEBUG(10,("set_inherited_process_capability: Set KERNEL_OPLOCK_CAPABILITY.\n"));  }#endif  return True;}/************************************************************************** Wrapper for random().****************************************************************************/long sys_random(void){#if defined(HAVE_RANDOM)  return (long)random();#elif defined(HAVE_RAND)  return (long)rand();#else  DEBUG(0,("Error - no random function available !\n"));  exit(1);#endif}/************************************************************************** Wrapper for srandom().****************************************************************************/void sys_srandom(unsigned int seed){#if defined(HAVE_SRANDOM)  srandom(seed);#elif defined(HAVE_SRAND)  srand(seed);#else  DEBUG(0,("Error - no srandom function available !\n"));  exit(1);#endif}/************************************************************************** Wrapper for getgroups. Deals with broken (int) case.****************************************************************************/int sys_getgroups(int setlen, gid_t *gidset){#if !defined(HAVE_BROKEN_GETGROUPS)  return getgroups(setlen, gidset);#else  GID_T gid;  GID_T *group_list;  int i, ngroups;  if(setlen == 0) {    return getgroups(setlen, &gid);  }  /*   * Broken case. We need to allocate a   * GID_T array of size setlen.   */  if(setlen < 0) {    errno = EINVAL;     return -1;  }   if (setlen == 0)    setlen = 1;  if((group_list = (GID_T *)malloc(setlen * sizeof(GID_T))) == NULL) {    DEBUG(0,("sys_getgroups: Malloc fail.\n"));    return -1;  }  if((ngroups = getgroups(setlen, group_list)) < 0) {    int saved_errno = errno;    free((char *)group_list);    errno = saved_errno;    return -1;  }  for(i = 0; i < ngroups; i++)    gidset[i] = (gid_t)group_list[i];  free((char *)group_list);  return ngroups;#endif /* HAVE_BROKEN_GETGROUPS */}#ifdef HAVE_SETGROUPS/************************************************************************** Wrapper for setgroups. Deals with broken (int) case. Automatically used if we have broken getgroups.****************************************************************************/int sys_setgroups(int setlen, gid_t *gidset){#if !defined(HAVE_BROKEN_GETGROUPS)  return setgroups(setlen, gidset);#else  GID_T *group_list;  int i ;   if (setlen == 0)    return 0 ;#ifdef NGROUPS_MAX  if (setlen > NGROUPS_MAX) {    errno = EINVAL;     return -1;     }#endif  /*   * Broken case. We need to allocate a   * GID_T array of size setlen.   */  if (setlen == 0)    setlen = 1;  if((group_list = (GID_T *)malloc(setlen * sizeof(GID_T))) == NULL) {    DEBUG(0,("sys_setgroups: Malloc fail.\n"));    return -1;      }   for(i = 0; i < setlen; i++)     group_list[i] = (GID_T) gidset[i];   if(setgroups(setlen, group_list) != 0) {    int saved_errno = errno;    free((char *)group_list);    errno = saved_errno;    return -1;  }   free((char *)group_list);  return 0 ;#endif /* HAVE_BROKEN_GETGROUPS */}#endif /* HAVE_SETGROUPS */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久综合久久综合九色| 久久99蜜桃精品| 蜜臀久久99精品久久久久宅男 | 国产片一区二区三区| 亚洲蜜臀av乱码久久精品 | 亚洲一区二区三区在线看| 国产综合久久久久影院| 欧美久久婷婷综合色| 中文字幕一区二区三区乱码在线 | 丝袜美腿亚洲一区| 一本久道中文字幕精品亚洲嫩| 日韩久久久久久| 午夜精品福利一区二区三区蜜桃| 成人精品免费看| 欧美哺乳videos| 蜜桃视频一区二区三区在线观看 | 久久夜色精品一区| 免费国产亚洲视频| 欧美高清性hdvideosex| 亚洲免费观看高清完整| 91亚洲精品久久久蜜桃网站| 日本一区二区视频在线观看| 精品一区中文字幕| 欧美tickling挠脚心丨vk| 石原莉奈在线亚洲三区| 56国语精品自产拍在线观看| 亚洲国产一区二区三区| 在线观看日韩电影| 午夜精品久久一牛影视| 欧美日韩精品免费观看视频| 香蕉加勒比综合久久| 欧美日韩国产乱码电影| 日韩av在线发布| 日韩久久精品一区| 国产精品88av| 中文字幕一区二区三区在线播放 | 日韩不卡一二三区| 日韩一区二区三区在线观看 | 日韩制服丝袜av| 91精品国产综合久久久久久久久久| 视频一区二区中文字幕| 91精品国产色综合久久ai换脸| 青娱乐精品在线视频| 欧美成人猛片aaaaaaa| 国产毛片精品国产一区二区三区| 欧美激情一区二区在线| 不卡视频一二三四| 一区二区三区在线播| 欧美日韩一区二区欧美激情| 日本午夜一区二区| 久久久久久一二三区| 成人黄色大片在线观看| 一区二区三区欧美久久| 欧美日韩国产片| 国产美女一区二区| 亚洲三级小视频| 91精品国产入口在线| 国产麻豆视频精品| 亚洲日本在线天堂| 日韩欧美一区在线观看| 国产精品资源在线观看| 有坂深雪av一区二区精品| 6080yy午夜一二三区久久| 国产不卡高清在线观看视频| 一卡二卡三卡日韩欧美| 日韩欧美中文字幕公布| 成人av一区二区三区| 亚洲va欧美va国产va天堂影院| 久久影院电视剧免费观看| 91在线观看免费视频| 轻轻草成人在线| 亚洲欧美二区三区| 欧美电影免费提供在线观看| 色综合激情五月| 精品一区免费av| 亚洲成a人v欧美综合天堂| 久久久精品人体av艺术| 欧美日韩一区精品| 成人av动漫在线| 麻豆精品久久精品色综合| 亚洲三级免费电影| 久久亚洲免费视频| 91精品国产全国免费观看| a美女胸又www黄视频久久| 麻豆久久一区二区| 一区二区激情视频| 国产精品久久一卡二卡| 日韩一本二本av| 欧美三级韩国三级日本一级| 成人免费不卡视频| 国产一区二区不卡| 久久精品国产澳门| 日韩二区三区在线观看| 亚洲影院久久精品| 亚洲精品久久久蜜桃| 国产精品久久二区二区| 国产亚洲一区二区三区四区 | 国产一区二区福利视频| 免费在线成人网| 亚洲国产精品久久人人爱| 亚洲伦理在线免费看| 亚洲国产精品激情在线观看| 26uuu精品一区二区三区四区在线| 欧美日韩精品综合在线| 欧美性生活一区| 91成人在线精品| 在线这里只有精品| 欧美午夜精品一区| 欧美色综合久久| 欧美区在线观看| 9191国产精品| 这里只有精品视频在线观看| 欧美日韩国产免费| 91精品国产一区二区三区香蕉| 7777精品伊人久久久大香线蕉经典版下载 | 国产精品的网站| 国产精品福利影院| 亚洲日本免费电影| 亚洲国产精品综合小说图片区| 亚洲最新视频在线观看| 亚洲永久精品国产| 午夜欧美在线一二页| 无码av免费一区二区三区试看| 亚洲电影一区二区| 蜜臀av在线播放一区二区三区| 久久激情综合网| 国产高清精品网站| 91在线国产观看| 欧美在线视频全部完| 欧美一区二区三区思思人| 精品国产区一区| 国产精品人成在线观看免费| 亚洲色图一区二区| 日韩av不卡一区二区| 久久99久久久久| av在线播放一区二区三区| 色婷婷综合中文久久一本| 欧美一区二区三区日韩| 国产日韩视频一区二区三区| 亚洲欧洲日韩女同| 日韩激情av在线| 国产99久久久国产精品潘金| 色偷偷久久人人79超碰人人澡 | 91猫先生在线| 欧美成人官网二区| 国产精品第13页| 日韩成人一区二区三区在线观看| 国产精品一区免费视频| 色狠狠综合天天综合综合| 欧美v亚洲v综合ⅴ国产v| 国产精品国产a| 久久成人免费网| 色婷婷一区二区三区四区| 日韩欧美国产一区二区三区| 国产精品久久福利| 极品销魂美女一区二区三区| 91丨porny丨国产入口| 欧美成人a∨高清免费观看| 亚洲精品国产无天堂网2021 | 欧美丝袜丝交足nylons图片| 亚洲精品一区二区三区福利| 亚洲激情一二三区| 国产盗摄视频一区二区三区| 欧美剧在线免费观看网站| 中文字幕一区二区视频| 韩国在线一区二区| 欧美日韩成人一区| 亚洲欧美二区三区| 国产成人免费视频一区| 日韩午夜中文字幕| 一区二区三区日韩欧美精品| 国产精品一级片在线观看| 欧美精品粉嫩高潮一区二区| 国产精品电影一区二区三区| 国产制服丝袜一区| 制服丝袜成人动漫| 亚洲成av人片在线| 色综合久久久久综合体| 国产精品私房写真福利视频| 韩国在线一区二区| 日韩免费看网站| 奇米一区二区三区| 51午夜精品国产| 亚洲图片欧美视频| 在线观看一区日韩| 一区二区三区在线观看视频| 99精品久久99久久久久| 中文字幕亚洲视频| 成人av网在线| 亚洲丝袜自拍清纯另类| 成人av在线网站| 国产精品久久久久一区二区三区共| 国产美女视频91| 久久精品夜夜夜夜久久| 国产黄人亚洲片| 国产午夜精品一区二区| 成人小视频在线| 日韩一区欧美小说| 91国产福利在线| 日韩精品久久理论片|