aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat/movenc.c
diff options
context:
space:
mode:
authorBaptiste Coudurier <baptiste.coudurier@gmail.com>2008-06-11 09:06:27 +0000
committerBaptiste Coudurier <baptiste.coudurier@gmail.com>2008-06-11 09:06:27 +0000
commitd32d6defeed5675183190c9aa6ae8e3fdddeffe6 (patch)
treea8d87b33bb408ebb4c3b2e63c00f2e2ee8c23eea /libavformat/movenc.c
parent20e22af85a57e76878d11381ee0cfff14e95f59a (diff)
downloadffmpeg-d32d6defeed5675183190c9aa6ae8e3fdddeffe6.tar.gz
simplify
Originally committed as revision 13743 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat/movenc.c')
-rw-r--r--libavformat/movenc.c32
1 files changed, 11 insertions, 21 deletions
diff --git a/libavformat/movenc.c b/libavformat/movenc.c
index fce27fc975..25f67848a5 100644
--- a/libavformat/movenc.c
+++ b/libavformat/movenc.c
@@ -1254,26 +1254,23 @@ static uint16_t language_code(const char *str)
return (((str[0]-0x60) & 0x1F) << 10) + (((str[1]-0x60) & 0x1F) << 5) + ((str[2]-0x60) & 0x1F);
}
-static int mov_write_psp_udta_tag(ByteIOContext *pb,
+static void mov_write_psp_udta_tag(ByteIOContext *pb,
const char *str, const char *lang, int type)
{
int len = utf8len(str)+1;
if(len<=0)
- return 0;
+ return;
put_be16(pb, len*2+10); /* size */
put_be32(pb, type); /* type */
put_be16(pb, language_code(lang)); /* language */
put_be16(pb, 0x01); /* ? */
ascii_to_wc(pb, str);
- return len*2+10;
}
static int mov_write_uuidusmt_tag(ByteIOContext *pb, AVFormatContext *s)
{
- size_t size;
- offset_t pos, curpos;
+ offset_t pos, pos2;
- size = 0;
if (s->title[0]) {
pos = url_ftell(pb);
put_be32(pb, 0); /* size placeholder*/
@@ -1282,12 +1279,11 @@ static int mov_write_uuidusmt_tag(ByteIOContext *pb, AVFormatContext *s)
put_be32(pb, 0x21d24fce); /* 96 bit UUID */
put_be32(pb, 0xbb88695c);
put_be32(pb, 0xfac9c740);
- size += 24;
+ pos2 = url_ftell(pb);
put_be32(pb, 0); /* size placeholder*/
put_tag(pb, "MTDT");
put_be16(pb, 4);
- size += 10;
// ?
put_be16(pb, 0x0C); /* size */
@@ -1295,23 +1291,17 @@ static int mov_write_uuidusmt_tag(ByteIOContext *pb, AVFormatContext *s)
put_be16(pb, language_code("und")); /* language */
put_be16(pb, 0x0); /* ? */
put_be16(pb, 0x021C); /* data */
- size += 12;
- size += mov_write_psp_udta_tag(pb, LIBAVCODEC_IDENT, "eng", 0x04);
- size += mov_write_psp_udta_tag(pb, s->title, "eng", 0x01);
+ mov_write_psp_udta_tag(pb, LIBAVCODEC_IDENT, "eng", 0x04);
+ mov_write_psp_udta_tag(pb, s->title, "eng", 0x01);
// snprintf(dt,32,"%04d/%02d/%02d %02d:%02d:%02d",t_st->tm_year+1900,t_st->tm_mon+1,t_st->tm_mday,t_st->tm_hour,t_st->tm_min,t_st->tm_sec);
- size += mov_write_psp_udta_tag(pb, "2006/04/01 11:11:11", "und", 0x03);
-
- // size
- curpos = url_ftell(pb);
- url_fseek(pb, pos, SEEK_SET);
- put_be32(pb, size);
- url_fseek(pb, pos+24, SEEK_SET);
- put_be32(pb, size-24);
- url_fseek(pb, curpos, SEEK_SET);
+ mov_write_psp_udta_tag(pb, "2006/04/01 11:11:11", "und", 0x03);
+
+ updateSize(pb, pos2);
+ return updateSize(pb, pos);
}
- return size;
+ return 0;
}
static int mov_write_moov_tag(ByteIOContext *pb, MOVContext *mov,