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

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

?? decoder.c

?? symbian下mp3文件的解碼源代碼
?? C
字號:
/* * libmad - MPEG audio decoder library * Copyright (C) 2000-2004 Underbit Technologies, Inc. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA * * $Id: decoder.c,v 1.22 2004/01/23 09:41:32 rob Exp $ */#include "mad.h"# ifdef HAVE_CONFIG_H#  include "config.h"# endif# include "global.h"# ifdef HAVE_SYS_TYPES_H#  include <sys/types.h># endif# ifdef HAVE_SYS_WAIT_H#  include <sys/wait.h># endif# ifdef HAVE_UNISTD_H#  include <unistd.h># endif# ifdef HAVE_FCNTL_H#  include <fcntl.h># endif# include <stdlib.h># ifdef HAVE_ERRNO_H#  include <errno.h># endif# include "stream.h"# include "frame.h"# include "synth.h"# include "decoder.h"/* * NAME:	decoder->init() * DESCRIPTION:	initialize a decoder object with callback routines */void mad_decoder_init(struct mad_decoder *decoder, void *data,		      enum mad_flow (*input_func)(void *,						  struct mad_stream *),		      enum mad_flow (*header_func)(void *,						   struct mad_header const *),		      enum mad_flow (*filter_func)(void *,						   struct mad_stream const *,						   struct mad_frame *),		      enum mad_flow (*output_func)(void *,						   struct mad_header const *,						   struct mad_pcm *),		      enum mad_flow (*error_func)(void *,						  struct mad_stream *,						  struct mad_frame *),		      enum mad_flow (*message_func)(void *,						    void *, unsigned int *)){  decoder->mode         = -1;  decoder->options      = 0;  decoder->async.pid    = 0;  decoder->async.in     = -1;  decoder->async.out    = -1;  decoder->sync         = 0;  decoder->cb_data      = data;  decoder->input_func   = input_func;  decoder->header_func  = header_func;  decoder->filter_func  = filter_func;  decoder->output_func  = output_func;  decoder->error_func   = error_func;  decoder->message_func = message_func;}int mad_decoder_finish(struct mad_decoder *decoder){# if defined(USE_ASYNC)  if (decoder->mode == MAD_DECODER_MODE_ASYNC && decoder->async.pid) {    pid_t pid;    int status;    close(decoder->async.in);    do      pid = waitpid(decoder->async.pid, &status, 0);    while (pid == -1 && errno == EINTR);    decoder->mode = -1;    close(decoder->async.out);    decoder->async.pid = 0;    decoder->async.in  = -1;    decoder->async.out = -1;    if (pid == -1)      return -1;    return (!WIFEXITED(status) || WEXITSTATUS(status)) ? -1 : 0;  }# endif  return 0;}# if defined(USE_ASYNC)staticenum mad_flow send_io(int fd, void const *data, size_t len){  char const *ptr = data;  ssize_t count;  while (len) {    do      count = write(fd, ptr, len);    while (count == -1 && errno == EINTR);    if (count == -1)      return MAD_FLOW_BREAK;    len -= count;    ptr += count;  }  return MAD_FLOW_CONTINUE;}staticenum mad_flow receive_io(int fd, void *buffer, size_t len){  char *ptr = buffer;  ssize_t count;  while (len) {    do      count = read(fd, ptr, len);    while (count == -1 && errno == EINTR);    if (count == -1)      return (errno == EAGAIN) ? MAD_FLOW_IGNORE : MAD_FLOW_BREAK;    else if (count == 0)      return MAD_FLOW_STOP;    len -= count;    ptr += count;  }  return MAD_FLOW_CONTINUE;}staticenum mad_flow receive_io_blocking(int fd, void *buffer, size_t len){  int flags, blocking;  enum mad_flow result;  flags = fcntl(fd, F_GETFL);  if (flags == -1)    return MAD_FLOW_BREAK;  blocking = flags & ~O_NONBLOCK;  if (blocking != flags &&      fcntl(fd, F_SETFL, blocking) == -1)    return MAD_FLOW_BREAK;  result = receive_io(fd, buffer, len);  if (flags != blocking &&      fcntl(fd, F_SETFL, flags) == -1)    return MAD_FLOW_BREAK;  return result;}staticenum mad_flow send(int fd, void const *message, unsigned int size){  enum mad_flow result;  /* send size */  result = send_io(fd, &size, sizeof(size));  /* send message */  if (result == MAD_FLOW_CONTINUE)    result = send_io(fd, message, size);  return result;}staticenum mad_flow receive(int fd, void **message, unsigned int *size){  enum mad_flow result;  unsigned int actual;  if (*message == 0)    *size = 0;  /* receive size */  result = receive_io(fd, &actual, sizeof(actual));  /* receive message */  if (result == MAD_FLOW_CONTINUE) {    if (actual > *size)      actual -= *size;    else {      *size  = actual;      actual = 0;    }    if (*size > 0) {      if (*message == 0) {	*message = malloc(*size);	if (*message == 0)	  return MAD_FLOW_BREAK;      }      result = receive_io_blocking(fd, *message, *size);    }    /* throw away remainder of message */    while (actual && result == MAD_FLOW_CONTINUE) {      char sink[256];      unsigned int len;      len = actual > sizeof(sink) ? sizeof(sink) : actual;      result = receive_io_blocking(fd, sink, len);      actual -= len;    }  }  return result;}staticenum mad_flow check_message(struct mad_decoder *decoder){  enum mad_flow result;  void *message = 0;  unsigned int size;  result = receive(decoder->async.in, &message, &size);  if (result == MAD_FLOW_CONTINUE) {    if (decoder->message_func == 0)      size = 0;    else {      result = decoder->message_func(decoder->cb_data, message, &size);      if (result == MAD_FLOW_IGNORE ||	  result == MAD_FLOW_BREAK)	size = 0;    }    if (send(decoder->async.out, message, size) != MAD_FLOW_CONTINUE)      result = MAD_FLOW_BREAK;  }  if (message)    free(message);  return result;}# endifstaticenum mad_flow error_default(void *data, struct mad_stream *stream,			    struct mad_frame *frame){  int *bad_last_frame = data;  switch (stream->error) {  case MAD_ERROR_BADCRC:    if (*bad_last_frame)      mad_frame_mute(frame);    else      *bad_last_frame = 1;    return MAD_FLOW_IGNORE;  default:    return MAD_FLOW_CONTINUE;  }}staticint run_sync(struct mad_decoder *decoder){  enum mad_flow (*error_func)(void *, struct mad_stream *, struct mad_frame *);  void *error_data;  int bad_last_frame = 0;  struct mad_stream *stream;  struct mad_frame *frame;  struct mad_synth *synth;  int result = 0;  if (decoder->input_func == 0)    return 0;  if (decoder->error_func) {    error_func = decoder->error_func;    error_data = decoder->cb_data;  }  else {    error_func = error_default;    error_data = &bad_last_frame;  }  stream = &decoder->sync->stream;  frame  = &decoder->sync->frame;  synth  = &decoder->sync->synth;  mad_stream_init(stream);  mad_frame_init(frame);  mad_synth_init(synth);  mad_stream_options(stream, decoder->options);  do {    switch (decoder->input_func(decoder->cb_data, stream)) {    case MAD_FLOW_STOP:      goto done;    case MAD_FLOW_BREAK:      goto fail;    case MAD_FLOW_IGNORE:      continue;    case MAD_FLOW_CONTINUE:      break;    }    while (1) {# if defined(USE_ASYNC)      if (decoder->mode == MAD_DECODER_MODE_ASYNC) {	switch (check_message(decoder)) {	case MAD_FLOW_IGNORE:	case MAD_FLOW_CONTINUE:	  break;	case MAD_FLOW_BREAK:	  goto fail;	case MAD_FLOW_STOP:	  goto done;	}      }# endif      if (decoder->header_func) {	if (mad_header_decode(&frame->header, stream) == -1) {	  if (!MAD_RECOVERABLE(stream->error))	    break;	  switch (error_func(error_data, stream, frame)) {	  case MAD_FLOW_STOP:	    goto done;	  case MAD_FLOW_BREAK:	    goto fail;	  case MAD_FLOW_IGNORE:	  case MAD_FLOW_CONTINUE:	  default:	    continue;	  }	}	switch (decoder->header_func(decoder->cb_data, &frame->header)) {	case MAD_FLOW_STOP:	  goto done;	case MAD_FLOW_BREAK:	  goto fail;	case MAD_FLOW_IGNORE:	  continue;	case MAD_FLOW_CONTINUE:	  break;	}      }      if (mad_frame_decode(frame, stream) == -1) {	if (!MAD_RECOVERABLE(stream->error))	  break;	switch (error_func(error_data, stream, frame)) {	case MAD_FLOW_STOP:	  goto done;	case MAD_FLOW_BREAK:	  goto fail;	case MAD_FLOW_IGNORE:	  break;	case MAD_FLOW_CONTINUE:	default:	  continue;	}      }      else	bad_last_frame = 0;      if (decoder->filter_func) {	switch (decoder->filter_func(decoder->cb_data, stream, frame)) {	case MAD_FLOW_STOP:	  goto done;	case MAD_FLOW_BREAK:	  goto fail;	case MAD_FLOW_IGNORE:	  continue;	case MAD_FLOW_CONTINUE:	  break;	}      }      mad_synth_frame(synth, frame);      if (decoder->output_func) {	switch (decoder->output_func(decoder->cb_data,				     &frame->header, &synth->pcm)) {	case MAD_FLOW_STOP:	  goto done;	case MAD_FLOW_BREAK:	  goto fail;	case MAD_FLOW_IGNORE:	case MAD_FLOW_CONTINUE:	  break;	}      }    }  }  while (stream->error == MAD_ERROR_BUFLEN); fail:  result = -1; done:  mad_synth_finish(synth);  mad_frame_finish(frame);  mad_stream_finish(stream);  return result;}# if defined(USE_ASYNC)staticint run_async(struct mad_decoder *decoder){  pid_t pid;  int ptoc[2], ctop[2], flags;  if (pipe(ptoc) == -1)    return -1;  if (pipe(ctop) == -1) {    close(ptoc[0]);    close(ptoc[1]);    return -1;  }  flags = fcntl(ptoc[0], F_GETFL);  if (flags == -1 ||      fcntl(ptoc[0], F_SETFL, flags | O_NONBLOCK) == -1) {    close(ctop[0]);    close(ctop[1]);    close(ptoc[0]);    close(ptoc[1]);    return -1;  }  pid = fork();  if (pid == -1) {    close(ctop[0]);    close(ctop[1]);    close(ptoc[0]);    close(ptoc[1]);    return -1;  }  decoder->async.pid = pid;  if (pid) {    /* parent */    close(ptoc[0]);    close(ctop[1]);    decoder->async.in  = ctop[0];    decoder->async.out = ptoc[1];    return 0;  }  /* child */  close(ptoc[1]);  close(ctop[0]);  decoder->async.in  = ptoc[0];  decoder->async.out = ctop[1];  _exit(run_sync(decoder));  /* not reached */  return -1;}# endif/* * NAME:	decoder->run() * DESCRIPTION:	run the decoder thread either synchronously or asynchronously */int mad_decoder_run(struct mad_decoder *decoder, enum mad_decoder_mode mode){  int result;  int (*run)(struct mad_decoder *) = 0;  switch (decoder->mode = mode) {  case MAD_DECODER_MODE_SYNC:    run = run_sync;    break;  case MAD_DECODER_MODE_ASYNC:# if defined(USE_ASYNC)    run = run_async;# endif    break;  }  if (run == 0)    return -1;  decoder->sync = malloc(sizeof(*decoder->sync));  if (decoder->sync == 0)    return -1;  result = run(decoder);  free(decoder->sync);  decoder->sync = 0;  return result;}/* * NAME:	decoder->message() * DESCRIPTION:	send a message to and receive a reply from the decoder process */int mad_decoder_message(struct mad_decoder *decoder,			void *message, unsigned int *len){# if defined(USE_ASYNC)  if (decoder->mode != MAD_DECODER_MODE_ASYNC ||      send(decoder->async.out, message, *len) != MAD_FLOW_CONTINUE ||      receive(decoder->async.in, &message, len) != MAD_FLOW_CONTINUE)    return -1;  return 0;# else  return -1;# endif}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
五月综合激情婷婷六月色窝| 91精品视频网| 国产一区二区久久| 老司机精品视频一区二区三区| 调教+趴+乳夹+国产+精品| 国产精品自在欧美一区| 福利视频网站一区二区三区| 成人av电影在线观看| 一本大道综合伊人精品热热| 欧美网站一区二区| 日韩一二三四区| 国产日韩三级在线| 亚洲激情成人在线| 蜜臀91精品一区二区三区| 国产一区二区精品久久91| 欧美日韩国产乱码电影| 日韩午夜av一区| 亚洲一区在线观看网站| 久久国产剧场电影| 欧美日韩国产精品成人| 亚洲综合久久久| 色先锋资源久久综合| 国产精品久久毛片a| 香蕉久久一区二区不卡无毒影院| 久久不见久久见免费视频1| 在线播放中文一区| 久久精品日产第一区二区三区高清版| 日韩美女视频19| 久久精品99久久久| 日韩一区二区三区av| 日韩av中文字幕一区二区| 成人精品视频.| 欧美一区二区三区免费在线看| 久久久国产精品麻豆| 天堂一区二区在线| 成人18视频日本| 日韩美女视频19| 在线看不卡av| 国产精品不卡在线| 99精品桃花视频在线观看| 日韩欧美亚洲国产另类| 一区二区久久久久久| 成人一级片在线观看| 国产精品成人在线观看| 91免费在线播放| 国产欧美日本一区视频| jizzjizzjizz欧美| 国产三级三级三级精品8ⅰ区| 国产精品一区二区不卡| 国产精品日韩成人| 国产一区91精品张津瑜| 中文一区一区三区高中清不卡| 午夜精品久久久久久不卡8050| 欧美精品tushy高清| 久久99精品久久久久久久久久久久| 色婷婷av一区二区三区gif| 亚洲激情综合网| 51精品久久久久久久蜜臀| 国产综合色在线视频区| 日韩一区二区三区电影在线观看 | 国产寡妇亲子伦一区二区| 欧美巨大另类极品videosbest| 久久电影网站中文字幕| 欧美国产精品劲爆| 欧美写真视频网站| 激情综合一区二区三区| 中文字幕制服丝袜一区二区三区| 欧美伊人久久久久久久久影院| 麻豆成人av在线| 国产精品久久久99| 欧美福利视频导航| 国v精品久久久网| 亚洲va欧美va人人爽午夜| 久久精子c满五个校花| 欧美在线免费观看视频| 国产一区二区看久久| 日韩中文字幕区一区有砖一区| 久久久久高清精品| 欧美日韩国产小视频| 粉嫩嫩av羞羞动漫久久久| 日韩在线a电影| 亚洲视频中文字幕| 久久久天堂av| 在线不卡免费av| 91精品1区2区| 日本不卡免费在线视频| 日韩女优毛片在线| 欧美色中文字幕| 99久久精品免费观看| 国内精品久久久久影院一蜜桃| 午夜久久久影院| 亚洲精品亚洲人成人网| 中文字幕二三区不卡| 欧美电视剧免费全集观看| 欧美日韩国产一区| 在线视频一区二区三| 99精品国产99久久久久久白柏| 激情亚洲综合在线| 日韩av电影免费观看高清完整版在线观看 | 成人免费视频播放| 美女网站视频久久| 日韩在线a电影| 天堂va蜜桃一区二区三区漫画版| 日韩伦理av电影| 国产精品亲子伦对白| 国产亚洲一区字幕| 国产亚洲一本大道中文在线| 日韩写真欧美这视频| 91精品视频网| 日韩免费福利电影在线观看| 91精品国模一区二区三区| 精品视频1区2区3区| 高清av一区二区| 成人高清视频在线观看| 成人av午夜影院| 91网站在线观看视频| 91日韩一区二区三区| 色狠狠综合天天综合综合| 欧美视频在线观看一区二区| 欧美日精品一区视频| 欧美男男青年gay1069videost| 欧美日韩第一区日日骚| 欧美三级一区二区| 日韩欧美成人一区二区| 久久午夜色播影院免费高清| 欧美午夜片在线观看| 欧美三级视频在线观看| 91精品国产综合久久久久久久| 91精品国产乱码| 久久综合九色综合久久久精品综合 | 欧美三级日本三级少妇99| 在线播放国产精品二区一二区四区| 欧美日韩一区不卡| 欧美大片国产精品| 国产三级精品视频| 亚洲免费观看高清完整版在线| 久久免费国产精品| 中文字幕在线一区二区三区| 一区二区三区四区亚洲| 日本不卡高清视频| 丁香啪啪综合成人亚洲小说 | 国产精品小仙女| 91在线精品秘密一区二区| 欧美色综合网站| 精品99999| 欧美成人一区二区三区在线观看| 欧美日韩黄色一区二区| 精品久久久久久久一区二区蜜臀| 中文字幕精品一区二区三区精品| 亚洲美女少妇撒尿| 日韩国产在线一| 丁香网亚洲国际| 91精品在线观看入口| 中文字幕日韩一区| 国产精品第四页| 日韩经典中文字幕一区| 不卡的电视剧免费网站有什么| 欧美喷水一区二区| 国产精品视频九色porn| 天天综合网天天综合色| 成人性生交大片免费看中文| 欧美老女人第四色| 国产精品久久久爽爽爽麻豆色哟哟 | 亚洲欧美日韩国产综合| 黄页网站大全一区二区| 在线影视一区二区三区| 国产欧美日韩在线| 日本欧美加勒比视频| 91美女片黄在线观看| 久久午夜色播影院免费高清| 性感美女极品91精品| 91免费看片在线观看| 国产欧美一区视频| 理论片日本一区| 欧美日韩精品一区视频| 日韩久久一区二区| 国产91色综合久久免费分享| 日韩一区二区在线免费观看| 亚洲一区影音先锋| 91色综合久久久久婷婷| 国产精品天美传媒| 国产精品一二三四五| 日韩一区二区三区在线| 香蕉久久一区二区不卡无毒影院| 91老司机福利 在线| 1024精品合集| av成人老司机| 国产精品国产精品国产专区不片| 国产一区美女在线| 欧美成人精品3d动漫h| 欧美96一区二区免费视频| 4438x亚洲最大成人网| 图片区小说区国产精品视频| 欧美色综合影院| 亚洲成人av资源| 91麻豆精品国产91久久久久久久久| 亚洲一卡二卡三卡四卡五卡| 欧美日韩午夜在线视频| 亚洲va韩国va欧美va| 欧美绝品在线观看成人午夜影视|