VapourSynth4.h

Table of contents

Introduction

Macros

VS_CC

VS_EXTERNAL_API

VAPOURSYNTH_API_MAJOR

VAPOURSYNTH_API_MINOR

VAPOURSYNTH_API_VERSION

VS_AUDIO_FRAME_SAMPLES

VS_MAKE_VERSION

Enums

VSColorFamily

VSSampleType

VSPresetVideoFormat

VSFilterMode

VSMediaType

VSAudioChannels

VSPropertyType

VSMapPropertyError

VSMapAppendMode

VSActivationReason

VSMessageType

VSCoreCreationFlags

VSPluginConfigFlags

VSDataTypeHint

VSRequestPattern

VSCacheMode

Structs

VSFrame

VSNode

VSCore

VSPlugin

VSPluginFunction

VSFunction

VSMap

VSLogHandle

VSFrameContext

VSVideoFormat

VSVideoInfo

VSAudioFormat

VSAudioInfo

VSCoreInfo

VSFilterDependency

VSPLUGINAPI

VSAPI

Functions

getVapourSynthAPI

Writing plugins

VSInitPlugin

VSFilterGetFrame

VSFilterFree

Introduction

This is VapourSynth’s main header file. Plugins and applications that use the library must include it.

VapourSynth’s public API is all C.

Macros

VapourSynth4.h defines some preprocessor macros that make the programmer’s life easier. The relevant ones are described below.

VS_CC

The VS_CC macro expands to the calling convention used by VapourSynth. All functions meant to be called by VapourSynth must use this macro (a filter’s “init”, “getframe”, “free” functions, etc).

Example:

static void VS_CC fooInit(...) { ... }

VS_EXTERNAL_API

The VS_EXTERNAL_API macro expands to the platform-specific magic required for functions exported by shared libraries. It also takes care of adding extern "C" when needed, and VS_CC.

This macro must be used for a plugin’s entry point, like so:

VS_EXTERNAL_API(void) VapourSynthPluginInit2(...) { ... }

VAPOURSYNTH_API_MAJOR

Major API version.

VAPOURSYNTH_API_MINOR

Minor API version. It is bumped when new functions are added to VSAPI or core behavior is noticeably changed.

VAPOURSYNTH_API_VERSION

API version. The high 16 bits are VAPOURSYNTH_API_MAJOR, the low 16 bits are VAPOURSYNTH_API_MINOR.

VS_AUDIO_FRAME_SAMPLES

The number of audio samples in an audio frame. It is a static number to make it possible to calculate which audio frames are needed to retrieve specific samples.

VS_MAKE_VERSION

Used to create version numbers. The first argument is the major version and second is the minor.

Enums

enum VSColorFamily

  • cfUndefined

  • cfGray

  • cfRGB

  • cfYUV

enum VSSampleType

  • stInteger

  • stFloat

enum VSPresetVideoFormat

The presets suffixed with H and S have floating point sample type. The H and S suffixes stand for half precision and single precision, respectively. All formats are planar. See the header for all currently defined video format presets.

  • pf*

enum VSFilterMode

Controls how a filter will be multithreaded, if at all.

  • fmParallel

    Completely parallel execution. Multiple threads will call a filter’s “getframe” function, to fetch several frames in parallel.

  • fmParallelRequests

    For filters that are serial in nature but can request in advance one or more frames they need. A filter’s “getframe” function will be called from multiple threads at a time with activation reason arInitial, but only one thread will call it with activation reason arAllFramesReady at a time.

  • fmUnordered

    Only one thread can call the filter’s “getframe” function at a time. Useful for filters that modify or examine their internal state to determine which frames to request.

    While the “getframe” function will only run in one thread at a time, the calls can happen in any order. For example, it can be called with reason arInitial for frame 0, then again with reason arInitial for frame 1, then with reason arAllFramesReady for frame 0.

  • fmFrameState

    For compatibility with other filtering architectures. DO NOT USE IN NEW FILTERS. The filter’s “getframe” function only ever gets called from one thread at a time. Unlike fmUnordered, only one frame is processed at a time.

enum VSMediaType

Used to indicate the type of a VSFrame or VSNode object.

  • mtVideo

  • mtAudio

enum VSAudioChannels

Audio channel positions as an enum. Mirrors the FFmpeg audio channel constants in older api versions. See the header for all available values.

  • ac*

enum VSPropertyType

Types of properties that can be stored in a VSMap.

  • ptUnset

  • ptInt

  • ptFloat

  • ptData

  • ptFunction

  • ptVideoNode

  • ptAudioNode

  • ptVideoFrame

  • ptAudioFrame

enum VSMapPropertyError

When a mapGet* function fails, it returns one of these in the err parameter.

All errors are non-zero.

  • peSuccess

  • peUnset

    The requested key was not found in the map.

  • peType

    The wrong function was used to retrieve the property. E.g. mapGetInt() was used on a property of type ptFloat.

  • peIndex

    The requested index was out of bounds.

  • peError

    The map has the error state set.

enum VSMapAppendMode

Controls the behaviour of mapSetInt() and friends.

  • maReplace

    All existing values associated with the key will be replaced with the new value.

  • maAppend

    The new value will be appended to the list of existing values associated with the key.

enum VSActivationReason

See VSFilterGetFrame.

  • arInitial

  • arAllFramesReady

  • arError

enum VSMessageType

See addLogHandler().

  • mtDebug

  • mtInformation

  • mtWarning

  • mtCritical

  • mtFatal

enum VSCoreCreationFlags

Options when creating a core.

  • ccfEnableGraphInspection

    Required to use the graph inspection api functions. Increases memory usage due to the extra information stored.

  • ccfDisableAutoLoading

    Don’t autoload any user plugins. Core plugins are always loaded.

  • ccfDisableLibraryUnloading

    Don’t unload plugin libraries when the core is destroyed. Due to a small amount of memory leaking every load and unload (windows feature, not my fault) of a library this may help in applications with extreme amount of script reloading.

enum VSPluginConfigFlags

Options when loading a plugin.

  • pcModifiable

    Allow functions to be added to the plugin object after the plugin loading phase. Mostly useful for Avisynth compatibility and other foreign plugin loaders.

enum VSDataTypeHint

Since the data type can contain both pure binary data and printable strings the type also contains a hint for whether or not it is human readable. Generally the unknown type should be very rare and is almost only created as an artifact of API3 compatibility.

  • dtUnknown

  • dtBinary

  • dtUtf8

enum VSRequestPattern

