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

org.eclipse.swt.widgets.FileDialog Maven / Gradle / Ivy

Go to download

The osx x86_64 swt jar as available in the Eclipse 4.6 (Neon) release for OSX. It is suitable for use with jface and other dependencies available from maven central in the org.eclipse.scout.sdk.deps group. The sources is copied from swt-4.6-cocoa-macosx-x86_64.zip from http://download.eclipse.org/eclipse/downloads/drops4/R-4.6-201606061100/ and javadoc is generated from sources.

The newest version!
/*******************************************************************************
 * Copyright (c) 2000, 2015 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.swt.widgets;


import java.util.*;

import org.eclipse.swt.*;
import org.eclipse.swt.internal.*;
import org.eclipse.swt.internal.cocoa.*;

/**
 * Instances of this class allow the user to navigate
 * the file system and select or enter a file name.
 * 
*
Styles:
*
SAVE, OPEN, MULTI
*
Events:
*
(none)
*
*

* Note: Only one of the styles SAVE and OPEN may be specified. *

* IMPORTANT: This class is not intended to be subclassed. *

* * @see FileDialog snippets * @see SWT Example: ControlExample, Dialog tab * @see Sample code and further information * @noextend This class is not intended to be subclassed by clients. */ public class FileDialog extends Dialog { NSSavePanel panel; NSPopUpButton popup; String [] filterNames = new String [0]; String [] filterExtensions = new String [0]; String [] fileNames = new String[0]; String filterPath = "", fileName = ""; int filterIndex = -1; boolean overwrite = false; static final char EXTENSION_SEPARATOR = ';'; /** * Constructs a new instance of this class given only its parent. * * @param parent a shell which will be the parent of the new instance * * @exception IllegalArgumentException
    *
  • ERROR_NULL_ARGUMENT - if the parent is null
  • *
* @exception SWTException
    *
  • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the parent
  • *
  • ERROR_INVALID_SUBCLASS - if this class is not an allowed subclass
  • *
*/ public FileDialog (Shell parent) { this (parent, SWT.APPLICATION_MODAL); } /** * Constructs a new instance of this class given its parent * and a style value describing its behavior and appearance. *

* The style value is either one of the style constants defined in * class SWT which is applicable to instances of this * class, or must be built by bitwise OR'ing together * (that is, using the int "|" operator) two or more * of those SWT style constants. The class description * lists the style constants that are applicable to the class. * Style bits are also inherited from superclasses. *

* * @param parent a shell which will be the parent of the new instance * @param style the style of dialog to construct * * @exception IllegalArgumentException
    *
  • ERROR_NULL_ARGUMENT - if the parent is null
  • *
* @exception SWTException
    *
  • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the parent
  • *
  • ERROR_INVALID_SUBCLASS - if this class is not an allowed subclass
  • *
* * @see SWT#SAVE * @see SWT#OPEN * @see SWT#MULTI */ public FileDialog (Shell parent, int style) { super (parent, checkStyle (parent, style)); if (Display.getSheetEnabled ()) { if (parent != null && (style & SWT.SHEET) != 0) this.style |= SWT.SHEET; } checkSubclass (); } /** * Returns the path of the first file that was * selected in the dialog relative to the filter path, or an * empty string if no such file has been selected. * * @return the relative path of the file */ public String getFileName () { return fileName; } /** * Returns a (possibly empty) array with the paths of all files * that were selected in the dialog relative to the filter path. * * @return the relative paths of the files */ public String [] getFileNames () { return fileNames; } /** * Returns the file extensions which the dialog will * use to filter the files it shows. * * @return the file extensions filter */ public String [] getFilterExtensions () { return filterExtensions; } /** * Get the 0-based index of the file extension filter * which was selected by the user, or -1 if no filter * was selected. *

* This is an index into the FilterExtensions array and * the FilterNames array. *

* * @return index the file extension filter index * * @see #getFilterExtensions * @see #getFilterNames * * @since 3.4 */ public int getFilterIndex () { return filterIndex; } /** * Returns the names that describe the filter extensions * which the dialog will use to filter the files it shows. * * @return the list of filter names */ public String [] getFilterNames () { return filterNames; } /** * Returns the directory path that the dialog will use, or an empty * string if this is not set. File names in this path will appear * in the dialog, filtered according to the filter extensions. * * @return the directory path string * * @see #setFilterExtensions */ public String getFilterPath () { return filterPath; } /** * Returns the flag that the dialog will use to * determine whether to prompt the user for file * overwrite if the selected file already exists. * * @return true if the dialog will prompt for file overwrite, false otherwise * * @since 3.4 */ public boolean getOverwrite () { return overwrite; } /** * Makes the dialog visible and brings it to the front * of the display. * * @return a string describing the absolute path of the first selected file, * or null if the dialog was cancelled or an error occurred * * @exception SWTException
    *
  • ERROR_WIDGET_DISPOSED - if the dialog has been disposed
  • *
  • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the dialog
  • *
*/ public String open () { String fullPath = null; fileNames = new String [0]; long /*int*/ method = 0; long /*int*/ methodImpl = 0; Callback callback = null; if ((style & SWT.SAVE) != 0) { NSSavePanel savePanel = NSSavePanel.savePanel(); panel = savePanel; if (!overwrite) { callback = new Callback(this, "_overwriteExistingFileCheck", 3); long /*int*/ proc = callback.getAddress(); if (proc == 0) error (SWT.ERROR_NO_MORE_CALLBACKS); method = OS.class_getInstanceMethod(OS.class_NSSavePanel, OS.sel_overwriteExistingFileCheck); if (method != 0) methodImpl = OS.method_setImplementation(method, proc); } } else { NSOpenPanel openPanel = NSOpenPanel.openPanel(); openPanel.setAllowsMultipleSelection((style & SWT.MULTI) != 0); panel = openPanel; } Display display = parent != null ? parent.getDisplay() : Display.getCurrent(); panel.setCanCreateDirectories(true); /* * This line is intentionally commented. Don't show hidden files forcefully, * instead allow File dialog to use the system preference. */ // OS.objc_msgSend(panel.id, OS.sel_setShowsHiddenFiles_, true); long /*int*/ jniRef = 0; SWTPanelDelegate delegate = null; if (filterExtensions != null && filterExtensions.length != 0) { delegate = (SWTPanelDelegate)new SWTPanelDelegate().alloc().init(); jniRef = OS.NewGlobalRef(this); if (jniRef == 0) error(SWT.ERROR_NO_HANDLES); OS.object_setInstanceVariable(delegate.id, Display.SWT_OBJECT, jniRef); panel.setDelegate(delegate); NSPopUpButton widget = (NSPopUpButton)new NSPopUpButton().alloc(); widget.initWithFrame(new NSRect(), false); widget.setTarget(delegate); widget.setAction(OS.sel_sendSelection_); NSMenu menu = widget.menu(); menu.setAutoenablesItems(false); for (int i = 0; i < filterExtensions.length; i++) { String str = filterExtensions [i]; if (filterNames != null && filterNames.length > i) { str = filterNames [i]; } NSMenuItem nsItem = (NSMenuItem)new NSMenuItem().alloc(); nsItem.initWithTitle(NSString.stringWith(str), 0, NSString.string()); menu.addItem(nsItem); nsItem.release(); } widget.selectItemAtIndex(0 <= filterIndex && filterIndex < filterExtensions.length ? filterIndex : 0); widget.sizeToFit(); panel.setAccessoryView(widget); popup = widget; setAllowedFileType(filterExtensions[0]); panel.setAllowsOtherFileTypes(true); panel.setTreatsFilePackagesAsDirectories(shouldTreatAppAsDirectory(filterExtensions[0])); } else { panel.setTreatsFilePackagesAsDirectories(false); } panel.setTitle(NSString.stringWith(title != null ? title : "")); NSApplication application = NSApplication.sharedApplication(); if (parent != null && (style & SWT.SHEET) != 0) { application.beginSheet(panel, parent.view.window (), null, 0, 0); } display.setModalDialog(this, panel); NSString dir = (filterPath != null && filterPath.length() > 0) ? NSString.stringWith(filterPath) : null; NSString file = (fileName != null && fileName.length() > 0) ? NSString.stringWith(fileName) : null; long /*int*/ response = panel.runModalForDirectory(dir, file); if (parent != null && (style & SWT.SHEET) != 0) { application.endSheet(panel, 0); } display.setModalDialog(null); if (!overwrite) { if (method != 0) OS.method_setImplementation(method, methodImpl); if (callback != null) callback.dispose(); } if (popup != null) { filterIndex = (int)/*64*/popup.indexOfSelectedItem(); } else { filterIndex = -1; } if (response == OS.NSFileHandlingPanelOKButton) { NSString filename = panel.filename(); if ((style & SWT.SAVE) != 0) { fullPath = filename.getString(); fileNames = new String [1]; fileName = fileNames [0] = filename.lastPathComponent().getString(); filterPath = filename.stringByDeletingLastPathComponent().getString(); } else { fullPath = filename.getString(); NSArray filenames = ((NSOpenPanel)panel).filenames(); int count = (int)/*64*/filenames.count(); fileNames = new String[count]; for (int i = 0; i < count; i++) { filename = new NSString(filenames.objectAtIndex(i)); NSString filenameOnly = filename.lastPathComponent(); NSString pathOnly = filename.stringByDeletingLastPathComponent(); if (i == 0) { /* Filter path */ filterPath = pathOnly.getString(); /* File name */ fileName = fileNames [0] = filenameOnly.getString(); } else { if (pathOnly.getString().equals (filterPath)) { fileNames [i] = filenameOnly.getString(); } else { fileNames [i] = filename.getString(); } } } } } if (popup != null) { panel.setAccessoryView(null); popup.release(); popup = null; } if (delegate != null) { panel.setDelegate(null); delegate.release(); } if (jniRef != 0) OS.DeleteGlobalRef(jniRef); panel = null; return fullPath; } long /*int*/ _overwriteExistingFileCheck (long /*int*/ id, long /*int*/ sel, long /*int*/ str) { return 1; } long /*int*/ panel_shouldShowFilename (long /*int*/ id, long /*int*/ sel, long /*int*/ arg0, long /*int*/ arg1) { NSString path = new NSString(arg1); if (filterExtensions != null && filterExtensions.length != 0) { NSFileManager manager = NSFileManager.defaultManager(); long /*int*/ ptr = OS.malloc(1); boolean found = manager.fileExistsAtPath(path, ptr); byte[] isDirectory = new byte[1]; OS.memmove(isDirectory, ptr, 1); OS.free(ptr); if (found) { if (isDirectory[0] != 0) { return 1; } else if (popup != null) { String fileName = path.lastPathComponent().getString(); int filterIndex = (int)/*64*/popup.indexOfSelectedItem(); String extensions = filterExtensions [filterIndex]; int start = 0, length = extensions.length (); while (start < length) { int index = extensions.indexOf (EXTENSION_SEPARATOR, start); if (index == -1) index = length; String filter = extensions.substring (start, index).trim (); if (filter.equalsIgnoreCase (fileName)) return 1; if (filter.equals ("*") || filter.equals ("*.*")) return 1; if (filter.startsWith ("*.")) filter = filter.substring (2); if ((fileName.toLowerCase ()).endsWith("." + filter.toLowerCase ())) return 1; start = index + 1; } return 0; } } } return 1; } void sendSelection (long /*int*/ id, long /*int*/ sel, long /*int*/ arg) { if (filterExtensions != null && filterExtensions.length > 0) { String fileTypes = filterExtensions[(int)/*64*/popup.indexOfSelectedItem ()]; panel.setTreatsFilePackagesAsDirectories (shouldTreatAppAsDirectory (fileTypes)); setAllowedFileType (fileTypes); } panel.validateVisibleColumns (); } void setAllowedFileType (String fileTypes) { if (fileTypes == null) return; StringTokenizer fileTypesToken = new StringTokenizer(fileTypes, String.valueOf(EXTENSION_SEPARATOR)); NSMutableArray allowedFileTypes = NSMutableArray.arrayWithCapacity(1); while(fileTypesToken.hasMoreTokens()) { String fileType = fileTypesToken.nextToken(); if (fileType.equals("*") || fileType.equals("*.*")) { panel.setAllowedFileTypes(null); return; } if (fileType.startsWith("*.")) { fileType = fileType.substring(2); } else if (fileType.startsWith(".")) { fileType = fileType.substring(1); } allowedFileTypes.addObject(NSString.stringWith(fileType)); } panel.setAllowedFileTypes(allowedFileTypes); } /** * Set the initial filename which the dialog will * select by default when opened to the argument, * which may be null. The name will be prefixed with * the filter path when one is supplied. * * @param string the file name */ public void setFileName (String string) { fileName = string; } /** * Set the file extensions which the dialog will * use to filter the files it shows to the argument, * which may be null. *

* The strings are platform specific. For example, on * some platforms, an extension filter string is typically * of the form "*.extension", where "*.*" matches all files. * For filters with multiple extensions, use semicolon as * a separator, e.g. "*.jpg;*.png". *

*

* Note: On Mac, setting the file extension filter affects how * app bundles are treated by the dialog. When a filter extension * having the app extension (.app) is selected, bundles are treated * as files. For all other extension filters, bundles are treated * as directories. When no filter extension is set, bundles are * treated as files. *

* * @param extensions the file extension filter * * @see #setFilterNames to specify the user-friendly * names corresponding to the extensions */ public void setFilterExtensions (String [] extensions) { filterExtensions = extensions; } /** * Set the 0-based index of the file extension filter * which the dialog will use initially to filter the files * it shows to the argument. *

* This is an index into the FilterExtensions array and * the FilterNames array. *

* * @param index the file extension filter index * * @see #setFilterExtensions * @see #setFilterNames * * @since 3.4 */ public void setFilterIndex (int index) { filterIndex = index; } /** * Sets the names that describe the filter extensions * which the dialog will use to filter the files it shows * to the argument, which may be null. *

* Each name is a user-friendly short description shown for * its corresponding filter. The names array must * be the same length as the extensions array. *

* * @param names the list of filter names, or null for no filter names * * @see #setFilterExtensions */ public void setFilterNames (String [] names) { filterNames = names; } /** * Sets the directory path that the dialog will use * to the argument, which may be null. File names in this * path will appear in the dialog, filtered according * to the filter extensions. If the string is null, * then the operating system's default filter path * will be used. *

* Note that the path string is platform dependent. * For convenience, either '/' or '\' can be used * as a path separator. *

* * @param string the directory path * * @see #setFilterExtensions */ public void setFilterPath (String string) { filterPath = string; } /** * Sets the flag that the dialog will use to * determine whether to prompt the user for file * overwrite if the selected file already exists. * * @param overwrite true if the dialog will prompt for file overwrite, false otherwise * * @since 3.4 */ public void setOverwrite (boolean overwrite) { this.overwrite = overwrite; } /** * Determines if the treatAppAsBundle property has to be enabled for the NSOpenPanel * for the filterExtensions passed as a parameter. */ boolean shouldTreatAppAsDirectory (String extensions) { if ((style & SWT.SAVE) != 0) return false; StringTokenizer fileTypesToken = new StringTokenizer (extensions, String.valueOf(EXTENSION_SEPARATOR)); while (fileTypesToken.hasMoreTokens ()) { String fileType = fileTypesToken.nextToken (); if (fileType.equals ("*") || fileType.equals ("*.*")) return true; if (fileType.equals ("*.app") || fileType.equals (".app")) return false; } return true; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy