FFmpeg
libavformat
vorbiscomment.h
Go to the documentation of this file.
1
/*
2
* VorbisComment writer
3
* Copyright (c) 2009 James Darnley
4
*
5
* This file is part of FFmpeg.
6
*
7
* FFmpeg is free software; you can redistribute it and/or
8
* modify it under the terms of the GNU Lesser General Public
9
* License as published by the Free Software Foundation; either
10
* version 2.1 of the License, or (at your option) any later version.
11
*
12
* FFmpeg is distributed in the hope that it will be useful,
13
* but WITHOUT ANY WARRANTY; without even the implied warranty of
14
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15
* Lesser General Public License for more details.
16
*
17
* You should have received a copy of the GNU Lesser General Public
18
* License along with FFmpeg; if not, write to the Free Software
19
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20
*/
21
22
#ifndef AVFORMAT_VORBISCOMMENT_H
23
#define AVFORMAT_VORBISCOMMENT_H
24
25
#include "
avformat.h
"
26
#include "
metadata.h
"
27
28
/**
29
* Calculate the length in bytes of a VorbisComment. This is the minimum
30
* size required by ff_vorbiscomment_write().
31
*
32
* @param m The metadata structure to be parsed. For no metadata, set to NULL.
33
* @param vendor_string The vendor string to be added into the VorbisComment.
34
* For no string, set to an empty string.
35
* @return The length in bytes.
36
*/
37
int64_t
ff_vorbiscomment_length
(
AVDictionary
*m,
const
char
*vendor_string,
38
AVChapter
**chapters,
unsigned
int
nb_chapters);
39
40
/**
41
* Write a VorbisComment into a buffer. The buffer, p, must have enough
42
* data to hold the whole VorbisComment. The minimum size required can be
43
* obtained by passing the same AVDictionary and vendor_string to
44
* ff_vorbiscomment_length()
45
*
46
* @param p The buffer in which to write.
47
* @param m The metadata struct to write.
48
* @param vendor_string The vendor string to write.
49
* @param chapters The chapters to write.
50
* @param nb_chapters The number of chapters to write.
51
*/
52
int
ff_vorbiscomment_write
(
uint8_t
**p,
AVDictionary
**m,
53
const
char
*vendor_string,
54
AVChapter
**chapters,
unsigned
int
nb_chapters);
55
56
extern
const
AVMetadataConv
ff_vorbiscomment_metadata_conv
[];
57
58
#endif
/* AVFORMAT_VORBISCOMMENT_H */
AVMetadataConv
Definition:
metadata.h:34
ff_vorbiscomment_length
int64_t ff_vorbiscomment_length(AVDictionary *m, const char *vendor_string, AVChapter **chapters, unsigned int nb_chapters)
Calculate the length in bytes of a VorbisComment.
Definition:
vorbiscomment.c:41
AVDictionary
Definition:
dict.c:30
AVChapter
Definition:
avformat.h:1299
ff_vorbiscomment_write
int ff_vorbiscomment_write(uint8_t **p, AVDictionary **m, const char *vendor_string, AVChapter **chapters, unsigned int nb_chapters)
Write a VorbisComment into a buffer.
Definition:
vorbiscomment.c:65
ff_vorbiscomment_metadata_conv
const AVMetadataConv ff_vorbiscomment_metadata_conv[]
VorbisComment metadata conversion mapping.
Definition:
vorbiscomment.c:33
uint8_t
uint8_t
Definition:
audio_convert.c:194
metadata.h
avformat.h
Generated on Wed Aug 24 2022 21:27:26 for FFmpeg by
1.8.17