Describes the upstream frame request pattern of a filter.

  • rpGeneral

    Anything goes. Note that filters that may be requesting beyond the end of a VSNode length in frames (repeating the last frame) should use rpGeneral and not any of the other modes.

  • rpNoFrameReuse

    Will only request an input frame at most once if all output frames are requested exactly one time. This includes filters such as Trim, Reverse, SelectEvery.

  • rpStrictSpatial

    Only requests frame N to output frame N. The main difference to rpNoFrameReuse is that the requested frame is always fixed and known ahead of time. Filter examples Lut, Expr (conditionally, see rpGeneral note) and similar.

  • rpFrameReuseLastOnly

    Similar to rpNoFrameReuse but the last frame is cached in case it’s requested multiple times.

enum VSCacheMode

Describes how the output of a node is cached.

  • cmAuto

    Cache is enabled or disabled based on the reported request patterns and number of consumers.

  • cmForceDisable

    Never cache anything.

  • cmForceEnable

    • Always use the cache.

Structs

Most structs are opaque and their contents can only be accessed using functions in the API.

struct VSFrame

A frame that can hold audio or video data.

Each row of pixels in a frame is guaranteed to have an alignment of at least 32 bytes. Two frames with the same width and bytes per sample are guaranteed to have the same stride.

Audio data is also guaranteed to be at least 32 byte aligned.

Any data can be attached to a frame, using a VSMap.

struct VSNode

A reference to a node in the constructed filter graph. Its primary use is as an argument to other filter or to request frames from.

struct VSCore

The core represents one instance of VapourSynth. Every core individually loads plugins and keeps track of memory.

struct VSPlugin

A VapourSynth plugin. There are a few of these built into the core, and therefore available at all times: the basic filters (identifier com.vapoursynth.std, namespace std), the resizers (identifier com.vapoursynth.resize, namespace resize), and the Avisynth compatibility module, if running in Windows (identifier com.vapoursynth.avisynth, namespace avs).

The Function Reference describes how to load VapourSynth and Avisynth plugins.

A VSPlugin instance is constructed by the core when loading a plugin (.so / .dylib / .dll), and the pointer is passed to the plugin’s VapourSynthPluginInit2() function.

A VapourSynth plugin can export any number of filters.

Plugins have a few attributes:

  • An identifier, which must be unique among all VapourSynth plugins in existence, because this is what the core uses to make sure a plugin only gets loaded once.

  • A namespace, also unique. The filters exported by a plugin end up in the plugin’s namespace.

  • A full name, which is used by the core in a few error messages.

  • The version of the plugin.

  • The VapourSynth API version the plugin requires.

  • A file name.

Things you can do with a VSPlugin:

All loaded plugins (including built-in) can be enumerated with getNextPlugin().

Once loaded, a plugin only gets unloaded when the VapourSynth core is freed.

struct VSPluginFunction

A function belonging to a Vapoursynth plugin. This object primarily exists so a plugin’s name, argument list and return type can be queried by editors.

One peculiarity is that plugin functions cannot be invoked using a VSPluginFunction pointer but is instead done using invoke() which takes a VSPlugin and the function name as a string.

struct VSFunction

Holds a reference to a function that may be called. This type primarily exists so functions can be shared between the scripting layer and plugins in the core.

struct VSMap

VSMap is a container that stores (key,value) pairs. The keys are strings and the values can be (arrays of) integers, floating point numbers, arrays of bytes, VSNode, VSFrame, or VSFunction.

The pairs in a VSMap are sorted by key.

In VapourSynth, VSMaps have several uses:
  • storing filters’ arguments and return values

  • storing user-defined functions’ arguments and return values

  • storing the properties attached to frames

Only alphanumeric characters and the underscore may be used in keys.

Creating and destroying a map can be done with createMap() and freeMap(), respectively.

A map’s contents can be retrieved and modified using a number of functions, all prefixed with “map”.

A map’s contents can be erased with clearMap().

struct VSLogHandle

Opaque type representing a registered logger.

struct VSFrameContext

Opaque type representing the current frame request in a filter.

struct VSVideoFormat

Describes the format of a clip.

Use queryVideoFormat() to fill it in with proper error checking. Manually filling out the struct is allowed but discouraged since illegal combinations of values will cause undefined behavior.

int colorFamily

See VSColorFamily.

int sampleType

See VSSampleType.

int bitsPerSample

Number of significant bits.

int bytesPerSample

Number of bytes needed for a sample. This is always a power of 2 and the smallest possible that can fit the number of bits used per sample.

int subSamplingW
int subSamplingH

log2 subsampling factor, applied to second and third plane. Convenient numbers that can be used like so:

uv_width = y_width >> subSamplingW;
int numPlanes

Number of planes.

struct VSVideoInfo

Contains information about a clip.

VSVideoFormat format

Format of the clip. Will have colorFamily set to cfUndefined if the format can vary.

int64_t fpsNum

Numerator part of the clip’s frame rate. It will be 0 if the frame rate can vary. Should always be a reduced fraction.

int64_t fpsDen

Denominator part of the clip’s frame rate. It will be 0 if the frame rate can vary. Should always be a reduced fraction.

int width

Width of the clip. Both width and height will be 0 if the clip’s dimensions can vary.

int height

Height of the clip. Both width and height will be 0 if the clip’s dimensions can vary.

int numFrames

Length of the clip.

struct VSAudioFormat

Describes the format of a clip.

Use queryAudioFormat() to fill it in with proper error checking. Manually filling out the struct is allowed but discouraged since illegal combinations of values will cause undefined behavior.

int sampleType

See VSSampleType.

int bitsPerSample

Number of significant bits.

int bytesPerSample

Number of bytes needed for a sample. This is always a power of 2 and the smallest possible that can fit the number of bits used per sample.

int numChannels

Number of audio channels.

uint64_t channelLayout

A bitmask representing the channels present using the constants in 1 left shifted by the constants in VSAudioChannels.

struct VSAudioInfo

Contains information about a clip.

VSAudioFormat format

Format of the clip. Unlike video the audio format can never change.

int sampleRate

Sample rate.

int64_t numSamples

Length of the clip in audio samples.

int numFrames

Length of the clip in audio frames.

struct VSCoreInfo

Contains information about a VSCore instance.

const char *versionString

Printable string containing the name of the library, copyright notice, core and API versions.

int core

Version of the core.

int api

Version of the API.

int numThreads

Number of worker threads.

int64_t maxFramebufferSize

The framebuffer cache will be allowed to grow up to this size (bytes) before memory is aggressively reclaimed.

int64_t usedFramebufferSize

Current size of the framebuffer cache, in bytes.

struct VSFilterDependency

Contains information about a VSCore instance.

VSNode *source

The node frames are requested from.

int requestPattern

A value from VSRequestPattern.

struct VSPLUGINAPI

