1
0
mirror of https://github.com/mitb-archive/filebot synced 2025-01-12 06:18:01 -05:00

* n00b counter measures: sample file not set issue

This commit is contained in:
Reinhard Pointner 2015-11-29 09:28:54 +00:00
parent 6b05c3f0c6
commit 58da1b2cfc
2 changed files with 32 additions and 46 deletions

View File

@ -78,6 +78,14 @@ public class MediaBindingBean {
this.context = context; this.context = context;
} }
public Object getInfoObject() {
return infoObject;
}
public File getFileObject() {
return mediaFile;
}
@Define(undefined) @Define(undefined)
public <T> T undefined(String name) { public <T> T undefined(String name) {
// omit expressions that depend on undefined values // omit expressions that depend on undefined values
@ -396,12 +404,12 @@ public class MediaBindingBean {
@Define("original") @Define("original")
public String getOriginalFileName() throws Exception { public String getOriginalFileName() throws Exception {
return getOriginalFileName(mediaFile); return getOriginalFileName(getMediaFile());
} }
@Define("xattr") @Define("xattr")
public Object getMetaAttributesObject() throws Exception { public Object getMetaAttributesObject() throws Exception {
return new MetaAttributes(mediaFile).getObject(); return new MetaAttributes(getMediaFile()).getObject();
} }
@Define("crc32") @Define("crc32")
@ -442,20 +450,14 @@ public class MediaBindingBean {
@Define("fn") @Define("fn")
public String getFileName() { public String getFileName() {
// make sure media file is defined // name without file extension
checkMediaFile(); return FileUtilities.getName(getMediaFile());
// file extension
return FileUtilities.getName(mediaFile);
} }
@Define("ext") @Define("ext")
public String getExtension() { public String getExtension() {
// make sure media file is defined
checkMediaFile();
// file extension // file extension
return FileUtilities.getExtension(mediaFile); return FileUtilities.getExtension(getMediaFile());
} }
@Define("source") @Define("source")
@ -509,15 +511,12 @@ public class MediaBindingBean {
@Define("lang") @Define("lang")
public Language detectSubtitleLanguage() throws Exception { public Language detectSubtitleLanguage() throws Exception {
// make sure media file is defined Locale languageSuffix = releaseInfo.getLanguageSuffix(FileUtilities.getName(getMediaFile()));
checkMediaFile();
Locale languageSuffix = releaseInfo.getLanguageSuffix(FileUtilities.getName(mediaFile));
if (languageSuffix != null) if (languageSuffix != null)
return Language.getLanguage(languageSuffix); return Language.getLanguage(languageSuffix);
// require subtitle file // require subtitle file
if (!SUBTITLE_FILES.accept(mediaFile)) { if (!SUBTITLE_FILES.accept(getMediaFile())) {
return null; return null;
} }
@ -745,6 +744,11 @@ public class MediaBindingBean {
@Define("file") @Define("file")
public File getMediaFile() { public File getMediaFile() {
// make sure file is not null, and that it is an existing file
if (mediaFile == null) {
throw new IllegalStateException("Path to media file not set. Click \"Change Sample\" and select a sample file.");
}
return mediaFile; return mediaFile;
} }
@ -785,11 +789,6 @@ public class MediaBindingBean {
return null; return null;
} }
@Define("object")
public Object getInfoObject() {
return infoObject;
}
@Define("i") @Define("i")
public Integer getModelIndex() { public Integer getModelIndex() {
return 1 + identityIndexOf(context.values(), getInfoObject()); return 1 + identityIndexOf(context.values(), getInfoObject());
@ -826,16 +825,13 @@ public class MediaBindingBean {
} }
public File getInferredMediaFile() { public File getInferredMediaFile() {
// make sure media file is defined if (getMediaFile().isDirectory()) {
checkMediaFile();
if (mediaFile.isDirectory()) {
// just select the first video file in the folder as media sample // just select the first video file in the folder as media sample
SortedSet<File> videos = new TreeSet<File>(filter(listFiles(mediaFile), VIDEO_FILES)); SortedSet<File> videos = new TreeSet<File>(filter(listFiles(getMediaFile()), VIDEO_FILES));
if (videos.size() > 0) { if (videos.size() > 0) {
return videos.iterator().next(); return videos.iterator().next();
} }
} else if (SUBTITLE_FILES.accept(mediaFile) || ((infoObject instanceof Episode || infoObject instanceof Movie) && !VIDEO_FILES.accept(mediaFile))) { } else if (SUBTITLE_FILES.accept(getMediaFile()) || ((infoObject instanceof Episode || infoObject instanceof Movie) && !VIDEO_FILES.accept(getMediaFile()))) {
// prefer equal match from current context if possible // prefer equal match from current context if possible
if (context != null) { if (context != null) {
for (Entry<File, Object> it : context.entrySet()) { for (Entry<File, Object> it : context.entrySet()) {
@ -846,8 +842,8 @@ public class MediaBindingBean {
} }
// file is a subtitle, or nfo, etc // file is a subtitle, or nfo, etc
String baseName = stripReleaseInfo(FileUtilities.getName(mediaFile)).toLowerCase(); String baseName = stripReleaseInfo(FileUtilities.getName(getMediaFile())).toLowerCase();
List<File> videos = getChildren(mediaFile.getParentFile(), VIDEO_FILES); List<File> videos = getChildren(getMediaFile().getParentFile(), VIDEO_FILES);
// find corresponding movie file // find corresponding movie file
for (File movieFile : videos) { for (File movieFile : videos) {
@ -858,7 +854,7 @@ public class MediaBindingBean {
// still no good match found -> just take the most probable video from the same folder // still no good match found -> just take the most probable video from the same folder
if (videos.size() > 0) { if (videos.size() > 0) {
sort(videos, new SimilarityComparator(FileUtilities.getName(mediaFile)) { sort(videos, new SimilarityComparator(FileUtilities.getName(getMediaFile())) {
@Override @Override
public int compare(Object o1, Object o2) { public int compare(Object o1, Object o2) {
@ -869,22 +865,12 @@ public class MediaBindingBean {
} }
} }
return mediaFile; return getMediaFile();
}
private void checkMediaFile() {
// make sure file is not null, and that it is an existing file
if (mediaFile == null) {
throw new IllegalStateException("Path to media file not set. Click (x)= and select a sample file.");
}
} }
private static final Map<File, MediaInfo> sharedMediaInfoObjects = new WeakValueHashMap<File, MediaInfo>(64); private static final Map<File, MediaInfo> sharedMediaInfoObjects = new WeakValueHashMap<File, MediaInfo>(64);
private synchronized MediaInfo getMediaInfo() { private synchronized MediaInfo getMediaInfo() {
// make sure media file is defined
checkMediaFile();
// lazy initialize // lazy initialize
if (mediaInfo == null) { if (mediaInfo == null) {
// use inferred media file (e.g. actual movie file instead of subtitle file) // use inferred media file (e.g. actual movie file instead of subtitle file)

View File

@ -235,8 +235,8 @@ public class FormatDialog extends JDialog {
@Override @Override
public void propertyChange(PropertyChangeEvent evt) { public void propertyChange(PropertyChangeEvent evt) {
if (isMacSandbox()) { if (isMacSandbox()) {
if (sample != null && sample.getMediaFile() != null && sample.getMediaFile().exists()) { if (sample != null && sample.getFileObject() != null && sample.getFileObject().exists()) {
MacAppUtilities.askUnlockFolders(getWindow(evt.getSource()), singleton(sample.getMediaFile())); MacAppUtilities.askUnlockFolders(getWindow(evt.getSource()), singleton(sample.getFileObject()));
} }
} }
checkFormatInBackground(); checkFormatInBackground();
@ -283,7 +283,7 @@ public class FormatDialog extends JDialog {
if (locked) { if (locked) {
this.setTitle(String.format("%s Format", mode)); this.setTitle(String.format("%s Format", mode));
title.setText(String.format("%s ⇔ %s", mode, bindings.getInfoObject(), bindings.getMediaFile() == null ? null : bindings.getMediaFile().getName())); title.setText(String.format("%s ⇔ %s", mode, bindings.getInfoObject(), bindings.getFileObject() == null ? null : bindings.getFileObject().getName()));
} else { } else {
this.setTitle(String.format("%s Format", mode)); this.setTitle(String.format("%s Format", mode));
title.setText(String.format("%s Format", mode)); title.setText(String.format("%s Format", mode));
@ -651,7 +651,7 @@ public class FormatDialog extends JDialog {
BindingDialog dialog = new BindingDialog(getWindow(evt.getSource()), String.format("%s Bindings", mode), mode.getFormat(), !locked); BindingDialog dialog = new BindingDialog(getWindow(evt.getSource()), String.format("%s Bindings", mode), mode.getFormat(), !locked);
dialog.setInfoObject(sample.getInfoObject()); dialog.setInfoObject(sample.getInfoObject());
dialog.setMediaFile(sample.getMediaFile()); dialog.setMediaFile(sample.getFileObject());
// open dialog // open dialog
dialog.setLocationRelativeTo((Component) evt.getSource()); dialog.setLocationRelativeTo((Component) evt.getSource());
@ -667,7 +667,7 @@ public class FormatDialog extends JDialog {
// remember sample // remember sample
try { try {
mode.persistentSample().setValue(info == null ? "" : JsonWriter.objectToJson(info)); mode.persistentSample().setValue(info == null ? "" : JsonWriter.objectToJson(info));
persistentSampleFile.setValue(file == null ? "" : sample.getMediaFile().getAbsolutePath()); persistentSampleFile.setValue(file == null ? "" : sample.getFileObject().getAbsolutePath());
} catch (Exception e) { } catch (Exception e) {
Logger.getLogger(FormatDialog.class.getName()).log(Level.WARNING, e.getMessage(), e); Logger.getLogger(FormatDialog.class.getName()).log(Level.WARNING, e.getMessage(), e);
} }