/* Copyright 2007-2012 David Robillard Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies. THIS SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ #ifndef LV2_RESIZE_PORT_H #define LV2_RESIZE_PORT_H #include #include #define LV2_RESIZE_PORT_URI "http://lv2plug.in/ns/ext/resize-port" #ifdef __cplusplus extern "C" { #else # include #endif typedef void* LV2_Resize_Port_Feature_Data; typedef struct { LV2_Resize_Port_Feature_Data data; /** Resize a port buffer to at least @a size bytes. * * This function MAY return false, in which case the port buffer was * not resized and the port is still connected to the same location. * Plugins MUST gracefully handle this situation. * * This function MUST NOT be called from any context other than * the context associated with the port of the given index. * * The host MUST preserve the contents of the port buffer when * resizing. * * Plugins MAY resize a port many times in a single run callback. * Hosts SHOULD make this an inexpensive as possible (i.e. plugins * can liberally use this function in a similar way to realloc). */ bool (*resize_port)(LV2_Resize_Port_Feature_Data data, uint32_t index, size_t size); } LV2_Resize_Port_Feature; #ifdef __cplusplus } /* extern "C" */ #endif #endif /* LV2_RESIZE_PORT_H */