This struct is used to access VapourSynth’s API when a plugin is initially loaded.


int getAPIVersion()

See getAPIVersion() in the struct VSAPI.


int configPlugin(const char *identifier, const char *pluginNamespace, const char *name, int pluginVersion, int apiVersion, int flags, VSPlugin *plugin)

Used to provide information about a plugin when loaded. Must be called exactly once from the VapourSynthPluginInit2 entry point. It is recommended to use the VS_MAKE_VERSION macro when providing the pluginVersion. If you don’t know the specific apiVersion you actually require simply pass VAPOURSYNTH_API_VERSION to match the header version you’re compiling against. The flags consist of values from VSPluginConfigFlags ORed together but should for most plugins typically be 0.

Returns non-zero on success.


int registerFunction(const char *name, const char *args, const char *returnType, VSPublicFunction argsFunc, void *functionData, VSPlugin *plugin)

See registerFunction() in the struct VSAPI.

struct VSAPI

This giant struct is the way to access VapourSynth’s public API.


VSCore *createCore(int flags)

Creates the VapourSynth processing core and returns a pointer to it. It is possible to create multiple cores but in most cases it shouldn’t be needed.

flags

VSCoreCreationFlags ORed together if desired. Pass 0 for sane defaults that should suit most uses.


void freeCore(VSCore *core)

Frees a core. Should only be done after all frame requests have completed and all objects belonging to the core have been released.


int64_t setMaxCacheSize(int64_t bytes, VSCore *core)

Sets the maximum size of the framebuffer cache. Returns the new maximum size.


int setThreadCount(int threads, VSCore *core)

Sets the number of threads used for processing. Pass 0 to automatically detect. Returns the number of threads that will be used for processing.


void getCoreInfo(VSCore *core, VSCoreInfo *info)

Returns information about the VapourSynth core.


int getAPIVersion()

Returns the highest VAPOURSYNTH_API_VERSION the library support.


void logMessage(int msgType, const char *msg, VSCore *core)

Send a message through VapourSynth’s logging framework. See addLogHandler.

msgType

The type of message. One of VSMessageType.

If msgType is mtFatal, VapourSynth will call abort() after delivering the message.

msg

The message.


VSLogHandle *addLogHandler(VSLogHandler handler, VSLogHandlerFree free, void *userData, VSCore *core)

Installs a custom handler for the various error messages VapourSynth emits. The message handler is per VSCore instance. Returns a unique handle.

If no log handler is installed up to a few hundred messages are cached and will be delivered as soon as a log handler is attached. This behavior exists mostly so that warnings when auto-loading plugins (default behavior) won’t disappear-

handler

typedef void (VS_CC *VSLogHandler)(int msgType, const char *msg, void *userdata)

Custom message handler. If this is NULL, the default message handler will be restored.

msgType

The type of message. One of VSMessageType.

If msgType is mtFatal, VapourSynth will call abort() after the message handler returns.

msg

The message.

free

typedef void (VS_CC *VSLogHandlerFree)(void *userData)

Called when a handler is removed.

userData

Pointer that gets passed to the message handler.


int removeLogHandler(VSLogHandle *handle, VSCore *core)

Removes a custom handler. Return non-zero on success and zero if the handle is invalid.

handle

Handle obtained from addLogHandler().


VSFrame *newVideoFrame(const VSVideoFormat *format, int width, int height, const VSFrame *propSrc, VSCore *core)

Creates a new video frame, optionally copying the properties attached to another frame. It is a fatal error to pass invalid arguments to this function.

The new frame contains uninitialised memory.

format

The desired colorspace format. Must not be NULL.

width

height

The desired dimensions of the frame, in pixels. Must be greater than 0 and have a suitable multiple for the subsampling in format.

propSrc

A frame from which properties will be copied. Can be NULL.

Returns a pointer to the created frame. Ownership of the new frame is transferred to the caller.

See also newVideoFrame2().


VSFrame *newVideoFrame2(const VSVideoFormat *format, int width, int height, const VSFrame **planeSrc, const int *planes, const VSFrame *propSrc, VSCore *core)

Creates a new video frame from the planes of existing frames, optionally copying the properties attached to another frame. It is a fatal error to pass invalid arguments to this function.

format

The desired colorspace format. Must not be NULL.

width

height

The desired dimensions of the frame, in pixels. Must be greater than 0 and have a suitable multiple for the subsampling in format.

planeSrc

Array of frames from which planes will be copied. If any elements of the array are NULL, the corresponding planes in the new frame will contain uninitialised memory.

planes

Array of plane numbers indicating which plane to copy from the corresponding source frame.

propSrc

A frame from which properties will be copied. Can be NULL.

Returns a pointer to the created frame. Ownership of the new frame is transferred to the caller.

Example (assume frameA, frameB, frameC are existing frames):

const VSFrame * frames[3] = { frameA, frameB, frameC };
const int planes[3] = { 1, 0, 2 };
VSFrame * newFrame = vsapi->newVideoFrame2(f, w, h, frames, planes, frameB, core);

The newFrame’s first plane is now a copy of frameA’s second plane, the second plane is a copy of frameB’s first plane, the third plane is a copy of frameC’s third plane and the properties have been copied from frameB.


VSFrame *newAudioFrame(const VSAudioFormat *format, int numSamples, const VSFrame *propSrc, VSCore *core)

Creates a new audio frame, optionally copying the properties attached to another frame. It is a fatal error to pass invalid arguments to this function.

The new frame contains uninitialised memory.

format

The desired audio format. Must not be NULL.

numSamples

The number of samples in the frame. All audio frames apart from the last one returned by a filter must have VS_AUDIO_FRAME_SAMPLES.

propSrc

A frame from which properties will be copied. Can be NULL.

Returns a pointer to the created frame. Ownership of the new frame is transferred to the caller.

See also newAudioFrame2().


VSFrame *newAudioFrame2(const VSAudioFormat *format, int numSamples, const VSFrame **channelSrc, const int *channels, const VSFrame *propSrc, VSCore *core)

Creates a new audio frame, optionally copying the properties attached to another frame. It is a fatal error to pass invalid arguments to this function.

The new frame contains uninitialised memory.

format

The desired audio format. Must not be NULL.

numSamples

The number of samples in the frame. All audio frames apart from the last one returned by a filter must have VS_AUDIO_FRAME_SAMPLES.

channelSrc

Array of frames from which channels will be copied. If any elements of the array are NULL, the corresponding planes in the new frame will contain uninitialised memory.

channels

Array of channel numbers indicating which channel to copy from the corresponding source frame. Note that the number refers to the nth channel and not a channel name constant.

propSrc

A frame from which properties will be copied. Can be NULL.

