All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.jface.viewers.ArrayContentProvider Maven / Gradle / Ivy

There is a newer version: 3.29.0
Show newest version
/*******************************************************************************
 * Copyright (c) 2000, 2008 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.Collection;

/**
 * This implementation of IStructuredContentProvider handles
 * the case where the viewer input is an unchanging array or collection of elements.
 * 

* This class is not intended to be subclassed outside the viewer framework. *

* * @since 1.0 * @noextend This class is not intended to be subclassed by clients. */ public class ArrayContentProvider implements IStructuredContentProvider { private static ArrayContentProvider instance; /** * Returns an instance of ArrayContentProvider. Since instances of this * class do not maintain any state, they can be shared between multiple * clients. * * @return an instance of ArrayContentProvider * * @since 1.3 */ public static ArrayContentProvider getInstance() { synchronized(ArrayContentProvider.class) { if (instance == null) { instance = new ArrayContentProvider(); } return instance; } } /** * Returns the elements in the input, which must be either an array or a * Collection. */ public Object[] getElements(Object inputElement) { if (inputElement instanceof Object[]) { return (Object[]) inputElement; } if (inputElement instanceof Collection) { return ((Collection) inputElement).toArray(); } return new Object[0]; } /** * This implementation does nothing. */ public void inputChanged(Viewer viewer, Object oldInput, Object newInput) { // do nothing. } /** * This implementation does nothing. */ public void dispose() { // do nothing. } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy