summaryrefslogtreecommitdiff
path: root/pktdumper.c
diff options
context:
space:
mode:
authorFrançois Revol <revol@free.fr>2005-04-07 16:52:28 +0000
committerFrançois Revol <revol@free.fr>2005-04-07 16:52:28 +0000
commit2d216336f80b294af056a8b1ee8c7306f4d543f3 (patch)
tree1f17d9e49978e143f31560af733bf1b3342344f1 /pktdumper.c
parentdebc2adb163ec66ffceeaaad1115c9024188e249 (diff)
"don't quit" option to attach a debugger /check mem leaks
"no write" option to only get next packets Originally committed as revision 4110 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'pktdumper.c')
-rw-r--r--pktdumper.c25
1 files changed, 21 insertions, 4 deletions
diff --git a/pktdumper.c b/pktdumper.c
index 72d83aaae8..48ed6ea167 100644
--- a/pktdumper.c
+++ b/pktdumper.c
@@ -12,7 +12,9 @@ static int usage(int ret)
{
fprintf(stderr, "dump (up to maxpkts) AVPackets as they are demuxed by libavformat.\n");
fprintf(stderr, "each packet is dumped in its own file named like `basename file.ext`_$PKTNUM_$STREAMINDEX_$STAMP_$SIZE_$FLAGS.bin\n");
- fprintf(stderr, "pktdumper file [maxpkts]\n");
+ fprintf(stderr, "pktdumper [-nw] file [maxpkts]\n");
+ fprintf(stderr, "-n\twrite No file at all, only demux.\n");
+ fprintf(stderr, "-w\tWait at end of processing instead of quitting.\n");
return ret;
}
@@ -24,8 +26,18 @@ int main(int argc, char **argv)
AVPacket pkt;
int64_t pktnum = 0;
int64_t maxpkts = 0;
+ int dontquit = 0;
+ int nowrite = 0;
int err;
+ if ((argc > 1) && !strncmp(argv[1], "-", 1)) {
+ if (strchr(argv[1], 'w'))
+ dontquit = 1;
+ if (strchr(argv[1], 'n'))
+ nowrite = 1;
+ argv++;
+ argc--;
+ }
if (argc < 2)
return usage(1);
if (argc > 2)
@@ -68,13 +80,18 @@ int main(int argc, char **argv)
snprintf(pktfilename, PATH_MAX-1, fntemplate, pktnum, pkt.stream_index, pkt.pts, pkt.size, (pkt.flags & PKT_FLAG_KEY)?'K':'_');
printf(PKTFILESUFF"\n", pktnum, pkt.stream_index, pkt.pts, pkt.size, (pkt.flags & PKT_FLAG_KEY)?'K':'_');
//printf("open(\"%s\")\n", pktfilename);
- fd = open(pktfilename, O_WRONLY|O_CREAT, 0644);
- write(fd, pkt.data, pkt.size);
- close(fd);
+ if (!nowrite) {
+ fd = open(pktfilename, O_WRONLY|O_CREAT, 0644);
+ write(fd, pkt.data, pkt.size);
+ close(fd);
+ }
pktnum++;
if (maxpkts && (pktnum >= maxpkts))
break;
}
+ while (dontquit)
+ sleep(60);
+
return 0;
}