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

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

?? meta.c

?? Sun公司Dream項目
?? C
字號:
/*
 * The contents of this file are subject to the terms
 * of the Common Development and Distribution License
 * (the "License").  You may not use this file except
 * in compliance with the License.
 *
 * You can obtain a copy of the license at
 * http://www.opensource.org/licenses/cddl1.php
 * See the License for the specific language governing
 * permissions and limitations under the License.
 *
 * When distributing Covered Code, include this CDDL
 * HEADER in each file and include the License file at
 * http://www.opensource.org/licenses/cddl1.php.  If 
 * applicable, add the following below this CDDL HEADER, 
 * with the fields enclosed by brackets "[]" replaced 
 * with your own identifying information: 
 * Portions Copyright [yyyy]
 * [name of copyright owner]
 */ 

/*
 * $(@)meta.c $Revision: 1.2 $ $Date: 2006/07/15 00:02:30 $
 * 
 * Copyright 2006 Sun Microsystems, Inc. All Rights Reserved.
 */
/*
 * Copyright (c) 2005 by Sun Microsystems, Inc.
 * Functions to perform TS parsing

 * Created:   August, 2005
 * Author:    Yongfang Liang
 *---------------------------------------------------------------*/

/* bugs: not memory allocation testing */
#include "ecmfile.h"

#include <errno.h>
#include <string.h>

ECMfile_info *GetECMFileInfo(FILE *hECMFile)
{
    int error = 0;

    /* read the header information */
    ECMfile_info *info = (ECMfile_info *)malloc(sizeof(ECMfile_info));
    if (info == NULL)
    	return NULL;
    
    assert(hECMFile != NULL);

    fseek(hECMFile, 0, SEEK_SET);
    //    error = fread(&info->header,1,sizeof(ECMfile_header),hECMFile);
    //    assert( error == sizeof(ECMfile_header));
    int nread = fread( &info->header.version, 1, sizeof(info->header.version),
                       hECMFile );
    nread += fread( &info->header.no_of_ECMs, 1, sizeof(info->header.no_of_ECMs),
                    hECMFile );
    nread += fread( &info->header.ecm_len, 1, sizeof(info->header.ecm_len), 
                    hECMFile);
    nread += fread( &info->header.metadata_offset, 1, 
                    sizeof(info->header.metadata_offset), hECMFile );

    if( nread != ECM_FILE_HEADER_SIZE ) {
        printf("ERROR: GetECMFileInfo(): Reading from Ecm file failed: %s\n",
               strerror(errno) );
        free(info);
        return NULL;
    }

    info->item_len = info->header.ecm_len + sizeof(FileOffset) +  sizeof(FileOffset);
    info->ecmItem.ecm_payload = (unsigned char *)malloc(info->header.ecm_len);

    return info;
}

void CleanECMInfo(ECMfile_info *info)
{
    if (info != NULL) 
    {
    	if (info->ecmItem.ecm_payload != NULL)
            free(info->ecmItem.ecm_payload);
        free(info);
    }
    return;
}


void WriteOneECMItem(FILE *hECMFile, ECMfile_info *info, 
	                     int index, unsigned char *buffer, int len, FileOffset pos)
{
    long position = 0L;
    FileOffset insert_pos = -1; /* don't know */
    FileOffset new_pos = (FileOffset)pos;
	assert(hECMFile != NULL);
    position = ftell(hECMFile);
    fseek(hECMFile, info->header.metadata_offset + info->item_len * index, SEEK_SET);
 	
	fwrite(&insert_pos, 1,sizeof(FileOffset),hECMFile); 
	fwrite(&pos, 1,sizeof(FileOffset),hECMFile);
	fwrite(buffer, 1, len, hECMFile);
    /* restore the file indicator */
    fseek(hECMFile, position, SEEK_SET);
    return;
}

void WriteECMFileHeader(FILE *hECMFile, ECMfile_info *info)
{
    assert(hECMFile != NULL);

    fseek(hECMFile, 0, SEEK_SET);

    //    int size = sizeof(ECMfile_header);    
    //fwrite(&info->header, 1, size, hECMFile);

    fwrite( &info->header.version, 1, sizeof(info->header.version), hECMFile );
    fwrite( &info->header.no_of_ECMs, 1, sizeof(info->header.no_of_ECMs), hECMFile);
    fwrite( &info->header.ecm_len, 1, sizeof(info->header.ecm_len), hECMFile );
    fwrite( &info->header.metadata_offset, 1, sizeof(info->header.metadata_offset), hECMFile);

    return;
}

