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

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

?? subreader.c.svn-base

?? sigmadesign smp8623 gui source code ,bingo
?? SVN-BASE
?? 第 1 頁 / 共 4 頁
字號:
/* * Subtitle reader with format autodetection * * Written by laaz * Some code cleanup & realloc() by A'rpi/ESP-team * */#include <stdio.h>#include <stdlib.h>#include <string.h>#include <ctype.h>#include <sys/types.h>#include <dirent.h>//#include "config.h"//#include "mp_msg.h"#include "../include/subreader.h"#include "../include/stream.h"#ifdef HAVE_ENCA#include <enca.h>#endif#define ERR ((void *) -1)#ifdef USE_ICONV#include <iconv.h>RMascii *sub_cp=NULL;#endif#ifdef USE_FRIBIDI#include <fribidi/fribidi.h>RMascii *fribidi_charset = NULL;   ///character set that will be passed to FriBiDiint flip_hebrew = 1;            ///flip subtitles using fribidiint fribidi_flip_commas = 0;    ///flip comma when fribidi is used#endifRMascii* dvdsub_lang = "de";//int suboverlap_enabled = 2;/* Maximal length of line of a subtitle */#define LINE_LEN 1000//static RMreal mpsub_position=0;static RMreal mpsub_multiplier=1.0;static int sub_slacktime = 20000; //20 secint sub_no_text_pp=0;   // 1 => do not apply text post-processing                        // like {\...} elimination in SSA format.int sub_match_fuzziness=1; // level of sub name matching fuzzinesssub_context subs;/* Use the SUB_* constant defined in the header file */int sub_format=SUB_INVALID;#ifdef USE_SORTSUB/*   Some subtitling formats, namely AQT and Subrip09, define the end of a   subtitle as the beginning of the following. Since currently we read one   subtitle at time, for these format we keep two global *subtitle,   previous_aqt_sub and previous_subrip09_sub, pointing to previous subtitle,   so we can change its end when we read current subtitle starting time.   When USE_SORTSUB is defined, we use a single global unsigned long,   previous_sub_end, for both (and even future) formats, to store the end of   the previous sub: it is initialized to 0 in sub_read_file and eventually   modified by sub_read_aqt_line or sub_read_subrip09_line. */unsigned long previous_sub_end;#endifstatic int eol(RMascii p) {	return (p=='\r' || p=='\n' || p=='\0');}/* Remove leading and trailing space */static void trail_space(RMascii *s) {	int i = 0;	while (isspace(s[i])) ++i;	if (i) RMCopyAscii(s, s + i);	i = RMasciiLength(s) - 1;	while (i > 0 && isspace(s[i])) s[i--] = '\0';}static RMascii *stristr(const RMascii *haystack, const RMascii *needle) {    int len = 0;    const RMascii *p = haystack;    if (!(haystack && needle)) return NULL;    len=RMasciiLength(needle);    while (*p != '\0') {	if (RMNCompareAsciiCaseInsensitively(p, needle, len) == 0) return (RMascii*)p;	p++;    }    return NULL;}static subtitle *sub_read_line_sami(stream_t* st, subtitle *current) {    static RMascii line[LINE_LEN+1];    static RMascii *s = NULL, *slacktime_s;    RMascii text[LINE_LEN+1], *p=NULL, *q;    int state;    current->lines = current->start = current->end = 0;    current->alignment = SUB_ALIGNMENT_BOTTOMCENTER;    state = 0;    /* read the first line */    if (!s)	    if (!(s = stream_read_line(st, line, LINE_LEN))) return 0;    do {	switch (state) {	case 0: /* find "START=" or "Slacktime:" */	    slacktime_s = stristr (s, "Slacktime:");	    if (slacktime_s)                sub_slacktime = strtol (slacktime_s+10, NULL, 0) / 10;	    s = stristr (s, "Start=");	    if (s) {		current->start = strtol (s + 6, &s, 0) / 10;                /* eat '>' */                for (; *s != '>' && *s != '\0'; s++);                s++;		state = 1; continue;	    }	    break;	case 1: /* find (optionnal) "<P", skip other TAGs */	    for  (; *s == ' ' || *s == '\t'; s++); /* strip blanks, if any */	    if (*s == '\0') break;	    if (*s != '<') { state = 3; p = text; continue; } /* not a TAG */	    s++;	    if (*s == 'P' || *s == 'p') { s++; state = 2; continue; } /* found '<P' */	    for (; *s != '>' && *s != '\0'; s++); /* skip remains of non-<P> TAG */	    if (s == '\0')	      break;	    s++;	    continue;	case 2: /* find ">" */	    if ((s = strchr (s, '>'))) { s++; state = 3; p = text; continue; }	    break;	case 3: /* get all text until '<' appears */	    if (*s == '\0') break;	    else if (!RMNCompareAsciiCaseInsensitively (s, "<br>", 4)) {		*p = '\0'; p = text; trail_space (text);		if (text[0] != '\0')		    current->text[current->lines++] = strdup (text);		s += 4;	    }	    else if ((*s == '{') && !sub_no_text_pp) { state = 5; ++s; continue; }	    else if (*s == '<') { state = 4; }	    else if (!RMNCompareAsciiCaseInsensitively (s, "&nbsp;", 6)) { *p++ = ' '; s += 6; }	    else if (*s == '\t') { *p++ = ' '; s++; }	    else if (*s == '\r' || *s == '\n') { s++; }	    else *p++ = *s++;	    /* skip duplicated space */	    if (p > text + 2) if (*(p-1) == ' ' && *(p-2) == ' ') p--;	    continue;	case 4: /* get current->end or skip <TAG> */	    q = stristr (s, "Start=");	    if (q) {		current->end = strtol (q + 6, &q, 0) / 10 - 1;		*p = '\0'; trail_space (text);		if (text[0] != '\0')		    current->text[current->lines++] = strdup (text);		if (current->lines > 0) { state = 99; break; }		state = 0; continue;	    }	   	s = strchr (s, '>');	    if (s) { s++; state = 3; continue; }	    break;       case 5: /* get rid of {...} text, but read the alignment code */	    if ((*s == '\\') && (*(s + 1) == 'a') && !sub_no_text_pp) {               if (stristr(s, "\\a1") != NULL) {                   current->alignment = SUB_ALIGNMENT_BOTTOMLEFT;                   s = s + 3;               }               if (stristr(s, "\\a2") != NULL) {                   current->alignment = SUB_ALIGNMENT_BOTTOMCENTER;                   s = s + 3;               } else if (stristr(s, "\\a3") != NULL) {                   current->alignment = SUB_ALIGNMENT_BOTTOMRIGHT;                   s = s + 3;               } else if ((stristr(s, "\\a4") != NULL) || (stristr(s, "\\a5") != NULL) || (stristr(s, "\\a8") != NULL)) {                   current->alignment = SUB_ALIGNMENT_TOPLEFT;                   s = s + 3;               } else if (stristr(s, "\\a6") != NULL) {                   current->alignment = SUB_ALIGNMENT_TOPCENTER;                   s = s + 3;               } else if (stristr(s, "\\a7") != NULL) {                   current->alignment = SUB_ALIGNMENT_TOPRIGHT;                   s = s + 3;               } else if (stristr(s, "\\a9") != NULL) {                   current->alignment = SUB_ALIGNMENT_MIDDLELEFT;                   s = s + 3;               } else if (stristr(s, "\\a10") != NULL) {                   current->alignment = SUB_ALIGNMENT_MIDDLECENTER;                   s = s + 4;               } else if (stristr(s, "\\a11") != NULL) {                   current->alignment = SUB_ALIGNMENT_MIDDLERIGHT;                   s = s + 4;               }	    }	    if (*s == '}') state = 3;	    ++s;	    continue;	}	/* read next line */	if (state != 99 && !(s = stream_read_line (st, line, LINE_LEN))) {	    if (current->start > 0) {		break; // if it is the last subtitle	    } else {		return 0;	    }	}    } while (state != 99);    // For the last subtitle    if (current->end <= 0) {        current->end = current->start + sub_slacktime;	*p = '\0'; trail_space (text);	if (text[0] != '\0')	    current->text[current->lines++] = strdup (text);    }    return current;}static RMascii *sub_readtext(RMascii *source, RMascii **dest) {    int len=0;    RMascii *p=source;//    printf("src=%p  dest=%p  \n",source,dest);    while ( !eol(*p) && *p!= '|' ) {	p++,len++;    }    *dest= MALLOC (len+1);    if (!dest) {return ERR;}    strncpy(*dest, source, len);    (*dest)[len]=0;    while (*p=='\r' || *p=='\n' || *p=='|') p++;    if (*p) return p;  // not-last text field    else return NULL;  // last text field}static subtitle *sub_read_line_microdvd(stream_t *st,subtitle *current) {    RMascii line[LINE_LEN+1];    RMascii line2[LINE_LEN+1];    RMascii *p, *next;    int i;    do {	if (!stream_read_line (st, line, LINE_LEN)) return NULL;    } while ((sscanf (line,		      "{%ld}{}%[^\r\n]",		      &(current->start), line2) < 2) &&	     (sscanf (line,		      "{%ld}{%ld}%[^\r\n]",		      &(current->start), &(current->end), line2) < 3));    p=line2;    next=p, i=0;    while ((next =sub_readtext (next, &(current->text[i])))) {        if (current->text[i]==ERR) {return ERR;}	i++;	if (i>=SUB_MAX_TEXT) { current->lines=i;return current;}    }    current->lines= ++i;    return current;}static subtitle *sub_read_line_mpl2(stream_t *st,subtitle *current) {    RMascii line[LINE_LEN+1];    RMascii line2[LINE_LEN+1];    RMascii *p, *next;    int i;    do {	if (!stream_read_line (st, line, LINE_LEN)) return NULL;    } while ((sscanf (line,		      "[%ld][%ld]%[^\r\n]",		      &(current->start), &(current->end), line2) < 3));    current->start *= 10;    current->end *= 10;    p=line2;    next=p, i=0;    while ((next =sub_readtext (next, &(current->text[i])))) {        if (current->text[i]==ERR) {return ERR;}	i++;	if (i>=SUB_MAX_TEXT) { current->lines=i;return current;}    }    current->lines= ++i;    return current;}static subtitle *sub_read_line_subrip(stream_t* st, subtitle *current) {    RMascii line[LINE_LEN+1];    int a1,a2,a3,a4,b1,b2,b3,b4;    RMascii *p=NULL, *q=NULL;    int len;    while (1) {	if (!stream_read_line (st, line, LINE_LEN)) return NULL;	if (sscanf (line, "%d:%d:%d.%d,%d:%d:%d.%d",&a1,&a2,&a3,&a4,&b1,&b2,&b3,&b4) < 8) continue;	current->start = a1*360000+a2*6000+a3*100+a4;	current->end   = b1*360000+b2*6000+b3*100+b4;	if (!stream_read_line (st, line, LINE_LEN)) return NULL;	p=q=line;	for (current->lines=1; current->lines < SUB_MAX_TEXT; current->lines++) {	    for (q=p,len=0; *p && *p!='\r' && *p!='\n' && *p!='|' && strncmp(p,"[br]",4); p++,len++);	    current->text[current->lines-1]=MALLOC (len+1);	    if (!current->text[current->lines-1]) return ERR;	    strncpy (current->text[current->lines-1], q, len);	    current->text[current->lines-1][len]='\0';	    if (!*p || *p=='\r' || *p=='\n') break;	    if (*p=='|') p++;	    else while (*p++!=']');	}	break;    }    return current;}static subtitle *sub_read_line_subviewer(stream_t *st,subtitle *current) {    RMascii line[LINE_LEN+1];    int a1,a2,a3,a4,b1,b2,b3,b4;    RMascii *p=NULL;    int i,len;    while (!current->text[0]) {	if (!stream_read_line (st, line, LINE_LEN)) return NULL;//	printf("sub_read_line_subviewer: %s\n", line);	if ((len=sscanf (line, "%d:%d:%d%[,.:]%d --> %d:%d:%d%[,.:]%d",&a1,&a2,&a3,(RMascii *)&i,&a4,&b1,&b2,&b3,(RMascii *)&i,&b4)) < 10)	    continue;	current->start = a1*360000+a2*6000+a3*100+a4/10;	current->end   = b1*360000+b2*6000+b3*100+b4/10;	for (i=0; i<SUB_MAX_TEXT;) {	    if (!stream_read_line (st, line, LINE_LEN)) break;	    len=0;	    for (p=line; *p!='\n' && *p!='\r' && *p; p++,len++);	    if (len) {                int j=0,skip=0;		RMascii *curptr=MALLOC (len+1);		current->text[i]=curptr;		if (!current->text[i]) return ERR;		//strncpy (current->text[i], line, len); current->text[i][len]='\0';                for(; j<len; j++) {		    /* let's filter html tags ::atmos */		    if(line[j]=='>') {			skip=0;			continue;		    }		    if(line[j]=='<') {			skip=1;			continue;		    }		    if(skip) {			continue;		    }		    *curptr=line[j];		    curptr++;		}		*curptr='\0';		i++;	    } else {		break;	    }	}	current->lines=i;    }    return current;}static subtitle *sub_read_line_subviewer2(stream_t *st,subtitle *current) {    RMascii line[LINE_LEN+1];    int a1,a2,a3,a4;    RMascii *p=NULL;    int i,len;    while (!current->text[0]) {        if (!stream_read_line (st, line, LINE_LEN)) return NULL;	if (line[0]!='{')	    continue;        if ((len=sscanf (line, "{T %d:%d:%d:%d",&a1,&a2,&a3,&a4)) < 4)            continue;        current->start = a1*360000+a2*6000+a3*100+a4/10;        for (i=0; i<SUB_MAX_TEXT;) {            if (!stream_read_line (st, line, LINE_LEN)) break;            if (line[0]=='}') break;            len=0;            for (p=line; *p!='\n' && *p!='\r' && *p; ++p,++len);            if (len) {                current->text[i]=MALLOC (len+1);                if (!current->text[i]) return ERR;                RMNCopyAscii (current->text[i], line, len); current->text[i][len]='\0';                ++i;            } else {                break;            }        }        current->lines=i;    }    return current;}static subtitle *sub_read_line_vplayer(stream_t *st,subtitle *current) {	RMascii line[LINE_LEN+1];	int a1,a2,a3;	RMascii *p=NULL, *next,separator;	int i,len,plen;	while (!current->text[0]) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美精品视频www在线观看| 日本在线不卡视频一二三区| 国产九色sp调教91| 欧美精品一区二区三区四区| 国产一区二区三区在线观看免费视频| 日韩精品中文字幕在线不卡尤物| 精品伊人久久久久7777人| 久久久影视传媒| 不卡视频在线看| 一区二区视频在线| 在线不卡欧美精品一区二区三区| 免费日韩伦理电影| 久久精品人人做人人爽人人| 91原创在线视频| 午夜成人免费电影| 精品国产一区二区三区四区四| 国产精品伊人色| 亚洲激情成人在线| 日韩欧美久久一区| 91麻豆成人久久精品二区三区| 亚洲成人先锋电影| 中文字幕的久久| 欧美日韩中文精品| 国产成人欧美日韩在线电影| 一区二区三区美女视频| 欧美成人官网二区| 91啪亚洲精品| 久久国内精品视频| 亚洲男人的天堂网| 久久综合色之久久综合| 91成人免费在线视频| 国产一区二区免费在线| 伊人性伊人情综合网| 久久免费视频一区| 欧美日韩国产a| 丁香亚洲综合激情啪啪综合| 日韩和欧美的一区| 国产精品女人毛片| 日韩视频永久免费| 欧美天堂一区二区三区| 国产成人av电影在线播放| 亚洲成人一区在线| 亚洲人成网站精品片在线观看| 久久日韩粉嫩一区二区三区 | 极品美女销魂一区二区三区| 亚洲日本乱码在线观看| 精品粉嫩aⅴ一区二区三区四区| 欧美午夜精品一区二区蜜桃| 高清av一区二区| 免费人成在线不卡| 亚洲 欧美综合在线网络| 亚洲天堂2014| 日本一区二区视频在线观看| 日韩精品资源二区在线| 欧美日韩一区二区三区在线 | 日本欧美大码aⅴ在线播放| 亚洲欧美日韩国产一区二区三区 | 日韩一卡二卡三卡四卡| 色噜噜狠狠成人网p站| 成人午夜精品一区二区三区| 久久国产夜色精品鲁鲁99| 日韩精品一级中文字幕精品视频免费观看| 中文字幕一区免费在线观看 | 色婷婷精品久久二区二区蜜臂av| 国产成人av一区| 经典三级视频一区| 麻豆久久久久久久| 日韩av不卡在线观看| 日韩精品每日更新| 亚洲福利视频一区| 亚洲6080在线| 日韩电影在线一区二区三区| 亚洲福利国产精品| 亚洲成人综合视频| 婷婷综合在线观看| 日韩精品亚洲一区二区三区免费| 五月综合激情网| 日本怡春院一区二区| 日本不卡在线视频| 日本亚洲免费观看| 久久99热这里只有精品| 国内精品伊人久久久久影院对白| 奇米影视在线99精品| 精品一区二区成人精品| 极品美女销魂一区二区三区免费| 国产综合色在线视频区| 懂色av中文一区二区三区| 丁香啪啪综合成人亚洲小说| 94-欧美-setu| 欧美伊人久久久久久午夜久久久久| 欧美亚洲高清一区二区三区不卡| 欧美日韩中文字幕一区| 日韩午夜精品视频| 久久精品亚洲国产奇米99| 国产精品久久久久久久岛一牛影视| 亚洲美女区一区| 午夜欧美2019年伦理| 捆绑调教一区二区三区| 国产麻豆日韩欧美久久| 91在线观看高清| 欧美一区二区视频观看视频| 国产日韩欧美精品一区| 亚洲私人黄色宅男| 日韩高清不卡一区二区三区| 国产精品 欧美精品| 91精品1区2区| 欧美一区二区三区公司| 国产精品乱人伦| 亚洲不卡一区二区三区| 国产美女av一区二区三区| 91欧美激情一区二区三区成人| 欧美久久久久久蜜桃| 亚洲国产精品成人综合| 亚洲国产一二三| 国产精品69毛片高清亚洲| 欧美午夜电影网| 国产欧美一区二区三区沐欲| 一区二区免费视频| 国产一区二区三区在线观看免费视频 | 亚洲一区二区欧美日韩| 久久99精品国产麻豆不卡| 成av人片一区二区| 日韩欧美的一区| 国产精品久久久久四虎| 蜜桃久久精品一区二区| 成人黄色av网站在线| 日韩一区二区三| 亚洲美女在线国产| 国产经典欧美精品| 51精品视频一区二区三区| 国产精品欧美精品| 久久成人av少妇免费| 91国产成人在线| 精品国产一区久久| 婷婷综合另类小说色区| 99久久99久久精品免费观看| 精品国产乱码久久久久久久久| 亚洲综合av网| 国产精品亚洲а∨天堂免在线| 欧美日韩国产片| 亚洲桃色在线一区| 国产精品一区二区男女羞羞无遮挡| 欧美男人的天堂一二区| 亚洲欧美日韩一区二区| 国产99久久精品| 久久人人爽爽爽人久久久| 青青草一区二区三区| 欧美日韩高清影院| 一区二区三区产品免费精品久久75| 国产69精品久久777的优势| 欧美xxxxx裸体时装秀| 午夜精品免费在线| 欧美在线一二三四区| 亚洲精品久久嫩草网站秘色| av动漫一区二区| 国产精品毛片a∨一区二区三区| 国产黄人亚洲片| 国产午夜精品福利| 国产一区二区在线观看视频| 日韩三级伦理片妻子的秘密按摩| 天天综合色天天综合色h| 欧美午夜免费电影| 伊人开心综合网| 欧洲另类一二三四区| 亚洲一区二区在线免费看| 色狠狠一区二区三区香蕉| 一区二区三区鲁丝不卡| 在线观看日韩高清av| 亚洲成人自拍网| 91精品国产综合久久福利软件| 日韩精品视频网站| 91精品国产一区二区三区蜜臀| 免费看黄色91| 久久免费偷拍视频| 成人手机在线视频| **欧美大码日韩| 欧洲亚洲精品在线| 日本va欧美va瓶| 久久综合久久综合久久| 国产 日韩 欧美大片| 自拍偷拍国产精品| 欧美色精品天天在线观看视频| 丝袜美腿高跟呻吟高潮一区| 制服丝袜国产精品| 国产乱码精品一区二区三区五月婷| 国产偷v国产偷v亚洲高清| 99国产精品久久| 亚洲综合清纯丝袜自拍| 欧美一级免费大片| 狠狠色狠狠色综合日日91app| 国产日韩精品久久久| 91亚洲永久精品| 爽好多水快深点欧美视频| 精品国产成人系列| 99热99精品| 欧美bbbbb| 国产精品美女www爽爽爽| 欧洲国产伦久久久久久久| 精品综合久久久久久8888| 国产精品成人在线观看|