1
0
mirror of https://github.com/mitb-archive/filebot synced 2025-01-11 05:48:01 -05:00

* refactoring

This commit is contained in:
Reinhard Pointner 2009-07-09 20:04:47 +00:00
parent d1f12dd628
commit 857d73bdc0
11 changed files with 120 additions and 70 deletions

View File

@ -4,6 +4,7 @@ package net.sourceforge.filebot.ui.panel.rename;
import static java.awt.datatransfer.DataFlavor.*; import static java.awt.datatransfer.DataFlavor.*;
import static net.sourceforge.filebot.FileBotUtilities.*; import static net.sourceforge.filebot.FileBotUtilities.*;
import static net.sourceforge.filebot.ui.transfer.FileTransferable.*;
import static net.sourceforge.tuned.FileUtilities.*; import static net.sourceforge.tuned.FileUtilities.*;
import java.awt.datatransfer.DataFlavor; import java.awt.datatransfer.DataFlavor;
@ -46,7 +47,7 @@ class NamesListTransferablePolicy extends FileTransferablePolicy {
@Override @Override
public boolean accept(Transferable tr) throws Exception { public boolean accept(Transferable tr) throws Exception {
return tr.isDataFlavorSupported(stringFlavor) || super.accept(tr); return tr.isDataFlavorSupported(stringFlavor) || hasFileListFlavor(tr);
} }
@ -65,7 +66,7 @@ class NamesListTransferablePolicy extends FileTransferablePolicy {
if (tr.isDataFlavorSupported(episodeArrayFlavor)) { if (tr.isDataFlavorSupported(episodeArrayFlavor)) {
// episode array transferable // episode array transferable
model.addAll(Arrays.asList((Episode[]) tr.getTransferData((episodeArrayFlavor)))); model.addAll(Arrays.asList((Episode[]) tr.getTransferData((episodeArrayFlavor))));
} else if (super.accept(tr)) { } else if (hasFileListFlavor(tr)) {
// file transferable // file transferable
load(getFilesFromTransferable(tr)); load(getFilesFromTransferable(tr));
} else if (tr.isDataFlavorSupported(stringFlavor)) { } else if (tr.isDataFlavorSupported(stringFlavor)) {

View File

@ -8,7 +8,7 @@ import java.util.ResourceBundle;
import java.util.Set; import java.util.Set;
class Language { public class Language {
private final String code; private final String code;
private final String name; private final String name;

View File

@ -85,6 +85,13 @@ class SubtitleDownloadComponent extends JComponent {
// file list view // file list view
final JList fileList = new ListView(createFileListModel()) { final JList fileList = new ListView(createFileListModel()) {
@Override
protected String convertValueToText(Object value) {
MemoryFile file = (MemoryFile) value;
return file.getName();
}
@Override @Override
protected Icon convertValueToIcon(Object value) { protected Icon convertValueToIcon(Object value) {
if (SUBTITLE_FILES.accept(value.toString())) if (SUBTITLE_FILES.accept(value.toString()))
@ -280,7 +287,7 @@ class SubtitleDownloadComponent extends JComponent {
fileChooser.setSelectedFile(new File(validateFileName(file.getName()))); fileChooser.setSelectedFile(new File(validateFileName(file.getName())));
if (fileChooser.showSaveDialog(null) == JFileChooser.APPROVE_OPTION) { if (fileChooser.showSaveDialog(null) == JFileChooser.APPROVE_OPTION) {
write(file, fileChooser.getSelectedFile()); write(file.getData(), fileChooser.getSelectedFile());
} }
} else { } else {
// multiple files // multiple files
@ -292,7 +299,7 @@ class SubtitleDownloadComponent extends JComponent {
for (Object object : selection) { for (Object object : selection) {
MemoryFile file = (MemoryFile) object; MemoryFile file = (MemoryFile) object;
write(file, new File(folder, validateFileName(file.getName()))); write(file.getData(), new File(folder, validateFileName(file.getName())));
} }
} }
} }

View File

@ -24,7 +24,7 @@ import net.sourceforge.filebot.web.SubtitleDescriptor;
import net.sourceforge.tuned.FileUtilities; import net.sourceforge.tuned.FileUtilities;
class SubtitlePackage { public class SubtitlePackage {
private final SubtitleDescriptor subtitle; private final SubtitleDescriptor subtitle;

View File

@ -3,10 +3,12 @@ package net.sourceforge.filebot.ui.panel.subtitle;
import java.io.File; import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream; import java.io.FileOutputStream;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.InputStreamReader; import java.io.InputStreamReader;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel; import java.nio.channels.FileChannel;
import java.util.ArrayDeque; import java.util.ArrayDeque;
import java.util.ArrayList; import java.util.ArrayList;
@ -60,11 +62,31 @@ final class SubtitleUtilities {
} }
public static void write(MemoryFile source, File destination) throws IOException { public static byte[] read(File source) throws IOException {
InputStream in = new FileInputStream(source);
try {
byte[] data = new byte[(int) source.length()];
int position = 0;
int read = 0;
while (position < data.length && (read = in.read(data, position, data.length - position)) >= 0) {
position += read;
}
return data;
} finally {
in.close();
}
}
public static void write(ByteBuffer data, File destination) throws IOException {
FileChannel fileChannel = new FileOutputStream(destination).getChannel(); FileChannel fileChannel = new FileOutputStream(destination).getChannel();
try { try {
fileChannel.write(source.getData()); fileChannel.write(data);
} finally { } finally {
fileChannel.close(); fileChannel.close();
} }

View File

@ -46,7 +46,7 @@ import net.sourceforge.tuned.ui.notification.SeparatorBorder;
import net.sourceforge.tuned.ui.notification.SeparatorBorder.Position; import net.sourceforge.tuned.ui.notification.SeparatorBorder.Position;
class SubtitleViewer extends JFrame { public class SubtitleViewer extends JFrame {
private final JLabel titleLabel = new JLabel(); private final JLabel titleLabel = new JLabel();

View File

@ -2,6 +2,8 @@
package net.sourceforge.filebot.ui.transfer; package net.sourceforge.filebot.ui.transfer;
import static net.sourceforge.filebot.ui.transfer.FileTransferable.*;
import java.awt.datatransfer.Transferable; import java.awt.datatransfer.Transferable;
import java.beans.PropertyChangeListener; import java.beans.PropertyChangeListener;
import java.beans.PropertyChangeSupport; import java.beans.PropertyChangeSupport;
@ -22,7 +24,7 @@ public abstract class BackgroundFileTransferablePolicy<V> extends FileTransferab
private final List<BackgroundWorker> workers = new ArrayList<BackgroundWorker>(2); private final List<BackgroundWorker> workers = new ArrayList<BackgroundWorker>(2);
@Override @Override
public void handleTransferable(Transferable tr, TransferAction action) throws Exception { public void handleTransferable(Transferable tr, TransferAction action) throws Exception {
List<File> files = getFilesFromTransferable(tr); List<File> files = getFilesFromTransferable(tr);
@ -98,12 +100,12 @@ public abstract class BackgroundFileTransferablePolicy<V> extends FileTransferab
}); });
} }
protected class BackgroundWorker extends SwingWorker<Object, V> { protected class BackgroundWorker extends SwingWorker<Object, V> {
private final List<File> files; private final List<File> files;
public BackgroundWorker(List<File> files) { public BackgroundWorker(List<File> files) {
this.files = files; this.files = files;
@ -166,9 +168,10 @@ public abstract class BackgroundFileTransferablePolicy<V> extends FileTransferab
} }
} }
protected final PropertyChangeSupport swingPropertyChangeSupport = new SwingPropertyChangeSupport(this, true); protected final PropertyChangeSupport swingPropertyChangeSupport = new SwingPropertyChangeSupport(this, true);
public void addPropertyChangeListener(PropertyChangeListener listener) { public void addPropertyChangeListener(PropertyChangeListener listener) {
swingPropertyChangeSupport.addPropertyChangeListener(listener); swingPropertyChangeSupport.addPropertyChangeListener(listener);
} }

View File

@ -6,9 +6,17 @@ import java.awt.datatransfer.DataFlavor;
import java.awt.datatransfer.Transferable; import java.awt.datatransfer.Transferable;
import java.awt.datatransfer.UnsupportedFlavorException; import java.awt.datatransfer.UnsupportedFlavorException;
import java.io.File; import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.net.URI;
import java.nio.CharBuffer; import java.nio.CharBuffer;
import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collection; import java.util.Collection;
import java.util.List;
import java.util.Scanner;
import java.util.logging.Level;
import java.util.logging.Logger;
public class FileTransferable implements Transferable { public class FileTransferable implements Transferable {
@ -82,4 +90,50 @@ public class FileTransferable implements Transferable {
return flavor.isFlavorJavaFileListType() || flavor.equals(uriListFlavor); return flavor.isFlavorJavaFileListType() || flavor.equals(uriListFlavor);
} }
public static boolean hasFileListFlavor(Transferable tr) {
return tr.isDataFlavorSupported(DataFlavor.javaFileListFlavor) || tr.isDataFlavorSupported(FileTransferable.uriListFlavor);
}
@SuppressWarnings("unchecked")
public static List<File> getFilesFromTransferable(Transferable tr) throws IOException, UnsupportedFlavorException {
if (tr.isDataFlavorSupported(DataFlavor.javaFileListFlavor)) {
// file list flavor
return (List<File>) tr.getTransferData(DataFlavor.javaFileListFlavor);
} else if (tr.isDataFlavorSupported(FileTransferable.uriListFlavor)) {
// file URI list flavor
Readable transferData = (Readable) tr.getTransferData(FileTransferable.uriListFlavor);
Scanner scanner = new Scanner(transferData);
List<File> files = new ArrayList<File>();
while (scanner.hasNextLine()) {
String uri = scanner.nextLine();
if (uri.startsWith("#")) {
// the line is a comment (as per RFC 2483)
continue;
}
try {
File file = new File(new URI(uri));
if (!file.exists())
throw new FileNotFoundException(file.toString());
files.add(file);
} catch (Exception e) {
// URISyntaxException, IllegalArgumentException, FileNotFoundException
Logger.getLogger(FileTransferable.class.getName()).log(Level.WARNING, "Invalid file uri: " + uri);
}
}
return files;
}
// cannot get files from transferable
throw new UnsupportedFlavorException(DataFlavor.javaFileListFlavor);
}
} }

View File

@ -2,71 +2,25 @@
package net.sourceforge.filebot.ui.transfer; package net.sourceforge.filebot.ui.transfer;
import java.awt.datatransfer.DataFlavor; import static net.sourceforge.filebot.ui.transfer.FileTransferable.*;
import java.awt.datatransfer.Transferable; import java.awt.datatransfer.Transferable;
import java.awt.datatransfer.UnsupportedFlavorException;
import java.io.File; import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException; import java.io.IOException;
import java.net.URI;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Scanner;
import java.util.logging.Level;
import java.util.logging.Logger;
public abstract class FileTransferablePolicy extends TransferablePolicy { public abstract class FileTransferablePolicy extends TransferablePolicy {
@Override @Override
public boolean accept(Transferable tr) throws Exception { public boolean accept(Transferable tr) throws Exception {
List<File> files = getFilesFromTransferable(tr); try {
return accept(getFilesFromTransferable(tr));
if (files.isEmpty()) } catch (UnsupportedFlavorException e) {
// no file list flavor
return false; return false;
return accept(files);
}
@SuppressWarnings("unchecked")
protected List<File> getFilesFromTransferable(Transferable tr) throws Exception {
if (tr.isDataFlavorSupported(DataFlavor.javaFileListFlavor)) {
// file list flavor
return (List<File>) tr.getTransferData(DataFlavor.javaFileListFlavor);
} else if (tr.isDataFlavorSupported(FileTransferable.uriListFlavor)) {
// file URI list flavor
Readable transferData = (Readable) tr.getTransferData(FileTransferable.uriListFlavor);
Scanner scanner = new Scanner(transferData);
List<File> files = new ArrayList<File>();
while (scanner.hasNextLine()) {
String uri = scanner.nextLine();
if (uri.startsWith("#")) {
// the line is a comment (as per RFC 2483)
continue;
}
try {
File file = new File(new URI(uri));
if (!file.exists())
throw new FileNotFoundException(file.toString());
files.add(file);
} catch (Exception e) {
// URISyntaxException, IllegalArgumentException, FileNotFoundException
Logger.getLogger(getClass().getName()).log(Level.WARNING, "Invalid file uri: " + uri);
}
}
return files;
} }
return Collections.emptyList();
} }
@ -88,9 +42,7 @@ public abstract class FileTransferablePolicy extends TransferablePolicy {
protected abstract void load(List<File> files) throws IOException; protected abstract void load(List<File> files) throws IOException;
protected void clear() { protected abstract void clear();
// do nothing
}
public String getFileFilterDescription() { public String getFileFilterDescription() {

View File

@ -6,7 +6,7 @@ import java.util.ArrayList;
import java.util.List; import java.util.List;
public final class EpisodeListUtilities { final class EpisodeListUtilities {
public static List<Episode> filterBySeason(Iterable<Episode> episodes, int season) { public static List<Episode> filterBySeason(Iterable<Episode> episodes, int season) {

View File

@ -93,6 +93,17 @@ public class ByteBufferOutputStream extends OutputStream {
} }
public byte[] getByteArray() {
ByteBuffer data = getByteBuffer();
// copy data to byte array
byte[] bytes = new byte[data.remaining()];
data.get(bytes);
return bytes;
}
public int transferFrom(ReadableByteChannel channel) throws IOException { public int transferFrom(ReadableByteChannel channel) throws IOException {
// make sure buffer is not at its limit // make sure buffer is not at its limit
ensureCapacity(buffer.position() + 1); ensureCapacity(buffer.position() + 1);