mirror of
https://github.com/mpv-player/mpv
synced 2025-03-11 00:29:02 +00:00
Get rid of the old vf.c code. Replace it with a generic filtering framework, which can potentially handle more than just --vf. At least reimplementing --af with this code is planned. This changes some --vf semantics (including runtime behavior and the "vf" command). The most important ones are listed in interface-changes. vf_convert.c is renamed to f_swscale.c. It is now an internal filter that can not be inserted by the user manually. f_lavfi.c is a refactor of player/lavfi.c. The latter will be removed once --lavfi-complex is reimplemented on top of f_lavfi.c. (which is conceptually easy, but a big mess due to the data flow changes). The existing filters are all changed heavily. The data flow of the new filter framework is different. Especially EOF handling changes - EOF is now a "frame" rather than a state, and must be passed through exactly once. Another major thing is that all filters must support dynamic format changes. The filter reconfig() function goes away. (This sounds complex, but since all filters need to handle EOF draining anyway, they can use the same code, and it removes the mess with reconfig() having to predict the output format, which completely breaks with libavfilter anyway.) In addition, there is no automatic format negotiation or conversion. libavfilter's primitive and insufficient API simply doesn't allow us to do this in a reasonable way. Instead, filters can use f_autoconvert as sub-filter, and tell it which formats they support. This filter will in turn add actual conversion filters, such as f_swscale, to perform necessary format changes. vf_vapoursynth.c uses the same basic principle of operation as before, but with worryingly different details in data flow. Still appears to work. The hardware deint filters (vf_vavpp.c, vf_d3d11vpp.c, vf_vdpaupp.c) are heavily changed. Fortunately, they all used refqueue.c, which is for sharing the data flow logic (especially for managing future/past surfaces and such). It turns out it can be used to factor out most of the data flow. Some of these filters accepted software input. Instead of having ad-hoc upload code in each filter, surface upload is now delegated to f_autoconvert, which can use f_hwupload to perform this. Exporting VO capabilities is still a big mess (mp_stream_info stuff). The D3D11 code drops the redundant image formats, and all code uses the hw_subfmt (sw_format in FFmpeg) instead. Although that too seems to be a big mess for now. f_async_queue is unused.
118 lines
3.8 KiB
C
118 lines
3.8 KiB
C
/*
|
|
* This file is part of mpv.
|
|
*
|
|
* mpv is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* mpv is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with mpv. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef MPLAYER_MPCOMMON_H
|
|
#define MPLAYER_MPCOMMON_H
|
|
|
|
#include <assert.h>
|
|
#include <stddef.h>
|
|
#include <stdlib.h>
|
|
#include <stdbool.h>
|
|
#include <stdint.h>
|
|
|
|
#include "osdep/compiler.h"
|
|
#include "mpv_talloc.h"
|
|
|
|
// double should be able to represent this exactly
|
|
#define MP_NOPTS_VALUE (-0x1p+63)
|
|
|
|
#define MP_CONCAT_(a, b) a ## b
|
|
#define MP_CONCAT(a, b) MP_CONCAT_(a, b)
|
|
|
|
#define MPMAX(a, b) ((a) > (b) ? (a) : (b))
|
|
#define MPMIN(a, b) ((a) > (b) ? (b) : (a))
|
|
#define MPCLAMP(a, min, max) (((a) < (min)) ? (min) : (((a) > (max)) ? (max) : (a)))
|
|
#define MPSWAP(type, a, b) \
|
|
do { type SWAP_tmp = b; b = a; a = SWAP_tmp; } while (0)
|
|
#define MP_ARRAY_SIZE(s) (sizeof(s) / sizeof((s)[0]))
|
|
|
|
// align must be a power of two (align >= 1), x >= 0
|
|
#define MP_ALIGN_UP(x, align) (((x) + (align) - 1) & ~((align) - 1))
|
|
#define MP_ALIGN_DOWN(x, align) ((x) & ~((align) - 1))
|
|
|
|
#define CONTROL_OK 1
|
|
#define CONTROL_TRUE 1
|
|
#define CONTROL_FALSE 0
|
|
#define CONTROL_UNKNOWN -1
|
|
#define CONTROL_ERROR -2
|
|
#define CONTROL_NA -3
|
|
|
|
enum stream_type {
|
|
STREAM_VIDEO,
|
|
STREAM_AUDIO,
|
|
STREAM_SUB,
|
|
STREAM_TYPE_COUNT,
|
|
};
|
|
|
|
enum {
|
|
DATA_OK = 1, // data is actually being returned
|
|
DATA_WAIT = 0, // async wait: check state again after next wakeup
|
|
DATA_AGAIN = -2, // repeat request (internal progress was made)
|
|
DATA_STARVE = -1, // need input (might require to drain other outputs)
|
|
DATA_EOF = -3, // no more data available
|
|
};
|
|
|
|
extern const char mpv_version[];
|
|
extern const char mpv_builddate[];
|
|
extern const char mpv_copyright[];
|
|
|
|
char *mp_format_time(double time, bool fractions);
|
|
char *mp_format_time_fmt(const char *fmt, double time);
|
|
|
|
struct mp_rect {
|
|
int x0, y0;
|
|
int x1, y1;
|
|
};
|
|
|
|
#define mp_rect_w(r) ((r).x1 - (r).x0)
|
|
#define mp_rect_h(r) ((r).y1 - (r).y0)
|
|
|
|
void mp_rect_union(struct mp_rect *rc, const struct mp_rect *src);
|
|
bool mp_rect_intersection(struct mp_rect *rc, const struct mp_rect *rc2);
|
|
bool mp_rect_contains(struct mp_rect *rc, int x, int y);
|
|
bool mp_rect_equals(struct mp_rect *rc1, struct mp_rect *rc2);
|
|
|
|
int mp_snprintf_cat(char *str, size_t size, const char *format, ...)
|
|
PRINTF_ATTRIBUTE(3, 4);
|
|
|
|
struct bstr;
|
|
|
|
void mp_append_utf8_bstr(void *talloc_ctx, struct bstr *buf, uint32_t codepoint);
|
|
|
|
bool mp_append_escaped_string_noalloc(void *talloc_ctx, struct bstr *dst,
|
|
struct bstr *src);
|
|
bool mp_append_escaped_string(void *talloc_ctx, struct bstr *dst,
|
|
struct bstr *src);
|
|
|
|
char *mp_strerror_buf(char *buf, size_t buf_size, int errnum);
|
|
#define mp_strerror(e) mp_strerror_buf((char[80]){0}, 80, e)
|
|
|
|
char *mp_tag_str_buf(char *buf, size_t buf_size, uint32_t tag);
|
|
#define mp_tag_str(t) mp_tag_str_buf((char[22]){0}, 22, t)
|
|
|
|
// Return a printf(format, ...) formatted string of the given SIZE. SIZE must
|
|
// be a compile time constant. The result is allocated on the stack and valid
|
|
// only within the current block scope.
|
|
#define mp_tprintf(SIZE, format, ...) \
|
|
mp_tprintf_buf((char[SIZE]){0}, (SIZE), (format), __VA_ARGS__)
|
|
char *mp_tprintf_buf(char *buf, size_t buf_size, const char *format, ...)
|
|
PRINTF_ATTRIBUTE(3, 4);
|
|
|
|
char **mp_dup_str_array(void *tctx, char **s);
|
|
|
|
#endif /* MPLAYER_MPCOMMON_H */
|