/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/***************************************************************************
 *            event.h
 *
 *  Sat Sep 18 22:02:16 CEST 2010
 *  Copyright 2010 Bent Bisballe Nyeng
 *  deva@aasimon.org
 ****************************************************************************/

/*
 *  This file is part of DrumGizmo.
 *
 *  DrumGizmo is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  DrumGizmo 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 General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with DrumGizmo; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA.
 */
#ifndef __DRUMGIZMO_EVENTS_H__
#define __DRUMGIZMO_EVENTS_H__

#include <map>
#include <stdio.h>
#include <string>
#include <sndfile.h>

#include "audiofile.h"
#include "audio.h"
#include "mutex.h"
#include "cachemanager.h"

typedef unsigned int timepos_t;

class Event {
public:
  virtual ~Event() {}

  typedef enum {
    sample
  } type_t;
  
  virtual type_t type() = 0;

  channel_t channel;
  timepos_t offset;
};

#define NO_RAMPDOWN -1
class EventSample : public Event {
public:
  EventSample(channel_t c, float g, AudioFile *af, std::string grp,
              void *instr)
  {
    cache_id = CACHE_NOID;
    channel = c;
    gain = g;
    t = 0;
    file = af;
    group = grp;
    instrument = instr;
    rampdown = NO_RAMPDOWN;
    ramp_start = 0;
  }

  Event::type_t type() { return Event::sample; }

  cacheid_t cache_id;
  sample_t *buffer;
  size_t buffer_size;

  float gain;
  unsigned int t;
  AudioFile *file;
  std::string group;
  void *instrument;
  int rampdown;
  int ramp_start;
};

class EventQueue {
public:
  void post(Event *event, timepos_t time);
  Event *take(timepos_t time);
  bool hasEvent(timepos_t time);
  size_t size() { return queue.size(); }

private:
  std::multimap< timepos_t, Event* > queue;
  Mutex mutex;
};

#endif/*__DRUMGIZMO_EVENTS_H__*/