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

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

?? nfslib.c

?? vxwork源代碼
?? 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一区二区三区免费野_久草精品视频
国产欧美日韩麻豆91| 欧美精品v国产精品v日韩精品| 日韩片之四级片| 亚洲成人福利片| 在线观看国产精品网站| 欧美狂野另类xxxxoooo| 亚洲一区在线播放| 色拍拍在线精品视频8848| 综合久久给合久久狠狠狠97色| 国产精品一区二区久久不卡| 日韩一区二区精品葵司在线| 日韩和欧美一区二区| 91精品国产一区二区人妖| 五月婷婷激情综合| 精品三级在线观看| 日韩va亚洲va欧美va久久| 555夜色666亚洲国产免| 天天综合日日夜夜精品| 日韩三级av在线播放| 美脚の诱脚舐め脚责91| 久久久久久一二三区| 大尺度一区二区| 亚洲日本在线观看| 欧美午夜免费电影| 另类调教123区| 欧美高清在线视频| 色88888久久久久久影院野外| 一个色在线综合| 欧美精品在线观看播放| 国产一区 二区 三区一级| 国产精品情趣视频| 欧美日韩国产首页在线观看| 久久99精品国产91久久来源| 国产精品久久久久影院亚瑟| 欧美日韩一区中文字幕| 国产成人在线看| 夜夜精品视频一区二区| 欧美精品一区二区三区四区| 色综合欧美在线| 精品影视av免费| 亚洲色图清纯唯美| 久久亚洲综合av| 欧美日韩高清一区二区三区| 国产成人av电影在线| 三级在线观看一区二区| 最新国产成人在线观看| 久久亚洲精品小早川怜子| 欧美女孩性生活视频| 成人夜色视频网站在线观看| 久久99深爱久久99精品| 亚洲自拍偷拍网站| 中文字幕一区二区三区乱码在线 | 国产99久久久久久免费看农村| 午夜电影网亚洲视频| 亚洲欧美日韩在线不卡| 日韩欧美一二三四区| 欧美性大战久久久久久久| 成人激情午夜影院| 黄色资源网久久资源365| 午夜精品在线视频一区| 国产精品久久777777| 国产欧美视频一区二区| 久久一日本道色综合| 日韩无一区二区| 91精品国产色综合久久ai换脸 | 欧美精品视频www在线观看| 色偷偷一区二区三区| 99久久伊人久久99| 色偷偷88欧美精品久久久| 91丨九色porny丨蝌蚪| 99久久99久久精品免费观看| 99久久精品情趣| 色综合一区二区| 色哟哟亚洲精品| 欧美精品三级日韩久久| 欧美日韩一级片网站| 欧美精品少妇一区二区三区| 91精品在线一区二区| 欧美成va人片在线观看| 久久久综合视频| 国产精品成人一区二区艾草 | 久久aⅴ国产欧美74aaa| 国产乱对白刺激视频不卡| 精品久久99ma| 日韩毛片精品高清免费| 亚洲午夜久久久久久久久电影院| 午夜精品一区二区三区电影天堂 | 国内欧美视频一区二区| 成人一区在线观看| 日本韩国欧美国产| 欧美成人女星排名| 国产精品国产三级国产专播品爱网| 亚洲精品欧美综合四区| 日韩黄色免费电影| 高清不卡一区二区在线| 欧美日韩在线免费视频| 欧美高清在线精品一区| 日韩激情在线观看| 成人免费不卡视频| 日韩亚洲欧美一区二区三区| 18欧美乱大交hd1984| 久久99久久精品| 欧美亚洲高清一区二区三区不卡| 26uuu亚洲综合色欧美| 亚洲一区二区视频在线| 成人a级免费电影| 精品第一国产综合精品aⅴ| 亚洲国产一区二区视频| 国产·精品毛片| 欧美v日韩v国产v| 亚洲成a人v欧美综合天堂| 99久久综合狠狠综合久久| 精品日韩99亚洲| 日韩精品色哟哟| 在线精品亚洲一区二区不卡| 日本一区二区免费在线| 国产精品一级片在线观看| 欧美一区二区三区小说| 亚洲18女电影在线观看| 欧洲一区在线电影| 亚洲欧美福利一区二区| 99re这里只有精品首页| 亚洲天堂网中文字| 在线亚洲高清视频| 亚洲免费资源在线播放| 91高清在线观看| 亚洲图片有声小说| 欧美日韩国产另类不卡| 亚洲18色成人| 91精品国产乱码久久蜜臀| 天天综合天天综合色| 日韩精品专区在线| 精品一区二区三区免费| 精品国精品国产| 国产精品一区二区三区四区| 欧美国产视频在线| 在线观看免费视频综合| 午夜精品久久久久久久99水蜜桃| 91精品婷婷国产综合久久竹菊| 韩国av一区二区| 粉嫩绯色av一区二区在线观看| 亚洲男人的天堂在线观看| 3751色影院一区二区三区| 国产精一区二区三区| 亚洲欧美国产高清| 精品美女在线播放| thepron国产精品| 午夜精品福利一区二区三区av| 精品欧美一区二区在线观看| av亚洲精华国产精华精华| 日韩电影在线免费观看| 亚洲国产精品ⅴa在线观看| 欧洲人成人精品| 国产寡妇亲子伦一区二区| 亚洲精品日日夜夜| 国产色产综合产在线视频| 在线影视一区二区三区| 国产一区二区三区久久悠悠色av| 亚洲综合偷拍欧美一区色| 精品久久久三级丝袜| 欧美亚洲综合久久| 成人午夜免费av| 毛片av一区二区三区| 亚洲主播在线观看| 中文字幕中文字幕一区二区| 精品国产人成亚洲区| 欧美久久久一区| 91久久奴性调教| 成人av手机在线观看| 国产二区国产一区在线观看| 欧美日韩国产经典色站一区二区三区 | 粉嫩一区二区三区在线看| 美女诱惑一区二区| 亚洲bdsm女犯bdsm网站| 亚洲品质自拍视频| 亚洲欧洲精品成人久久奇米网| 国产午夜亚洲精品午夜鲁丝片| 欧美一区二区三区视频在线| 欧美性受xxxx黑人xyx| 日本道精品一区二区三区| 91视频在线观看| 日本精品视频一区二区| 91女神在线视频| 91麻豆精品一区二区三区| fc2成人免费人成在线观看播放| 国产精品一二三区在线| 国产乱理伦片在线观看夜一区| 国产乱子轮精品视频| 国产另类ts人妖一区二区| 国产福利一区二区三区| 国产成人免费在线观看| 成人av网站免费| 麻豆国产一区二区| 蜜臀va亚洲va欧美va天堂| 午夜精品福利久久久| 亚洲综合网站在线观看| 一区二区三区欧美亚洲| 国产色综合久久| 91精品国产丝袜白色高跟鞋| av在线不卡观看免费观看|