01: package net.sourceforge.squirrel_sql.fw.gui;
02:
03: /*
04: * Copyright (C) 2002 Colin Bell
05: * colbell@users.sourceforge.net
06: *
07: * This library is free software; you can redistribute it and/or
08: * modify it under the terms of the GNU Lesser General Public
09: * License as published by the Free Software Foundation; either
10: * version 2.1 of the License, or (at your option) any later version.
11: *
12: * This library is distributed in the hope that it will be useful,
13: * but WITHOUT ANY WARRANTY; without even the implied warranty of
14: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15: * Lesser General Public License for more details.
16: *
17: * You should have received a copy of the GNU Lesser General Public
18: * License along with this library; if not, write to the Free Software
19: * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20: */
21: import javax.swing.DefaultListModel;
22:
23: import java.io.File;
24:
25: /**
26: * This is the default model for the <TT>FileListBox</TT>.
27: *
28: * @author <A HREF="mailto:colbell@users.sourceforge.net">Colin Bell</A>
29: */
30: public class DefaultFileListBoxModel extends DefaultListModel implements
31: IFileListBoxModel {
32: /**
33: * Default ctor.
34: */
35: public DefaultFileListBoxModel() {
36: super ();
37: }
38:
39: public void addFile(File file) {
40: addElement(file);
41: }
42:
43: /**
44: * Return the File at the passed index.
45: *
46: * @param idx Index to return File for.
47: *
48: * @return The File at <TT>idx</TT>.
49: *
50: * @throws ArrayInexOutOfBoundsException
51: * Thrown if <TT>idx</TT> < 0 or >= <TT>getSize()</TT>.
52: */
53: public File getFile(int idx) {
54: return (File) get(idx);
55: }
56:
57: /**
58: * Return array of File names in list.
59: *
60: * @return array of File names in list.
61: */
62: public String[] getFileNames() {
63: String[] fileNames = new String[getSize()];
64: for (int i = 0, limit = fileNames.length; i < limit; ++i) {
65: fileNames[i] = getFile(i).getAbsolutePath();
66: }
67: return fileNames;
68: }
69:
70: /**
71: * Build list. Empty method.
72: */
73: // public void reload()
74: // {
75: // }
76: public void insertFileAt(File file, int idx) {
77: insertElementAt(file, idx);
78: }
79:
80: public File removeFile(int idx) {
81: return (File) remove(idx);
82: }
83:
84: }
|