Returns a pointer to the created frame. Ownership of the new frame is transferred to the caller.

See also newVideoFrame2().


void freeFrame(const VSFrame *f)

Decrements the reference count of a frame and deletes it when it reaches 0.

It is safe to pass NULL.


const VSFrame *addFrameRef(const VSFrame *f)

Increments the reference count of a frame. Returns f as a convenience.


VSFrame *copyFrame(const VSFrame *f, VSCore *core)

Duplicates the frame (not just the reference). As the frame buffer is shared in a copy-on-write fashion, the frame content is not really duplicated until a write operation occurs. This is transparent for the user.

Returns a pointer to the new frame. Ownership is transferred to the caller.


const VSMap *getFramePropertiesRO(const VSFrame *f)

Returns a read-only pointer to a frame’s properties. The pointer is valid as long as the frame lives.


VSMap *getFramePropertiesRW(VSFrame *f)

Returns a read/write pointer to a frame’s properties. The pointer is valid as long as the frame lives.


ptrdiff_t getStride(const VSFrame *f, int plane)

Returns the distance in bytes between two consecutive lines of a plane of a video frame. The stride is always positive. Returns 0 if the requested plane doesn’t exist or if it isn’t a video frame.


const uint8_t *getReadPtr(const VSFrame *f, int plane)

Returns a read-only pointer to a plane or channel of a frame. Returns NULL if an invalid plane or channel number is passed.

Note

Don’t assume all three planes of a frame are allocated in one contiguous chunk (they’re not).


uint8_t *getWritePtr(VSFrame *f, int plane)

Returns a read-write pointer to a plane or channel of a frame. Returns NULL if an invalid plane or channel number is passed.

Note

Don’t assume all three planes of a frame are allocated in one contiguous chunk (they’re not).


const VSVideoFormat *getVideoFrameFormat(const VSFrame *f)

Retrieves the format of a video frame.


const VSAudioFormat *getAudioFrameFormat(const VSFrame *f)

Retrieves the format of an audio frame.


int getFrameType(const VSFrame *f)

Returns a value from VSMediaType to distinguish audio and video frames.


int getFrameWidth(const VSFrame *f, int plane)

Returns the width of a plane of a given video frame, in pixels. The width depends on the plane number because of the possible chroma subsampling. Returns 0 for audio frames.


int getFrameHeight(const VSFrame *f, int plane)

Returns the height of a plane of a given video frame, in pixels. The height depends on the plane number because of the possible chroma subsampling. Returns 0 for audio frames.


int getFrameLength(const VSFrame *f)

Returns the number of audio samples in a frame. Always returns 1 for video frames.


void createVideoFilter(VSMap *out, const char *name, const VSVideoInfo *vi, VSFilterGetFrame getFrame, VSFilterFree free, int filterMode, const VSFilterDependency *dependencies, int numDeps, void *instanceData, VSCore *core)

Creates a new video filter node.

out

Output map for the filter node.

name

Instance name. Please make it the same as the filter’s name for easy identification.

vi

The output format of the filter.

getFrame

The filter’s “getframe” function. Must not be NULL.

free

The filter’s “free” function. Can be NULL.

filterMode

One of VSFilterMode. Indicates the level of parallelism supported by the filter.

dependencies

An array of nodes the filter requests frames from and the access pattern. Used to more efficiently configure caches.

numDeps

Length of the dependencies array.

instanceData

A pointer to the private filter data. This pointer will be passed to the getFrame and free functions. It should be freed by the free function.

After this function returns, out will contain the new node appended to the “clip” property, or an error, if something went wrong.


VSNode *createVideoFilter2(const char *name, const VSVideoInfo *vi, VSFilterGetFrame getFrame, VSFilterFree free, int filterMode, const VSFilterDependency *dependencies, int numDeps, void *instanceData, VSCore *core)

Identical to createVideoFilter except that the new node is returned instead of appended to the out map. Returns NULL on error.


void createAudioFilter(VSMap *out, const char *name, const VSAudioInfo *ai, VSFilterGetFrame getFrame, VSFilterFree free, int filterMode, const VSFilterDependency *dependencies, int numDeps, void *instanceData, VSCore *core)

Creates a new video filter node.

out

Output map for the filter node.

name

Instance name. Please make it the same as the filter’s name for easy identification.

ai

The output format of the filter.

getFrame

The filter’s “getframe” function. Must not be NULL.

free

The filter’s “free” function. Can be NULL.

filterMode

One of VSFilterMode. Indicates the level of parallelism supported by the filter.

dependencies

An array of nodes the filter requests frames from and the access pattern. Used to more efficiently configure caches.

numDeps

Length of the dependencies array.

instanceData

A pointer to the private filter data. This pointer will be passed to the getFrame and free functions. It should be freed by the free function.

After this function returns, out will contain the new node appended to the “clip” property, or an error, if something went wrong.


VSNode *createAudioFilter2(const char *name, const VSAudioInfo *ai, VSFilterGetFrame getFrame, VSFilterFree free, int filterMode, const VSFilterDependency *dependencies, int numDeps, void *instanceData, VSCore *core)

Identical to createAudioFilter except that the new node is returned instead of appended to the out map. Returns NULL on error.


int setLinearFilter(VSNode *node)

Must be called immediately after audio or video filter creation. Returns the upper bound of how many additional frames it is reasonable to pass to cacheFrame when trying to make a request more linear.


void setCacheMode(VSNode *node, int mode)

Determines the strategy for frame caching. Pass a VSCacheMode constant. Mostly useful for cache debugging since the auto mode should work well in just about all cases. Calls to this function may also be silently ignored.

Resets the cache to default options when called, discarding setCacheOptions changes.


void setCacheOptions(VSNode *node, int fixedSize, int maxSize, int maxHistorySize)

Call after setCacheMode or the changes will be discarded. Sets internal details of a node’s associated cache. Calls to this function may also be silently ignored.

fixedSize

Set to non-zero to make the cache always hold maxSize frames.

maxSize

The maximum number of frames to cache. Note that this value is automatically adjusted using an internal algorithm unless fixedSize is set.

maxHistorySize

How many frames that have been recently evicted from the cache to keep track off. Used to determine if growing or shrinking the cache is beneficial. Has no effect when fixedSize is set.


void freeNode(VSNode *node)

Decreases the reference count of a node and destroys it once it reaches 0.

It is safe to pass NULL.


VSNode *addNodeRef(VSNode *node)

Increment the reference count of a node. Returns the same node for convenience.


int getNodeType(VSNode *node)

Returns VSMediaType. Used to determine if a node is of audio or video type.


const VSVideoInfo *getVideoInfo(VSNode *node)

