/*******************************************************************************
* Copyright (c) 2012-2015 Codenvy, S.A.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Codenvy, S.A. - initial API and implementation
*******************************************************************************/
package org.eclipse.che.ide.debug;
import org.eclipse.che.ide.api.event.ProjectActionEvent;
import org.eclipse.che.ide.api.event.ProjectActionHandler;
import org.eclipse.che.ide.collections.Collections;
import org.eclipse.che.ide.collections.StringMap;
import com.google.inject.Inject;
import com.google.inject.Singleton;
import com.google.web.bindery.event.shared.EventBus;
/**
* The manager provides to return debugger for current project.
*
* @author Andrey Plotnikov
*/
@Singleton
public class DebuggerManager {
private Debugger currentDebugger;
private StringMap<Debugger> debuggers;
/**
* Create manager.
*
* @param eventBus
*/
@Inject
protected DebuggerManager(EventBus eventBus) {
this.debuggers = Collections.createStringMap();
eventBus.addHandler(ProjectActionEvent.TYPE, new ProjectActionHandler() {
@Override
public void onProjectOpened(ProjectActionEvent event) {
currentDebugger = debuggers.get(event.getProject().getType());
}
@Override
public void onProjectClosed(ProjectActionEvent event) {
currentDebugger = null;
}
});
}
/**
* Register new debugger for the specified project type ID.
*
* @param projectTypeId
* @param debugger
*/
public void registeredDebugger(String projectTypeId, Debugger debugger) {
debuggers.put(projectTypeId, debugger);
}
/** @return debugger for project type */
public Debugger getDebugger() {
return currentDebugger;
}
}