KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > edu > rice > cs > util > swing > DefaultFileDisplayManager


1 /*BEGIN_COPYRIGHT_BLOCK
2  *
3  * This file is part of DrJava. Download the current version of this project from http://www.drjava.org/
4  * or http://sourceforge.net/projects/drjava/
5  *
6  * DrJava Open Source License
7  *
8  * Copyright (C) 2001-2006 JavaPLT group at Rice University (javaplt@rice.edu). All rights reserved.
9  *
10  * Developed by: Java Programming Languages Team, Rice University, http://www.cs.rice.edu/~javaplt/
11  *
12  * Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated
13  * documentation files (the "Software"), to deal with the Software without restriction, including without limitation
14  * the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and
15  * to permit persons to whom the Software is furnished to do so, subject to the following conditions:
16  *
17  * - Redistributions of source code must retain the above copyright notice, this list of conditions and the
18  * following disclaimers.
19  * - Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the
20  * following disclaimers in the documentation and/or other materials provided with the distribution.
21  * - Neither the names of DrJava, the JavaPLT, Rice University, nor the names of its contributors may be used to
22  * endorse or promote products derived from this Software without specific prior written permission.
23  * - Products derived from this software may not be called "DrJava" nor use the term "DrJava" as part of their
24  * names without prior written permission from the JavaPLT group. For permission, write to javaplt@rice.edu.
25  *
26  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO
27  * THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
28  * CONTRIBUTORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
29  * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
30  * WITH THE SOFTWARE.
31  *
32  *END_COPYRIGHT_BLOCK*/

33
34 package edu.rice.cs.util.swing;
35
36 import javax.swing.Icon JavaDoc;
37 import javax.swing.JFileChooser JavaDoc;
38 import java.io.File JavaDoc;
39
40 /** This FileDisplayManager uses the same icons and naming schemes as the JFileChooser offered by swing. */
41 public class DefaultFileDisplayManager implements FileDisplayManager {
42   
43   private JFileChooser JavaDoc _jfc;
44   
45   public DefaultFileDisplayManager() { _jfc = new JFileChooser JavaDoc(); }
46   
47   /** Given a file, decide which icon to use
48    * @param f The file to base the icon decision on
49    * @return The icon to display for the given file
50    */

51   public Icon JavaDoc getIcon(File JavaDoc f) {
52     // avoid problem with windows filesystem drivers that would cause a filenotfound exception
53
if (f != null && ! f.exists()) f = null;
54     
55     return _jfc.getIcon(f);
56   }
57   
58   /** Given a file, decide on which name to display for it
59    * @param f The file to base the naming decison on
60    * @return The name to display for the file
61    */

62   public String JavaDoc getName(File JavaDoc f) { return _jfc.getName(f); }
63   
64   /** Creates a file display that displays a file as this manager specifies
65    * @param f the file to display using the display manager
66    * @return the file display object used to display a file's name
67    */

68   public FileDisplay makeFileDisplay(File JavaDoc f) { return new FileDisplay(f, this); }
69   
70   /** Creates a file display that displays a file as this manager specifies
71    * @param parent the parent of the file to display using the display manager
72    * @param child the name of the child such that <code>new File(parent, child)</code> is
73    * the file to be displayed.
74    * @return the file display object used to display a file's name
75    */

76   public FileDisplay makeFileDisplay(File JavaDoc parent, String JavaDoc child) { return new FileDisplay(parent, child, this); }
77   
78   /** Creates a FileDisplay representing a new untitled folder that is yet to be created.
79    * @param parent the parent folder of the new folder
80    * @return the new file display
81    */

82   public FileDisplay makeNewFolderDisplay(File JavaDoc parent) { return FileDisplay.newFile(parent, this); }
83   
84   /** Updates the UI to reflect any changes in the fs. */
85   public void update() { _jfc.updateUI(); }
86 }
Popular Tags