diff options
author | wm4 <wm4@nowhere> | 2013-07-14 17:55:54 +0200 |
---|---|---|
committer | wm4 <wm4@nowhere> | 2013-07-14 17:55:54 +0200 |
commit | 5ead20bdb3328d199dad693039d18e7a05eb2465 (patch) | |
tree | ee32576349dcddfa139b5bef2c0872107d42c8ba /demux | |
parent | 5ad42d0caf040bc8bff2a9bed39a6f2624728821 (diff) |
demux_raw: uncrustify
Should have been done before doing all the changes...
Diffstat (limited to 'demux')
-rw-r--r-- | demux/demux_raw.c | 322 |
1 files changed, 162 insertions, 160 deletions
diff --git a/demux/demux_raw.c b/demux/demux_raw.c index 54d237e11c..4b3e8844a4 100644 --- a/demux/demux_raw.c +++ b/demux/demux_raw.c @@ -43,10 +43,10 @@ static int samplerate = 44100; static int aformat = AF_FORMAT_S16_NE; const m_option_t demux_rawaudio_opts[] = { - { "channels", &channels, &m_option_type_chmap, CONF_MIN, 1 }, - { "rate", &samplerate, CONF_TYPE_INT,CONF_RANGE,1000,8*48000, NULL }, - { "format", &aformat, CONF_TYPE_AFMT, 0, 0, 0, NULL }, - {NULL, NULL, 0, 0, 0, 0, NULL} + { "channels", &channels, &m_option_type_chmap, CONF_MIN, 1 }, + { "rate", &samplerate, CONF_TYPE_INT, CONF_RANGE, 1000, 8 * 48000, NULL }, + { "format", &aformat, CONF_TYPE_AFMT, 0, 0, 0, NULL }, + {NULL, NULL, 0, 0, 0, 0, NULL} }; static int vformat = MP_FOURCC_I420; @@ -55,181 +55,183 @@ static char *codec; static int width = 0; static int height = 0; static float fps = 25; -static int imgsize=0; +static int imgsize = 0; const m_option_t demux_rawvideo_opts[] = { - // size: - { "w", &width, CONF_TYPE_INT,CONF_RANGE,1,8192, NULL }, - { "h", &height, CONF_TYPE_INT,CONF_RANGE,1,8192, NULL }, - // format: - { "format", &vformat, CONF_TYPE_FOURCC, 0, 0 , 0, NULL }, - { "mp-format", &mp_format, CONF_TYPE_IMGFMT, 0, 0 , 0, NULL }, - { "codec", &codec, CONF_TYPE_STRING, 0, 0 , 0, NULL }, - // misc: - { "fps", &fps, CONF_TYPE_FLOAT,CONF_RANGE,0.001,1000, NULL }, - { "size", &imgsize, CONF_TYPE_INT, CONF_RANGE, 1 , 8192*8192*4, NULL }, - - {NULL, NULL, 0, 0, 0, 0, NULL} + // size: + { "w", &width, CONF_TYPE_INT, CONF_RANGE, 1, 8192, NULL }, + { "h", &height, CONF_TYPE_INT, CONF_RANGE, 1, 8192, NULL }, + // format: + { "format", &vformat, CONF_TYPE_FOURCC, 0, 0, 0, NULL }, + { "mp-format", &mp_format, CONF_TYPE_IMGFMT, 0, 0, 0, NULL }, + { "codec", &codec, CONF_TYPE_STRING, 0, 0, 0, NULL }, + // misc: + { "fps", &fps, CONF_TYPE_FLOAT, CONF_RANGE, 0.001, 1000, NULL }, + { "size", &imgsize, CONF_TYPE_INT, CONF_RANGE, 1, 8192 * 8192 * 4, NULL }, + + {NULL, NULL, 0, 0, 0, 0, NULL} }; -static int demux_rawaudio_open(demuxer_t* demuxer, enum demux_check check) +static int demux_rawaudio_open(demuxer_t *demuxer, enum demux_check check) { - struct sh_stream *sh; - sh_audio_t* sh_audio; - WAVEFORMATEX* w; - - if (check != DEMUX_CHECK_REQUEST && check != DEMUX_CHECK_FORCE) - return -1; - - if ((aformat & AF_FORMAT_SPECIAL_MASK) != 0) - return -1; - - sh = new_sh_stream(demuxer, STREAM_AUDIO); - sh_audio = sh->audio; - sh_audio->gsh->codec = "mp-pcm"; - sh_audio->format = aformat; - sh_audio->wf = w = malloc(sizeof(*w)); - w->wFormatTag = 0; - sh_audio->channels = channels; - w->nChannels = sh_audio->channels.num; - w->nSamplesPerSec = sh_audio->samplerate = samplerate; - int samplesize = (af_fmt2bits(aformat) + 7) / 8; - w->nAvgBytesPerSec = samplerate * samplesize * w->nChannels; - w->nBlockAlign = w->nChannels * samplesize; - w->wBitsPerSample = 8 * samplesize; - w->cbSize = 0; - - demuxer->movi_start = demuxer->stream->start_pos; - demuxer->movi_end = demuxer->stream->end_pos; - - struct priv *p = talloc_ptrtype(demuxer, p); - demuxer->priv = p; - *p = (struct priv) { - .frame_size = samplesize * sh_audio->channels.num, - .frame_rate = samplerate, - }; - - return 0; + struct sh_stream *sh; + sh_audio_t *sh_audio; + WAVEFORMATEX *w; + + if (check != DEMUX_CHECK_REQUEST && check != DEMUX_CHECK_FORCE) + return -1; + + if ((aformat & AF_FORMAT_SPECIAL_MASK) != 0) + return -1; + + sh = new_sh_stream(demuxer, STREAM_AUDIO); + sh_audio = sh->audio; + sh_audio->gsh->codec = "mp-pcm"; + sh_audio->format = aformat; + sh_audio->wf = w = malloc(sizeof(*w)); + w->wFormatTag = 0; + sh_audio->channels = channels; + w->nChannels = sh_audio->channels.num; + w->nSamplesPerSec = sh_audio->samplerate = samplerate; + int samplesize = (af_fmt2bits(aformat) + 7) / 8; + w->nAvgBytesPerSec = samplerate * samplesize * w->nChannels; + w->nBlockAlign = w->nChannels * samplesize; + w->wBitsPerSample = 8 * samplesize; + w->cbSize = 0; + + demuxer->movi_start = demuxer->stream->start_pos; + demuxer->movi_end = demuxer->stream->end_pos; + + struct priv *p = talloc_ptrtype(demuxer, p); + demuxer->priv = p; + *p = (struct priv) { + .frame_size = samplesize * sh_audio->channels.num, + .frame_rate = samplerate, + }; + + return 0; } -static int demux_rawvideo_open(demuxer_t* demuxer, enum demux_check check) +static int demux_rawvideo_open(demuxer_t *demuxer, enum demux_check check) { - struct sh_stream *sh; - sh_video_t* sh_video; - - if (check != DEMUX_CHECK_REQUEST && check != DEMUX_CHECK_FORCE) - return -1; - - if(!width || !height){ - mp_msg(MSGT_DEMUX,MSGL_ERR,"rawvideo: width or height not specified!\n"); - return -1; - } - - const char *decoder = "rawvideo"; - int imgfmt = vformat; - if (mp_format) { - decoder = "mp-rawvideo"; - imgfmt = mp_format; - if (!imgsize) { - struct mp_imgfmt_desc desc = mp_imgfmt_get_desc(mp_format); - for (int p = 0; p < desc.num_planes; p++) { - imgsize += ((width >> desc.xs[p]) * (height >> desc.ys[p]) * - desc.bpp[p] + 7) / 8; - } - } - } else if (codec && codec[0]) { - decoder = talloc_strdup(demuxer, codec); - } - - if (!imgsize) { - int bpp = 0; - switch(vformat){ - case MP_FOURCC_I420: case MP_FOURCC_IYUV: - case MP_FOURCC_NV12: case MP_FOURCC_NV21: - case MP_FOURCC_HM12: - case MP_FOURCC_YV12: - bpp = 12; - break; - case MP_FOURCC_RGB12: case MP_FOURCC_BGR12: - case MP_FOURCC_RGB15: case MP_FOURCC_BGR15: - case MP_FOURCC_RGB16: case MP_FOURCC_BGR16: - case MP_FOURCC_YUY2: case MP_FOURCC_UYVY: - bpp = 16; - break; - case MP_FOURCC_RGB8: case MP_FOURCC_BGR8: - case MP_FOURCC_Y800: case MP_FOURCC_Y8: - bpp = 8; - break; - case MP_FOURCC_RGB24: case MP_FOURCC_BGR24: - bpp = 24; - break; - case MP_FOURCC_RGB32: case MP_FOURCC_BGR32: - bpp = 32; - break; + struct sh_stream *sh; + sh_video_t *sh_video; + + if (check != DEMUX_CHECK_REQUEST && check != DEMUX_CHECK_FORCE) + return -1; + + if (!width || !height) { + mp_msg(MSGT_DEMUX, MSGL_ERR, "rawvideo: width or height not specified!\n"); + return -1; } - if (!bpp) { - mp_msg(MSGT_DEMUX,MSGL_ERR,"rawvideo: img size not specified and unknown format!\n"); - return -1; + + const char *decoder = "rawvideo"; + int imgfmt = vformat; + if (mp_format) { + decoder = "mp-rawvideo"; + imgfmt = mp_format; + if (!imgsize) { + struct mp_imgfmt_desc desc = mp_imgfmt_get_desc(mp_format); + for (int p = 0; p < desc.num_planes; p++) { + imgsize += ((width >> desc.xs[p]) * (height >> desc.ys[p]) * + desc.bpp[p] + 7) / 8; + } + } + } else if (codec && codec[0]) + decoder = talloc_strdup(demuxer, codec); + + if (!imgsize) { + int bpp = 0; + switch (vformat) { + case MP_FOURCC_I420: case MP_FOURCC_IYUV: + case MP_FOURCC_NV12: case MP_FOURCC_NV21: + case MP_FOURCC_HM12: + case MP_FOURCC_YV12: + bpp = 12; + break; + case MP_FOURCC_RGB12: case MP_FOURCC_BGR12: + case MP_FOURCC_RGB15: case MP_FOURCC_BGR15: + case MP_FOURCC_RGB16: case MP_FOURCC_BGR16: + case MP_FOURCC_YUY2: case MP_FOURCC_UYVY: + bpp = 16; + break; + case MP_FOURCC_RGB8: case MP_FOURCC_BGR8: + case MP_FOURCC_Y800: case MP_FOURCC_Y8: + bpp = 8; + break; + case MP_FOURCC_RGB24: case MP_FOURCC_BGR24: + bpp = 24; + break; + case MP_FOURCC_RGB32: case MP_FOURCC_BGR32: + bpp = 32; + break; + } + if (!bpp) { + mp_msg(MSGT_DEMUX, MSGL_ERR, + "rawvideo: img size not specified and unknown format!\n"); + return -1; + } + imgsize = width * height * bpp / 8; } - imgsize = width * height * bpp / 8; - } - - sh = new_sh_stream(demuxer, STREAM_VIDEO); - sh_video = sh->video; - sh_video->gsh->codec=decoder; - sh_video->format=imgfmt; - sh_video->fps=fps; - sh_video->disp_w=width; - sh_video->disp_h=height; - sh_video->i_bps=fps*imgsize; - - demuxer->movi_start = demuxer->stream->start_pos; - demuxer->movi_end = demuxer->stream->end_pos; - - struct priv *p = talloc_ptrtype(demuxer, p); - demuxer->priv = p; - *p = (struct priv) { - .frame_size = imgsize, - .frame_rate = fps, - }; - - return 0; + + sh = new_sh_stream(demuxer, STREAM_VIDEO); + sh_video = sh->video; + sh_video->gsh->codec = decoder; + sh_video->format = imgfmt; + sh_video->fps = fps; + sh_video->disp_w = width; + sh_video->disp_h = height; + sh_video->i_bps = fps * imgsize; + + demuxer->movi_start = demuxer->stream->start_pos; + demuxer->movi_end = demuxer->stream->end_pos; + + struct priv *p = talloc_ptrtype(demuxer, p); + demuxer->priv = p; + *p = (struct priv) { + .frame_size = imgsize, + .frame_rate = fps, + }; + + return 0; } -static int raw_fill_buffer(demuxer_t* demuxer) +static int raw_fill_buffer(demuxer_t *demuxer) { - struct priv *p = demuxer->priv; + struct priv *p = demuxer->priv; - if (demuxer->stream->eof) - return 0; + if (demuxer->stream->eof) + return 0; - struct demux_packet *dp = new_demux_packet(p->frame_size); - dp->pos = stream_tell(demuxer->stream) - demuxer->movi_start; - dp->pts = (dp->pos / p->frame_size) / p->frame_rate; + struct demux_packet *dp = new_demux_packet(p->frame_size); + dp->pos = stream_tell(demuxer->stream) - demuxer->movi_start; + dp->pts = (dp->pos / p->frame_size) / p->frame_rate; - int len = stream_read(demuxer->stream, dp->buffer, dp->len); - resize_demux_packet(dp, len); - demuxer_add_packet(demuxer, demuxer->streams[0], dp); + int len = stream_read(demuxer->stream, dp->buffer, dp->len); + resize_demux_packet(dp, len); + demuxer_add_packet(demuxer, demuxer->streams[0], dp); - return 1; + return 1; } -static void raw_seek(demuxer_t *demuxer,float rel_seek_secs,float audio_delay,int flags){ - struct priv *p = demuxer->priv; - stream_t* s = demuxer->stream; - stream_update_size(s); - int64_t start = s->start_pos; - int64_t end = s->end_pos; - int64_t pos = (flags & SEEK_ABSOLUTE) ? start : stream_tell(s); - if (flags & SEEK_FACTOR) - pos += (end - start) * rel_seek_secs; - else - pos += rel_seek_secs * p->frame_rate * p->frame_size; - if(pos < 0) - pos = 0; - if (end && pos > end) - pos = end; - stream_seek(s, (pos / p->frame_size) * p->frame_size); +static void raw_seek(demuxer_t *demuxer, float rel_seek_secs, float audio_delay, + int flags) +{ + struct priv *p = demuxer->priv; + stream_t *s = demuxer->stream; + stream_update_size(s); + int64_t start = s->start_pos; + int64_t end = s->end_pos; + int64_t pos = (flags & SEEK_ABSOLUTE) ? start : stream_tell(s); + if (flags & SEEK_FACTOR) + pos += (end - start) * rel_seek_secs; + else + pos += rel_seek_secs * p->frame_rate * p->frame_size; + if (pos < 0) + pos = 0; + if (end && pos > end) + pos = end; + stream_seek(s, (pos / p->frame_size) * p->frame_size); } static int raw_control(demuxer_t *demuxer, int cmd, void *arg) |