annotate img.c @ 922:7f20b3ce1100 libavformat

dynamically increase probe buffer until format is detected
author michael
date Thu, 02 Feb 2006 11:27:35 +0000
parents edbe5c3717f9
children 2d57ce58f576
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
1 /*
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
2 * Image format
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
3 * Copyright (c) 2000, 2001, 2002 Fabrice Bellard.
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
4 *
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
5 * This library is free software; you can redistribute it and/or
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
6 * modify it under the terms of the GNU Lesser General Public
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
7 * License as published by the Free Software Foundation; either
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
8 * version 2 of the License, or (at your option) any later version.
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
9 *
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
10 * This library is distributed in the hope that it will be useful,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
13 * Lesser General Public License for more details.
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
14 *
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
15 * You should have received a copy of the GNU Lesser General Public
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
16 * License along with this library; if not, write to the Free Software
896
edbe5c3717f9 Update licensing information: The FSF changed postal address.
diego
parents: 885
diff changeset
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
18 */
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
19 #include "avformat.h"
11
932b59c66c60 mingw patch by (Bill Eldridge <bill at rfa dot org>)
michaelni
parents: 10
diff changeset
20
199
66a05c4f8350 suppressed frame number modulus hack - added loop_input hack which I find easier to understand
bellard
parents: 189
diff changeset
21 /* XXX: this is a hack */
66a05c4f8350 suppressed frame number modulus hack - added loop_input hack which I find easier to understand
bellard
parents: 189
diff changeset
22 int loop_input = 0;
66a05c4f8350 suppressed frame number modulus hack - added loop_input hack which I find easier to understand
bellard
parents: 189
diff changeset
23
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
24 typedef struct {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
25 int width;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
26 int height;
199
66a05c4f8350 suppressed frame number modulus hack - added loop_input hack which I find easier to understand
bellard
parents: 189
diff changeset
27 int img_first;
66a05c4f8350 suppressed frame number modulus hack - added loop_input hack which I find easier to understand
bellard
parents: 189
diff changeset
28 int img_last;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
29 int img_number;
199
66a05c4f8350 suppressed frame number modulus hack - added loop_input hack which I find easier to understand
bellard
parents: 189
diff changeset
30 int img_count;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
31 int img_size;
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
32 AVImageFormat *img_fmt;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
33 int pix_fmt;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
34 int is_pipe;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
35 char path[1024];
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
36 /* temporary usage */
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
37 void *ptr;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
38 } VideoData;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
39
189
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
40
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
41 /* return -1 if no image found */
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 820
diff changeset
42 static int find_image_range(int *pfirst_index, int *plast_index,
189
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
43 const char *path)
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
44 {
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
45 char buf[1024];
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
46 int range, last_index, range1, first_index;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
47
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
48 /* find the first image */
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
49 for(first_index = 0; first_index < 5; first_index++) {
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
50 if (get_frame_filename(buf, sizeof(buf), path, first_index) < 0)
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
51 goto fail;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
52 if (url_exist(buf))
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
53 break;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
54 }
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
55 if (first_index == 5)
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
56 goto fail;
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 820
diff changeset
57
189
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
58 /* find the last image */
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
59 last_index = first_index;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
60 for(;;) {
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
61 range = 0;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
62 for(;;) {
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
63 if (!range)
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
64 range1 = 1;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
65 else
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
66 range1 = 2 * range;
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 820
diff changeset
67 if (get_frame_filename(buf, sizeof(buf), path,
189
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
68 last_index + range1) < 0)
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
69 goto fail;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
70 if (!url_exist(buf))
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
71 break;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
72 range = range1;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
73 /* just in case... */
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
74 if (range >= (1 << 30))
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
75 goto fail;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
76 }
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
77 /* we are sure than image last_index + range exists */
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
78 if (!range)
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
79 break;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
80 last_index += range;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
81 }
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
82 *pfirst_index = first_index;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
83 *plast_index = last_index;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
84 return 0;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
85 fail:
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
86 return -1;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
87 }
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
88
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
89
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
90 static int image_probe(AVProbeData *p)
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
91 {
21
3d2d2f8725f9 jpeg detection fix - fixed imagepipe output
bellard
parents: 20
diff changeset
92 if (filename_number_test(p->filename) >= 0 && guess_image_format(p->filename))
582
c5ff083848b4 prefer image2 over image
michael
parents: 482
diff changeset
93 return AVPROBE_SCORE_MAX-1;
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
94 else
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
95 return 0;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
96 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
97
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
98 static int read_header_alloc_cb(void *opaque, AVImageInfo *info)
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
99 {
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
100 VideoData *s = opaque;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
101
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
102 s->width = info->width;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
103 s->height = info->height;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
104 s->pix_fmt = info->pix_fmt;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
105 /* stop image reading but no error */
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
106 return 1;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
107 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
108
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
109 static int img_read_header(AVFormatContext *s1, AVFormatParameters *ap)
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
110 {
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
111 VideoData *s = s1->priv_data;
189
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
112 int ret, first_index, last_index;
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
113 char buf[1024];
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
114 ByteIOContext pb1, *f = &pb1;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
115 AVStream *st;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
116
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
117 st = av_new_stream(s1, 0);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
118 if (!st) {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
119 av_free(s);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
120 return -ENOMEM;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
121 }
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
122
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
123 if (ap && ap->image_format)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
124 s->img_fmt = ap->image_format;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
125
639
0b52743104ac integer overflows, heap corruption
michael
parents: 582
diff changeset
126 pstrcpy(s->path, sizeof(s->path), s1->filename);
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
127 s->img_number = 0;
199
66a05c4f8350 suppressed frame number modulus hack - added loop_input hack which I find easier to understand
bellard
parents: 189
diff changeset
128 s->img_count = 0;
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 820
diff changeset
129
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
130 /* find format */
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
131 if (s1->iformat->flags & AVFMT_NOFILE)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
132 s->is_pipe = 0;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
133 else
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
134 s->is_pipe = 1;
743
af4e24d6310c switch to native time bases
michael
parents: 639
diff changeset
135
af4e24d6310c switch to native time bases
michael
parents: 639
diff changeset
136 if (!ap || !ap->time_base.num) {
820
feca73904e67 changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents: 743
diff changeset
137 st->codec->time_base= (AVRational){1,25};
189
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
138 } else {
820
feca73904e67 changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents: 743
diff changeset
139 st->codec->time_base= ap->time_base;
189
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
140 }
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 820
diff changeset
141
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
142 if (!s->is_pipe) {
189
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
143 if (find_image_range(&first_index, &last_index, s->path) < 0)
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
144 goto fail;
199
66a05c4f8350 suppressed frame number modulus hack - added loop_input hack which I find easier to understand
bellard
parents: 189
diff changeset
145 s->img_first = first_index;
66a05c4f8350 suppressed frame number modulus hack - added loop_input hack which I find easier to understand
bellard
parents: 189
diff changeset
146 s->img_last = last_index;
189
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
147 s->img_number = first_index;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
148 /* compute duration */
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
149 st->start_time = 0;
743
af4e24d6310c switch to native time bases
michael
parents: 639
diff changeset
150 st->duration = last_index - first_index + 1;
189
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
151 if (get_frame_filename(buf, sizeof(buf), s->path, s->img_number) < 0)
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
152 goto fail;
e3cfb9131dfa update duration and start_time
bellard
parents: 88
diff changeset
153 if (url_fopen(f, buf, URL_RDONLY) < 0)
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
154 goto fail;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
155 } else {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
156 f = &s1->pb;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
157 }
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 820
diff changeset
158
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
159 ret = av_read_image(f, s1->filename, s->img_fmt, read_header_alloc_cb, s);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
160 if (ret < 0)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
161 goto fail1;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
162
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
163 if (!s->is_pipe) {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
164 url_fclose(f);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
165 } else {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
166 url_fseek(f, 0, SEEK_SET);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
167 }
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 820
diff changeset
168
820
feca73904e67 changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents: 743
diff changeset
169 st->codec->codec_type = CODEC_TYPE_VIDEO;
feca73904e67 changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents: 743
diff changeset
170 st->codec->codec_id = CODEC_ID_RAWVIDEO;
feca73904e67 changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents: 743
diff changeset
171 st->codec->width = s->width;
feca73904e67 changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents: 743
diff changeset
172 st->codec->height = s->height;
feca73904e67 changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents: 743
diff changeset
173 st->codec->pix_fmt = s->pix_fmt;
459
ce1a3e82328b segfault fix
michael
parents: 439
diff changeset
174 s->img_size = avpicture_get_size(s->pix_fmt, (s->width+15)&(~15), (s->height+15)&(~15));
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
175
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
176 return 0;
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
177 fail1:
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
178 if (!s->is_pipe)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
179 url_fclose(f);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
180 fail:
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
181 av_free(s);
482
0fdc96c2f2fe sweeping change from -EIO -> AVERROR_IO
melanson
parents: 468
diff changeset
182 return AVERROR_IO;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
183 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
184
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
185 static int read_packet_alloc_cb(void *opaque, AVImageInfo *info)
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
186 {
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
187 VideoData *s = opaque;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
188
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
189 if (info->width != s->width ||
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
190 info->height != s->height)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
191 return -1;
459
ce1a3e82328b segfault fix
michael
parents: 439
diff changeset
192 avpicture_fill(&info->pict, s->ptr, info->pix_fmt, (info->width+15)&(~15), (info->height+15)&(~15));
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
193 return 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
194 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
195
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
196 static int img_read_packet(AVFormatContext *s1, AVPacket *pkt)
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
197 {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
198 VideoData *s = s1->priv_data;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
199 char filename[1024];
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
200 int ret;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
201 ByteIOContext f1, *f;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
202
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
203 if (!s->is_pipe) {
199
66a05c4f8350 suppressed frame number modulus hack - added loop_input hack which I find easier to understand
bellard
parents: 189
diff changeset
204 /* loop over input */
66a05c4f8350 suppressed frame number modulus hack - added loop_input hack which I find easier to understand
bellard
parents: 189
diff changeset
205 if (loop_input && s->img_number > s->img_last) {
66a05c4f8350 suppressed frame number modulus hack - added loop_input hack which I find easier to understand
bellard
parents: 189
diff changeset
206 s->img_number = s->img_first;
66a05c4f8350 suppressed frame number modulus hack - added loop_input hack which I find easier to understand
bellard
parents: 189
diff changeset
207 }
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
208 if (get_frame_filename(filename, sizeof(filename),
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
209 s->path, s->img_number) < 0)
482
0fdc96c2f2fe sweeping change from -EIO -> AVERROR_IO
melanson
parents: 468
diff changeset
210 return AVERROR_IO;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
211 f = &f1;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
212 if (url_fopen(f, filename, URL_RDONLY) < 0)
482
0fdc96c2f2fe sweeping change from -EIO -> AVERROR_IO
melanson
parents: 468
diff changeset
213 return AVERROR_IO;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
214 } else {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
215 f = &s1->pb;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
216 if (url_feof(f))
482
0fdc96c2f2fe sweeping change from -EIO -> AVERROR_IO
melanson
parents: 468
diff changeset
217 return AVERROR_IO;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
218 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
219
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
220 av_new_packet(pkt, s->img_size);
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
221 pkt->stream_index = 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
222
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
223 s->ptr = pkt->data;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
224 ret = av_read_image(f, filename, s->img_fmt, read_packet_alloc_cb, s);
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
225 if (!s->is_pipe) {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
226 url_fclose(f);
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
227 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
228
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
229 if (ret < 0) {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
230 av_free_packet(pkt);
482
0fdc96c2f2fe sweeping change from -EIO -> AVERROR_IO
melanson
parents: 468
diff changeset
231 return AVERROR_IO; /* signal EOF */
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
232 } else {
199
66a05c4f8350 suppressed frame number modulus hack - added loop_input hack which I find easier to understand
bellard
parents: 189
diff changeset
233 /* XXX: computing this pts is not necessary as it is done in
66a05c4f8350 suppressed frame number modulus hack - added loop_input hack which I find easier to understand
bellard
parents: 189
diff changeset
234 the generic code too */
820
feca73904e67 changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents: 743
diff changeset
235 pkt->pts = av_rescale((int64_t)s->img_count * s1->streams[0]->codec->time_base.num, s1->streams[0]->time_base.den, s1->streams[0]->codec->time_base.den) / s1->streams[0]->time_base.num;
199
66a05c4f8350 suppressed frame number modulus hack - added loop_input hack which I find easier to understand
bellard
parents: 189
diff changeset
236 s->img_count++;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
237 s->img_number++;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
238 return 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
239 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
240 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
241
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
242 static int img_read_close(AVFormatContext *s1)
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
243 {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
244 return 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
245 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
246
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
247 /******************************************************/
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
248 /* image output */
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
249
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
250 static int img_set_parameters(AVFormatContext *s, AVFormatParameters *ap)
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
251 {
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
252 VideoData *img = s->priv_data;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
253 AVStream *st;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
254 AVImageFormat *img_fmt;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
255 int i;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
256
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
257 /* find output image format */
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
258 if (ap && ap->image_format) {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
259 img_fmt = ap->image_format;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
260 } else {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
261 img_fmt = guess_image_format(s->filename);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
262 }
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
263 if (!img_fmt)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
264 return -1;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
265
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
266 if (s->nb_streams != 1)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
267 return -1;
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 820
diff changeset
268
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
269 st = s->streams[0];
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
270 /* we select the first matching format */
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
271 for(i=0;i<PIX_FMT_NB;i++) {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
272 if (img_fmt->supported_pixel_formats & (1 << i))
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
273 break;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
274 }
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
275 if (i >= PIX_FMT_NB)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
276 return -1;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
277 img->img_fmt = img_fmt;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
278 img->pix_fmt = i;
820
feca73904e67 changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents: 743
diff changeset
279 st->codec->pix_fmt = img->pix_fmt;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
280 return 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
281 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
282
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
283 static int img_write_header(AVFormatContext *s)
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
284 {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
285 VideoData *img = s->priv_data;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
286
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
287 img->img_number = 1;
639
0b52743104ac integer overflows, heap corruption
michael
parents: 582
diff changeset
288 pstrcpy(img->path, sizeof(img->path), s->filename);
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
289
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
290 /* find format */
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
291 if (s->oformat->flags & AVFMT_NOFILE)
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
292 img->is_pipe = 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
293 else
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
294 img->is_pipe = 1;
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 820
diff changeset
295
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
296 return 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
297 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
298
468
60f897e8dd2d pass AVPacket into av_write_frame()
michael
parents: 462
diff changeset
299 static int img_write_packet(AVFormatContext *s, AVPacket *pkt)
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
300 {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
301 VideoData *img = s->priv_data;
468
60f897e8dd2d pass AVPacket into av_write_frame()
michael
parents: 462
diff changeset
302 AVStream *st = s->streams[pkt->stream_index];
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
303 ByteIOContext pb1, *pb;
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
304 AVPicture *picture;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
305 int width, height, ret;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
306 char filename[1024];
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
307 AVImageInfo info;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
308
820
feca73904e67 changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents: 743
diff changeset
309 width = st->codec->width;
feca73904e67 changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents: 743
diff changeset
310 height = st->codec->height;
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 820
diff changeset
311
468
60f897e8dd2d pass AVPacket into av_write_frame()
michael
parents: 462
diff changeset
312 picture = (AVPicture *)pkt->data;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
313
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
314 if (!img->is_pipe) {
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 820
diff changeset
315 if (get_frame_filename(filename, sizeof(filename),
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
316 img->path, img->img_number) < 0)
482
0fdc96c2f2fe sweeping change from -EIO -> AVERROR_IO
melanson
parents: 468
diff changeset
317 return AVERROR_IO;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
318 pb = &pb1;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
319 if (url_fopen(pb, filename, URL_WRONLY) < 0)
482
0fdc96c2f2fe sweeping change from -EIO -> AVERROR_IO
melanson
parents: 468
diff changeset
320 return AVERROR_IO;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
321 } else {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
322 pb = &s->pb;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
323 }
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
324 info.width = width;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
325 info.height = height;
820
feca73904e67 changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents: 743
diff changeset
326 info.pix_fmt = st->codec->pix_fmt;
280
75e061728d92 recommit of
michael
parents: 241
diff changeset
327 info.interleaved = 0; /* FIXME: there should be a way to set it right */
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
328 info.pict = *picture;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
329 ret = av_write_image(pb, img->img_fmt, &info);
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
330 if (!img->is_pipe) {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
331 url_fclose(pb);
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
332 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
333
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
334 img->img_number++;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
335 return 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
336 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
337
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
338 static int img_write_trailer(AVFormatContext *s)
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
339 {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
340 return 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
341 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
342
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
343 /* input */
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
344
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
345 static AVInputFormat image_iformat = {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
346 "image",
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
347 "image sequence",
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
348 sizeof(VideoData),
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
349 image_probe,
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
350 img_read_header,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
351 img_read_packet,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
352 img_read_close,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
353 NULL,
439
michael
parents: 280
diff changeset
354 NULL,
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
355 AVFMT_NOFILE | AVFMT_NEEDNUMBER,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
356 };
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
357
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
358 static AVInputFormat imagepipe_iformat = {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
359 "imagepipe",
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
360 "piped image sequence",
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
361 sizeof(VideoData),
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
362 NULL, /* no probe */
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
363 img_read_header,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
364 img_read_packet,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
365 img_read_close,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
366 NULL,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
367 };
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
368
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
369
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
370 /* output */
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
371
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
372 static AVOutputFormat image_oformat = {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
373 "image",
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
374 "image sequence",
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
375 "",
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
376 "",
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
377 sizeof(VideoData),
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
378 CODEC_ID_NONE,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
379 CODEC_ID_RAWVIDEO,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
380 img_write_header,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
381 img_write_packet,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
382 img_write_trailer,
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
383 AVFMT_NOFILE | AVFMT_NEEDNUMBER | AVFMT_RAWPICTURE,
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
384 img_set_parameters,
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
385 };
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
386
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
387 static AVOutputFormat imagepipe_oformat = {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
388 "imagepipe",
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
389 "piped image sequence",
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
390 "",
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
391 "",
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
392 sizeof(VideoData),
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
393 CODEC_ID_NONE,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
394 CODEC_ID_RAWVIDEO,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
395 img_write_header,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
396 img_write_packet,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
397 img_write_trailer,
21
3d2d2f8725f9 jpeg detection fix - fixed imagepipe output
bellard
parents: 20
diff changeset
398 AVFMT_RAWPICTURE,
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
399 img_set_parameters,
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
400 };
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
401
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
402 int img_init(void)
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
403 {
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
404 av_register_input_format(&image_iformat);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
405 av_register_output_format(&image_oformat);
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
406
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
407 av_register_input_format(&imagepipe_iformat);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
408 av_register_output_format(&imagepipe_oformat);
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 820
diff changeset
409
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
410 return 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
411 }