/*
This file is part of Ingen.
Copyright 2007-2012 David Robillard
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 .
*/
#include
#include "ingen/LV2Features.hpp"
using namespace std;
namespace Ingen {
LV2Features::LV2Features()
{
}
void
LV2Features::add_feature(SPtr 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::lv2_features(World* world, Node* node) const
{
FeatureArray::FeatureVector vec;
for (const auto& f : _features) {
SPtr fptr = f->feature(world, node);
if (fptr) {
vec.push_back(fptr);
}
}
return SPtr(new FeatureArray(vec));
}
} // namespace Ingen