Returns a pointer to the video info associated with a node. The pointer is valid as long as the node lives. It is undefined behavior to pass a non-video node.


const VSAudioInfo *getAudioInfo(VSNode *node)

Returns a pointer to the audio info associated with a node. The pointer is valid as long as the node lives. It is undefined behavior to pass a non-audio node.


int getVideoFormatName(const VSVideoFormat *format, char *buffer)

Tries to output a fairly human-readable name of a video format.

format

The input video format.

buffer

Destination buffer. At most 32 bytes including terminating NULL will be written.

Returns non-zero on success.


int getAudioFormatName(const VSAudioFormat *format, char *buffer)

Tries to output a fairly human-readable name of an audio format.

format

The input audio format.

buffer

Destination buffer. At most 32 bytes including terminating NULL will be written.

Returns non-zero on success.


int queryVideoFormat(VSVideoFormat *format, int colorFamily, int sampleType, int bitsPerSample, int subSamplingW, int subSamplingH, VSCore *core)

Fills out a VSVideoInfo struct based on the provided arguments. Validates the arguments before filling out format.

format

The struct to fill out.

colorFamily

One of VSColorFamily.

sampleType

One of VSSampleType.

bitsPerSample

Number of meaningful bits for a single component. The valid range is 8-32.

For floating point formats only 16 or 32 bits are allowed.

subSamplingW

log2 of the horizontal chroma subsampling. 0 == no subsampling. The valid range is 0-4.

subSamplingH

log2 of the vertical chroma subsampling. 0 == no subsampling. The valid range is 0-4.

Note

RGB formats are not allowed to be subsampled in VapourSynth.

Returns non-zero on success.


int queryAudioFormat(VSAudioFormat *format, int sampleType, int bitsPerSample, uint64_t channelLayout, VSCore *core)

Fills out a VSAudioFormat struct based on the provided arguments. Validates the arguments before filling out format.

format

The struct to fill out.

sampleType

One of VSSampleType.

bitsPerSample

Number of meaningful bits for a single component. The valid range is 8-32.

For floating point formats only 32 bits are allowed.

channelLayout

A bitmask constructed from bitshifted constants in VSAudioChannels. For example stereo is expressed as (1 << acFrontLeft) | (1 << acFrontRight).

Returns non-zero on success.


uint32_t queryVideoFormatID(int colorFamily, int sampleType, int bitsPerSample, int subSamplingW, int subSamplingH, VSCore *core)

Get the id associated with a video format. Similar to queryVideoFormat() except that it returns a format id instead of filling out a VSVideoInfo struct.

colorFamily

One of VSColorFamily.

sampleType

One of VSSampleType.

bitsPerSample

Number of meaningful bits for a single component. The valid range is 8-32.

For floating point formats, only 16 or 32 bits are allowed.

subSamplingW

log2 of the horizontal chroma subsampling. 0 == no subsampling. The valid range is 0-4.

subSamplingH

log2 of the vertical chroma subsampling. 0 == no subsampling. The valid range is 0-4.

Note

RGB formats are not allowed to be subsampled in VapourSynth.

Returns a valid format id if the provided arguments are valid, on error 0 is returned.


int getVideoFormatByID(VSVideoFormat *format, uint32_t id, VSCore *core)

Fills out the VSVideoFormat struct passed to format based

format

The struct to fill out.

id

The format identifier: one of VSPresetVideoFormat or a value gotten from queryVideoFormatID.

Returns 0 on failure and non-zero on success.


VSMap *createMap(void)

Creates a new property map. It must be deallocated later with freeMap().


void freeMap(VSMap *map)

Frees a map and all the objects it contains.


void clearMap(VSMap *map)

Deletes all the keys and their associated values from the map, leaving it empty.


const char *mapGetError(const VSMap *map)

Returns a pointer to the error message contained in the map, or NULL if there is no error set. The pointer is valid until the next modifying operation on the map.


void mapSetError(VSMap *map, const char *errorMessage)

Adds an error message to a map. The map is cleared first. The error message is copied. In this state the map may only be freed, cleared or queried for the error message.

For errors encountered in a filter’s “getframe” function, use setFilterError.


int mapNumKeys(const VSMap *map)

Returns the number of keys contained in a property map.


const char *mapGetKey(const VSMap *map, int index)

Returns the nth key from a property map.

Passing an invalid index will cause a fatal error.

The pointer is valid as long as the key exists in the map.


int mapDeleteKey(VSMap *map, const char *key)

Removes the property with the given key. All values associated with the key are lost.

Returns 0 if the key isn’t in the map. Otherwise it returns 1.


int mapNumElements(const VSMap *map, const char *key)

Returns the number of elements associated with a key in a property map. Returns -1 if there is no such key in the map.


int mapGetType(const VSMap *map, const char *key)

Returns a value from VSPropertyType representing type of elements in the given key. If there is no such key in the map, the returned value is ptUnset. Note that also empty arrays created with mapSetEmpty are typed.


int mapSetEmpty(const VSMap *map, const char *key, int type)

Creates an empty array of type in key. Returns non-zero value on failure due to key already existing or having an invalid name.


int64_t mapGetInt(const VSMap *map, const char *key, int index, int *error)

Retrieves an integer from a specified key in a map.

Returns the number on success, or 0 in case of error.

If the map has an error set (i.e. if mapGetError() returns non-NULL), VapourSynth will die with a fatal error.

index

Zero-based index of the element.

Use mapNumElements() to know the total number of elements associated with a key.

error

One of VSMapPropertyError, peSuccess on success.

You may pass NULL here, but then any problems encountered while retrieving the property will cause VapourSynth to die with a fatal error.


int mapGetIntSaturated(const VSMap *map, const char *key, int index, int *error)

Works just like mapGetInt() except that the value returned is also converted to an integer using saturation.


const int64_t *mapGetIntArray(const VSMap *map, const char *key, int *error)

Retrieves an array of integers from a map. Use this function if there are a lot of numbers associated with a key, because it is faster than calling mapGetInt() in a loop.

Returns a pointer to the first element of the array on success, or NULL in case of error. Use mapNumElements() to know the total number of elements associated with a key.

See mapGetInt() for a complete description of the arguments and general behavior.


int mapSetInt(VSMap *map, const char *key, int64_t i, int append)

Sets an integer to the specified key in a map.

Multiple values can be associated with one key, but they must all be the same type.

key

Name of the property. Alphanumeric characters and underscore may be used.

i

Value to store.

append

One of VSMapAppendMode.

Returns 0 on success, or 1 if trying to append to a property with the wrong type to an existing key.


int mapSetIntArray(VSMap *map, const char *key, const int64_t *i, int size)

Adds an array of integers to a map. Use this function if there are a lot of numbers to add, because it is faster than calling mapSetInt() in a loop.

If map already contains a property with this key, that property will be overwritten and all old values will be lost.

key

Name of the property. Alphanumeric characters and underscore may be used.

i

Pointer to the first element of the array to store.

size

Number of integers to read from the array. It can be 0, in which case no integers are read from the array, and the property will be created empty.

Returns 0 on success, or 1 if size is negative.


double mapGetFloat(const VSMap *map, const char *key, int index, int *error)

Retrieves a floating point number from a map.

Returns the number on success, or 0 in case of error.

See mapGetInt() for a complete description of the arguments and general behavior.


float mapGetFloatSaturated(const VSMap *map, const char *key, int index, int *error)

Works just like mapGetFloat() except that the value returned is also converted to a float.


const double *mapGetFloatArray(const VSMap *map, const char *key, int *error)

Retrieves an array of floating point numbers from a map. Use this function if there are a lot of numbers associated with a key, because it is faster than calling mapGetFloat() in a loop.

Returns a pointer to the first element of the array on success, or NULL in case of error. Use mapNumElements() to know the total number of elements associated with a key.

See mapGetInt() for a complete description of the arguments and general behavior.


int mapSetFloat(VSMap *map, const char *key, double d, int append)

Sets a float to the specified key in a map.

See mapSetInt() for a complete description of the arguments and general behavior.


int mapSetFloatArray(VSMap *map, const char *key, const double *d, int size)

Adds an array of floating point numbers to a map. Use this function if there are a lot of numbers to add, because it is faster than calling mapSetFloat() in a loop.

If map already contains a property with this key, that property will be overwritten and all old values will be lost.

key

Name of the property. Alphanumeric characters and underscore may be used.

d

Pointer to the first element of the array to store.

size

Number of floating point numbers to read from the array. It can be 0, in which case no numbers are read from the array, and the property will be created empty.

Returns 0 on success, or 1 if size is negative.


const char *mapGetData(const VSMap *map, const char *key, int index, int *error)

Retrieves arbitrary binary data from a map. Checking mapGetDataTypeHint() may provide a hint about whether or not the data is human readable.

Returns a pointer to the data on success, or NULL in case of error.

The array returned is guaranteed to be NULL-terminated. The NULL byte is not considered to be part of the array (mapGetDataSize doesn’t count it).

The pointer is valid until the map is destroyed, or until the corresponding key is removed from the map or altered.

See mapGetInt() for a complete description of the arguments and general behavior.


int mapGetDataSize(const VSMap *map, const char *key, int index, int *error)

Returns the size in bytes of a property of type ptData (see VSPropertyType), or 0 in case of error. The terminating NULL byte added by mapSetData() is not counted.

See mapGetInt() for a complete description of the arguments and general behavior.


int mapGetDataTypeHint(const VSMap *map, const char *key, int index, int *error)

Returns the size in bytes of a property of type ptData (see VSPropertyType), or 0 in case of error. The terminating NULL byte added by mapSetData() is not counted.

See mapGetInt() for a complete description of the arguments and general behavior.


int mapSetData(VSMap *map, const char *key, const char *data, int size, int type, int append)

Sets binary data to the specified key in a map.

Multiple values can be associated with one key, but they must all be the same type.

key

Name of the property. Alphanumeric characters and the underscore may be used.

data

Value to store.

This function copies the data, so the pointer should be freed when no longer needed. A terminating NULL is always added to the copied data but not included in the total size to make string handling easier.

size

The number of bytes to copy. If this is negative, everything up to the first NULL byte will be copied.

type

One of VSDataTypeHint to hint whether or not it is human readable data.

append

One of VSMapAppendMode.

Returns 0 on success, or 1 if trying to append to a property with the wrong type.


VSNode *mapGetNode(const VSMap *map, const char *key, int index, int *error)

Retrieves a node from a map.

Returns a pointer to the node on success, or NULL in case of error.

This function increases the node’s reference count, so freeNode() must be used when the node is no longer needed.

See mapGetInt() for a complete description of the arguments and general behavior.


int mapSetNode(VSMap *map, const char *key, VSNode *node, int append)

Sets a node to the specified key in a map.

See mapSetInt() for a complete description of the arguments and general behavior.


int mapConsumeNode(VSMap *map, const char *key, VSNode *node, int append)

Sets a node to the specified key in a map and decreases the reference count.

See mapSetInt() for a complete description of the arguments and general behavior.


const VSFrame *mapGetFrame(const VSMap *map, const char *key, int index, int *error)

Retrieves a frame from a map.

Returns a pointer to the frame on success, or NULL in case of error.

This function increases the frame’s reference count, so freeFrame() must be used when the frame is no longer needed.

See mapGetInt() for a complete description of the arguments and general behavior.


int mapSetFrame(VSMap *map, const char *key, const VSFrame *f, int append)

Sets a frame to the specified key in a map.

See mapSetInt() for a complete description of the arguments and general behavior.


int mapConsumeFrame(VSMap *map, const char *key, const VSFrame *f, int append)

Sets a frame to the specified key in a map and decreases the reference count.

See mapSetInt() for a complete description of the arguments and general behavior.


VSFunctionRef *mapGetFunction(const VSMap *map, const char *key, int index, int *error)

Retrieves a function from a map.

Returns a pointer to the function on success, or NULL in case of error.

This function increases the function’s reference count, so freeFunction() must be used when the function is no longer needed.

See mapGetInt() for a complete description of the arguments and general behavior.


int mapSetFunction(VSMap *map, const char *key, VSFunction *func, int append)

Sets a function object to the specified key in a map.

See mapSetInt() for a complete description of the arguments and general behavior.


int mapConsumeFunction(VSMap *map, const char *key, VSFunction *func, int append)

Sets a function object to the specified key in a map and decreases the reference count.

See mapSetInt() for a complete description of the arguments and general behavior.


VSPlugin *getPluginByID(const char *identifier, VSCore *core)

Returns a pointer to the plugin with the given identifier, or NULL if not found.

identifier

Reverse URL that uniquely identifies the plugin.


VSPlugin *getPluginByNamespace(const char *ns, VSCore *core)

Returns a pointer to the plugin with the given namespace, or NULL if not found.

getPluginByID is generally a better option.

ns

Namespace.


VSPlugin *getNextPlugin(VSPlugin *plugin, VSCore *core)

Used to enumerate over all currently loaded plugins. The order is fixed but provides no other guarantees.

plugin

Current plugin. Pass NULL to get the first plugin.

Returns a pointer to the next plugin in order or NULL if the final plugin has been reached.


const char *getPluginName(VSPlugin *plugin)

Returns the name of the plugin that was passed to configPlugin.


const char *getPluginID(VSPlugin *plugin)

Returns the identifier of the plugin that was passed to configPlugin.


const char *getPluginNamespace(VSPlugin *plugin)

Returns the namespace the plugin currently is loaded in.


VSPluginFunction *getNextPluginFunction(VSPluginFunction *func, VSPlugin *plugin)

Used to enumerate over all functions in a plugin. The order is fixed but provides no other guarantees.

func

Current function. Pass NULL to get the first function.

plugin

The plugin to enumerate functions in.

Returns a pointer to the next function in order or NULL if the final function has been reached.


VSPluginFunction *getPluginFunctionByName(const char *name, VSPlugin *plugin)

Get a function belonging to a plugin by its name.


const char *getPluginFunctionName(VSPluginFunction *func)

Returns the name of the function that was passed to registerFunction.


const char *getPluginFunctionArguments(VSPluginFunction *func)

Returns the argument string of the function that was passed to registerFunction.


const char *getPluginFunctionReturnType(VSPluginFunction *func)

Returns the return type string of the function that was passed to registerFunction.


const char *getPluginPath(const VSPlugin *plugin)

Returns the absolute path to the plugin, including the plugin’s file name. This is the real location of the plugin, i.e. there are no symbolic links in the path.

Path elements are always delimited with forward slashes.

VapourSynth retains ownership of the returned pointer.


int getPluginVersion(const VSPlugin *plugin)

Returns the version of the plugin. This is the same as the version number passed to configPlugin.


VSMap *invoke(VSPlugin *plugin, const char *name, const VSMap *args)

Invokes a filter.

invoke() checks that the args passed to the filter are consistent with the argument list registered by the plugin that contains the filter, calls the filter’s “create” function, and checks that the filter returns the declared types. If everything goes smoothly, the filter will be ready to generate frames after invoke() returns.

plugin

A pointer to the plugin where the filter is located. Must not be NULL.

See getPluginByID().

name

Name of the filter to invoke.

args

Arguments for the filter.

Returns a map containing the filter’s return value(s). The caller takes ownership of the map. Use mapGetError() to check if the filter was invoked successfully.

Most filters will either set an error, or one or more clips with the key “clip”. The exception to this are functions, for example LoadPlugin, which doesn’t return any clips for obvious reasons.


VSFunction *createFunction(VSPublicFunction func, void *userData, VSFreeFunctionData free, VSCore *core)

func

typedef void (VS_CC *VSPublicFunction)(const VSMap *in, VSMap *out, void *userData, VSCore *core, const VSAPI *vsapi)

User-defined function that may be called in any context.

userData

Pointer passed to func.

free

typedef void (VS_CC *VSFreeFunctionData)(void *userData)

Callback tasked with freeing userData. Can be NULL.


void freeFunction(VSFunction *f)

Decrements the reference count of a function and deletes it when it reaches 0.

It is safe to pass NULL.


VSFunction *addFunctionRef(VSFunction *f)

Increments the reference count of a function. Returns f as a convenience.


void callFunction(VSFunction *func, const VSMap *in, VSMap *out)

Calls a function. If the call fails out will have an error set.

func

Function to be called.

in

Arguments passed to func.

out

Returned values from func.


const VSFrame *getFrame(int n, VSNode *node, char *errorMsg, int bufSize)

Fetches a frame synchronously. The frame is available when the function returns.

This function is meant for external applications using the core as a library, or if frame requests are necessary during a filter’s initialization.

Thread-safe.

n

The frame number. Negative values will cause an error.

node

The node from which the frame is requested.

errorMsg

Pointer to a buffer of bufSize bytes to store a possible error message. Can be NULL if no error message is wanted.

bufSize

Maximum length for the error message, in bytes (including the trailing ‘0’). Can be 0 if no error message is wanted.

Returns a reference to the generated frame, or NULL in case of failure. The ownership of the frame is transferred to the caller.

Warning

Never use inside a filter’s “getframe” function.


void getFrameAsync(int n, VSNode *node, VSFrameDoneCallback callback, void *userData)

Requests the generation of a frame. When the frame is ready, a user-provided function is called. Note that the completion callback will only be called from a single thread at a time.

This function is meant for applications using VapourSynth as a library.

Thread-safe.

n

Frame number. Negative values will cause an error.

node

The node from which the frame is requested.

callback

typedef void (VS_CC *VSFrameDoneCallback)(void *userData, const VSFrame *f, int n, VSNode *node, const char *errorMsg)

Function of the client application called by the core when a requested frame is ready, after a call to getFrameAsync().

If multiple frames were requested, they can be returned in any order. Client applications must take care of reordering them.

This function is only ever called from one thread at a time.

getFrameAsync() may be called from this function to request more frames.

userData

Pointer to private data from the client application, as passed previously to getFrameAsync().

f

Contains a reference to the generated frame, or NULL in case of failure. The ownership of the frame is transferred to the caller.

n

The frame number.

node

Node the frame belongs to.

errorMsg

String that usually contains an error message if the frame generation failed. NULL if there is no error.

userData

Pointer passed to the callback.

Warning

Never use inside a filter’s “getframe” function.


const VSFrame *getFrameFilter(int n, VSNode *node, VSFrameContext *frameCtx)

Retrieves a frame that was previously requested with requestFrameFilter().

Only use inside a filter’s “getframe” function.

A filter usually calls this function when its activation reason is arAllFramesReady or arFrameReady. See VSActivationReason.

It is safe to retrieve a frame more than once, but each reference needs to be freed.

n

The frame number.

node

The node from which the frame is retrieved.

frameCtx

The context passed to the filter’s “getframe” function.

Returns a pointer to the requested frame, or NULL if the requested frame is not available for any reason. The ownership of the frame is transferred to the caller.


void requestFrameFilter(int n, VSNode *node, VSFrameContext *frameCtx)

Requests a frame from a node and returns immediately.

Only use inside a filter’s “getframe” function.

A filter usually calls this function when its activation reason is arInitial. The requested frame can then be retrieved using getFrameFilter(), when the filter’s activation reason is arAllFramesReady. See VSActivationReason.

It is best to request frames in ascending order, i.e. n, n+1, n+2, etc.

n

The frame number. Negative values will cause an error.

node

The node from which the frame is requested.

frameCtx

The context passed to the filter’s “getframe” function.


void releaseFrameEarly(VSNode *node, int n, VSFrameContext *frameCtx)

By default all requested frames are referenced until a filter’s frame request is done. In extreme cases where a filter needs to reduce 20+ frames into a single output frame it may be beneficial to request these in batches and incrementally process the data instead.

