mirror of
https://github.com/gabehf/Tdarr_Plugins.git
synced 2026-03-16 10:45:53 -07:00
Better precision when files are .1 .01 .001 % off for example
Lets you set upper and lower bounds more accurately and prints out more accurate error figures. Default has error range of 2%, this default has error range of 1% (.5% above or below). In testing it appears that going even to 99.8 <> 100.2 would also be acceptable and present little to no false positives with an error range of .4%. I've seen random failures that are just barely caught at 98% of original. newData & oldData maintain up to 3 to 5 decimal places of accuracy sometimes. This allows ratio to more accurately reflect that. 2 places should be sufficient.
This commit is contained in:
parent
0fed4e0ddc
commit
84435cf43f
1 changed files with 7 additions and 7 deletions
|
|
@ -8,13 +8,13 @@ const details = () => ({
|
||||||
Operation: 'Transcode',
|
Operation: 'Transcode',
|
||||||
Description: `Give an error if new file is not within the specified upper and lower bound duration limits.
|
Description: `Give an error if new file is not within the specified upper and lower bound duration limits.
|
||||||
Make sure MediaInfo scan is enabled in library settings \n\n`,
|
Make sure MediaInfo scan is enabled in library settings \n\n`,
|
||||||
Version: '1.00',
|
Version: '1.01',
|
||||||
Tags: '',
|
Tags: '',
|
||||||
Inputs: [
|
Inputs: [
|
||||||
{
|
{
|
||||||
name: 'upperBound',
|
name: 'upperBound',
|
||||||
type: 'number',
|
type: 'number',
|
||||||
defaultValue: 101,
|
defaultValue: 100.5,
|
||||||
inputUI: {
|
inputUI: {
|
||||||
type: 'text',
|
type: 'text',
|
||||||
},
|
},
|
||||||
|
|
@ -25,7 +25,7 @@ const details = () => ({
|
||||||
{
|
{
|
||||||
name: 'lowerBound',
|
name: 'lowerBound',
|
||||||
type: 'number',
|
type: 'number',
|
||||||
defaultValue: 99,
|
defaultValue: 99.5,
|
||||||
inputUI: {
|
inputUI: {
|
||||||
type: 'text',
|
type: 'text',
|
||||||
},
|
},
|
||||||
|
|
@ -50,8 +50,8 @@ const plugin = (file, librarySettings, inputs, otherArguments) => {
|
||||||
infoLog: '',
|
infoLog: '',
|
||||||
};
|
};
|
||||||
|
|
||||||
let newData = 0;
|
let newData = 0.0;
|
||||||
let oldData = 0;
|
let oldData = 0.0;
|
||||||
|
|
||||||
const getData = (obj) => {
|
const getData = (obj) => {
|
||||||
try {
|
try {
|
||||||
|
|
@ -65,12 +65,12 @@ const plugin = (file, librarySettings, inputs, otherArguments) => {
|
||||||
newData = getData(file);
|
newData = getData(file);
|
||||||
oldData = getData(otherArguments.originalLibraryFile);
|
oldData = getData(otherArguments.originalLibraryFile);
|
||||||
|
|
||||||
const ratio = parseInt((newData / oldData) * 100, 10);
|
const ratio = ((newData / oldData) * 100.0).toFixed(2);
|
||||||
|
|
||||||
const dataText = `New file has duration ${newData} s which is ${ratio}% `
|
const dataText = `New file has duration ${newData} s which is ${ratio}% `
|
||||||
+ `of original file duration: ${oldData} s`;
|
+ `of original file duration: ${oldData} s`;
|
||||||
|
|
||||||
const getBound = (bound) => (bound / 100) * oldData;
|
const getBound = (bound) => (bound / 100.0) * oldData;
|
||||||
|
|
||||||
const errText = 'New file duration not within limits.';
|
const errText = 'New file duration not within limits.';
|
||||||
if (newData > getBound(inputs.upperBound)) {
|
if (newData > getBound(inputs.upperBound)) {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue