aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAnton Khirnov <anton@khirnov.net>2023-11-04 08:04:11 +0100
committerAnton Khirnov <anton@khirnov.net>2023-11-09 11:25:17 +0100
commitacf63d5350adeae551d412db699f8ca03f7e76b9 (patch)
tree3a4d5280fa0ea0ff773fc3cf241fd6075b196858
parent26ebd96371d8d32ea5c227e0b97af5bbd847332f (diff)
downloadffmpeg-acf63d5350adeae551d412db699f8ca03f7e76b9.tar.gz
lavu/log: do not assume AVClass.item_name is always set
-rw-r--r--libavutil/log.c9
1 files changed, 7 insertions, 2 deletions
diff --git a/libavutil/log.c b/libavutil/log.c
index 2d358b7ab9..46662f3db0 100644
--- a/libavutil/log.c
+++ b/libavutil/log.c
@@ -291,6 +291,11 @@ static const char *get_level_str(int level)
}
}
+static const char *item_name(void *obj, const AVClass *cls)
+{
+ return (cls->item_name ? cls->item_name : av_default_item_name)(obj);
+}
+
static void format_line(void *avcl, int level, const char *fmt, va_list vl,
AVBPrint part[4], int *print_prefix, int type[2])
{
@@ -307,12 +312,12 @@ static void format_line(void *avcl, int level, const char *fmt, va_list vl,
avc->parent_log_context_offset);
if (parent && *parent) {
av_bprintf(part+0, "[%s @ %p] ",
- (*parent)->item_name(parent), parent);
+ item_name(parent, *parent), parent);
if(type) type[0] = get_category(parent);
}
}
av_bprintf(part+1, "[%s @ %p] ",
- avc->item_name(avcl), avcl);
+ item_name(avcl, avc), avcl);
if(type) type[1] = get_category(avcl);
}