mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-24 13:56:33 +02:00
Merge commit '38c1466ca41c73c7ce347da702362cb69c151716'
* commit '38c1466ca41c73c7ce347da702362cb69c151716': dict: add av_dict_parse_string() doc: support multitable in texi2pod Conflicts: doc/APIchanges libavutil/version.h Merged-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
commit
e7e14bc69a
@ -138,6 +138,10 @@ API changes, most recent first:
|
|||||||
2012-03-26 - a67d9cf - lavfi 2.66.100
|
2012-03-26 - a67d9cf - lavfi 2.66.100
|
||||||
Add avfilter_fill_frame_from_{audio_,}buffer_ref() functions.
|
Add avfilter_fill_frame_from_{audio_,}buffer_ref() functions.
|
||||||
|
|
||||||
|
2013-xx-xx - xxxxxxx - lavu 52.7.0 - dict.h
|
||||||
|
Add av_dict_parse_string() to set multiple key/value pairs at once from a
|
||||||
|
string.
|
||||||
|
|
||||||
2013-01-xx - xxxxxxx - lavu 52.6.0 - avstring.h
|
2013-01-xx - xxxxxxx - lavu 52.6.0 - avstring.h
|
||||||
Add av_strnstr()
|
Add av_strnstr()
|
||||||
|
|
||||||
|
@ -169,7 +169,7 @@ INF: while(<$inf>) {
|
|||||||
} elsif ($ended =~ /^(?:example|smallexample|display)$/) {
|
} elsif ($ended =~ /^(?:example|smallexample|display)$/) {
|
||||||
$shift = "";
|
$shift = "";
|
||||||
$_ = ""; # need a paragraph break
|
$_ = ""; # need a paragraph break
|
||||||
} elsif ($ended =~ /^(?:itemize|enumerate|[fv]?table)$/) {
|
} elsif ($ended =~ /^(?:itemize|enumerate|(?:multi|[fv])?table)$/) {
|
||||||
$_ = "\n=back\n";
|
$_ = "\n=back\n";
|
||||||
$ic = pop @icstack;
|
$ic = pop @icstack;
|
||||||
} else {
|
} else {
|
||||||
@ -269,7 +269,7 @@ INF: while(<$inf>) {
|
|||||||
$endw = "enumerate";
|
$endw = "enumerate";
|
||||||
};
|
};
|
||||||
|
|
||||||
/^\@([fv]?table)\s+(\@[a-z]+)/ and do {
|
/^\@((?:multi|[fv])?table)\s+(\@[a-z]+)/ and do {
|
||||||
push @endwstack, $endw;
|
push @endwstack, $endw;
|
||||||
push @icstack, $ic;
|
push @icstack, $ic;
|
||||||
$endw = $1;
|
$endw = $1;
|
||||||
@ -278,6 +278,7 @@ INF: while(<$inf>) {
|
|||||||
$ic =~ s/\@(?:code|kbd)/C/;
|
$ic =~ s/\@(?:code|kbd)/C/;
|
||||||
$ic =~ s/\@(?:dfn|var|emph|cite|i)/I/;
|
$ic =~ s/\@(?:dfn|var|emph|cite|i)/I/;
|
||||||
$ic =~ s/\@(?:file)/F/;
|
$ic =~ s/\@(?:file)/F/;
|
||||||
|
$ic =~ s/\@(?:columnfractions)//;
|
||||||
$_ = "\n=over 4\n";
|
$_ = "\n=over 4\n";
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -288,6 +289,21 @@ INF: while(<$inf>) {
|
|||||||
$_ = ""; # need a paragraph break
|
$_ = ""; # need a paragraph break
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/^\@item\s+(.*\S)\s*$/ and $endw eq "multitable" and do {
|
||||||
|
my $columns = $1;
|
||||||
|
$columns =~ s/\@tab/ : /;
|
||||||
|
|
||||||
|
$_ = "\n=item B<". $columns .">\n";
|
||||||
|
};
|
||||||
|
|
||||||
|
/^\@tab\s+(.*\S)\s*$/ and $endw eq "multitable" and do {
|
||||||
|
my $columns = $1;
|
||||||
|
$columns =~ s/\@tab/ : /;
|
||||||
|
|
||||||
|
$_ = " : ". $columns;
|
||||||
|
$section =~ s/\n+\s+$//;
|
||||||
|
};
|
||||||
|
|
||||||
/^\@itemx?\s*(.+)?$/ and do {
|
/^\@itemx?\s*(.+)?$/ and do {
|
||||||
if (defined $1) {
|
if (defined $1) {
|
||||||
# Entity escapes prevent munging by the <> processing below.
|
# Entity escapes prevent munging by the <> processing below.
|
||||||
|
@ -110,6 +110,53 @@ int av_dict_set(AVDictionary **pm, const char *key, const char *value, int flags
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int parse_key_value_pair(AVDictionary **pm, const char **buf,
|
||||||
|
const char *key_val_sep, const char *pairs_sep,
|
||||||
|
int flags)
|
||||||
|
{
|
||||||
|
char *key = av_get_token(buf, key_val_sep);
|
||||||
|
char *val = NULL;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
if (key && *key && strspn(*buf, key_val_sep)) {
|
||||||
|
(*buf)++;
|
||||||
|
val = av_get_token(buf, pairs_sep);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (key && *key && val && *val)
|
||||||
|
ret = av_dict_set(pm, key, val, flags);
|
||||||
|
else
|
||||||
|
ret = AVERROR(EINVAL);
|
||||||
|
|
||||||
|
av_freep(&key);
|
||||||
|
av_freep(&val);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
int av_dict_parse_string(AVDictionary **pm, const char *str,
|
||||||
|
const char *key_val_sep, const char *pairs_sep,
|
||||||
|
int flags)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
if (!str)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
/* ignore STRDUP flags */
|
||||||
|
flags &= ~(AV_DICT_DONT_STRDUP_KEY | AV_DICT_DONT_STRDUP_VAL);
|
||||||
|
|
||||||
|
while (*str) {
|
||||||
|
if ((ret = parse_key_value_pair(pm, &str, key_val_sep, pairs_sep, flags)) < 0)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
if (*str)
|
||||||
|
str++;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
void av_dict_free(AVDictionary **pm)
|
void av_dict_free(AVDictionary **pm)
|
||||||
{
|
{
|
||||||
AVDictionary *m = *pm;
|
AVDictionary *m = *pm;
|
||||||
|
@ -112,6 +112,23 @@ int av_dict_count(const AVDictionary *m);
|
|||||||
*/
|
*/
|
||||||
int av_dict_set(AVDictionary **pm, const char *key, const char *value, int flags);
|
int av_dict_set(AVDictionary **pm, const char *key, const char *value, int flags);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parse the key/value pairs list and add to a dictionary.
|
||||||
|
*
|
||||||
|
* @param key_val_sep a 0-terminated list of characters used to separate
|
||||||
|
* key from value
|
||||||
|
* @param pairs_sep a 0-terminated list of characters used to separate
|
||||||
|
* two pairs from each other
|
||||||
|
* @param flags flags to use when adding to dictionary.
|
||||||
|
* AV_DICT_DONT_STRDUP_KEY and AV_DICT_DONT_STRDUP_VAL
|
||||||
|
* are ignored since the key/value tokens will always
|
||||||
|
* be duplicated.
|
||||||
|
* @return 0 on success, negative AVERROR code on failure
|
||||||
|
*/
|
||||||
|
int av_dict_parse_string(AVDictionary **pm, const char *str,
|
||||||
|
const char *key_val_sep, const char *pairs_sep,
|
||||||
|
int flags);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Copy entries from one AVDictionary struct into another.
|
* Copy entries from one AVDictionary struct into another.
|
||||||
* @param dst pointer to a pointer to a AVDictionary struct. If *dst is NULL,
|
* @param dst pointer to a pointer to a AVDictionary struct. If *dst is NULL,
|
||||||
|
@ -75,7 +75,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#define LIBAVUTIL_VERSION_MAJOR 52
|
#define LIBAVUTIL_VERSION_MAJOR 52
|
||||||
#define LIBAVUTIL_VERSION_MINOR 16
|
#define LIBAVUTIL_VERSION_MINOR 17
|
||||||
#define LIBAVUTIL_VERSION_MICRO 100
|
#define LIBAVUTIL_VERSION_MICRO 100
|
||||||
|
|
||||||
#define LIBAVUTIL_VERSION_INT AV_VERSION_INT(LIBAVUTIL_VERSION_MAJOR, \
|
#define LIBAVUTIL_VERSION_INT AV_VERSION_INT(LIBAVUTIL_VERSION_MAJOR, \
|
||||||
|
Loading…
x
Reference in New Issue
Block a user