summaryrefslogtreecommitdiffstats
path: root/input/cmd_parse.c
diff options
context:
space:
mode:
authorwm4 <wm4@nowhere>2014-10-23 14:40:38 +0200
committerwm4 <wm4@nowhere>2014-10-23 15:13:05 +0200
commitdd77f0d37e6b1f73c68bd6155356590477289422 (patch)
tree8c8d5b472b65007732a247a64dbbca987db347cb /input/cmd_parse.c
parent6f958be3253ed002251039be9863c130f8d443e1 (diff)
downloadmpv-dd77f0d37e6b1f73c68bd6155356590477289422.tar.bz2
mpv-dd77f0d37e6b1f73c68bd6155356590477289422.tar.xz
command: print executed commands with -v
Diffstat (limited to 'input/cmd_parse.c')
-rw-r--r--input/cmd_parse.c21
1 files changed, 21 insertions, 0 deletions
diff --git a/input/cmd_parse.c b/input/cmd_parse.c
index 335d0d96b4..90d2650cf9 100644
--- a/input/cmd_parse.c
+++ b/input/cmd_parse.c
@@ -423,6 +423,27 @@ mp_cmd_t *mp_cmd_clone(mp_cmd_t *cmd)
return ret;
}
+void mp_cmd_dump(struct mp_log *log, int msgl, char *header, struct mp_cmd *cmd)
+{
+ if (!mp_msg_test(log, msgl))
+ return;
+ if (header)
+ mp_msg(log, msgl, "%s: ", header);
+ if (!cmd) {
+ mp_msg(log, msgl, "(NULL)\n");
+ return;
+ }
+ mp_msg(log, msgl, "%s, flags=%d args=[", cmd->name, cmd->flags);
+ for (int n = 0; n < cmd->nargs; n++) {
+ char *s = m_option_print(cmd->args[n].type, &cmd->args[n].v);
+ if (n)
+ mp_msg(log, msgl, ", ");
+ mp_msg(log, msgl, "%s", s ? s : "(NULL)");
+ talloc_free(s);
+ }
+ mp_msg(log, msgl, "]\n");
+}
+
static int parse_cycle_dir(struct mp_log *log, const struct m_option *opt,
struct bstr name, struct bstr param, void *dst)
{