Commit 95144729 authored by Michael Niedermayer's avatar Michael Niedermayer

avutil & avdevice: remove av_bprint_fd_contents()

MSVC does not allow passing file pointers between libs
This API can thus not work with MSVC and as it was very recently added
and its it was in no release its removial should not cause any problems

A better API will be implemented, but its not finished yet, this revert is
to avoid potentially blocking the release
Found-by: 's avatarHendrik Leppkes <h.leppkes@gmail.com>
Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent 7a15c22c
...@@ -26,7 +26,6 @@ ...@@ -26,7 +26,6 @@
/* #define DEBUG */ /* #define DEBUG */
#include <float.h> /* DBL_MIN, DBL_MAX */ #include <float.h> /* DBL_MIN, DBL_MAX */
#include <fcntl.h> /* O_RDONLY */
#include "libavutil/bprint.h" #include "libavutil/bprint.h"
#include "libavutil/channel_layout.h" #include "libavutil/channel_layout.h"
...@@ -42,13 +41,6 @@ ...@@ -42,13 +41,6 @@
#include "libavformat/internal.h" #include "libavformat/internal.h"
#include "avdevice.h" #include "avdevice.h"
#if HAVE_UNISTD_H
#include <unistd.h> /* close() */
#endif
#if HAVE_IO_H
#include <io.h>
#endif
typedef struct { typedef struct {
AVClass *class; ///< class for private options AVClass *class; ///< class for private options
char *graph_str; char *graph_str;
...@@ -123,22 +115,23 @@ av_cold static int lavfi_read_header(AVFormatContext *avctx) ...@@ -123,22 +115,23 @@ av_cold static int lavfi_read_header(AVFormatContext *avctx)
} }
if (lavfi->graph_filename) { if (lavfi->graph_filename) {
AVBPrint graph_file_pb; uint8_t *file_buf, *graph_buf;
int fd = avpriv_open(lavfi->graph_filename, O_RDONLY); size_t file_bufsize;
if (fd == -1) ret = av_file_map(lavfi->graph_filename,
FAIL(AVERROR(EINVAL)); &file_buf, &file_bufsize, 0, avctx);
av_bprint_init(&graph_file_pb, 0, AV_BPRINT_SIZE_UNLIMITED); if (ret < 0)
ret = av_bprint_fd_contents(&graph_file_pb, fd); goto end;
av_bprint_chars(&graph_file_pb, '\0', 1);
close(fd); /* create a 0-terminated string based on the read file */
if (!ret && !av_bprint_is_complete(&graph_file_pb)) graph_buf = av_malloc(file_bufsize + 1);
ret = AVERROR(ENOMEM); if (!graph_buf) {
if (ret) { av_file_unmap(file_buf, file_bufsize);
av_bprint_finalize(&graph_file_pb, NULL); FAIL(AVERROR(ENOMEM));
FAIL(ret);
} }
if ((ret = av_bprint_finalize(&graph_file_pb, &lavfi->graph_str))) memcpy(graph_buf, file_buf, file_bufsize);
FAIL(ret); graph_buf[file_bufsize] = 0;
av_file_unmap(file_buf, file_bufsize);
lavfi->graph_str = graph_buf;
} }
if (!lavfi->graph_str) if (!lavfi->graph_str)
......
...@@ -30,14 +30,6 @@ ...@@ -30,14 +30,6 @@
#include "error.h" #include "error.h"
#include "mem.h" #include "mem.h"
#if HAVE_IO_H
#include <io.h>
#endif
#if HAVE_UNISTD_H
#include <unistd.h>
#endif
#define av_bprint_room(buf) ((buf)->size - FFMIN((buf)->len, (buf)->size)) #define av_bprint_room(buf) ((buf)->size - FFMIN((buf)->len, (buf)->size))
#define av_bprint_is_allocated(buf) ((buf)->str != (buf)->reserved_internal_buffer) #define av_bprint_is_allocated(buf) ((buf)->str != (buf)->reserved_internal_buffer)
...@@ -312,22 +304,6 @@ void av_bprint_escape(AVBPrint *dstbuf, const char *src, const char *special_cha ...@@ -312,22 +304,6 @@ void av_bprint_escape(AVBPrint *dstbuf, const char *src, const char *special_cha
} }
} }
int av_bprint_fd_contents(AVBPrint *pb, int fd)
{
int ret;
char buf[1024];
while (1) {
ret = read(fd, buf, sizeof(buf));
if (!ret)
return 0;
else if (ret < 0)
return AVERROR(errno);
av_bprint_append_data(pb, buf, ret);
if (!av_bprint_is_complete(pb))
return AVERROR(ENOMEM);
}
}
#ifdef TEST #ifdef TEST
#undef printf #undef printf
......
...@@ -213,11 +213,4 @@ int av_bprint_finalize(AVBPrint *buf, char **ret_str); ...@@ -213,11 +213,4 @@ int av_bprint_finalize(AVBPrint *buf, char **ret_str);
void av_bprint_escape(AVBPrint *dstbuf, const char *src, const char *special_chars, void av_bprint_escape(AVBPrint *dstbuf, const char *src, const char *special_chars,
enum AVEscapeMode mode, int flags); enum AVEscapeMode mode, int flags);
/**
* Read contents of fd into print buffer up to EOF.
*
* @return 0 for success, error code otherwise
*/
int av_bprint_fd_contents(AVBPrint *pb, int fd);
#endif /* AVUTIL_BPRINT_H */ #endif /* AVUTIL_BPRINT_H */
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment