view libmain.cpp @ 25:aa588f3b46a2

* Fix SV bug #1720391 -- tempo tracker output 4x too long
author Chris Cannam <c.cannam@qmul.ac.uk>
date Thu, 17 May 2007 13:29:02 +0000
parents bec0d544984b
children 3256bfa04ed8
line wrap: on
line source
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*-  vi:set ts=8 sts=4 sw=4: */

/*
    QM Vamp Plugin Set

    Centre for Digital Music, Queen Mary, University of London.
    All rights reserved.
*/

#include <vamp/vamp.h>
#include <vamp-sdk/PluginAdapter.h>

#include "plugins/BeatDetect.h"
#include "plugins/ChromagramPlugin.h"
#include "plugins/ConstantQSpectrogram.h"
#include "plugins/TonalChangeDetect.h"
#include "plugins/KeyDetect.h"

static Vamp::PluginAdapter<BeatDetector> beatDetectorAdapter;
static Vamp::PluginAdapter<ChromagramPlugin> chromagramPluginAdapter;
static Vamp::PluginAdapter<ConstantQSpectrogram> constantQAdapter;
static Vamp::PluginAdapter<TonalChangeDetect> tonalChangeDetectorAdapter;
static Vamp::PluginAdapter<KeyDetector> keyDetectorAdapter;

const VampPluginDescriptor *vampGetPluginDescriptor(unsigned int vampApiVersion,
                                                    unsigned int index)
{
    if (vampApiVersion < 1) return 0;

    switch (index) {
    case  0: return beatDetectorAdapter.getDescriptor();
    case  1: return chromagramPluginAdapter.getDescriptor();
    case  2: return constantQAdapter.getDescriptor();
    case  3: return tonalChangeDetectorAdapter.getDescriptor();
    case  4: return keyDetectorAdapter.getDescriptor();
    default: return 0;
    }
}