/*
* Copyright (C) 2012 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.motorola.studio.android.emulator.device;
import static com.motorola.studio.android.common.log.StudioLogger.error;
import static com.motorola.studio.android.common.log.StudioLogger.info;
import java.util.LinkedHashMap;
import java.util.Map;
import org.eclipse.core.runtime.NullProgressMonitor;
import org.eclipse.sequoyah.device.framework.events.InstanceEvent;
import org.eclipse.sequoyah.device.framework.events.InstanceEventManager;
import org.eclipse.sequoyah.device.framework.events.InstanceEvent.InstanceEventType;
import com.motorola.studio.android.emulator.EmulatorPlugin;
import com.motorola.studio.android.emulator.device.instance.AndroidDeviceInstance;
import com.motorola.studio.android.emulator.logic.AbstractStartAndroidEmulatorLogic.LogicMode;
public class AndroidDeviceUtils
{
public static synchronized void fireDummyStartTransition(AndroidDeviceInstance instance,
String serialNumber)
{
// if instance is not already started, is not starting and is already associated to a VM...
boolean instanceStarted = instance.isStarted();
boolean instanceIsStarting = instance.getStateMachineHandler().isTransitioning();
boolean vmAlreadyUp = instance.hasDevice();
instance.setNameSuffix(serialNumber + ", " + instance.getTarget());
InstanceEventManager.getInstance().notifyListeners(
new InstanceEvent(InstanceEventType.INSTANCE_UPDATED, instance));
if (vmAlreadyUp && !instanceStarted && !instanceIsStarting)
{
info("The TmL Instance is not started/Starting, but the emulator/VM is already online. Execute a dummy start service to force a transition to start status...");
Map<Object, Object> attributes = new LinkedHashMap<Object, Object>();
attributes.put(LogicMode.class, LogicMode.DO_NOTHING);
try
{
EmulatorPlugin.getStartServiceHandler().run(instance, attributes,
new NullProgressMonitor());
}
catch (Exception e)
{
error("Failed to run the dummy start service on " + instance + " : "
+ e.getMessage());
}
}
}
/**
* Verifies whether or not a given AndroidDeviceInstance is running.
* @param androidInstance
* @return true if instance is running, false otherwise.
*/
public static boolean isInstanceStarting(AndroidDeviceInstance androidInstance)
{
return androidInstance.getStateMachineHandler().isTransitioning();
}
}