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

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

?? fileunix.c

?? Boost provides free peer-reviewed portable C++ source libraries. We emphasize libraries that work
?? C
字號:
/* * Copyright 1993-2002 Christopher Seiwald and Perforce Software, Inc. * * This file is part of Jam - see jam.c for Copyright information. *//*  This file is ALSO: *  Copyright 2001-2004 David Abrahams. *  Copyright 2005 Rene Rivera. *  Distributed under the Boost Software License, Version 1.0. *  (See accompanying file LICENSE_1_0.txt or http://www.boost.org/LICENSE_1_0.txt) */# include "jam.h"# include "filesys.h"# include "strings.h"# include "pathsys.h"# include "newstr.h"# include <stdio.h>#if defined(sun) || defined(__sun) || defined(linux)# include <unistd.h> /* needed for read and close prototype */#endif# ifdef USE_FILEUNIX#if defined(sun) || defined(__sun)# include <unistd.h> /* needed for read and close prototype */#endif# if defined( OS_SEQUENT ) || \     defined( OS_DGUX ) || \     defined( OS_SCO ) || \     defined( OS_ISC ) # define PORTAR 1# endif# ifdef __EMX__# include <sys/types.h># include <sys/stat.h># endif# if defined( OS_RHAPSODY ) || \     defined( OS_MACOSX ) || \     defined( OS_NEXT )/* need unistd for rhapsody's proper lseek */# include <sys/dir.h># include <unistd.h># define STRUCT_DIRENT struct direct # else# include <dirent.h># define STRUCT_DIRENT struct dirent # endif# ifdef OS_COHERENT# include <arcoff.h># define HAVE_AR# endif# if defined( OS_MVS ) || \		 defined( OS_INTERIX )#define	ARMAG	"!<arch>\n"#define	SARMAG	8#define	ARFMAG	"`\n"struct ar_hdr		/* archive file member header - printable ascii */{	char	ar_name[16];	/* file member name - `/' terminated */	char	ar_date[12];	/* file member date - decimal */	char	ar_uid[6];	/* file member user id - decimal */	char	ar_gid[6];	/* file member group id - decimal */	char	ar_mode[8];	/* file member mode - octal */	char	ar_size[10];	/* file member size - decimal */	char	ar_fmag[2];	/* ARFMAG - string to end header */};# define HAVE_AR# endif# if defined( OS_QNX ) || \     defined( OS_BEOS ) || \     defined( OS_MPEIX )# define NO_AR# define HAVE_AR# endif# ifndef HAVE_AR# ifdef OS_AIX/* Define those for AIX to get the definitions for both the small and the * big variant of the archive file format. */#	 define __AR_SMALL__#	 define __AR_BIG__# endif# include <ar.h># endif	/* * fileunix.c - manipulate file names and scan directories on UNIX/AmigaOS * * External routines: * *	file_dirscan() - scan a directory for files *	file_time() - get timestamp of file, if not done by file_dirscan() *	file_archscan() - scan an archive for files * * File_dirscan() and file_archscan() call back a caller provided function * for each file found.  A flag to this callback function lets file_dirscan() * and file_archscan() indicate that a timestamp is being provided with the * file.   If file_dirscan() or file_archscan() do not provide the file's * timestamp, interested parties may later call file_time(). * * 04/08/94 (seiwald) - Coherent/386 support added. * 12/19/94 (mikem) - solaris string table insanity support * 02/14/95 (seiwald) - parse and build /xxx properly * 05/03/96 (seiwald) - split into pathunix.c * 11/21/96 (peterk) - BEOS does not have Unix-style archives *//* * file_dirscan() - scan a directory for files */voidfile_dirscan( 	char *dir,	scanback func,	void *closure ){    PROFILE_ENTER(FILE_DIRSCAN);        file_info_t * d = 0;    d = file_query( dir );        if ( ! d || ! d->is_dir )    {        PROFILE_EXIT(FILE_DIRSCAN);        return;    }    if ( ! d->files )    {        LIST* files = L0;        PATHNAME f;        DIR *dd;        STRUCT_DIRENT *dirent;        string filename[1];        /* First enter directory itself */        memset( (char *)&f, '\0', sizeof( f ) );        f.f_dir.ptr = dir;        f.f_dir.len = strlen(dir);        dir = *dir ? dir : ".";        /* Now enter contents of directory */        if( !( dd = opendir( dir ) ) )        {            PROFILE_EXIT(FILE_DIRSCAN);            return;        }        if( DEBUG_BINDSCAN )            printf( "scan directory %s\n", dir );        string_new( filename );        while( dirent = readdir( dd ) )        {            file_info_t * ff = 0;                        # ifdef old_sinix            /* Broken structure definition on sinix. */            f.f_base.ptr = dirent->d_name - 2;            # else            f.f_base.ptr = dirent->d_name;            # endif            f.f_base.len = strlen( f.f_base.ptr );            string_truncate( filename, 0 );            path_build( &f, filename, 0 );            files = list_new( files, newstr(filename->value) );            file_query( filename->value );        }        string_free( filename );        closedir( dd );            d->files = files;    }    /* Special case / : enter it */    {        unsigned long len = strlen(d->name);        if( len == 1 && d->name[0] == '/' )            (*func)( closure, d->name, 1 /* stat()'ed */, d->time );    }    /* Now enter contents of directory */    if ( d->files )    {        LIST * files = d->files;        while ( files )        {            file_info_t * ff = file_info( files->string );            (*func)( closure, ff->name, 1 /* stat()'ed */, ff->time );            files = list_next( files );        }    }        PROFILE_EXIT(FILE_DIRSCAN);}file_info_t * file_query( char * filename ){    file_info_t * ff = file_info( filename );    if ( ! ff->time )    {        struct stat statbuf;        if( stat( *filename ? filename : ".", &statbuf ) < 0 )            return 0;        ff->is_file = statbuf.st_mode & S_IFREG ? 1 : 0;        ff->is_dir = statbuf.st_mode & S_IFDIR ? 1 : 0;        ff->size = statbuf.st_size;        ff->time = statbuf.st_mtime ? statbuf.st_mtime : 1;    }    return ff;}/* * file_time() - get timestamp of file, if not done by file_dirscan() */intfile_time(	char	*filename,	time_t	*time ){    file_info_t * ff = file_query( filename );    if ( !ff ) return -1;    *time = ff->time;    return 0;}int file_is_file(char* filename){    file_info_t * ff = file_query( filename );    if ( !ff ) return -1;    return ff->is_file;}/* * file_archscan() - scan an archive for files */# ifndef AIAMAG	/* God-fearing UNIX */# define SARFMAG 2# define SARHDR sizeof( struct ar_hdr )voidfile_archscan(	char *archive,	scanback func,	void *closure ){# ifndef NO_AR	struct ar_hdr ar_hdr;	char buf[ MAXJPATH ];	long offset;	char    *string_table = 0;	int fd;	if( ( fd = open( archive, O_RDONLY, 0 ) ) < 0 )	    return;	if( read( fd, buf, SARMAG ) != SARMAG ||	    strncmp( ARMAG, buf, SARMAG ) )	{	    close( fd );	    return;	}	offset = SARMAG;	if( DEBUG_BINDSCAN )	    printf( "scan archive %s\n", archive );	while( read( fd, &ar_hdr, SARHDR ) == SARHDR	       && ! ( memcmp( ar_hdr.ar_fmag, ARFMAG, SARFMAG )#ifdef ARFZMAG		      /* OSF also has a compressed format */		      && memcmp( ar_hdr.ar_fmag, ARFZMAG, SARFMAG )#endif	      ) )	{	    char    lar_name_[257];            char*   lar_name = lar_name_ + 1;	    long    lar_date;	    long    lar_size;	    long    lar_offset;	    char *c;	    char    *src, *dest;	    strncpy( lar_name, ar_hdr.ar_name, sizeof(ar_hdr.ar_name) );	    sscanf( ar_hdr.ar_date, "%ld", &lar_date );	    sscanf( ar_hdr.ar_size, "%ld", &lar_size );	    if (ar_hdr.ar_name[0] == '/')	    {		if (ar_hdr.ar_name[1] == '/')		{		    /* this is the "string table" entry of the symbol table,		    ** which holds strings of filenames that are longer than		    ** 15 characters (ie. don't fit into a ar_name		    */		    string_table = (char *)BJAM_MALLOC_ATOMIC(lar_size);		    lseek(fd, offset + SARHDR, 0);		    if (read(fd, string_table, lar_size) != lar_size)			printf("error reading string table\n");		}		else if (string_table && ar_hdr.ar_name[1] != ' ')		{		    /* Long filenames are recognized by "/nnnn" where nnnn is		    ** the offset of the string in the string table represented		    ** in ASCII decimals.		    */		    dest = lar_name;		    lar_offset = atoi(lar_name + 1);		    src = &string_table[lar_offset];		    while (*src != '/')			*dest++ = *src++;		    *dest = '/';		}	    }	    c = lar_name - 1;	    while( *++c != ' ' && *c != '/' )		;	    *c = '\0';	    if ( DEBUG_BINDSCAN )		printf( "archive name %s found\n", lar_name );	    sprintf( buf, "%s(%s)", archive, lar_name );	    (*func)( closure, buf, 1 /* time valid */, (time_t)lar_date );	    offset += SARHDR + ( ( lar_size + 1 ) & ~1 );	    lseek( fd, offset, 0 );	}	if (string_table)	    BJAM_FREE(string_table);	close( fd );# endif /* NO_AR */}# else /* AIAMAG - RS6000 AIX */static void file_archscan_small(    int fd, char const *archive, scanback func, void *closure){    struct fl_hdr fl_hdr;    struct {        struct ar_hdr hdr;        char pad[ 256 ];    } ar_hdr ;    char buf[ MAXJPATH ];    long offset;    if( read( fd, (char *)&fl_hdr, FL_HSZ ) != FL_HSZ)        return;    sscanf( fl_hdr.fl_fstmoff, "%ld", &offset );      if( DEBUG_BINDSCAN )        printf( "scan archive %s\n", archive );      while( offset > 0           && lseek( fd, offset, 0 ) >= 0           && read( fd, &ar_hdr, sizeof( ar_hdr ) ) >= sizeof( ar_hdr.hdr ) )    {        long    lar_date;        int     lar_namlen;            sscanf( ar_hdr.hdr.ar_namlen, "%d", &lar_namlen );        sscanf( ar_hdr.hdr.ar_date, "%ld", &lar_date );        sscanf( ar_hdr.hdr.ar_nxtmem, "%ld", &offset );            if( !lar_namlen )            continue;              ar_hdr.hdr._ar_name.ar_name[ lar_namlen ] = '\0';        sprintf( buf, "%s(%s)", archive, ar_hdr.hdr._ar_name.ar_name );        (*func)( closure, buf, 1 /* time valid */, (time_t)lar_date );    }}/* Check for OS version which supports the big variant. */#ifdef AR_HSZ_BIGstatic void file_archscan_big(    int fd, char const *archive, scanback func, void *closure){    struct fl_hdr_big fl_hdr;    struct {        struct ar_hdr_big hdr;        char pad[ 256 ];    } ar_hdr ;    char buf[ MAXJPATH ];    long long offset;    if( read( fd, (char *)&fl_hdr, FL_HSZ_BIG) != FL_HSZ_BIG)        return;    sscanf( fl_hdr.fl_fstmoff, "%lld", &offset );    if( DEBUG_BINDSCAN )        printf( "scan archive %s\n", archive );    while( offset > 0           && lseek( fd, offset, 0 ) >= 0           && read( fd, &ar_hdr, sizeof( ar_hdr ) ) >= sizeof( ar_hdr.hdr ) )    {        long    lar_date;        int     lar_namlen;        sscanf( ar_hdr.hdr.ar_namlen, "%d", &lar_namlen );        sscanf( ar_hdr.hdr.ar_date, "%ld", &lar_date );        sscanf( ar_hdr.hdr.ar_nxtmem, "%lld", &offset );        if( !lar_namlen )            continue;        ar_hdr.hdr._ar_name.ar_name[ lar_namlen ] = '\0';        sprintf( buf, "%s(%s)", archive, ar_hdr.hdr._ar_name.ar_name );        (*func)( closure, buf, 1 /* time valid */, (time_t)lar_date );    }}#endif /* AR_HSZ_BIG */void file_archscan(char *archive, scanback func, void *closure){    int fd;    char fl_magic[SAIAMAG];    if(( fd = open(archive, O_RDONLY, 0)) < 0)        return;      if(read( fd, fl_magic, SAIAMAG) != SAIAMAG       || lseek(fd, 0, SEEK_SET) == -1)    {        close(fd);        return;    }    if (strncmp(AIAMAG, fl_magic, SAIAMAG) == 0)    {        /* read small variant */        file_archscan_small(fd, archive, func, closure);    }#ifdef AR_HSZ_BIG    else if (strncmp(AIAMAGBIG, fl_magic, SAIAMAG) == 0)    {        /* read big variant */        file_archscan_big(fd, archive, func, closure);    }#endif      close( fd );}# endif /* AIAMAG - RS6000 AIX */# endif /* USE_FILEUNIX */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
3751色影院一区二区三区| 日韩欧美中文字幕公布| 717成人午夜免费福利电影| 久久久久久亚洲综合| 午夜婷婷国产麻豆精品| 成人在线视频一区二区| 日韩亚洲电影在线| 亚洲午夜在线视频| 91在线视频18| 久久精品亚洲精品国产欧美kt∨| 亚洲国产精品影院| 91女厕偷拍女厕偷拍高清| 国产日韩三级在线| 精品一区二区免费看| 欧美精品亚洲二区| 亚洲精品少妇30p| 不卡一区二区在线| 欧美激情一区不卡| 国产精品乡下勾搭老头1| 日韩欧美国产三级| 奇米综合一区二区三区精品视频| 欧美日韩国产影片| 中文字幕一区在线| 最新热久久免费视频| 久久久一区二区三区捆绑**| 2022国产精品视频| 色999日韩国产欧美一区二区| 奇米亚洲午夜久久精品| 夜夜精品浪潮av一区二区三区| 在线观看视频欧美| www.日韩大片| 国产精选一区二区三区| 亚洲欧美aⅴ...| 日韩中文欧美在线| 亚洲国产成人av网| 欧美性一区二区| 亚洲自拍偷拍麻豆| 欧美精品色综合| 免费在线欧美视频| 精品欧美一区二区三区精品久久| 日本三级亚洲精品| 精品欧美一区二区久久| 国产高清不卡二三区| 国产精品久久久久久亚洲伦| 不卡高清视频专区| 亚洲精品日产精品乱码不卡| 欧美巨大另类极品videosbest | 亚洲人123区| 91视频com| 亚洲成a人片综合在线| 欧美主播一区二区三区美女| 肉色丝袜一区二区| 精品国产一区二区三区久久久蜜月| 极品少妇xxxx偷拍精品少妇| 中文成人综合网| 在线视频亚洲一区| 蜜桃av一区二区三区| 国产亚洲精品中文字幕| 91亚洲永久精品| 轻轻草成人在线| 中文字幕欧美激情一区| 在线一区二区观看| 九九视频精品免费| **欧美大码日韩| 日韩一级高清毛片| 成人午夜在线视频| 日韩国产精品久久| 中文字幕成人av| 欧美一区二区三区在线电影| 床上的激情91.| 日本sm残虐另类| 中文字幕一区二区三中文字幕| 91精品国产色综合久久不卡电影| 国产成人av影院| 亚洲v日本v欧美v久久精品| 亚洲夂夂婷婷色拍ww47 | 麻豆国产精品777777在线| 国产成人av影院| 久久久久99精品国产片| 开心九九激情九九欧美日韩精美视频电影| 日本美女一区二区| 成人av手机在线观看| 国产片一区二区| 91高清视频在线| 亚洲日本电影在线| 欧美日韩aaaaa| 99re成人精品视频| 天天色天天爱天天射综合| 国产精品欧美久久久久一区二区 | 亚洲资源中文字幕| 国产欧美一区二区三区在线看蜜臀 | 久久久久9999亚洲精品| 欧美乱妇15p| 色综合久久天天| 国产91对白在线观看九色| 日韩电影网1区2区| 亚洲福利视频一区| 亚洲精品视频一区| 成人免费在线播放视频| 久久精品视频一区二区三区| 日韩亚洲欧美中文三级| 欧美怡红院视频| 色哟哟精品一区| 97精品久久久久中文字幕| 成人小视频在线| 粉嫩aⅴ一区二区三区四区五区| 久久国产婷婷国产香蕉| 热久久一区二区| 秋霞国产午夜精品免费视频| 蜜桃精品视频在线| 久久精品国产亚洲aⅴ| 蜜臀a∨国产成人精品| 五月婷婷综合在线| 日韩和的一区二区| 日韩av中文字幕一区二区| 亚洲国产aⅴ天堂久久| 亚洲一二三级电影| 亚洲高清一区二区三区| 首页亚洲欧美制服丝腿| 天天综合色天天综合| 日本不卡一二三| 精品亚洲国内自在自线福利| 精品一区二区精品| 成人在线综合网| 色噜噜夜夜夜综合网| 91极品美女在线| 国产精品狼人久久影院观看方式| 一本色道久久综合亚洲精品按摩| 欧美福利电影网| 91麻豆精品91久久久久久清纯| 91色porny| 波多野结衣中文字幕一区 | 欧美日韩在线免费视频| 国产成人综合精品三级| 肉丝袜脚交视频一区二区| 老司机精品视频一区二区三区| 激情小说亚洲一区| 国产福利一区二区三区视频在线| 国产a久久麻豆| 色系网站成人免费| 欧美色爱综合网| 精品日韩av一区二区| 国产精品欧美一级免费| 亚洲国产精品久久久男人的天堂| 美日韩黄色大片| 丰满放荡岳乱妇91ww| 欧美性生活久久| 国产偷国产偷亚洲高清人白洁| 1区2区3区欧美| 蜜臂av日日欢夜夜爽一区| av电影天堂一区二区在线| 欧美亚洲动漫精品| 欧美精品一区二区在线播放| 中文字幕亚洲区| 青青草视频一区| 99在线精品观看| 精品国产亚洲在线| 一区二区视频在线看| 久久99日本精品| 欧亚一区二区三区| 久久精品视频在线免费观看| 亚洲最快最全在线视频| 国产一区二区不卡老阿姨| 欧美视频在线一区二区三区 | 亚洲欧美偷拍另类a∨色屁股| 亚洲成人免费看| 99久久精品国产一区二区三区 | 日韩欧美三级在线| 亚洲你懂的在线视频| 狠狠狠色丁香婷婷综合久久五月| 91老司机福利 在线| 久久婷婷成人综合色| 舔着乳尖日韩一区| 91社区在线播放| 国产精品日产欧美久久久久| 麻豆91在线看| 欧美日韩中字一区| 亚洲色欲色欲www| 国产精品综合二区| 日韩天堂在线观看| 午夜精品福利久久久| 久久女同互慰一区二区三区| 午夜精品爽啪视频| 欧美96一区二区免费视频| 91精品国产品国语在线不卡| 日本不卡视频在线观看| 日韩一二三四区| 国产91精品一区二区麻豆亚洲| 久久久久久久久久电影| 精品亚洲国产成人av制服丝袜| 亚洲精品一区二区三区蜜桃下载| 蓝色福利精品导航| 国产精品久久久久永久免费观看| 国产成人精品免费看| 一二三四社区欧美黄| 亚洲国产一区二区在线播放| 91丨porny丨中文| 国产精品久久福利| www.色综合.com| 日韩理论片一区二区|