/* This file is part of Ingen.  Copyright (C) 2006 Dave Robillard.
 * 
 * Ingen 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.
 * 
 * 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 General Public License for details.
 * 
 * You should have received a copy of the GNU General Public License along
 * with this program; if not, write to the Free Software Foundation, Inc.,
 * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
 */

#include "ObjectStore.h"
#include "Patch.h"
#include "Node.h"
#include "Port.h"
#include "List.h"
#include "util/Path.h"
#include "Tree.h"

namespace Ingen {


/** Find the Patch at the given path.
 */
Patch*
ObjectStore::find_patch(const Path& path) 
{
	GraphObject* const object = find(path);
	return dynamic_cast<Patch*>(object);
}


/** Find the Node at the given path.
 */
Node*
ObjectStore::find_node(const Path& path) 
{
	GraphObject* const object = find(path);
	return dynamic_cast<Node*>(object);
}


/** Find the Port at the given path.
 */
Port*
ObjectStore::find_port(const Path& path) 
{
	GraphObject* const object = find(path);
	return dynamic_cast<Port*>(object);
}


/** Find the Object at the given path.
 */
GraphObject*
ObjectStore::find(const Path& path)
{
	return m_objects.find(path);
}


/** Add an object to the store. Not realtime safe.
 */
void
ObjectStore::add(GraphObject* o)
{
	//cerr << "[ObjectStore] Adding " << o->path() << endl;
	m_objects.insert(new TreeNode<GraphObject*>(o->path(), o));
}


/** Add an object to the store. Not realtime safe.
 */
void
ObjectStore::add(TreeNode<GraphObject*>* tn)
{
	//cerr << "[ObjectStore] Adding " << tn->key() << endl;
	m_objects.insert(tn);
}


/** Remove a patch from the store.
 *
 * It it the caller's responsibility to delete the returned ListNode.
 * 
 * @returns TreeNode containing object removed on success, NULL if not found.
 */
TreeNode<GraphObject*>*
ObjectStore::remove(const string& path)
{
	TreeNode<GraphObject*>* const removed = m_objects.remove(path);

	if (removed == NULL)
		cerr << "[ObjectStore] WARNING: Removing " << path << " failed." << endl;
	//else
	//	cerr << "[ObjectStore] Removed " << path << endl;
	
	return removed;
}


} // namespace Ingen