* added -DuseNativeShell to jnlp
* don't create auto-create folders when not necessary * manually set java/jna.library.path to make sure it's in the install folder
This commit is contained in:
parent
306eda5c8a
commit
6963eb41eb
@ -18,3 +18,7 @@
|
||||
# http connection timeouts
|
||||
-Dsun.net.client.defaultConnectTimeout=5000
|
||||
-Dsun.net.client.defaultReadTimeout=25000
|
||||
|
||||
# look for native libs here
|
||||
-Djna.library.path="%EXEDIR%"
|
||||
-Djava.library.path="%EXEDIR%"
|
||||
|
@ -24,6 +24,10 @@
|
||||
-Dsun.net.client.defaultConnectTimeout=5000
|
||||
-Dsun.net.client.defaultReadTimeout=25000
|
||||
|
||||
# look for native libs here
|
||||
-Djna.library.path="%EXEDIR%"
|
||||
-Djava.library.path="%EXEDIR%"
|
||||
|
||||
# force english locale
|
||||
-Dfile.encoding=UTF-8
|
||||
-Duser.country=US
|
||||
|
@ -24,9 +24,11 @@
|
||||
<resources>
|
||||
<property name="application.deployment" value="webstart" />
|
||||
<property name="application.update" value="skip" />
|
||||
<property name="jnlp.packEnabled" value="true" />
|
||||
<property name="useNativeShell" value="true" />
|
||||
|
||||
<java version="1.6+" max-heap-size="256m" />
|
||||
<property name="jnlp.packEnabled" value="true" />
|
||||
|
||||
<jar href="filebot.jar" download="eager" main="true" />
|
||||
<jar href="groovy.jar" download="eager" />
|
||||
<jar href="icu4j.jar" download="eager" />
|
||||
|
@ -26,7 +26,7 @@ public enum NativeRenameAction implements RenameAction {
|
||||
|
||||
@Override
|
||||
public File rename(File src, File dst) throws IOException {
|
||||
dst = resolveDestination(src, dst).getCanonicalFile();
|
||||
dst = resolveDestination(src, dst, false).getCanonicalFile();
|
||||
rename(singletonMap(src, dst));
|
||||
return dst;
|
||||
}
|
||||
@ -40,13 +40,18 @@ public enum NativeRenameAction implements RenameAction {
|
||||
int i = 0;
|
||||
for (Entry<File, File> it : map.entrySet()) {
|
||||
src[i] = it.getKey().getCanonicalPath();
|
||||
dst[i] = resolveDestination(it.getKey(), it.getValue()).getCanonicalPath();
|
||||
dst[i] = resolveDestination(it.getKey(), it.getValue(), false).getCanonicalPath();
|
||||
i++;
|
||||
}
|
||||
|
||||
callNative_Shell32(this, src, dst);
|
||||
}
|
||||
|
||||
|
||||
private static void callNative_Shell32(NativeRenameAction action, String[] src, String[] dst) {
|
||||
// configure parameter structure
|
||||
SHFILEOPSTRUCT op = new SHFILEOPSTRUCT();
|
||||
op.wFunc = (this == MOVE) ? ShellAPI.FO_MOVE : ShellAPI.FO_COPY;
|
||||
op.wFunc = (action == MOVE) ? ShellAPI.FO_MOVE : ShellAPI.FO_COPY;
|
||||
op.fFlags = Shell32.FOF_MULTIDESTFILES | Shell32.FOF_NOCONFIRMMKDIR;
|
||||
|
||||
op.pFrom = new WString(op.encodePaths(src));
|
||||
|
@ -50,8 +50,7 @@ public final class Settings {
|
||||
|
||||
|
||||
public static boolean useNativeShell() {
|
||||
//TODO disable by default for final release
|
||||
return System.getProperty("useNativeShell") == null ? true : Boolean.parseBoolean(System.getProperty("useNativeShell"));
|
||||
return Boolean.parseBoolean(System.getProperty("useNativeShell"));
|
||||
}
|
||||
|
||||
|
||||
@ -91,7 +90,7 @@ public final class Settings {
|
||||
applicationFolder = new File(System.getProperty("user.dir"));
|
||||
}
|
||||
|
||||
// create folder if necessary
|
||||
// create folder if necessary
|
||||
if (!applicationFolder.exists()) {
|
||||
applicationFolder.mkdirs();
|
||||
}
|
||||
@ -104,7 +103,6 @@ public final class Settings {
|
||||
return new Settings(Preferences.userNodeForPackage(type));
|
||||
}
|
||||
|
||||
|
||||
private final Preferences prefs;
|
||||
|
||||
|
||||
|
@ -30,7 +30,7 @@ public enum StandardRenameAction implements RenameAction {
|
||||
|
||||
@Override
|
||||
public File rename(File from, File to) throws Exception {
|
||||
File destionation = FileUtilities.resolveDestination(from, to);
|
||||
File destionation = FileUtilities.resolveDestination(from, to, true);
|
||||
|
||||
// move file and the create a symlink to the new location via NIO.2
|
||||
try {
|
||||
@ -48,7 +48,7 @@ public enum StandardRenameAction implements RenameAction {
|
||||
|
||||
@Override
|
||||
public File rename(File from, File to) throws Exception {
|
||||
File destionation = FileUtilities.resolveDestination(from, to);
|
||||
File destionation = FileUtilities.resolveDestination(from, to, true);
|
||||
|
||||
// create symlink via NIO.2
|
||||
try {
|
||||
@ -65,7 +65,7 @@ public enum StandardRenameAction implements RenameAction {
|
||||
|
||||
@Override
|
||||
public File rename(File from, File to) throws Exception {
|
||||
File destionation = FileUtilities.resolveDestination(from, to);
|
||||
File destionation = FileUtilities.resolveDestination(from, to, true);
|
||||
|
||||
// create hardlink via NIO.2
|
||||
try {
|
||||
@ -82,7 +82,7 @@ public enum StandardRenameAction implements RenameAction {
|
||||
|
||||
@Override
|
||||
public File rename(File from, File to) throws IOException {
|
||||
return FileUtilities.resolveDestination(from, to);
|
||||
return FileUtilities.resolveDestination(from, to, false);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -47,6 +47,7 @@ class RenameAction extends AbstractAction {
|
||||
|
||||
public static final String RENAME_ACTION = "RENAME_ACTION";
|
||||
|
||||
|
||||
private final RenameModel model;
|
||||
|
||||
|
||||
@ -63,6 +64,7 @@ class RenameAction extends AbstractAction {
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent evt) {
|
||||
if (model.getRenameMap().isEmpty()) {
|
||||
return;
|
||||
@ -102,7 +104,7 @@ class RenameAction extends AbstractAction {
|
||||
dialog.setVisible(true);
|
||||
}
|
||||
}
|
||||
} catch (Exception e) {
|
||||
} catch (Throwable e) {
|
||||
// could not rename one of the files, revert all changes
|
||||
UILogger.log(Level.WARNING, e.getMessage(), e);
|
||||
}
|
||||
@ -253,7 +255,7 @@ class RenameAction extends AbstractAction {
|
||||
// rename file, throw exception on failure
|
||||
action.rename(mapping.getKey(), mapping.getValue());
|
||||
|
||||
// remember successfully renamed matches for history entry and possible revert
|
||||
// remember successfully renamed matches for history entry and possible revert
|
||||
renameLog.put(mapping.getKey(), mapping.getValue());
|
||||
}
|
||||
} finally {
|
||||
@ -323,7 +325,7 @@ class RenameAction extends AbstractAction {
|
||||
super.cancel(false);
|
||||
throw e;
|
||||
} finally {
|
||||
// check status of renamed files
|
||||
// check status of renamed files
|
||||
for (Entry<File, File> it : renameMap.entrySet()) {
|
||||
if (it.getValue().exists()) {
|
||||
renameLog.put(it.getKey(), it.getValue());
|
||||
|
@ -44,7 +44,7 @@ public final class FileUtilities {
|
||||
|
||||
public static File moveRename(File source, File destination) throws IOException {
|
||||
// resolve destination
|
||||
destination = resolveDestination(source, destination);
|
||||
destination = resolveDestination(source, destination, true);
|
||||
|
||||
if (source.isDirectory()) {
|
||||
// move folder
|
||||
@ -64,7 +64,7 @@ public final class FileUtilities {
|
||||
|
||||
public static File copyAs(File source, File destination) throws IOException {
|
||||
// resolve destination
|
||||
destination = resolveDestination(source, destination);
|
||||
destination = resolveDestination(source, destination, true);
|
||||
|
||||
if (source.isDirectory()) {
|
||||
// copy folder
|
||||
@ -82,7 +82,7 @@ public final class FileUtilities {
|
||||
}
|
||||
|
||||
|
||||
public static File resolveDestination(File source, File destination) throws IOException {
|
||||
public static File resolveDestination(File source, File destination, boolean mkdirs) throws IOException {
|
||||
// resolve destination
|
||||
if (!destination.isAbsolute()) {
|
||||
// same folder, different name
|
||||
@ -93,7 +93,7 @@ public final class FileUtilities {
|
||||
File destinationFolder = destination.getParentFile();
|
||||
|
||||
// create parent folder if necessary
|
||||
if (!destinationFolder.isDirectory() && !destinationFolder.mkdirs()) {
|
||||
if (mkdirs && !destinationFolder.isDirectory() && !destinationFolder.mkdirs()) {
|
||||
throw new IOException("Failed to create folder: " + destinationFolder);
|
||||
}
|
||||
|
||||
@ -502,7 +502,7 @@ public final class FileUtilities {
|
||||
tr.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "yes");
|
||||
tr.setOutputProperty(OutputKeys.INDENT, "yes");
|
||||
|
||||
//create string from dom
|
||||
// create string from dom
|
||||
StringWriter buffer = new StringWriter();
|
||||
tr.transform(new DOMSource(dom), new StreamResult(buffer));
|
||||
return buffer.toString();
|
||||
@ -532,6 +532,7 @@ public final class FileUtilities {
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
public static final FileFilter FILES = new FileFilter() {
|
||||
|
||||
@Override
|
||||
@ -540,6 +541,7 @@ public final class FileUtilities {
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
public static final FileFilter TEMPORARY = new FileFilter() {
|
||||
|
||||
private final String tmpdir = System.getProperty("java.io.tmpdir");
|
||||
|
Loading…
Reference in New Issue
Block a user