Use human sort order for all paths loaded into the UI

This commit is contained in:
Reinhard Pointner 2016-09-28 20:25:11 +08:00
parent 99ad431994
commit aea553b154
11 changed files with 63 additions and 48 deletions

View File

@ -56,6 +56,7 @@ class AttributeTool extends Tool<TableModel> {
}
List<File> files = filter(listFiles(root), VIDEO_FILES, SUBTITLE_FILES);
files.sort(HUMAN_ORDER);
for (File file : files) {
Object metaObject = xattr.getMetaInfo(file);

View File

@ -1,6 +1,5 @@
package net.filebot.ui.filter;
import static java.util.Collections.*;
import static net.filebot.Logging.*;
import static net.filebot.UserFiles.*;
import static net.filebot.util.ExceptionUtilities.*;
@ -78,20 +77,21 @@ class ExtractTool extends Tool<TableModel> {
@Override
protected TableModel createModelInBackground(File root) throws InterruptedException {
List<File> files = root != null ? listFiles(root) : emptyList();
if (root == null) {
return new ArchiveEntryModel();
}
// ignore non-archives files and trailing multi-volume parts
List<File> files = filter(listFiles(root), Archive.VOLUME_ONE_FILTER);
files.sort(HUMAN_ORDER);
List<ArchiveEntry> entries = new ArrayList<ArchiveEntry>();
try {
for (File file : files) {
// ignore non-archives files and trailing multi-volume parts
if (Archive.VOLUME_ONE_FILTER.accept(file)) {
Archive archive = Archive.open(file);
try {
for (FileInfo it : archive.listFiles()) {
entries.add(new ArchiveEntry(file, it));
}
} finally {
archive.close();
try (Archive archive = Archive.open(file)) {
for (FileInfo it : archive.listFiles()) {
entries.add(new ArchiveEntry(file, it));
}
}

View File

@ -86,10 +86,8 @@ class FileTreeTransferablePolicy extends BackgroundFileTransferablePolicy<TreeNo
if (file.isDirectory()) {
LinkedList<TreeNode> children = new LinkedList<TreeNode>();
for (File f : getChildren(file)) {
if (f.isHidden())
continue;
for (File f : getChildren(file, NOT_HIDDEN, HUMAN_ORDER)) {
if (f.isDirectory()) {
children.addFirst(getTreeNode(f));
} else {

View File

@ -59,6 +59,8 @@ class MediaInfoTool extends Tool<TableModel> {
}
List<File> files = filter(listFiles(root), VIDEO_FILES, AUDIO_FILES);
files.sort(HUMAN_ORDER);
Map<MediaInfoKey, String[]> data = new TreeMap<MediaInfoKey, String[]>();
try (MediaInfo mi = new MediaInfo()) {

View File

@ -1,5 +1,6 @@
package net.filebot.ui.filter;
import static java.util.Collections.*;
import static net.filebot.util.FileUtilities.*;
import java.awt.Color;
@ -68,10 +69,15 @@ class SplitTool extends Tool<TreeModel> {
@Override
protected TreeModel createModelInBackground(File root) throws InterruptedException {
if (root == null) {
return new DefaultTreeModel(new FolderNode("Volumes", emptyList()));
}
int nextPart = 1;
long splitSize = getSplitSize();
List<File> files = (root != null) ? listFiles(root) : new ArrayList<File>();
List<File> files = listFiles(root);
files.sort(HUMAN_ORDER);
List<TreeNode> rootGroup = new ArrayList<TreeNode>();
List<File> currentPart = new ArrayList<File>();

View File

@ -82,9 +82,12 @@ class FileListTransferablePolicy extends FileTransferablePolicy {
title.accept(getFolderName(files.get(0)));
}
List<File> list = listFiles(files);
list.sort(HUMAN_ORDER);
// load all files from the given folders recursively up do a depth of 32
format.accept(ListPanel.DEFAULT_FILE_FORMAT);
model.accept(listFiles(files));
model.accept(list);
}
}

View File

@ -1,6 +1,7 @@
package net.filebot.ui.rename;
import static java.util.Collections.*;
import static net.filebot.util.FileUtilities.*;
import static net.filebot.util.ui.SwingUI.*;
import java.awt.event.ActionEvent;
@ -15,7 +16,6 @@ import net.filebot.format.ExpressionFileFilter;
import net.filebot.format.ExpressionFilter;
import net.filebot.format.ExpressionFormat;
import net.filebot.mac.MacAppUtilities;
import net.filebot.util.FileUtilities;
import net.filebot.web.Datasource;
import net.filebot.web.EpisodeListProvider;
import net.filebot.web.MovieIdentificationService;
@ -84,10 +84,12 @@ public class Preset {
}
}
List<File> files = FileUtilities.listFiles(getInputFolder());
List<File> files = listFiles(getInputFolder());
if (filter != null) {
files = FileUtilities.filter(files, filter);
files = filter(files, filter);
}
files.sort(HUMAN_ORDER);
return files;
}

View File

@ -677,19 +677,20 @@ public class RenamePanel extends JComponent {
@Override
public List<File> getFiles(ActionEvent evt) {
List<File> input = preset.selectInputFiles(evt);
List<File> selection = preset.selectInputFiles(evt);
if (input != null) {
if (selection != null) {
renameModel.clear();
renameModel.files().addAll(input);
renameModel.files().addAll(selection);
} else {
input = new ArrayList<File>(super.getFiles(evt));
selection = new ArrayList<File>(super.getFiles(evt));
}
if (input.isEmpty()) {
if (selection.isEmpty()) {
throw new IllegalStateException("No files selected.");
}
return input;
return selection;
}
@Override

View File

@ -96,7 +96,7 @@ class ChecksumTableTransferablePolicy extends BackgroundFileTransferablePolicy<C
// handle single folder drop
if (files.size() == 1 && containsOnly(files, FOLDERS)) {
for (File folder : files) {
for (File file : getChildren(folder, NOT_HIDDEN, CASE_INSENSITIVE_ORDER)) {
for (File file : getChildren(folder, NOT_HIDDEN, HUMAN_ORDER)) {
load(file, null, folder);
}
}
@ -179,7 +179,7 @@ class ChecksumTableTransferablePolicy extends BackgroundFileTransferablePolicy<C
if (absoluteFile.isDirectory()) {
// load all files in the file tree
for (File child : getChildren(absoluteFile, NOT_HIDDEN, CASE_INSENSITIVE_ORDER)) {
for (File child : getChildren(absoluteFile, NOT_HIDDEN, HUMAN_ORDER)) {
load(child, relativeFile, root);
}
} else {

View File

@ -19,6 +19,7 @@ import java.awt.dnd.DropTargetEvent;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.File;
import java.util.ArrayList;
import java.util.Collection;
import java.util.LinkedHashMap;
import java.util.List;
@ -159,13 +160,13 @@ abstract class SubtitleDropTarget extends JButton {
public abstract String getQueryLanguage();
@Override
protected DropAction getDropAction(List<File> input) {
protected DropAction getDropAction(List<File> selection) {
// accept video files and folders
return filter(input, VIDEO_FILES, FOLDERS).size() > 0 ? DropAction.Accept : DropAction.Cancel;
}
@Override
protected boolean handleDrop(List<File> input) {
protected boolean handleDrop(List<File> selection) {
if (getQueryLanguage() == null) {
log.info("Please select your preferred subtitle language.");
return false;
@ -176,14 +177,11 @@ abstract class SubtitleDropTarget extends JButton {
return false;
}
// perform a drop action depending on the given files
final Collection<File> videoFiles = new TreeSet<File>();
List<File> files = filter(listFiles(selection), VIDEO_FILES);
files.sort(HUMAN_ORDER);
// video files only
videoFiles.addAll(filter(listFiles(input), VIDEO_FILES));
if (videoFiles.size() > 0) {
handleDownload(videoFiles);
if (files.size() > 0) {
handleDownload(files);
return true;
}
@ -234,13 +232,13 @@ abstract class SubtitleDropTarget extends JButton {
public static abstract class Upload extends SubtitleDropTarget {
@Override
protected DropAction getDropAction(List<File> input) {
protected DropAction getDropAction(List<File> selection) {
// accept video files and folders
return filter(input, SUBTITLE_FILES).size() > 0 || filter(input, FOLDERS).size() > 0 ? DropAction.Accept : DropAction.Cancel;
return filter(selection, SUBTITLE_FILES).size() > 0 || filter(selection, FOLDERS).size() > 0 ? DropAction.Accept : DropAction.Cancel;
}
@Override
protected boolean handleDrop(List<File> input) {
protected boolean handleDrop(List<File> selection) {
if (getSubtitleService().isAnonymous()) {
log.info(String.format("%s: You must be logged in to upload subtitles.", getSubtitleService().getName()));
return false;
@ -250,19 +248,20 @@ abstract class SubtitleDropTarget extends JButton {
// make sure we have access to the parent folder structure, not just the dropped file
if (isMacSandbox()) {
MacAppUtilities.askUnlockFolders(getWindow(this), input);
MacAppUtilities.askUnlockFolders(getWindow(this), selection);
}
// perform a drop action depending on the given files
final Collection<File> files = new TreeSet<File>();
List<File> files = listFiles(selection);
// video files only
files.addAll(listFiles(input));
List<File> videos = filter(files, VIDEO_FILES);
videos.sort(HUMAN_ORDER);
final List<File> videos = filter(files, VIDEO_FILES);
final List<File> subtitles = filter(files, SUBTITLE_FILES);
List<File> subtitles = filter(files, SUBTITLE_FILES);
subtitles.sort(HUMAN_ORDER);
Map<File, File> uploadPlan = new LinkedHashMap<File, File>();
final Map<File, File> uploadPlan = new LinkedHashMap<File, File>();
for (File subtitle : subtitles) {
File video = getVideoForSubtitle(subtitle, filter(videos, new ParentFilter(subtitle.getParentFile())));
uploadPlan.put(subtitle, video);
@ -274,6 +273,7 @@ abstract class SubtitleDropTarget extends JButton {
handleUpload(uploadPlan);
return true;
}
return false;
}

View File

@ -443,8 +443,10 @@ public final class FileUtilities {
// children array may be null if folder permissions do not allow listing of files
if (files == null) {
files = new File[0];
} else if (order != null) {
return emptyList();
}
if (order != null) {
sort(files, order);
}