void ReWrOneECMItem(FILE *hECMFile, ECMfile_info *info, 
	                     int index, bool b_read)
{
    long position = 0L;
	assert(hECMFile != NULL);
    position = ftell(hECMFile);
    fseek(hECMFile, info->header.metadata_offset + info->item_len * index, SEEK_SET);
 	assert(info->ecmItem.ecm_payload);
 	
    if (b_read)
    {
	    fread(&info->ecmItem.insert_offset,1,sizeof(FileOffset),hECMFile);
	    fread(&info->ecmItem.new_offset, 1,sizeof(FileOffset),hECMFile);
	    fread(info->ecmItem.ecm_payload, 1, info->header.ecm_len, hECMFile);
    }
    else
    {
	    fwrite(&info->ecmItem.insert_offset,1,sizeof(FileOffset),hECMFile);
	    fwrite(&info->ecmItem.new_offset, 1,sizeof(FileOffset),hECMFile);
	    fwrite(info->ecmItem.ecm_payload, 1, info->header.ecm_len, hECMFile);
    }
    /* restore the file indicator */
    fseek(hECMFile, position, SEEK_SET);
    return;
}

void ConvertECMfile(FILE *hECMFile, FILE *ascii)
{
    ECMfile_info *info;
    int i = 0;
    info = GetECMFileInfo(hECMFile);
    if (info == NULL)
    	return;
    fprintf(ascii, "Version: %d\n", info->header.version);
    fprintf(ascii, "Number of ECMs: %d\n", info->header.no_of_ECMs);
    fprintf(ascii, "Length of ECM: %d\n", info->header.ecm_len);
    fprintf(ascii, "Offset: %d\n", info->header.metadata_offset);
    
    for (i = 0; i < info->header.no_of_ECMs; i++)
    {
    	ReWrOneECMItem(hECMFile, info, i, TRUE);
	    fprintf(ascii, "ECM %10d, InsertOffset: %10d, NewOffset: %10d\n", 
	    	i, (int)(info->ecmItem.insert_offset), (int)(info->ecmItem.new_offset));
    }
    CleanECMInfo(info);
    
    return;
}

static void ResetInsertPosition(FILE *hECMFile, ECMfile_info *info)
{
    int i = 0;
    for (i = 0; i < info->header.no_of_ECMs; i++)
    {
    	ReWrOneECMItem(hECMFile, info, i, TRUE);
    	info->ecmItem.insert_offset = -1;
    	ReWrOneECMItem(hECMFile, info, i, FALSE);
    }
    return;
}


static int ReadUpdateMetaDataItem(metadata *p_meta, picFrame_metadata *picFrame, int frame_no, bool b_read)
{
    long position = ftell(p_meta->meta_file);
    long offset = sizeof(picFrame->frame_number) + sizeof(picFrame->frametype) 
    	        + p_meta->header->no_of_streams*sizeof(FileOffset);

    long seek_offset = p_meta->header->metadata_offset + (frame_no)*offset;

	fseek(p_meta->meta_file, seek_offset, SEEK_SET);

    if (b_read)
    {
		fread(&picFrame->frame_number,1,
			sizeof(picFrame->frame_number),p_meta->meta_file);
		fread(&picFrame->frametype,1,
			sizeof(picFrame->frametype),p_meta->meta_file);
		fread(picFrame->offsets,1,
			 p_meta->header->no_of_streams*sizeof(FileOffset),p_meta->meta_file);
    }
    else
    {
		fwrite(&picFrame->frame_number,1,
			sizeof(picFrame->frame_number),p_meta->meta_file);
		fwrite(&picFrame->frametype,1,
			sizeof(picFrame->frametype),p_meta->meta_file);
		fwrite(picFrame->offsets,1,
			 p_meta->header->no_of_streams*sizeof(FileOffset),p_meta->meta_file);
    }

	fseek(p_meta->meta_file, position, SEEK_SET);
    return 1;
}

