org.eclipse.jface.viewers.StructuredSelection Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of spotless-ext-greclipse Show documentation
Show all versions of spotless-ext-greclipse Show documentation
Groovy Eclipse's formatter bundled for Spotless
The newest version!
/*******************************************************************************
* Copyright (c) 2000, 2013 IBM Corporation and others.
* 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:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.jface.viewers;
import java.util.Arrays;
import java.util.Iterator;
import java.util.List;
import org.eclipse.core.runtime.Assert;
import org.eclipse.jface.resource.JFaceResources;
/**
* A concrete implementation of the IStructuredSelection
interface,
* suitable for instantiating.
*
* This class is not intended to be subclassed.
*
* @noextend This class is not intended to be subclassed by clients.
*/
public class StructuredSelection implements IStructuredSelection {
/**
* The element that make up this structured selection.
*/
private Object[] elements;
/**
* The element comparer, or null
*/
private IElementComparer comparer;
/**
* The canonical empty selection. This selection should be used instead of
* null
.
*/
public static final StructuredSelection EMPTY = new StructuredSelection();
/**
* Creates a new empty selection.
* See also the static field EMPTY
which contains an empty selection singleton.
*
* @see #EMPTY
*/
public StructuredSelection() {
}
/**
* Creates a structured selection from the given elements.
* The given element array must not be null
.
*
* @param elements an array of elements
*/
public StructuredSelection(Object[] elements) {
Assert.isNotNull(elements);
this.elements = new Object[elements.length];
System.arraycopy(elements, 0, this.elements, 0, elements.length);
}
/**
* Creates a structured selection containing a single object.
* The object must not be null
.
*
* @param element the element
*/
public StructuredSelection(Object element) {
Assert.isNotNull(element);
elements = new Object[] { element };
}
/**
* Creates a structured selection from the given List
.
* @param elements list of selected elements
*/
public StructuredSelection(List elements) {
this(elements, null);
}
/**
* Creates a structured selection from the given List
and
* element comparer. If an element comparer is provided, it will be used to
* determine equality between structured selection objects provided that
* they both are based on the same (identical) comparer. See bug
*
* @param elements
* list of selected elements
* @param comparer
* the comparer, or null
* @since 3.4
*/
public StructuredSelection(List elements, IElementComparer comparer) {
Assert.isNotNull(elements);
this.elements = elements.toArray();
this.comparer = comparer;
}
/**
* Returns whether this structured selection is equal to the given object.
* Two structured selections are equal if they contain the same elements
* in the same order.
*
* @param o the other object
* @return true
if they are equal, and false
otherwise
*/
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
//null and other classes
if (!(o instanceof StructuredSelection)) {
return false;
}
StructuredSelection s2 = (StructuredSelection) o;
// either or both empty?
if (isEmpty()) {
return s2.isEmpty();
}
if (s2.isEmpty()) {
return false;
}
boolean useComparer = comparer != null && comparer == s2.comparer;
//size
int myLen = elements.length;
if (myLen != s2.elements.length) {
return false;
}
//element comparison
for (int i = 0; i < myLen; i++) {
if (useComparer) {
if (!comparer.equals(elements[i], s2.elements[i])) {
return false;
}
} else {
if (!elements[i].equals(s2.elements[i])) {
return false;
}
}
}
return true;
}
@Override
public Object getFirstElement() {
return isEmpty() ? null : elements[0];
}
@Override
public boolean isEmpty() {
return elements == null || elements.length == 0;
}
@Override
public Iterator iterator() {
return Arrays.asList(elements == null ? new Object[0] : elements)
.iterator();
}
@Override
public int size() {
return elements == null ? 0 : elements.length;
}
@Override
public Object[] toArray() {
return elements == null ? new Object[0] : (Object[]) elements.clone();
}
@Override
public List toList() {
return Arrays.asList(elements == null ? new Object[0] : elements);
}
/**
* Internal method which returns a string representation of this
* selection suitable for debug purposes only.
*
* @return debug string
*/
@Override
public String toString() {
return isEmpty() ? JFaceResources.getString("") : toList().toString(); //$NON-NLS-1$
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy