/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/***************************************************************************
 *            selection.h
 *
 *  Sat Nov 21 13:20:46 CET 2009
 *  Copyright 2009 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_SELECTION_H__
#define __DRUMGIZMO_SELECTION_H__

#include <QObject>

#include <QMap>
#include <QVector>

class Selection {
public:
  Selection(int from = 0, int to = 0, int fadein = 0, int fadeout = 0) {
    this->from = from;
    this->to = to;
    this->fadein = fadein;
    this->fadeout = fadeout;
  }
  size_t from;
  size_t to;
  size_t fadein;
  size_t fadeout;

  double energy;

  QString name;
};

typedef int sel_id_t;
#define SEL_NONE -1

class Selections : public QObject {
Q_OBJECT
public:
  Selections();

  /**
   * Add a new selection object. The new id is returned.
   * Adding a new selections will emit an added signal with the new id.
   */
  sel_id_t add(Selection selection);

  /**
   * Get a stack copy of a specific selection object, by id.
   * NOTE: If id does not exist an empty selection (from = to = 0) is
   * returned.
   */
  Selection get(sel_id_t id);

  /**
   * Return vector (unsorted) of all ids in the object.
   */
  QVector<sel_id_t> ids();

  /**
   * Set active selection (to be rendered yellow)
   */
  void setActive(sel_id_t id);

  /**
   * Get active selection id.
   */
  sel_id_t active();

public slots:
  /**
   * Update a selection by id.
   * Updating a selection will emit a updated signal.
   */
  void update(sel_id_t id, Selection selection);

  /**
   * Delete a selection by id.
   * Deleting a selection will emit a deleted signal.
   */
  void remove(sel_id_t id);

  /**
   * Delete all selections
   */
  void clear();

signals:
  /**
   * This signal is emitted when a new selection has been added.
   */
  void added(sel_id_t id);

  /**
   * This signal is emitted when an existing selection has been updated.
   */
  void updated(sel_id_t id);

  /**
   * This signal is emitted when a selection has been removed.
   */
  void removed(sel_id_t id);

  /**
   * The active selection changed.
   */
  void activeChanged(sel_id_t id);

private:
  QMap<sel_id_t, Selection> sels;
  sel_id_t nextid;
  sel_id_t act;
};


#endif/*__DRUMGIZMO_SELECTION_H__*/