org.eclipse.jface.preference.PathEditor Maven / Gradle / Ivy
// RAP [bm]: DirectoryDialog
///*******************************************************************************
// * Copyright (c) 2000, 2006 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.preference;
//
//import java.io.File;
//import java.util.ArrayList;
//import java.util.StringTokenizer;
//
//import org.eclipse.swt.widgets.Composite;
//import org.eclipse.swt.widgets.DirectoryDialog;
//
///**
// * A field editor to edit directory paths.
// */
//public class PathEditor extends ListEditor {
//
// /**
// * The last path, or null
if none.
// */
// private String lastPath;
//
// /**
// * The special label text for directory chooser,
// * or null
if none.
// */
// private String dirChooserLabelText;
//
// /**
// * Creates a new path field editor
// */
// protected PathEditor() {
// }
//
// /**
// * Creates a path field editor.
// *
// * @param name the name of the preference this field editor works on
// * @param labelText the label text of the field editor
// * @param dirChooserLabelText the label text displayed for the directory chooser
// * @param parent the parent of the field editor's control
// */
// public PathEditor(String name, String labelText,
// String dirChooserLabelText, Composite parent) {
// init(name, labelText);
// this.dirChooserLabelText = dirChooserLabelText;
// createControl(parent);
// }
//
// /* (non-Javadoc)
// * Method declared on ListEditor.
// * Creates a single string from the given array by separating each
// * string with the appropriate OS-specific path separator.
// */
// protected String createList(String[] items) {
// StringBuffer path = new StringBuffer("");//$NON-NLS-1$
//
// for (int i = 0; i < items.length; i++) {
// path.append(items[i]);
// path.append(File.pathSeparator);
// }
// return path.toString();
// }
//
// /* (non-Javadoc)
// * Method declared on ListEditor.
// * Creates a new path element by means of a directory dialog.
// */
// protected String getNewInputObject() {
//
// DirectoryDialog dialog = new DirectoryDialog(getShell());
// if (dirChooserLabelText != null) {
// dialog.setMessage(dirChooserLabelText);
// }
// if (lastPath != null) {
// if (new File(lastPath).exists()) {
// dialog.setFilterPath(lastPath);
// }
// }
// String dir = dialog.open();
// if (dir != null) {
// dir = dir.trim();
// if (dir.length() == 0) {
// return null;
// }
// lastPath = dir;
// }
// return dir;
// }
//
// /* (non-Javadoc)
// * Method declared on ListEditor.
// */
// protected String[] parseString(String stringList) {
// StringTokenizer st = new StringTokenizer(stringList, File.pathSeparator
// + "\n\r");//$NON-NLS-1$
// ArrayList v = new ArrayList();
// while (st.hasMoreElements()) {
// v.add(st.nextElement());
// }
// return (String[]) v.toArray(new String[v.size()]);
// }
//}