FFmpeg 7.1.1
Loading...
Searching...
No Matches
avio_list_dir.c

Show how to list directories through the libavformat AVIOContext API.

Show how to list directories through the libavformat AVIOContext API.

/*
* Copyright (c) 2014 Lukasz Marek
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
/**
* @file libavformat AVIOContext list directory API usage example
* @example avio_list_dir.c
*
* Show how to list directories through the libavformat AVIOContext API.
*/
static const char *type_string(int type)
{
switch (type) {
return "<DIR>";
return "<FILE>";
return "<BLOCK DEVICE>";
return "<CHARACTER DEVICE>";
return "<PIPE>";
return "<LINK>";
return "<SOCKET>";
return "<SERVER>";
return "<SHARE>";
return "<WORKGROUP>";
default:
break;
}
return "<UNKNOWN>";
}
static int list_op(const char *input_dir)
{
AVIODirEntry *entry = NULL;
AVIODirContext *ctx = NULL;
int cnt, ret;
char filemode[4], uid_and_gid[20];
if ((ret = avio_open_dir(&ctx, input_dir, NULL)) < 0) {
av_log(NULL, AV_LOG_ERROR, "Cannot open directory: %s.\n", av_err2str(ret));
goto fail;
}
cnt = 0;
for (;;) {
if ((ret = avio_read_dir(ctx, &entry)) < 0) {
av_log(NULL, AV_LOG_ERROR, "Cannot list directory: %s.\n", av_err2str(ret));
goto fail;
}
if (!entry)
break;
if (entry->filemode == -1) {
snprintf(filemode, 4, "???");
} else {
snprintf(filemode, 4, "%3"PRIo64, entry->filemode);
}
snprintf(uid_and_gid, 20, "%"PRId64"(%"PRId64")", entry->user_id, entry->group_id);
if (cnt == 0)
av_log(NULL, AV_LOG_INFO, "%-9s %12s %30s %10s %s %16s %16s %16s\n",
"TYPE", "SIZE", "NAME", "UID(GID)", "UGO", "MODIFIED",
"ACCESSED", "STATUS_CHANGED");
av_log(NULL, AV_LOG_INFO, "%-9s %12"PRId64" %30s %10s %s %16"PRId64" %16"PRId64" %16"PRId64"\n",
type_string(entry->type),
entry->size,
entry->name,
uid_and_gid,
filemode,
cnt++;
};
fail:
return ret;
}
static void usage(const char *program_name)
{
fprintf(stderr, "usage: %s input_dir\n"
"API example program to show how to list files in directory "
"accessed through AVIOContext.\n", program_name);
}
int main(int argc, char *argv[])
{
int ret;
if (argc < 2) {
usage(argv[0]);
return 1;
}
ret = list_op(argv[1]);
return ret < 0 ? 1 : 0;
}
Libavcodec external API header.
Main libavformat public API header.
Buffered I/O operations.
struct AVIODirContext AVIODirContext
Definition avio.h:104
int avio_close_dir(AVIODirContext **s)
Close directory.
int avio_open_dir(AVIODirContext **s, const char *url, AVDictionary **options)
Open directory for reading.
void avio_free_directory_entry(AVIODirEntry **entry)
Free entry allocated by avio_read_dir().
int avio_read_dir(AVIODirContext *s, AVIODirEntry **next)
Get next directory entry.
@ AVIO_ENTRY_UNKNOWN
Definition avio.h:68
@ AVIO_ENTRY_NAMED_PIPE
Definition avio.h:72
@ AVIO_ENTRY_WORKGROUP
Definition avio.h:78
@ AVIO_ENTRY_SERVER
Definition avio.h:76
@ AVIO_ENTRY_SHARE
Definition avio.h:77
@ AVIO_ENTRY_BLOCK_DEVICE
Definition avio.h:69
@ AVIO_ENTRY_SYMBOLIC_LINK
Definition avio.h:73
@ AVIO_ENTRY_DIRECTORY
Definition avio.h:71
@ AVIO_ENTRY_CHARACTER_DEVICE
Definition avio.h:70
@ AVIO_ENTRY_FILE
Definition avio.h:75
@ AVIO_ENTRY_SOCKET
Definition avio.h:74
int main(int argc, char *argv[])
static void usage(const char *program_name)
static const char * type_string(int type)
static int list_op(const char *input_dir)
int avformat_network_deinit(void)
Undo the initialization done by avformat_network_init.
int avformat_network_init(void)
Do global initialization of network libraries.
#define av_err2str(errnum)
Convenience macro, the return value should be used only directly in function arguments but never stan...
Definition error.h:122
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
Definition log.h:201
#define AV_LOG_INFO
Standard information.
Definition log.h:191
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
Definition log.h:180
void av_log_set_level(int level)
Set the log level.
void av_log(void *avcl, int level, const char *fmt,...) av_printf_format(3
Send the specified message to the log if the level is less than or equal to the current av_log_level.
Describes single entry of the directory.
Definition avio.h:87
int64_t user_id
User ID of owner, -1 if unknown.
Definition avio.h:99
int type
Type of the entry.
Definition avio.h:89
int64_t access_timestamp
Time of last access in microseconds since unix epoch, -1 if unknown.
Definition avio.h:95
int64_t status_change_timestamp
Time of last status change in microseconds since unix epoch, -1 if unknown.
Definition avio.h:97
int64_t size
File size in bytes, -1 if unknown.
Definition avio.h:92
int64_t group_id
Group ID of owner, -1 if unknown.
Definition avio.h:100
char * name
Filename.
Definition avio.h:88
int64_t modification_timestamp
Time of last modification in microseconds since unix epoch, -1 if unknown.
Definition avio.h:93
int64_t filemode
Unix file mode, -1 if unknown.
Definition avio.h:101