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

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

?? nfslib.c

?? Tornado平臺下
?? C
?? 第 1 頁 / 共 5 頁
字號:
    if ((newDirName = (char *) alloca (nfsMaxPath)) == NULL)	return (ERROR);    if ((oldDirName = (char *) alloca (nfsMaxPath)) == NULL)	return (ERROR);    bzero ((char *) &dirResults, sizeof (dirResults));    bzero ((char *) &status, sizeof (status));    pathSplit (oldName, oldDirName, oldFileName);    pathSplit (newName, newDirName, newFileName);    bcopy ((char *) pOldDirHandle, (char *) &renameArgs.from.dir,	   sizeof (nfs_fh));    renameArgs.from.name = oldFileName;    if (newDirName [0] == EOS)	{	/* NULL directory name */	bcopy ((char *) pMountHandle, (char *) &renameArgs.to.dir,	       sizeof (nfs_fh));	}    else	{	if (nfsLookUpByName (hostName, newDirName, pMountHandle,			     &dirResults, &dummyDirHandle) != OK)	    return (ERROR);	bcopy ((char *) &dirResults.diropres_u.diropres.file,	       (char *) &renameArgs.to.dir, sizeof (nfs_fh));	}    renameArgs.to.name = newFileName;    if (nfsClientCall (hostName, NFS_PROGRAM, NFS_VERSION, NFSPROC_RENAME,			    xdr_renameargs, (char *) &renameArgs,			    xdr_nfsstat, (char *) &status) == ERROR)	{	return (ERROR);	}    if (status != NFS_OK)	{	nfsErrnoSet (status);	return (ERROR);	}    return (OK);    }/********************************************************************************* nfsThingCreate - creates file or directory** RETURNS:  OK | ERROR | FOLLOW_LINK,*	    if FOLLOW_LINK, then fullFileName contains the name of the link** NOMANUAL*/int nfsThingCreate    (    char *      hostName,    char *      fullFileName,   /* name of thing being created */    nfs_fh *    pMountHandle,   /* mount device's file handle */    diropres *  pDirOpRes,      /* ptr to returned direc. operation results */    nfs_fh *    pDirHandle,     /* ptr to returned file's directory file hndl */    u_int       mode            /* mode that file or dir is created with                                 *   UNIX chmod style */    )    {    FAST int	status;    char *	newName;              /* new name if name contained a link */    char *	dirName;              /* dir where file will be created */    char	fileName[NAME_MAX + 1];	   /* name of file without path */    char *	tmpName;	      /* temporary file name */    FAST sattr *pSattr;			/* ptr to attributes */    diropres	lookUpResult;    createargs	createArgs;    nfs_fh	dummyDirHandle;    u_int	nfsProc;		/* which nfs procedure to call,					 * depending on whether a file or					 * directory is made */    if (nfsInit () != OK)	return (ERROR);    if ((newName = (char *) alloca (nfsMaxPath)) == NULL)	return (ERROR);    if ((dirName = (char *) alloca (nfsMaxPath)) == NULL)	return (ERROR);    /* Extra 4 characters allocated for '/../' */    if ((tmpName = (char *) alloca (nfsMaxPath + 1 + 3)) == NULL)	return (ERROR);    bzero ((char *) &createArgs, sizeof (createArgs));    bzero ((char *) &lookUpResult, sizeof (lookUpResult));    bzero ((char *) pDirOpRes, sizeof (diropres));    pathSplit (fullFileName, dirName, fileName);    status = nfsLookUpByName (hostName, dirName, pMountHandle, &lookUpResult,			      &dummyDirHandle);    if (status == FOLLOW_LINK)	{	if ((strlen (dirName) + strlen (fileName) + 1) >= nfsMaxPath)	    {	    errnoSet (S_ioLib_NAME_TOO_LONG);	    status = ERROR;	    }	else	    {	    pathCat (dirName, fileName, newName);	    (void) strcpy (fullFileName, newName);	    }	}    if (status != OK)	return (status);    bcopy ((char *) &lookUpResult.diropres_u.diropres.file,	   (char *) &createArgs.where.dir, sizeof (nfs_fh));    bcopy ((char *) &lookUpResult.diropres_u.diropres.file,	   (char *) pDirHandle, sizeof (nfs_fh));    createArgs.where.name = fileName;    pSattr = &createArgs.attributes;    if (mode == 0)    	/* create a file with default permissions */	pSattr->mode = NFS_FSTAT_REG | DEFAULT_FILE_PERM;    else	pSattr->mode = mode;    /* don't set these attributes */    pSattr->uid = pSattr->gid = pSattr->size = -1;	/* user ID */    pSattr->atime.seconds = pSattr->atime.useconds = -1;    pSattr->mtime.seconds = pSattr->mtime.useconds = -1;    if (mode & NFS_FSTAT_DIR)	nfsProc = NFSPROC_MKDIR;    else        nfsProc = NFSPROC_CREATE;    if (nfsClientCall (hostName, NFS_PROGRAM, NFS_VERSION, nfsProc,			    xdr_createargs, (char *) &createArgs,			    xdr_diropres, (char *) pDirOpRes) == ERROR)	{	return (ERROR);	}    /*     * If the file created is really a symlink, then change the name and     * return FOLLOW_LINK     */    if (pDirOpRes->diropres_u.diropres.attributes.type == NFLNK)        {	strcpy (tmpName, fullFileName);	/* Make a copy of fullFileName to					 * use with nfsLinkGet */	nfsLinkGet (hostName, &pDirOpRes->diropres_u.diropres.file, tmpName);        /*	 * Need to replace last element of fullFileName with return value from         * nfsLinkGet.  Add /../newFileName to fullFileName, call         * pathCondense().	 */	strcpy (fullFileName, tmpName);	return (FOLLOW_LINK);	}    if (pDirOpRes->status != NFS_OK)	{	nfsErrnoSet (pDirOpRes->status);	return (ERROR);	}    return (OK);    }/********************************************************************************* nfsFileWrite - write to a file** Either all characters will be written, or there is an ERROR.** RETURNS:  number of characters written | ERROR** NOMANUAL*/int nfsFileWrite    (    char *      hostName,    nfs_fh *    pHandle,        /* file handle of file being written to */    unsigned    offset,         /* current byte offset in file */    unsigned    count,          /* number of bytes to write */    char *      data,           /* data to be written (up to NFS_MAXDATA) */    fattr *     pNewAttr    )    {    FAST unsigned nWrite = 0;	      /* bytes written in one nfs write */    FAST unsigned nTotalWrite = 0;    /* bytes written in all writes together */    writeargs	writeArgs;	      /* arguments to pass to nfs server */    attrstat	writeResult;	      /* info returned from nfs server */    if (nfsInit () != OK)	return (ERROR);    bzero ((char *) &writeArgs, sizeof (writeArgs));    bcopy ((char *) pHandle, (char *) &writeArgs.file, sizeof (nfs_fh));    /* set offset into file where write starts */    writeArgs.offset = offset;    while (nTotalWrite < count)	{	/* can only write up to NFS_MAXDATA bytes in one nfs write */	if (count - nTotalWrite > nfsMaxMsgLen)	    nWrite = nfsMaxMsgLen;	else	    nWrite = count - nTotalWrite;	writeArgs.totalcount = nWrite;	writeArgs.data.data_len = nWrite;	writeArgs.data.data_val = data + nTotalWrite;	writeArgs.offset = offset + nTotalWrite;	bzero ((char *) &writeResult, sizeof (attrstat));	if (nfsClientCall (hostName, NFS_PROGRAM, NFS_VERSION, NFSPROC_WRITE,				xdr_writeargs, (char *) &writeArgs,				xdr_attrstat, (char *) &writeResult) == ERROR)	    {	    return (ERROR);	    /* XXX if some writes have been done and there was an error,	     * nTotalWrite should be returned */	    }	if (writeResult.status != NFS_OK)	    {	    nfsErrnoSet (writeResult.status);	    return (ERROR);	    }	nTotalWrite += nWrite;	}    bcopy ((char *) &writeResult.attrstat_u.attributes, (char *) pNewAttr,	   sizeof (fattr));    /* if nfs write returned ok, then all bytes were written */    return (count);    }/********************************************************************************* nfsFileRead - read from a file** Reads as many bytes as are requested if that many bytes are left before* the end of file.** RETURNS: number of characters read or ERROR** NOMANUAL*/int nfsFileRead    (    char *      hostName,    nfs_fh *    pHandle,        /* file handle of file being read */    unsigned    offset,         /* start at offset bytes from beg. of file */    unsigned    count,          /* number bytes to read up to */    char *      buf,            /* buffer that data is read into */    fattr *     pNewAttr        /* arguments returned from server */    )    {    FAST unsigned nRead = 0;		/* number of bytes read in one read */    FAST unsigned nTotalRead = 0;	/* bytes read in all reads together */    readargs	readArgs;		/* arguments to pass to nfs server */    readres	readReply;    if (nfsInit () != OK)	return (ERROR);    bzero ((char *) &readArgs, sizeof (readArgs));    bcopy ((char *) pHandle, (char *) &readArgs.file, sizeof (nfs_fh));    while (nTotalRead < count)	{	if (count - nTotalRead > nfsMaxMsgLen)	    readArgs.count = nfsMaxMsgLen;	else	    readArgs.count = count - nTotalRead;	readArgs.offset = offset + nTotalRead;	bzero ((char *) &readReply, sizeof (readReply));	/* make xdr buffer point to caller's buffer */	readReply.readres_u.reply.data.data_val = buf + nTotalRead;	if (nfsClientCall (hostName, NFS_PROGRAM, NFS_VERSION, NFSPROC_READ,				xdr_readargs, (char *) &readArgs,				xdr_readres, (char *) &readReply) == ERROR)	    {	    return (ERROR);	    }	if (readReply.status != NFS_OK)	    {	    nfsErrnoSet (readReply.status);	    return (ERROR);	    }	/* check for end of file (data_len == 0) */	if ((nRead = readReply.readres_u.reply.data.data_len) == 0)	    break;	/* update attributes */	bcopy ((char *) &(readReply.readres_u.reply.attributes),	       (char *) pNewAttr, sizeof (fattr));	nTotalRead += nRead;	} /* while not all bytes requested have been read */    return (nTotalRead);    }/********************************************************************************* nfsLinkGet - gets name of real file from a symbolic link** RETURNS: OK or ERROR*/LOCAL STATUS nfsLinkGet    (    char *      hostName,    nfs_fh *    pHandle,        /* file handle of file being read */    nfspath     realPath        /* the actual pathname gets returned here */    )    {    readlinkres	pathStatus;    if (nfsInit () != OK)	return (ERROR);    bzero ((char *) &pathStatus, sizeof (readlinkres));    /* make xdr buffer point to caller's buffer */    pathStatus.readlinkres_u.data = realPath;    if (nfsClientCall (hostName, NFS_PROGRAM, NFS_VERSION, NFSPROC_READLINK,			    xdr_nfs_fh, (char *) pHandle,			    xdr_readlinkres, (char *) &pathStatus) == ERROR)	{	return (ERROR);	}    if (pathStatus.status != NFS_OK)	{	nfsErrnoSet (pathStatus.status);	return (ERROR);	}    return (OK);    }#if 0/********************************************************************************* nfsDirRead - read entries from a directory** RETURNS: OK or ERROR*/LOCAL STATUS nfsDirRead    (    char *      hostName,    nfs_fh *    pDirHandle,    nfscookie   cookie,         /* hand this cookie to the server.  The cookie                                 * marks a place in the directory where entries                                 * are to be read from */    unsigned    count,          /* number of bytes that nfs may return */    readdirres *pReadDirRes     /* return the results of directory read here */    )    {    readdirargs readDirArgs;    if (nfsInit () != OK)	return (ERROR);    bzero ((char *) &readDirArgs, sizeof (readdirargs));    bcopy ((char *) pDirHandle, (char *) &readDirArgs.dir, sizeof (nfs_fh));    bcopy (cookie, readDirArgs.cookie, sizeof (nfscookie));    readDirArgs.count = count;    bzero ((char *) pReadDirRes, sizeof (*pReadDirRes));    if (nfsClientCall (hostName, NFS_PROGRAM, NFS_VERSION, NFSPROC_READDIR,			    xdr_readdirargs, (char *) &readDirArgs,			    xdr_readdirres, (char *) pReadDirRes) == ERROR)	{	return (ERROR);	}    if (pReadDirRes->status != NFS_OK)	{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲综合一二区| aaa欧美大片| av中文一区二区三区| 亚洲日本va午夜在线影院| 亚洲欧美日韩电影| 日本午夜精品一区二区三区电影| 亚洲第一主播视频| 不卡的av在线| 91福利国产成人精品照片| 色狠狠综合天天综合综合| 亚洲精品中文字幕在线观看| 欧美日韩在线直播| 久久噜噜亚洲综合| 色婷婷精品大视频在线蜜桃视频| 国产精品色噜噜| 国产激情91久久精品导航| 日韩欧美国产小视频| 久久av资源站| 成人国产视频在线观看| 日韩中文字幕av电影| 精品一区二区三区视频| 欧美日韩美女一区二区| 亚洲精品欧美综合四区| 欧美精品一区二区在线播放| 亚洲高清视频中文字幕| 久久久蜜臀国产一区二区| 欧美性色欧美a在线播放| 国产不卡在线一区| 精品国精品自拍自在线| 色偷偷成人一区二区三区91 | 黄色日韩三级电影| 亚洲另类在线制服丝袜| 久久久91精品国产一区二区三区| 欧美亚州韩日在线看免费版国语版| 韩国精品主播一区二区在线观看| 午夜精品福利视频网站| 欧美猛男gaygay网站| 成人精品gif动图一区| 国内成人自拍视频| 视频一区二区国产| 一区二区三区色| 日韩色在线观看| 欧美三级电影精品| 粉嫩绯色av一区二区在线观看| 日韩电影在线免费看| 亚洲精品高清在线| 亚洲免费毛片网站| 亚洲欧洲韩国日本视频| 国产欧美日韩中文久久| 精品第一国产综合精品aⅴ| 欧美二区三区91| 欧美午夜片在线看| 91偷拍与自偷拍精品| 国产69精品久久777的优势| 婷婷综合五月天| 国产精品久久久久久久久久免费看| 欧美mv日韩mv国产网站app| 91精品久久久久久久91蜜桃| 欧美日本一道本| 99久久精品情趣| 丁香啪啪综合成人亚洲小说| 精品美女在线观看| 日韩欧美一区二区在线视频| 在线播放一区二区三区| 欧美老肥妇做.爰bbww视频| 欧美色中文字幕| 欧美日韩一区小说| 91精品国产欧美一区二区18 | 日韩欧美国产成人一区二区| 欧美精品自拍偷拍动漫精品| 欧美视频一区在线观看| 欧美精品黑人性xxxx| 51精品视频一区二区三区| 欧美精品高清视频| 欧美一区二区三区四区久久| 日韩一区二区高清| 精品欧美久久久| 久久久亚洲高清| 中文字幕不卡一区| 国产精品美女久久久久久久网站| 国产精品免费av| 亚洲码国产岛国毛片在线| 一区二区三区日韩精品| 亚洲大尺度视频在线观看| 丝袜美腿亚洲一区| 韩国av一区二区三区在线观看| 国产原创一区二区| 99re亚洲国产精品| 欧美日韩精品一区视频| 日韩欧美国产综合| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 日本一区二区三级电影在线观看| 中文字幕久久午夜不卡| 樱花影视一区二区| 久久国产乱子精品免费女| 国产a视频精品免费观看| 97se亚洲国产综合自在线观| 欧美视频一区在线| 精品粉嫩超白一线天av| 国产精品初高中害羞小美女文| 亚洲夂夂婷婷色拍ww47| 蜜臀av亚洲一区中文字幕| 国产91清纯白嫩初高中在线观看| 91一区二区在线| 欧美一二三区在线| 日韩久久一区二区| 麻豆91在线播放| 国产盗摄一区二区三区| 不卡一卡二卡三乱码免费网站| 欧美日韩国产影片| 国产日韩欧美a| 亚洲三级电影网站| 午夜激情久久久| 成人一区二区三区中文字幕| 欧美性猛交xxxx乱大交退制版 | 8v天堂国产在线一区二区| 久久久久国产免费免费| 国产精品美女久久久久久| 亚洲成a人v欧美综合天堂下载| 免费的成人av| 成人av在线网站| 欧美大尺度电影在线| 亚洲最色的网站| 精品一区二区三区久久久| 99精品视频一区二区| 久久影视一区二区| 天天色天天爱天天射综合| 99综合影院在线| 久久久久久一级片| 美女一区二区视频| 欧美影院精品一区| 中文字幕在线不卡一区二区三区| 日本亚洲电影天堂| 欧美日韩激情一区| 亚洲免费av在线| 99久久伊人久久99| 国产欧美综合在线| 精品中文av资源站在线观看| 欧美精品一二三| 亚洲一区影音先锋| 色天天综合色天天久久| 国产精品久久久久久亚洲伦 | 国产一区二区女| 日韩欧美亚洲国产另类 | 中文乱码免费一区二区| 亚洲一区二区三区四区五区中文| 激情综合五月婷婷| 日韩久久久久久| 免费观看30秒视频久久| 911国产精品| 丝袜亚洲另类欧美| 欧美久久一区二区| 一区二区三区中文字幕精品精品| av资源网一区| 成人欧美一区二区三区视频网页| 国产黄色91视频| 久久久亚洲国产美女国产盗摄| 狠狠色丁香婷综合久久| 精品三级av在线| 精品一区二区三区视频 | 日韩午夜在线影院| 免费在线观看成人| 精品久久一区二区| 国产一区二区三区不卡在线观看| 久久女同精品一区二区| 国产精品自在在线| 国产日本亚洲高清| 成人黄色综合网站| 亚洲色图都市小说| 欧美性猛交一区二区三区精品| 午夜伦欧美伦电影理论片| 在线成人av网站| 久久99国内精品| 国产日韩精品视频一区| 不卡视频一二三四| 一区二区免费视频| 欧美精品久久一区| 久草中文综合在线| 欧美激情中文不卡| 一本到不卡精品视频在线观看| 一区二区三区色| 91精品国产综合久久久蜜臀图片| 精品一区二区三区蜜桃| 中文字幕第一区第二区| thepron国产精品| 亚洲国产日韩a在线播放性色| 欧美情侣在线播放| 久久国产精品一区二区| 国产嫩草影院久久久久| 色先锋久久av资源部| 亚洲国产精品一区二区久久恐怖片| 亚洲免费观看视频| 久久久国产精品午夜一区ai换脸| 欧美日韩免费一区二区三区视频| 精品一区免费av| 亚洲成av人片一区二区三区 | 国产精品女上位| 日韩欧美电影一区| 欧美日韩夫妻久久| 一本色道**综合亚洲精品蜜桃冫 |