metadata *OpenMetaDataFile(FILE *hMetaFile)
{
    metadata *p_meta;
    int i, size;
    long end_pos, pos;
    picFrame_metadata picFrame;
    /* meta data file */
	p_meta = (metadata *)malloc(sizeof(metadata));
	p_meta->header = (metadata_header *)malloc(sizeof(metadata_header));
	p_meta->meta_file = hMetaFile;
	p_meta->stream_no = -1; //no curr stream
	p_meta->speed = -1;

	fseek(hMetaFile,0,SEEK_SET);
	assert(fread(p_meta->header,1,sizeof(metadata_header),hMetaFile) != NULL);

	if(p_meta->header->version != METADATA_VERSION)	
		FATAL_ERROR("metadata version not supported");
	
	for(i=0;i<p_meta->header->no_of_streams; i++)
	{
		stream_metadata *stream = (stream_metadata *)malloc(sizeof(stream_metadata));
    	assert(fread(stream,1,sizeof(stream_metadata),hMetaFile) != NULL);
		p_meta->stream[i] = stream;
	}
        
    size = sizeof(picFrame.frame_number) + sizeof(picFrame.frametype) 
    	        + p_meta->header->no_of_streams*sizeof(FileOffset);
    pos = ftell(hMetaFile);
    fseek(hMetaFile,0,SEEK_END);
    end_pos = ftell(hMetaFile);
    fseek(hMetaFile, pos, SEEK_SET);
    p_meta->total_frames = (end_pos - p_meta->header->metadata_offset)/size;
    return p_meta;
}

void CleanMetaData(metadata *p_meta)
{
    if (p_meta)
    {
		int i;
		assert(p_meta->header != NULL);
		for(i=0;i<p_meta->header->no_of_streams;i++)
		{
			if (p_meta->stream[i])
			{
			    free(p_meta->stream[i]);
			}
		}
		free(p_meta->header);
		free(p_meta);
    }
    return;
}

void UpdateECMandMetaFile(FILE *hECMFile, FILE* hMetaFile, int stream_no, int ecm_ts_len)
{
    metadata *p_meta;
    ECMfile_info *info;
    int ecm_index = 0;
    int from;
    int total_ecm_ts_inserted = 0;
    int frame_no = 0;
    int frame_start, frame_end;
    bool b_reverse;
	assert(hECMFile != NULL && hMetaFile != NULL);

    info = GetECMFileInfo(hECMFile);
    if (info->header.no_of_ECMs < 1)
    {
    	return; /* no need to update the meta data file */
    }

    ResetInsertPosition(hECMFile, info);
    assert(info->header.ecm_len > 0);

    p_meta = OpenMetaDataFile(hMetaFile);
    assert(p_meta->header->no_of_streams >= stream_no);
    
    b_reverse = p_meta->stream[stream_no]->speed > 0 ? FALSE : TRUE;
    from = b_reverse? info->header.no_of_ECMs - 1 : 0;
    
    frame_start = b_reverse? p_meta->total_frames - 1 : 0;
    frame_end   = b_reverse? 0 : p_meta->total_frames - 1;
    
	for (frame_no = frame_start; frame_no != frame_end; frame_no += b_reverse?-1:1) 
	{
	    picFrame_metadata picFrame;
		int err = ReadUpdateMetaDataItem(p_meta,&picFrame, frame_no, TRUE);
		if(err == 0)
		{
			break;
		}
		
		if (picFrame.offsets[stream_no] == -1) // not availabe in this stream
		{
			continue;
		}

		/* search for the ECM used for this frame */
		if (!b_reverse)
		{
			for (ecm_index = from; ecm_index < info->header.no_of_ECMs; ecm_index ++)
			{
				ReWrOneECMItem(hECMFile, info, ecm_index, TRUE);
				if ( info->ecmItem.new_offset > picFrame.offsets[0])
				{
					break;
				}
			}
			ecm_index --;
		}
		else
		{
			for (ecm_index = from; ecm_index >= 0; ecm_index --)
			{
				ReWrOneECMItem(hECMFile, info, ecm_index, TRUE);
				if ( info->ecmItem.new_offset < picFrame.offsets[0])
				{
					break;
				}
			}
		}
		
		if (ecm_index < 0)
		{
			/* no ECM for this frame, no need to update */
            from = b_reverse? info->header.no_of_ECMs - 1 : 0;
			continue;
		}
		else
		{
	        ReWrOneECMItem(hECMFile, info, ecm_index, TRUE);
	        if (info->ecmItem.insert_offset == -1) // not calculated
	        {
	        	/* need to insert this ECM in front of this frame, update ECM file */
	        	/* at TS boundary */
	        	info->ecmItem.insert_offset = picFrame.offsets[stream_no] / TP_LENGTH * TP_LENGTH;
	        	ReWrOneECMItem(hECMFile, info, ecm_index, FALSE);
	        	total_ecm_ts_inserted += ecm_ts_len;
	        	
			     /* if the ECM is inserted right in front of the beginning of one frame */
			     /* adjust the position to be the position of the ECM packet */
			     picFrame.offsets[stream_no] -= TP_LENGTH;
	        }
	        /* update the meta data file */
	        picFrame.offsets[stream_no] += total_ecm_ts_inserted;
            ReadUpdateMetaDataItem(p_meta,&picFrame, frame_no, FALSE);
	        from = ecm_index;
		}
	}

    CleanMetaData(p_meta);
    CleanECMInfo(info);
	return;
}

