⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 playtreeparser.c

📁 自己移植的linux下的流媒体播放器原代码,支持mms协议,支持ftp和http协议.
💻 C
📖 第 1 页 / 共 2 页
字号:
  strstrip(line);  if(strcasecmp(line,"#EXTM3U"))    return NULL;  mp_msg(MSGT_PLAYTREE,MSGL_V,"Detected extended m3u playlist format\n");  play_tree_parser_stop_keeping(p);  while((line = play_tree_parser_get_line(p)) != NULL) {    strstrip(line);    if(line[0] == '\0')      continue;    /* EXTM3U files contain such lines:     * #EXTINF:<seconds>, <title>     * followed by a line with the filename     * for now we have no place to put that     * so we just skip that extra-info ::atmos     */    if(line[0] == '#') {#if 0 /* code functional */      if(strncasecmp(line,"#EXTINF:",8) == 0) {        mp_msg(MSGT_PLAYTREE,MSGL_INFO,"[M3U] Duration: %dsec  Title: %s\n",          strtol(line+8,&line,10), line+2);      }#endif      continue;    }    entry = play_tree_new();    play_tree_add_file(entry,line);    if(!list)      list = entry;    else      play_tree_append_entry(last_entry,entry);    last_entry = entry;  }     if(!list) return NULL;  entry = play_tree_new();  play_tree_set_child(entry,list);  return entry;    }play_tree_t*parse_smil(play_tree_parser_t* p) {  int entrymode=0;  char* line,source[512],*pos,*s_start,*s_end;  play_tree_t *list = NULL, *entry = NULL, *last_entry = NULL;  mp_msg(MSGT_PLAYTREE,MSGL_V,"Trying smil playlist...\n");  // Check if smil  while((line = play_tree_parser_get_line(p)) != NULL) {    strstrip(line);    if(line[0] == '\0') // Ignore empties      continue;    if (strncasecmp(line,"<smil",5)==0)      break; // smil header found    else      return NULL; //line not smil exit  }  mp_msg(MSGT_PLAYTREE,MSGL_V,"Detected smil playlist format\n");  play_tree_parser_stop_keeping(p);  //Get entries from smil   while((line = play_tree_parser_get_line(p)) != NULL) {    strstrip(line);    if (line[0]=='\0')      continue;    if (!entrymode) { // all entries filled so far       if (strncasecmp(line,"<video",6)==0  || strncasecmp(line,"<audio",6)==0) {        pos=strstr(line,"src=");   // Is source present on this line        if (pos !=NULL) {          s_start=pos+5;          s_end=strchr(s_start,'"');            if (s_end == NULL) {              mp_msg(MSGT_PLAYTREE,MSGL_V,"Error parsing this source line %s\n",line);              continue;               }          if (s_end-s_start> 511) {            mp_msg(MSGT_PLAYTREE,MSGL_V,"Cannot store such a large source %s\n",line);            continue;          }          strncpy(source,s_start,s_end-s_start);          source[(s_end-s_start)]='\0'; // Null terminate          entry = play_tree_new();          play_tree_add_file(entry,source);          if(!list)  //Insert new entry            list = entry;          else            play_tree_append_entry(last_entry,entry);          last_entry = entry;        } else {          entrymode=1;        }      }    } else { //Entry found but not yet filled      pos = strstr(line,"src=");   // Is source present on this line      if (pos != NULL) {        entrymode=0;        s_start=pos+5;        s_end=strchr(s_start,'"');        if (s_end == NULL) {          mp_msg(MSGT_PLAYTREE,MSGL_V,"Error parsing this source line %s\n",line);          continue;        }        if (s_end-s_start> 511) {          mp_msg(MSGT_PLAYTREE,MSGL_V,"Cannot store such a large source %s\n",line);          continue;        }        strncpy(source,s_start,s_end-s_start);        source[(s_end-s_start)]='\0'; // Null terminate        entry = play_tree_new();        play_tree_add_file(entry,source);        if(!list)  //Insert new entry          list = entry;        else          play_tree_append_entry(last_entry,entry);        last_entry = entry;      }    }  }  if(!list) return NULL; // Nothing found  entry = play_tree_new();  play_tree_set_child(entry,list);  return entry;}play_tree_t*embedded_playlist_parse(char *line) {  int f=DEMUXER_TYPE_PLAYLIST;  stream_t* stream;  play_tree_parser_t* ptp;  play_tree_t* entry;  // Get stream opened to link  stream=open_stream(line,0,&f);  if(!stream) {    mp_msg(MSGT_PLAYTREE,MSGL_WARN,"Can't open playlist %s\n",line);    return NULL;  }  //add new playtree  mp_msg(MSGT_PLAYTREE,MSGL_V,"Adding playlist %s to element entryref\n",line);  ptp = play_tree_parser_new(stream,1);  entry = play_tree_parser_get_play_tree(ptp, 1);  play_tree_parser_free(ptp);  free_stream(stream);  return entry;}play_tree_t*parse_textplain(play_tree_parser_t* p) {  char* line;  char *c;  int embedded;  play_tree_t *list = NULL, *entry = NULL, *last_entry = NULL;  mp_msg(MSGT_PLAYTREE,MSGL_V,"Trying plaintext playlist...\n");  play_tree_parser_stop_keeping(p);  while((line = play_tree_parser_get_line(p)) != NULL) {    strstrip(line);    if(line[0] == '\0' || line[0] == '#' || (line[0] == '/' && line[1] == '/'))      continue;    //Special check for embedded smil or ram reference in file    embedded = 0;    if (strlen(line) > 5)      for(c = line; c[0]; c++ )        if ( ((c[0] == '.') && //start with . and next have smil with optional ? or &           (tolower(c[1]) == 's') && (tolower(c[2])== 'm') &&            (tolower(c[3]) == 'i') && (tolower(c[4]) == 'l') &&           (!c[5] || c[5] == '?' || c[5] == '&')) || // or          ((c[0] == '.') && // start with . and next have smi or ram with optional ? or &          ( ((tolower(c[1]) == 's') && (tolower(c[2])== 'm') && (tolower(c[3]) == 'i')) ||             ((tolower(c[1]) == 'r') && (tolower(c[2])== 'a') && (tolower(c[3]) == 'm')) )           && (!c[4] || c[4] == '?' || c[4] == '&')) ){          entry=embedded_playlist_parse(line);          embedded = 1;          break;        }    if (!embedded) {      //regular file link      entry = play_tree_new();      play_tree_add_file(entry,line);    }    if (entry != NULL) {      if(!list)        list = entry;      else        play_tree_append_entry(last_entry,entry);      last_entry = entry;    }  }     if(!list) return NULL;  entry = play_tree_new();  play_tree_set_child(entry,list);  return entry;    }play_tree_t*parse_playtree(stream_t *stream, int forced) {  play_tree_parser_t* p;  play_tree_t* ret;#ifdef MP_DEBUG  assert(stream != NULL);#endif  p = play_tree_parser_new(stream,0);  if(!p)    return NULL;  ret = play_tree_parser_get_play_tree(p, forced);  play_tree_parser_free(p);  return ret;}static voidplay_tree_add_basepath(play_tree_t* pt, char* bp) {  int i,bl = strlen(bp),fl;  if(pt->child) {    play_tree_t* i;    for(i = pt->child ; i != NULL ; i = i->next)      play_tree_add_basepath(i,bp);    return;  }  if(!pt->files)    return;  for(i = 0 ; pt->files[i] != NULL ; i++) {    fl = strlen(pt->files[i]);    // if we find a full unix path, url:// or X:\ at the beginning,    // don't mangle it.    if(fl <= 0 || strstr(pt->files[i],"://") || (strstr(pt->files[i],":\\") == pt->files[i] + 1) || (pt->files[i][0] == '/') )      continue;    // if the path begins with \ then prepend drive letter to it.    if (pt->files[i][0] == '\\') {      pt->files[i] = (char*)realloc(pt->files[i],2+fl+1);      memmove(pt->files[i] + 2,pt->files[i],fl+1);      memcpy(pt->files[i],bp,2);      return;    }    pt->files[i] = (char*)realloc(pt->files[i],bl+fl+1);    memmove(pt->files[i] + bl,pt->files[i],fl+1);    memcpy(pt->files[i],bp,bl);  }}// Wrapper for play_tree_add_basepath (add base path from file)void play_tree_add_bpf(play_tree_t* pt, char* filename){  char *ls, *file;    if (pt && filename)  {    file = strdup(filename);    if (file)    {      ls = strrchr(file,'/');      if(!ls) ls = strrchr(file,'\\');      if(ls) {        ls[1] = '\0';        play_tree_add_basepath(pt,file);      }      free(file);    }  }}play_tree_t*parse_playlist_file(char* file) {  stream_t *stream;  play_tree_t* ret;  int f=DEMUXER_TYPE_PLAYLIST;  stream = open_stream(file,0,&f);  if(!stream) {    mp_msg(MSGT_PLAYTREE,MSGL_ERR,"Error while opening playlist file %s: %s\n",file,strerror(errno));    return NULL;  }  mp_msg(MSGT_PLAYTREE,MSGL_V,"Parsing playlist file %s...\n",file);  ret = parse_playtree(stream,1);  free_stream(stream);  play_tree_add_bpf(ret, file);  return ret;}play_tree_parser_t*play_tree_parser_new(stream_t* stream,int deep) {  play_tree_parser_t* p;  p = (play_tree_parser_t*)calloc(1,sizeof(play_tree_parser_t));  if(!p)    return NULL;  p->stream = stream;  p->deep = deep;  p->keep = 1;  return p;}voidplay_tree_parser_free(play_tree_parser_t* p) {#ifdef MP_DEBUG  assert(p != NULL);#endif  if(p->buffer) free(p->buffer);  if(p->line) free(p->line);  free(p);}play_tree_t*play_tree_parser_get_play_tree(play_tree_parser_t* p, int forced) {  play_tree_t* tree = NULL;#ifdef MP_DEBUG  assert(p != NULL);#endif  while(play_tree_parser_get_line(p) != NULL) {    play_tree_parser_reset(p);    tree = parse_asx(p);    if(tree) break;    play_tree_parser_reset(p);    tree = parse_pls(p);    if(tree) break;    play_tree_parser_reset(p);    tree = parse_m3u(p);    if(tree) break;    play_tree_parser_reset(p);        tree = parse_ref_ini(p);    if(tree) break;    play_tree_parser_reset(p);    tree = parse_smil(p);    if(tree) break;    play_tree_parser_reset(p);         // Here come the others formats ( textplain must stay the last one )    if (forced)    {      tree = parse_textplain(p);      if(tree) break;    }    break;  }  if(tree)    mp_msg(MSGT_PLAYTREE,MSGL_V,"Playlist successfully parsed\n");  else     mp_msg(MSGT_PLAYTREE,((forced==1)?MSGL_ERR:MSGL_V),"Error while parsing playlist\n");  if(tree)    tree = play_tree_cleanup(tree);    if(!tree) mp_msg(MSGT_PLAYTREE,((forced==1)?MSGL_WARN:MSGL_V),"Warning: empty playlist\n");  return tree;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -