/ VST Home / Technical Documentation

[3.0.0] Interfaces supported by the host

On this page:

Related pages


List of interfaces supported/implemented by the host in VST 3.0.0

IAttributeList

Attribute list used in IMessage and IStreamAttributes.

  • [host imp]
  • [released: 3.0.0]
  • [mandatory]

An attribute list associates values with a key (id: some predefined keys can be found in Predefined Preset Attributes).

IComponentHandler

Host callback interface for an edit controller.

  • [host imp]
  • [released: 3.0.0]
  • [mandatory]

Allow transfer of parameter editing to component (processor) via host and support automation. Cause the host to react on configuration changes (restartComponent).

See also IEditController.

IEventList

List of events to process.

  • [host imp]
  • [released: 3.0.0]
  • [mandatory]

See also ProcessData, Event.

IUnitHandler

Host callback for unit support.

Host callback interface, used with IUnitInfo. Retrieve via queryInterface from IComponentHandler.

See also VST 3 Units, IUnitInfo.

IHostApplication

Basic host callback interface.

Basic VST host application interface.

IMessage

Private plug-in message.

Messages are sent from the processor component to then controller component and vice versa.

See also IAttributeList, IConnectionPoint, Communication between the components.

IParamValueQueue

Queue of changes for a specific parameter.

  • [host imp]
  • [released: 3.0.0]
  • [mandatory]

The change queue can be interpreted as segment of an automation curve. For each processing block, a segment with the size of the block is transmitted to the processor. The curve is expressed as sampling points of a linear approximation of the original automation curve. If the original already is a linear curve, it can be transmitted precisely. A non-linear curve has to be converted to a linear approximation by the host. Every point of the value queue defines a linear section of the curve as a straight line from the previous point of a block to the new one. So the plug-in can calculate the value of the curve for any sample position in the block.

Implicit Points:
In each processing block, the section of the curve for each parameter is transmitted. In order to reduce the amount of points, the point at block position 0 can be omitted.

  • If the curve has a slope of 0 over a period of multiple blocks, only one point is transmitted for the block where the constant curve section starts. The queue for the following blocks will be empty as long as the curve slope is 0.

  • If the curve has a constant slope other than 0 over the period of several blocks, only the value for the last sample of the block is transmitted. In this case, the last valid point is at block position -1. The processor can calculate the value for each sample in the block by using a linear interpolation:

    double x1 = -1; // position of last point related to current buffer
    double y1 = currentParameterValue; // last transmitted value
    
    int32 pointTime = 0;
    ParamValue pointValue = 0;
    IParamValueQueue::getPoint (0, pointTime, pointValue);
    
    double x2 = pointTime;
    double y2 = pointValue;
    
    double slope = (y2 - y1) / (x2 - x1);
    double offset = y1 - (slope * x1);
    
    double curveValue = (slope * bufferTime) + offset; // bufferTime is any position in buffer
    

Jumps:
A jump in the automation curve has to be transmitted as two points: one with the old value and one with the new value at the next sample position.

Tech_doc_29

See also IParameterChanges, ProcessData.

IParameterChanges

All parameter changes of a processing block.

  • [host imp]
  • [released: 3.0.0]
  • [mandatory]

This interface is used to transmit any changes to be applied to parameters in the current processing block. A change can be caused by GUI interaction as well as automation. Changes are transmitted as a list of queues (IParamValueQueue) containing only queues for parameters that actually did change.

See IParamValueQueue, ProcessData.

IPlugFrame

Callback interface passed to IPlugView.

  • [host imp]
  • [released: 3.0.0]
  • [mandatory]

Enables a plug-in to resize the view and causes the host to resize the window.