/******************************************************************************* * Copyright (c) 2012-2017 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.api.debugger.server; import org.eclipse.che.api.debugger.server.Debugger.DebuggerCallback; import org.eclipse.che.api.debugger.server.exceptions.DebuggerException; import java.util.Map; /** * Responsibility to create a new {@link Debugger} instance of specific type every time * client starts a new debugger session. * * @author Anatoliy Bazko */ public interface DebuggerFactory { /** * Returns a debugger type. */ String getType(); /** * Creates a new {@link Debugger} instance with given properties. * * @param properties * the specific properties to create debugger with * @param debuggerCallback * is used to sent any events back to the client * * @return {@link Debugger} * @throws DebuggerException * if any exception occurred */ Debugger create(Map<String, String> properties, DebuggerCallback debuggerCallback) throws DebuggerException; }