Copyright (c) 2005, 2015 IBM Corporation and others. This program and the accompanying materials are made available under the terms of the Eclipse Public License 2.0 which accompanies this distribution, and is available at https://www.eclipse.org/legal/epl-2.0/ SPDX-License-Identifier: EPL-2.0 Contributors: IBM Corporation - initial API and implementation
/******************************************************************************* * Copyright (c) 2005, 2015 IBM Corporation and others. * * This program and the accompanying materials * are made available under the terms of the Eclipse Public License 2.0 * which accompanies this distribution, and is available at * https://www.eclipse.org/legal/epl-2.0/ * * SPDX-License-Identifier: EPL-2.0 * * Contributors: * IBM Corporation - initial API and implementation *******************************************************************************/
package org.eclipse.jdt.internal.launching; import java.io.ByteArrayInputStream; import java.io.IOException; import java.util.HashMap; import java.util.HashSet; import java.util.Iterator; import java.util.List; import java.util.Map; import java.util.Set; import org.eclipse.core.runtime.CoreException; import org.eclipse.core.runtime.preferences.IEclipsePreferences; import org.eclipse.core.runtime.preferences.IPreferenceNodeVisitor; import org.eclipse.core.runtime.preferences.InstanceScope; import org.eclipse.core.runtime.preferences.PreferenceModifyListener; import org.eclipse.jdt.launching.IVMInstall; import org.eclipse.jdt.launching.JavaRuntime; import org.eclipse.jdt.launching.VMStandin; import org.osgi.service.prefs.BackingStoreException;
Manages import of installed JREs. Merges valid imported JREs with existing JREs.
Since:3.1
/** * Manages import of installed JREs. Merges valid imported JREs with existing JREs. * * @since 3.1 */
public class JREPreferenceModifyListener extends PreferenceModifyListener { class Visitor implements IPreferenceNodeVisitor { @Override public boolean visit(IEclipsePreferences node) throws BackingStoreException { if (node.name().equals(LaunchingPlugin.getUniqueIdentifier())) { String jresXML = node.get(JavaRuntime.PREF_VM_XML, null); if (jresXML != null) { VMDefinitionsContainer vms = new VMDefinitionsContainer(); String pref = InstanceScope.INSTANCE.getNode(LaunchingPlugin.ID_PLUGIN).get(JavaRuntime.PREF_VM_XML, ""); //$NON-NLS-1$ // names -> existing vm's Map<String, IVMInstall> names = new HashMap<>(); Set<String> ids = new HashSet<>(); if (pref.length() > 0) { try { VMDefinitionsContainer container = VMDefinitionsContainer.parseXMLIntoContainer(new ByteArrayInputStream(pref.getBytes("UTF8"))); //$NON-NLS-1$ List<IVMInstall> validVMList = container.getValidVMList(); Iterator<IVMInstall> iterator = validVMList.iterator(); while (iterator.hasNext()) { IVMInstall vm = iterator.next(); names.put(vm.getName(), vm); ids.add(vm.getId()); vms.addVM(vm); } vms.setDefaultVMInstallCompositeID(container.getDefaultVMInstallCompositeID()); vms.setDefaultVMInstallConnectorTypeID(container.getDefaultVMInstallConnectorTypeID()); } catch (IOException e) { LaunchingPlugin.log(e); return false; } } // merge valid VMs with existing VMs try { ByteArrayInputStream inputStream = new ByteArrayInputStream(jresXML.getBytes("UTF8")); //$NON-NLS-1$ VMDefinitionsContainer container = VMDefinitionsContainer.parseXMLIntoContainer(inputStream); List<IVMInstall> validVMList = container.getValidVMList(); Iterator<IVMInstall> iterator = validVMList.iterator(); while (iterator.hasNext()) { IVMInstall vm = iterator.next(); IVMInstall existing = names.get(vm.getName()); if (existing != null) { // VM with same name already exists - replace with imported VM vms.removeVM(existing); ids.remove(existing.getId()); } boolean collision = ids.contains(vm.getId()); if (collision) { // conflicting id, create a new one with unique id long unique = System.currentTimeMillis(); while(ids.contains(String.valueOf(unique))){ unique++; } vm = new VMStandin(vm, String.valueOf(unique)); ids.add(vm.getId()); } vms.addVM(vm); } // update default VM if it exists String defaultVMInstallCompositeID = container.getDefaultVMInstallCompositeID(); validVMList = vms.getValidVMList(); iterator = validVMList.iterator(); while (iterator.hasNext()) { IVMInstall vm = iterator.next(); if (JavaRuntime.getCompositeIdFromVM(vm).equals(defaultVMInstallCompositeID)) { vms.setDefaultVMInstallCompositeID(defaultVMInstallCompositeID); break; } } } catch (IOException e) { LaunchingPlugin.log(e); return false; } try { String xml = vms.getAsXML(); node.put(JavaRuntime.PREF_VM_XML, xml); } catch (CoreException e) { LaunchingPlugin.log(e); return false; } } return false; } return true; } } @Override public IEclipsePreferences preApply(IEclipsePreferences node) { try { // force VMs to be initialized before we import the new VMs JavaRuntime.getVMInstallTypes(); node.accept(new Visitor()); } catch (BackingStoreException e) { LaunchingPlugin.log(e); } return node; } }