Should rarely be needed.

Only use inside a filter’s “getframe” function.

node

The node from which the frame was requested.

n

The frame number. Invalid frame numbers (not cached or negative) will simply be ignored.

frameCtx

The context passed to the filter’s “getframe” function.


int registerFunction(const char *name, const char *args, const char *returnType, VSPublicFunction argsFunc, void *functionData, VSPlugin *plugin)

Function that registers a filter exported by the plugin. A plugin can export any number of filters. This function may only be called during the plugin loading phase unless the pcModifiable flag was set by configPlugin.

name

Filter name. The characters allowed are letters, numbers, and the underscore. The first character must be a letter. In other words: ^[a-zA-Z][a-zA-Z0-9_]*$

Filter names should be PascalCase.

args

String containing the filter’s list of arguments.

Arguments are separated by a semicolon. Each argument is made of several fields separated by a colon. Don’t insert additional whitespace characters, or VapourSynth will die.

Fields:
The argument name.

The same characters are allowed as for the filter’s name. Argument names should be all lowercase and use only letters and the underscore.

The type.

“int”: int64_t

“float”: double

“data”: const char*

“anode”: const VSNode* (audio type)

“vnode”: const VSNode* (video type)

“aframe”: const VSFrame* (audio type)

“vframe”: const VSFrame* (video type)

“func”: const VSFunctionRef*

It is possible to declare an array by appending “[]” to the type.

“opt”

If the parameter is optional.

“empty”

For arrays that are allowed to be empty.

“any”

Can only be placed last without a semicolon after. Indicates that all remaining arguments that don’t match should also be passed through.

The following example declares the arguments “blah”, “moo”, and “asdf”:

blah:vnode;moo:int[]:opt;asdf:float:opt;

The following example declares the arguments “blah” and accepts all other arguments no matter the type:

blah:vnode;any
returnType

Specifies works similarly to args but instead specifies which keys and what type will be returned. Typically this will be:

clip:vnode;

for video filters. It is important to not simply specify “any” for all filters since this information is used for better auto-completion in many editors.

argsFunc

typedef void (VS_CC *VSPublicFunction)(const VSMap *in, VSMap *out, void *userData, VSCore *core, const VSAPI *vsapi)

User-defined function called by the core to create an instance of the filter. This function is often named fooCreate.

In this function, the filter’s input parameters should be retrieved and validated, the filter’s private instance data should be initialised, and createAudioFilter() or createVideoFilter() should be called. This is where the filter should perform any other initialisation it requires.

If for some reason you cannot create the filter, you have to free any created node references using freeNode(), call mapSetError() on out, and return.

in

Input parameter list.

Use mapGetInt() and friends to retrieve a parameter value.

The map is guaranteed to exist only until the filter’s “init” function returns. In other words, pointers returned by mapGetData() will not be usable in the filter’s “getframe” and “free” functions.

out

Output parameter list. createAudioFilter() or createVideoFilter() will add the output node(s) with the key named “clip”, or an error, if something went wrong.

userData

Pointer that was passed to registerFunction().

functionData

Pointer to user data that gets passed to argsFunc when creating a filter. Useful to register multiple filters using a single argsFunc function.

plugin

Pointer to the plugin object in the core, as passed to VapourSynthPluginInit2().


void cacheFrame(const VSFrame *frame, int n, VSFrameContext *frameCtx)

Pushes a not requested frame into the cache. This is useful for (source) filters that greatly benefit from completely linear access and producing all output in linear order.

This function may only be used in filters that were created with setLinearFilter.

Only use inside a filter’s “getframe” function.


void setFilterError(const char *errorMessage, VSFrameContext *frameCtx)

Adds an error message to a frame context, replacing the existing message, if any.

This is the way to report errors in a filter’s “getframe” function. Such errors are not necessarily fatal, i.e. the caller can try to request the same frame again.

Functions

const VSAPI* getVapourSynthAPI(int version)

Returns a pointer to the global VSAPI instance.

Returns NULL if the requested API version is not supported or if the system does not meet the minimum requirements to run VapourSynth. It is recommended to pass VAPOURSYNTH_API_VERSION.

Writing plugins

A simple VapourSynth plugin which exports one filter will contain five functions: an entry point (called VapourSynthPluginInit2), a function tasked with creating a filter instance (often called fooCreate), an “init” function (often called fooInit), a “getframe” function (often called fooGetframe), and a “free” function (often called fooFree). These functions are described below.

Another thing a filter requires is an object for storing a filter instance’s private data. This object will usually contain the filter’s input nodes (if it has any) and a VSVideoInfo struct describing the video the filter wants to return.

The sdk folder in the VapourSynth source contains some examples.


typedef void (VS_CC *VSInitPlugin)(VSPlugin *plugin, const VSPLUGINAPI *vspapi)

A plugin’s entry point. It must be called VapourSynthPluginInit2. This function is called after the core loads the shared library. Its purpose is to configure the plugin and to register the filters the plugin wants to export.

plugin

A pointer to the plugin object to be initialized.

vspapi

A pointer to a VSPLUGINAPI struct with a subset of the VapourSynth API used for initializing plugins. The proper way to do things is to call configPlugin and then registerFunction for each function to export.


typedef const VSFrame *(VS_CC *VSFilterGetFrame)(int n, int activationReason, void *instanceData, void **frameData, VSFrameContext *frameCtx, VSCore *core, const VSAPI *vsapi)

A filter’s “getframe” function. It is called by the core when it needs the filter to generate a frame.

It is possible to allocate local data, persistent during the multiple calls requesting the output frame.

In case of error, call setFilterError(), free *frameData if required, and return NULL.

Depending on the VSFilterMode set for the filter, multiple output frames could be requested concurrently.

It is never called concurrently for the same frame number.

n

Requested frame number.

activationReason

One of VSActivationReason.

This function is first called with activationReason arInitial. At this point the function should request the input frames it needs and return NULL. When one or all of the requested frames are ready, this function is called again with arAllFramesReady. The function should only return a frame when called with activationReason arAllFramesReady.

If a the function is called with arError all processing has to be aborted and any.

instanceData

The filter’s private instance data.

frameData

Optional private data associated with output frame number n. It must be deallocated before the last call for the given frame (arAllFramesReady or error).

It points to a void *[4] array of memory that may be used freely. See filters like Splice and Trim for examples.

Return a reference to the output frame number n when it is ready, or NULL. The ownership of the frame is transferred to the caller.


typedef void (VS_CC *VSFilterFree)(void *instanceData, VSCore *core, const VSAPI *vsapi)

A filter’s “free” function.

This is where the filter should free everything it allocated, including its instance data.

instanceData

The filter’s private instance data.