Git Inbox Mirror of the ffmpeg-devel mailing list - see https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
 help / color / mirror / Atom feed
From: Nicolas George <george@nsup.org>
To: FFmpeg development discussions and patches <ffmpeg-devel@ffmpeg.org>
Subject: Re: [FFmpeg-devel] [PATCH 5/8] lavu: add a JSON writer API (WIP)
Date: Sat, 29 Apr 2023 11:11:59 +0200
Message-ID: <ZEzfX4ngQa2hVNOT@phare.normalesup.org> (raw)
In-Reply-To: <20230428095508.221826-5-george@nsup.org>


[-- Attachment #1.1: Type: text/plain, Size: 2172 bytes --]

Nicolas George (12023-04-28):
> Signed-off-by: Nicolas George <george@nsup.org>
> ---
>  libavutil/Makefile |   1 +
>  libavutil/json.c   | 368 +++++++++++++++++++++++++++++++++++
>  libavutil/json.h   | 470 +++++++++++++++++++++++++++++++++++++++++++++
>  3 files changed, 839 insertions(+)
>  create mode 100644 libavutil/json.c
>  create mode 100644 libavutil/json.h

I forgot to write: I wrote this code not only because we have half-baked
JSON output in multiple places in the code, but also to show the
kind of API AVWriter makes possible.

Typical JSON APIs would have a function to write a string value or an
object key, requiring the caller to build the string beforehand. Of
course, this API can do that:

> +void av_json_add_string(AVJson *jc, const char *str);

including with a format string, which is less usual:

> +void av_json_add_string_printf(AVJson *jc, const char *fmt, ...) av_printf_format(2, 3);

But these are just wrappers for convenience over the real API:

> +AVWriter av_json_begin_string(AVJson *jc);

It starts a string, i.e. outputs a quote, and then we get a writer to
write into that string. It will be automatically escaped, no
intermediate buffer will be used, and all the functions of the writer
API are available, including all the av_something_write() to come to
serialize our various types.

Also note that this API as a whole can produce small JSON outputs
without any dynamic allocation, making it suitable for once-per-frame
calls, but is not limited to that.

Do we *need* that: of course not, we still put “len += snprintf()” and
“av_realloc()” and error checks all over the place.

Now, while people maybe look at the code, there are a few things I can
work on, and I wonder which one you would like to see first:

- Finishing this JSON API.

- A XML API: that would be useful for dashenc, movenc, ttmlenc, ffprobe
  and possibly others.

- Add serialization functions for our various types, like I did for
  av_disposition_write().

- Go forward with the others API enhancements that I promised and that
  depend on AVWriter.

Regards,

-- 
  Nicolas George

[-- Attachment #1.2: signature.asc --]
[-- Type: application/pgp-signature, Size: 833 bytes --]

[-- Attachment #2: Type: text/plain, Size: 251 bytes --]

_______________________________________________
ffmpeg-devel mailing list
ffmpeg-devel@ffmpeg.org
https://ffmpeg.org/mailman/listinfo/ffmpeg-devel

To unsubscribe, visit link above, or email
ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".

  reply	other threads:[~2023-04-29  9:12 UTC|newest]

Thread overview: 38+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-04-28  9:55 [FFmpeg-devel] [PATCH 1/8] lavu: add macros to help making future-proof structures Nicolas George
2023-04-28  9:55 ` [FFmpeg-devel] [PATCH 2/8] lavu: new AVWriter API Nicolas George
2023-04-28 10:37   ` Rodney Baker
2023-04-28 11:20     ` Nicolas George
2023-05-02 15:53   ` Rémi Denis-Courmont
2023-05-02 16:53     ` Nicolas George
2023-05-02 18:29       ` Rémi Denis-Courmont
2023-05-02 18:36         ` Nicolas George
2023-05-02 18:46           ` Rémi Denis-Courmont
2023-05-02 18:47             ` Nicolas George
2023-04-28  9:55 ` [FFmpeg-devel] [PATCH 3/8] lavu/writer: add test Nicolas George
2023-04-28  9:55 ` [FFmpeg-devel] [PATCH 4/8] lavf/dump: use a writer Nicolas George
2023-04-28  9:55 ` [FFmpeg-devel] [PATCH 5/8] lavu: add a JSON writer API (WIP) Nicolas George
2023-04-29  9:11   ` Nicolas George [this message]
2023-04-29  9:41     ` Anton Khirnov
2023-04-29 14:06       ` James Almer
2023-04-29 17:17         ` Nicolas George
2023-04-29 15:06       ` Derek Buitenhuis
2023-04-30  0:29         ` Kieran Kunhya
2023-05-01  6:20           ` Vittorio Giovara
2023-04-29 17:11       ` Nicolas George
2023-04-29 18:27         ` Anton Khirnov
2023-04-29 18:33           ` Nicolas George
2023-05-01  6:57             ` Leo Izen
2023-05-01  9:51               ` Nicolas George
2023-05-01 10:18               ` Jean-Baptiste Kempf
2023-04-30 15:06           ` Michael Niedermayer
2023-04-30 21:51             ` Kieran Kunhya
2023-05-01  9:46             ` Nicolas George
2023-04-28  9:55 ` [FFmpeg-devel] [PATCH 6/8] lavu: add JSON writer test (WIP) Nicolas George
2023-04-28  9:55 ` [FFmpeg-devel] [PATCH 7/8] lavf/options: add av_disposition_write() Nicolas George
2023-04-28  9:55 ` [FFmpeg-devel] [PATCH 8/8] lavf/dump: use av_disposition_write() Nicolas George
2023-04-29  8:17 ` [FFmpeg-devel] [PATCH 1/8] lavu: add macros to help making future-proof structures Anton Khirnov
2023-04-29 15:11   ` Derek Buitenhuis
2023-05-02 15:36 ` Rémi Denis-Courmont
2023-05-02 16:42   ` Nicolas George
2023-05-02 18:31     ` Rémi Denis-Courmont
2023-05-02 18:38       ` Nicolas George

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=ZEzfX4ngQa2hVNOT@phare.normalesup.org \
    --to=george@nsup.org \
    --cc=ffmpeg-devel@ffmpeg.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link

Git Inbox Mirror of the ffmpeg-devel mailing list - see https://ffmpeg.org/mailman/listinfo/ffmpeg-devel

This inbox may be cloned and mirrored by anyone:

	git clone --mirror https://master.gitmailbox.com/ffmpegdev/0 ffmpegdev/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 ffmpegdev ffmpegdev/ https://master.gitmailbox.com/ffmpegdev \
		ffmpegdev@gitmailbox.com
	public-inbox-index ffmpegdev

Example config snippet for mirrors.


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git