diff mbox

[FFmpeg-devel,v3,4/5] avcodec/bsf: Add custom item name func for BSF list

Message ID 1471257516-15442-2-git-send-email-sebechlebskyjan@gmail.com
State Accepted
Commit 57503fab4f18ff5550ad774cb96c434fea5e59ed
Headers show

Commit Message

sebechlebskyjan@gmail.com Aug. 15, 2016, 10:38 a.m. UTC
From: Jan Sebechlebsky <sebechlebskyjan@gmail.com>

Add custom item name function for bsf list, which will
construct string description of filter chain. This is
done using lazy-initialization, so there is no overhead
if item name is never accessed.

Signed-off-by: Jan Sebechlebsky <sebechlebskyjan@gmail.com>

Conflicts:
	libavcodec/bsf.c
---
 Changes since the last version of the patch:
 - added av_freep(&bsf->item_name) from previous commit to bsf_list_close

 libavcodec/bsf.c | 29 ++++++++++++++++++++++++++++-
 1 file changed, 28 insertions(+), 1 deletion(-)

Comments

Michael Niedermayer Aug. 21, 2016, 9:56 a.m. UTC | #1
On Mon, Aug 15, 2016 at 12:38:36PM +0200, sebechlebskyjan@gmail.com wrote:
> From: Jan Sebechlebsky <sebechlebskyjan@gmail.com>
> 
> Add custom item name function for bsf list, which will
> construct string description of filter chain. This is
> done using lazy-initialization, so there is no overhead
> if item name is never accessed.
> 
> Signed-off-by: Jan Sebechlebsky <sebechlebskyjan@gmail.com>
> 
> Conflicts:
> 	libavcodec/bsf.c
> ---
>  Changes since the last version of the patch:
>  - added av_freep(&bsf->item_name) from previous commit to bsf_list_close
> 
>  libavcodec/bsf.c | 29 ++++++++++++++++++++++++++++-
>  1 file changed, 28 insertions(+), 1 deletion(-)

applied

thanks

[...]
diff mbox

Patch

diff --git a/libavcodec/bsf.c b/libavcodec/bsf.c
index 664565f..2462e62 100644
--- a/libavcodec/bsf.c
+++ b/libavcodec/bsf.c
@@ -248,6 +248,7 @@  typedef struct BSFListContext {
     unsigned idx;           // index of currently processed BSF
     unsigned flushed_idx;   // index of BSF being flushed
 
+    char * item_name;
 } BSFListContext;
 
 
@@ -345,11 +346,37 @@  static void bsf_list_close(AVBSFContext *bsf)
     for (i = 0; i < lst->nb_bsfs; ++i)
         av_bsf_free(&lst->bsfs[i]);
     av_freep(&lst->bsfs);
+    av_freep(&lst->item_name);
+}
+
+static const char *bsf_list_item_name(void *ctx)
+{
+    static const char *null_filter_name = "null";
+    AVBSFContext *bsf_ctx = ctx;
+    BSFListContext *lst = bsf_ctx->priv_data;
+
+    if (!lst->nb_bsfs)
+        return null_filter_name;
+
+    if (!lst->item_name) {
+        int i;
+        AVBPrint bp;
+        av_bprint_init(&bp, 16, 128);
+
+        av_bprintf(&bp, "bsf_list(");
+        for (i = 0; i < lst->nb_bsfs; i++)
+            av_bprintf(&bp, i ? ",%s" : "%s", lst->bsfs[i]->filter->name);
+        av_bprintf(&bp, ")");
+
+        av_bprint_finalize(&bp, &lst->item_name);
+    }
+
+    return lst->item_name;
 }
 
 static const AVClass bsf_list_class = {
         .class_name = "bsf_list",
-        .item_name  = av_default_item_name,
+        .item_name  = bsf_list_item_name,
         .version    = LIBAVUTIL_VERSION_INT,
 };