Go to the documentation of this file.
34 #ifndef __AVXSYNTH_C__
35 #define __AVXSYNTH_C__
41 # define EXTERN_C extern "C"
46 #define AVSC_USE_STDCALL 1
48 #ifndef AVSC_USE_STDCALL
49 # define AVSC_CC __cdecl
51 # define AVSC_CC __stdcall
54 #define AVSC_INLINE static __inline
56 #ifdef AVISYNTH_C_EXPORTS
57 # define AVSC_EXPORT EXTERN_C
58 # define AVSC_API(ret, name) EXTERN_C __declspec(dllexport) ret AVSC_CC name
60 # define AVSC_EXPORT EXTERN_C __declspec(dllexport)
61 # ifndef AVSC_NO_DECLSPEC
62 # define AVSC_API(ret, name) EXTERN_C __declspec(dllimport) ret AVSC_CC name
64 # define AVSC_API(ret, name) typedef ret (AVSC_CC *name##_func)
80 #ifndef __AVXSYNTH_H__
147 #define AVS_FRAME_ALIGN 16
177 {
return (p->
width!=0); }
204 {
return ((p->
pixel_type & property)==property ); }
289 unsigned x=numerator, y=denominator;
291 unsigned t = x%y; x = y; y = t;
420 #if defined __cplusplus
423 #endif // __cplusplus
427 #if defined __cplusplus
429 #endif // __cplusplus
431 #ifndef AVSC_NO_DECLSPEC
433 {avs_release_video_frame(
f);}
435 {
return avs_copy_video_frame(
f);}
486 #if defined __cplusplus
489 #endif // __cplusplus
492 #if defined __cplusplus
494 #endif // __cplusplus
525 #ifndef AVSC_NO_DECLSPEC
527 {
AVS_Value v = {0}; avs_set_to_clip(&v,
v0);
return v; }
536 #if defined __cplusplus
539 #endif // __cplusplus
561 #if defined __cplusplus
563 #endif // __cplusplus
598 #if defined __cplusplus
601 #endif // __cplusplus
605 #if defined __cplusplus
607 #endif // __cplusplus
630 #if defined __cplusplus
633 #endif // __cplusplus
668 #if defined __cplusplus
670 #endif // __cplusplus
672 #ifndef AVSC_NO_DECLSPEC
684 #if defined __cplusplus
687 #endif // __cplusplus
705 #if defined __cplusplus
707 #endif // __cplusplus
715 #if defined __cplusplus
718 #endif // __cplusplus
724 #if defined __cplusplus
726 #endif // __cplusplus
728 #endif //__AVXSYNTH_C__
AVSC_INLINE AVS_Value avs_new_value_error(const char *v0)
const AVSC_INLINE AVS_Value * avs_as_array(AVS_Value v)
AVSC_INLINE int avs_has_audio(const AVS_VideoInfo *p)
AVSC_INLINE int avs_is_yv12(const AVS_VideoInfo *p)
@ AVS_FILTER_INPUT_COLORSPACE
AVSC_INLINE AVS_Value avs_new_value_string(const char *v0)
@ AVISYNTH_INTERFACE_VERSION
AVSC_INLINE int avs_is_clip(AVS_Value v)
AVSC_INLINE int avs_is_bff(const AVS_VideoInfo *p)
int(AVSC_CC *get_parity)(AVS_FilterInfo *
@ AVS_FILTER_ARGS_DESCRIPTION
AVS_VideoFrame int int int int new_height
AVSC_INLINE unsigned char * avs_get_write_ptr(const AVS_VideoFrame *p)
const AVSC_INLINE unsigned char * avs_get_read_ptr(const AVS_VideoFrame *p)
AVSC_INLINE int avs_get_row_size_p(const AVS_VideoFrame *p, int plane)
AVSC_INLINE int avs_audio_channels(const AVS_VideoInfo *p)
AVSC_INLINE int avs_samples_per_second(const AVS_VideoInfo *p)
AVSC_INLINE int avs_is_field_based(const AVS_VideoInfo *p)
AVS_ScriptEnvironment * env
const AVSC_INLINE unsigned char * avs_get_read_ptr_p(const AVS_VideoFrame *p, int plane)
AVSC_INLINE AVS_Value avs_new_value_bool(int v0)
AVSC_INLINE int avs_get_height_p(const AVS_VideoFrame *p, int plane)
const AVSC_EXPORT char *AVSC_CC avisynth_c_plugin_init(AVS_ScriptEnvironment *env)
unsigned char int dst_pitch
AVSC_INLINE unsigned char * avs_get_write_ptr_p(const AVS_VideoFrame *p, int plane)
@ AVS_FILTER_OUTPUT_TYPE_DIFFERENT
AVSC_INLINE int avs_is_rgb24(const AVS_VideoInfo *p)
AVSC_INLINE AVS_VideoFrame * avs_new_frame(AVS_ScriptEnvironment *env, const AVS_VideoInfo *vi)
AVSC_INLINE int avs_is_same_colorspace(AVS_VideoInfo *x, AVS_VideoInfo *y)
AVSC_INLINE AVS_Value avs_array_elt(AVS_Value v, int index)
AVS_VideoFrame *AVSC_CC * get_frame(AVS_FilterInfo *, int n)
AVSC_INLINE int avs_is_string(AVS_Value v)
AVSC_INLINE int avs_get_row_size(const AVS_VideoFrame *p)
AVSC_INLINE int avs_array_size(AVS_Value v)
if it could not because there are no more frames
@ AVS_FILTER_OUTPUT_TYPE_SAME
AVSC_INLINE int avs_bytes_per_channel_sample(const AVS_VideoInfo *p)
AVSC_INLINE int avs_is_rgb32(const AVS_VideoInfo *p)
void(AVSC_CC *free_filter)(AVS_FilterInfo *)
AVSC_INLINE int avs_is_error(AVS_Value v)
AVS_Value(AVSC_CC * AVS_ApplyFunc)(AVS_ScriptEnvironment *, AVS_Value args, void *user_data)
AVSC_INLINE int avs_is_int(AVS_Value v)
AVSC_INLINE int avs_is_array(AVS_Value v)
AVS_VideoFrame int int int int int int rel_offsetV
AVSC_INLINE int avs_bmp_size(const AVS_VideoInfo *vi)
AVSC_INLINE AVS_VideoFrame * avs_new_video_frame(AVS_ScriptEnvironment *env, const AVS_VideoInfo *vi)
AVS_VideoFrame int int int new_row_size
AVS_FilterInfo AVS_Value int store_child
#define AVSC_API(ret, name)
AVSC_INLINE int avs_get_pitch_p(const AVS_VideoFrame *p, int plane)
AVSC_INLINE AVS_Value avs_new_value_int(int v0)
AVS_VideoFrame int int int int int int int new_pitchUV
struct AVS_ScriptEnvironment AVS_ScriptEnvironment
AVSC_INLINE AVS_Value avs_new_value_array(AVS_Value *v0, int size)
AVSC_INLINE int avs_is_writable(const AVS_VideoFrame *p)
AVSC_INLINE int avs_has_video(const AVS_VideoInfo *p)
AVSC_INLINE int avs_get_pitch(const AVS_VideoFrame *p)
unsigned char int const unsigned char int src_pitch
AVSC_INLINE int avs_as_int(AVS_Value v)
AVSC_INLINE void avs_release_frame(AVS_VideoFrame *f)
const char const char AVS_ApplyFunc apply
const char AVS_Value const char ** arg_names
AVS_VideoFrame int int int int int rel_offsetU
AVSC_INLINE int avs_is_property(const AVS_VideoInfo *p, int property)
AVSC_INLINE int avs_is_parity_known(const AVS_VideoInfo *p)
const char const char * params
AVS_VideoFrame int int new_pitch
AVSC_INLINE int avs_bits_per_pixel(const AVS_VideoInfo *p)
const AVS_VideoInfo int align
AVSC_INLINE void avs_clear_property(AVS_VideoInfo *p, int property)
unsigned char int const unsigned char * srcp
AVSC_INLINE double avs_as_float(AVS_Value v)
AVSC_INLINE int avs_row_size(const AVS_VideoInfo *p)
AVSC_INLINE int avs_is_yuv(const AVS_VideoInfo *p)
AVSC_INLINE int avs_is_float(AVS_Value v)
AVSC_INLINE void avs_set_fps(AVS_VideoInfo *p, unsigned numerator, unsigned denominator)
const AVSC_INLINE char * avs_as_string(AVS_Value v)
AVSC_INLINE int avs_bytes_from_pixels(const AVS_VideoInfo *p, int pixels)
AVSC_INLINE int avs_sample_type(const AVS_VideoInfo *p)
AVSC_INLINE int avs_is_tff(const AVS_VideoInfo *p)
AVSC_INLINE int avs_get_height(const AVS_VideoFrame *p)
AVSC_INLINE AVS_VideoFrame * avs_copy_frame(AVS_VideoFrame *f)
AVS_ScriptEnvironment AVS_Clip *AVSC_INLINE int avs_as_bool(AVS_Value v)
AVSC_INLINE INT64 avs_audio_samples_from_bytes(const AVS_VideoInfo *p, INT64 bytes)
static const AVS_Value avs_void
AVSC_INLINE INT64 avs_audio_samples_from_frames(const AVS_VideoInfo *p, INT64 frames)
AVS_VideoFrame int rel_offset
AVSC_INLINE int avs_bytes_per_audio_sample(const AVS_VideoInfo *p)
AVSC_INLINE int avs_frames_from_audio_samples(const AVS_VideoInfo *p, INT64 samples)
unsigned char int const unsigned char int int int height
volatile long sequence_number
AVSC_INLINE int avs_defined(AVS_Value v)
const AVSC_INLINE char * avs_as_error(AVS_Value v)
AVSC_INLINE AVS_Value avs_new_value_float(float v0)
Filter the word “frame” indicates either a video frame or a group of audio samples
const char const char va_list val
const char const char AVS_ApplyFunc void * user_data
unsigned char int const unsigned char int int row_size
AVSC_INLINE AVS_Value avs_new_value_clip(AVS_Clip *v0)
AVS_FilterInfo AVS_Value child
AVS_VideoFrameBuffer * vfb
AVSC_INLINE INT64 avs_bytes_from_audio_samples(const AVS_VideoInfo *p, INT64 samples)
AVSC_INLINE void avs_set_field_based(AVS_VideoInfo *p, int isfieldbased)
AVSC_INLINE int avs_is_rgb(const AVS_VideoInfo *p)
AVSC_INLINE int avs_is_color_space(const AVS_VideoInfo *p, int c_space)
AVSC_INLINE int avs_is_yuy2(const AVS_VideoInfo *p)
const char AVS_Value args
AVSC_INLINE void avs_set_property(AVS_VideoInfo *p, int property)
AVSC_INLINE int avs_is_planar(const AVS_VideoInfo *p)
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf default minimum maximum flags name is the option keep it simple and lowercase description are short
void(AVSC_CC * AVS_ShutdownFunc)(void *user_data, AVS_ScriptEnvironment *env)
AVSC_INLINE int avs_is_bool(AVS_Value v)
int audio_samples_per_second