int CheckReverse(FILE* hMetaFile, int stream_no)
{
    metadata *p_meta;
    int reverse = 0;
	assert(hMetaFile != NULL);
    p_meta = OpenMetaDataFile(hMetaFile);
    assert(p_meta->header->no_of_streams >= stream_no);
    reverse = p_meta->stream[stream_no]->speed > 0 ? FALSE : TRUE;
    CleanMetaData(p_meta);
    return reverse;

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
这里是久久伊人| 国产精品毛片无遮挡高清| 欧美日韩日日摸| 在线观看av一区| 欧美调教femdomvk| 欧美在线观看视频在线| 欧美天堂一区二区三区| 在线精品视频免费播放| 欧美性受xxxx黑人xyx| 91成人免费在线视频| 欧美日韩一区二区不卡| 欧美日韩国产首页| 日韩欧美一二三| wwww国产精品欧美| www国产亚洲精品久久麻豆| 国产亚洲欧美激情| 国产精品久久久久aaaa| 一区二区三区在线播放| 亚洲成人一二三| 麻豆国产精品官网| 高清国产午夜精品久久久久久| 不卡一区中文字幕| 欧美三级视频在线观看| 欧美一级日韩不卡播放免费| 久久久九九九九| 亚洲三级免费观看| 日韩福利电影在线观看| 精久久久久久久久久久| 成人理论电影网| 一本到三区不卡视频| 欧美色图一区二区三区| 日韩精品中文字幕一区| 国产欧美日韩一区二区三区在线观看 | 成a人片亚洲日本久久| 日本精品免费观看高清观看| 欧美福利视频导航| 国产性色一区二区| 一区二区在线看| 日本免费在线视频不卡一不卡二| 韩日欧美一区二区三区| 色综合久久久久久久久久久| 欧美精品粉嫩高潮一区二区| 久久精品视频一区二区三区| 亚洲国产一区在线观看| 国产米奇在线777精品观看| 色婷婷激情久久| 精品国产精品网麻豆系列| 欧美二区三区91| 国产精品传媒在线| 日韩高清不卡在线| 色综合久久综合网97色综合| 日韩欧美国产三级| 一区二区三区在线观看国产 | 一本色道久久综合精品竹菊| 日韩欧美国产精品| 亚洲精品网站在线观看| 久久99久久99精品免视看婷婷| 91亚洲国产成人精品一区二区三 | 亚洲午夜免费视频| 国产**成人网毛片九色| 日韩一区二区精品| 一区二区在线观看免费| 国产精品一级二级三级| 欧美精品乱码久久久久久| 国产精品入口麻豆九色| 久久99精品久久久久久久久久久久| 一本一道久久a久久精品综合蜜臀| 亚洲精品一线二线三线无人区| 亚洲综合久久久| 9色porny自拍视频一区二区| 日韩精品一区二区三区三区免费| 亚洲愉拍自拍另类高清精品| av一区二区三区黑人| 精品福利一区二区三区 | 色先锋aa成人| 欧美国产日韩在线观看| 久久成人久久鬼色| 欧美精品一卡二卡| 日韩电影一区二区三区| 色婷婷国产精品久久包臀| 亚洲激情第一区| 91小视频在线免费看| 国产精品久久777777| 97久久精品人人澡人人爽| 国产亚洲欧洲一区高清在线观看| 狠狠色丁香久久婷婷综| 精品国产乱码久久久久久久久| 午夜av一区二区三区| 欧美三级中文字幕| 国产香蕉久久精品综合网| 日韩精品电影在线观看| 欧美午夜精品一区二区蜜桃| 亚洲视频一区在线观看| 国产成人午夜高潮毛片| 国产人久久人人人人爽| 韩国毛片一区二区三区| 欧美精品一区二区三区很污很色的| 日本免费新一区视频| 日韩一级精品视频在线观看| 日本中文在线一区| 欧美一区二区性放荡片| 日韩精品五月天| 91精品国产欧美一区二区18| 丝袜亚洲另类欧美| 欧美一级高清片| 久久国产乱子精品免费女| 日韩你懂的在线播放| 狠狠色伊人亚洲综合成人| 欧美精品一区二区三区高清aⅴ| 另类小说图片综合网| 久久影视一区二区| 高清不卡一区二区| 中文字幕亚洲欧美在线不卡| 91蝌蚪porny| 午夜精品在线视频一区| 日韩你懂的在线观看| 国产99精品视频| 中文字幕日韩av资源站| 色综合久久中文字幕综合网| 亚洲成a人片综合在线| 日韩一级完整毛片| 国产精品91一区二区| 久久精品人人做人人爽人人| 成人免费观看av| 亚洲福利视频导航| 日韩欧美国产综合一区| 国产精品亚洲成人| 亚洲手机成人高清视频| 在线播放中文一区| 国产一区二区三区观看| 综合久久久久综合| 69堂成人精品免费视频| 国产最新精品免费| 亚洲精品伦理在线| 欧美一区中文字幕| 粉嫩绯色av一区二区在线观看| 亚洲视频电影在线| 欧美不卡一区二区三区四区| 成人自拍视频在线观看| 亚洲线精品一区二区三区八戒| 欧美成人aa大片| 色视频成人在线观看免| 男人的天堂久久精品| 欧美国产日韩a欧美在线观看| 欧美在线制服丝袜| 国产精品456露脸| 亚洲午夜电影网| 国产拍揄自揄精品视频麻豆| 精品视频123区在线观看| 国产精品小仙女| 亚洲国产精品久久人人爱蜜臀| 欧美大白屁股肥臀xxxxxx| 91在线视频播放| 久久99热99| 亚洲精品日产精品乱码不卡| 精品国一区二区三区| 91福利社在线观看| 国产99久久久精品| 蜜桃久久久久久| 亚洲欧美激情在线| 国产三区在线成人av| 欧美日韩国产三级| 成人av手机在线观看| 久久国产精品99精品国产| 亚洲精品高清视频在线观看| 久久久久久久久久久久久久久99 | 一本色道久久综合精品竹菊 | 精品国内二区三区| 欧美日本免费一区二区三区| 成人h版在线观看| 国产在线不卡一区| 一区二区成人在线| 日本一区二区免费在线观看视频| 7777精品久久久大香线蕉| 在线观看日韩一区| eeuss鲁一区二区三区| 久久99久国产精品黄毛片色诱| 亚洲综合久久av| 亚洲视频一区二区免费在线观看| 久久一区二区视频| 日韩精品一区二| 91精品国产91久久久久久一区二区 | 国产精一区二区三区| 天堂va蜜桃一区二区三区漫画版| 中文字幕中文字幕中文字幕亚洲无线| 日韩欧美自拍偷拍| 91精品国产色综合久久不卡电影 | 欧美激情综合在线| 日韩欧美亚洲国产精品字幕久久久| 日本乱码高清不卡字幕| av日韩在线网站| www.欧美.com| 成人黄色小视频| 高清国产一区二区| 成人免费看视频| 99re这里都是精品| 91影院在线观看| 色一情一乱一乱一91av| 91影院在线免费观看| 色悠久久久久综合欧美99|