/* This file is part of Ingen. Copyright 2007-2012 David Robillard <http://drobilla.net/> Ingen is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or any later version. Ingen 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 Affero General Public License for details. You should have received a copy of the GNU Affero General Public License along with Ingen. If not, see <http://www.gnu.org/licenses/>. */ #include <cstdlib> #include "ingen/LV2Features.hpp" using namespace std; namespace Ingen { LV2Features::LV2Features() { } void LV2Features::add_feature(SPtr<Feature> feature) { _features.push_back(feature); } LV2Features::FeatureArray::FeatureArray(FeatureVector& features) : _features(features) { _array = (LV2_Feature**)malloc(sizeof(LV2_Feature) * (features.size() + 1)); _array[features.size()] = NULL; for (size_t i = 0; i < features.size(); ++i) { _array[i] = features[i].get(); } } LV2Features::FeatureArray::~FeatureArray() { free(_array); } bool LV2Features::is_supported(const std::string& uri) const { for (const auto& f : _features) { if (f->uri() == uri) { return true; } } return false; } SPtr<LV2Features::FeatureArray> LV2Features::lv2_features(World* world, Node* node) const { FeatureArray::FeatureVector vec; for (const auto& f : _features) { SPtr<LV2_Feature> fptr = f->feature(world, node); if (fptr) { vec.push_back(fptr); } } return SPtr<FeatureArray>(new FeatureArray(vec)); } } // namespace Ingen