1
0
Fork 0

pedazo refactor

This commit is contained in:
Xavier Fontanet 2023-05-10 00:32:27 +02:00
parent 95cb29d287
commit f815a32a06
2 changed files with 105 additions and 140 deletions

View File

@ -1,4 +1,8 @@
//by @xeviff
/* HARDCODED */
def skipAudioCheck = true
def relocation = false
/*************/
/** RUTAS **/
def ubuntu_desktop=false
@ -19,11 +23,6 @@ def ruta_asiaticas = root+"Pelis_asiaticas/"
def rutaKO = root+"error/"
/**********/
/* HARDCODED */
def skipAudioCheck = true
def relocation = true
/*************/
/** Audio (definición) **/
def hayEAC3=false
@ -76,7 +75,7 @@ def printAudio (audio2Print) {
else if (idiomaOrigin =~ /(?i)\bcast\b|\bspa\b/)
idioma = "Es"
} else {
idioma = idiomaOrigin.replace("Catalan","Cat").replace("Espanol / Espanol", "Es").replaceFirst(/(?i)(spanish|espa.ol)/,"Es")
idioma = idiomaOrigin.replace("Catalan","Cat").replace("Espanol / Espanol", "Es").replaceFirst(/(?i)(spanish|espa.ol)/,"Es").replace("(ES)","")
}
def formato_audio = audio2Print.Format_Commercial.replace("Dolby Digital":"Dolby").replace(" Plus","+")
.replace("DTS-HD Master Audio","DTS-MA").replace("DTS-HD High Resolution Audio","DTS-HD-H")
@ -85,6 +84,20 @@ def printAudio (audio2Print) {
def canales = audio2Print.Channels.replace(2:'2.0', 6:'5.1', 8:'7.1')
return idioma + ' ' + formato_audio + ' ' + canales
}
def bloqueSubs
def handleSub(sub, capturedSubs) {
def lang = sub.Language_String != null ? sub.Language_String : sub.title
def lang3 = sub.Language_String3 != null ? sub.Language_String3 : sub.title
def forced = sub.title!=null ? sub.title.toLowerCase().contains("forzado") : false
if (!capturedSubs.containsKey(lang)) {
capturedSubs[lang] = lang3+(forced?'+F':'')
} else {
def existing=capturedSubs[lang]
if (!existing.contains('+F') && !existing.contains('+'))
capturedSubs[lang] = lang3+(forced?'+F':'+')
}
}
/***********/
/* otras funciones */
def getInicial () {
@ -100,8 +113,8 @@ def normalLang(langs) {
return !langs.isEmpty() ? {try { for (lan in languages) langs.add(lan.toString()) } catch(err) {langs}}() : langs
}
def sanityCheck(newId) {
def oldId = fn.find(/\{tmdb-\d+\}/).find(/\d+/)
return oldId == newId.toString()
def oldId = fn.find(/\{tmdb-\d+\}/)?.find(/\d+/)
return oldId!=null ? oldId == newId.toString() : true
}
/***********/
@ -137,31 +150,84 @@ try { //empieza el script
def peso = bytes.toString().before(' ').toDouble()
def numericBps = (mbps.toString().before(' ').toDouble()*1000000).round()
def calidad =
['480p', '576p', '360p', '240p'].contains(vf) ? 'SD' //SD
: (vf == '2160p') ? //4K
(vf == '2160p') ? //4K
(peso > 30 && numericBps >= 26000000)
? "4K-UHDRemux"
? "UHDRemux"
: (peso > 15)
? "4K-UHDRip"
: "4K-MicroUHD"
? "UHDRip"
: "microUHD"
: (vf == '1080p') ? //1080
(peso > 15 && numericBps >= 18000000)
? "1080-BDRemux"
: (numericBps > 8000000)
? "1080-HD"
: "1080-MicroHD"
: vf //720
? "1080"
: "microHD"
: vf
def calidadF = calidad=="4K-UHDRemux" ? "4K"
: calidad=="4K-UHDRip" ? "4K"
: calidad=="4K-MicroUHD" ? "micro4K"
: calidad=="1080-BDRemux" ? "HD"
: calidad=="1080-HD" ? "HD"
: calidad=="1080-MicroHD" ? "microHD"
: calidad=="SD" ? vf // Los SD vamos a poner su resolución
: calidad //tal cual
/***************************/
/** Formato distribución **/
formato_distribucion =
fn=~/(?i)\bblu.?ray\b|\bbdrip\b/ ? (calidad==~"rip" ? '' : 'BDRip') :
fn=~/(?i)remux/ ? (calidad==~"remux" ? '' : 'BDRemux') :
fn=~/(?i)\bWEB.??(DL|RIP)\b/ ? 'WEB-DL' :
''
if (formato_distribucion=='WEB-DL') {
def plataforma = fn.find( //coge el contenido que encaja
/(?i)\bAMZN?\b|\bNF\b|\bHBO\b|\bHBO.?MAX\b|\bHMAX\b|\bHULU\b|\bA3P\b|\bDPLY\b|\bSTARZ\b|\bFILMIN\b|\bFLMN\b|\bNETFLIX\b|\bDSN.?\b|\bDSP+?\b|\bRTVE\b|\bFLIXOL.\b|\bM\+\b/ )
if (plataforma!=null) plataforma = plataforma.replace("MVPLUS","MV+")
formato_distribucion = formato_distribucion+(plataforma!=null?(' '+plataforma.toUpperCase()):'')
} else if (hayEAC3) //por el audio también se determina que es web-dl
formato_distribucion = 'WEB-DL'
if (formato_distribucion!='') formato_distribucion=' '+formato_distribucion
/**********************************/
/**** HDR ********/
def hdr_info=''
try{
def mHDRCol = ["BT.709" : "NO", "BT.2020" : "YES"]
def _HDRMap = ["HDR10": "HDR10", "SMPTE ST 2086": "HDR10", "SMPTE ST 2094 App 4": "HDR10+", "Dolby Vision / SMPTE ST 2086": "Dolby Vision", "Dolby Vision / HDR10": "Dolby Vision",]
def vid = video.first()
String _HDR
switch (bitdepth) {
case { it > 8 }:
_HDR = any
{ vid["HDR_Format_Commercial"] }
{ vid["HDR_Format"] }
{ hdr }
{ null }
break
default:
"$bitdepth-bit"
break
}
hdr_info = _HDRMap.find { k, v -> k =~ _HDR }?.value
if (hdr_info!=null) hdr_info=' '+hdr_info
} catch (err) {}
/*****************/
/**** Profundidad de color */
def profundidadColor=''
try{profundidadColor = ' '+bitdepth+"bits" } catch(err){}
/**************************/
/**** Profundidad vídeo ****/
def myBitrate = 'noBRdef'
try{ myBitrate = mbps.replace(/.0/,'').replace(' ','') }catch(err){}
def myFps = ' FRvar'
try { myFps = ' '+fps.replace(/.0/,'').replace(' ','') }catch(err){}
/***************************/
/* RESULTADO MEDIAINFO */
def bloqueCalidadVideo = calidad + formato_distribucion
def bloqueDescVideo = myBitrate + profundidadColor + myFps + hdr_info
def bloqueVideo = ' ['+codecVideo+' '+bloqueCalidadVideo+'] ['+bloqueDescVideo+']'
/** Audio (ejecución) **/
def catalanAudios=[]
def spanishAudios=[]
@ -221,118 +287,20 @@ try { //empieza el script
} else {
if (!skipAudioCheck) throw new Exception("[idioma_audio_no_encontrado]")
}
if (bloqueAudio==null) bloqueAudio = "audio_no_def"
if (bloqueAudio==null) bloqueAudio = "[audio_no_def]"
else bloqueAudio = ' ['+bloqueAudio+']'
/***********/
/** Formato distribución **/
formato_distribucion =
fn=~/(?i)\bblu.?ray\b/ ? 'BDRip' :
fn=~/(?i)\bdrip\b/ ? 'BDRip' :
fn=~/(?i)\bDVD.?RIP\b/ ? 'DVDRip' :
fn=~/(?i)\bHDiTunes\b/ ? 'HDiTunes' :
fn=~/(?i)\bTV.?RIP\b/ ? 'TVRip' :
fn=~/(?i)\bWEB.?Screener\b/ ? 'WEB-SRC' :
'no_encontrado'
def plataforma
def esWEB_DL=false
if (formato_distribucion=='no_encontrado') {
esWEB_DL = fn=~/(?i)\bWEB.??(DL|RIP)\b/ //WEB-DL o WEB-RIP (todo junto o con punto/guión/etc)
if (esWEB_DL) {
def web_x = fn=~/(?i)\bWEB.?DL\b/ ? 'WEB-DL' : 'WEB-RIP' //guardar el que es
plataforma = fn.find( //coge el contenido que encaja
/(?i)\bAMZN?\b|\bNF\b|\bHBO\b|\bHBO.?MAX\b|\bHMAX\b|\bHULU\b|\bA3P\b|\bDPLY\b|\bSTARZ\b|\bFILMIN\b|\bFLMN\b|\bNETFLIX\b|\bDSN.?\b|\bDSP+?\b|\bRTVE\b|\bFLIXOL.\b|\bM\+\b/ )
if (plataforma!=null) plataforma = plataforma.replace("MVPLUS","MV+")
formato_distribucion = web_x+(plataforma!=null?(' '+plataforma.toUpperCase()):'') //web-dl/rip + plataforma(si hay)
} else {
if (hayEAC3) //por el audio también se determina que es web-dl
formato_distribucion = 'WEB-DL'
else {
def otrosFD = fn.find( /(?i)\bMTL\b |\bMUBI\b/ )
if (otrosFD!= null && !otrosFD.isEmpty())
formato_distribucion = otrosFD.toUpperCase() //si son estos, se setea
}
}
}
/**********/
/** Formato distribución 2ª ronda**/
//formato_distribucion = formato_distribucion=='no_encontrado'? '' : ' '+formato_distribucion
if (formato_distribucion=='no_encontrado') {
formato_distribucion =
calidad=="4K-UHDRemux" ? "UHDRemux" :
calidad=="4K-UHDRip" ? "UHDRip" :
calidad=="4K-MicroUHD" ? "UHDRip" :
calidad=="1080-BDRemux" ? "BDRemux" :
calidad=="1080-HD" ? "DBRip" :
calidad=="1080-MicroHD" ? "BDRip" :
'' //no_encontrado -> ''
} else {
if (calidad=~/(?i)\remux\b/) {
formato_distribucion =
calidad=="4K-UHDRemux" ? "UHDRemux" :
calidad=="1080-BDRemux" ? "BDRemux" :
'' //no_encontrado -> ''
}
}
if (formato_distribucion!='') formato_distribucion=' '+formato_distribucion
/**********************************/
/**** HDR ********/
def hdr_info=''
try{
def mHDRCol = ["BT.709" : "NO", "BT.2020" : "YES"]
def hdr_info_old = (bitdepth >= 10 && mHDRCol.get(self.video[0].colourprimaries) == "YES" ) ? ' HDR' : ''
def _HDRMap = [
"HDR10": "HDR10",
"SMPTE ST 2086": "HDR10",
"SMPTE ST 2094 App 4": "HDR10+",
"Dolby Vision / SMPTE ST 2086": "Dolby Vision",
"Dolby Vision / HDR10": "Dolby Vision",
]
def vid = video.first()
String _HDR
switch (bitdepth) {
case { it > 8 }:
_HDR = any
{ vid["HDR_Format_Commercial"] }
{ vid["HDR_Format"] }
{ hdr }
{ null }
break
default:
"$bitdepth-bit"
break
}
def hdr_info_ = _HDRMap.find { k, v ->
k =~ _HDR
}?.value
if (hdr_info_!=null) hdr_info=' '+hdr_info_
} catch (err) {}
/*****************/
/**** Profundidad de color */
def profundidadColor=''
try{profundidadColor = bitdepth+"bits" } catch(err){}
/**************************/
/**** Profundidad vídeo ****/
def myBitrate = 'noBRdef'
try{ myBitrate = mbps.replace(/.0/,'').replace(' ','') }catch(err){}
def myFps = ' FRvar'
try { myFps = ' '+fps.replace(/.0/,'').replace(' ','') }catch(err){}
/***************************/
/* RESULTADO MEDIAINFO */
def bloqueCalidadVideo = calidadF+formato_distribucion+hdr_info
def bloqueProfundidad = myBitrate+myFps
if (bloqueProfundidad!='' && profundidadColor!='') bloqueProfundidad=' '+bloqueProfundidad
def bloqueMediainfo = ' ['+codecVideo+' '+bloqueCalidadVideo+']['+profundidadColor+bloqueProfundidad+']'+' ['+bloqueAudio+']'
/***** subtitulos *******/
try {
def capturedSubs = [:]
bloqueSubs = ' [sub '
for (sub in text) handleSub(sub, capturedSubs)
for (entry in capturedSubs) bloqueSubs += entry.value+', '
bloqueSubs = bloqueSubs.substring(0,bloqueSubs.size()-2)+']'
}catch(err){bloqueSubs=' [no sub]'}
/************************/
/**************************************/
@ -434,20 +402,17 @@ try { //empieza el script
else if (y<2000) ruta = ruta_retro
if (ruta==rutaOK && y>=2021) ruta = ruta_estrenos
/********************************************/
/**************************************/
/**** Nombre pelicula ****/
def nombrePelicula_formatoPlex = {try { primaryTitle!=localize.Catalan.n ? localize.Catalan.plex.name : localize.Spanish.plex.name } catch (err) {localize.Spanish.plex.name} }()
/*************************/
/*** RESULTADO FINAL ***/
def inicial = (ruta==rutaOK || ruta==ruta_retro) ? getInicial() : ''
def tmdb = " {tmdb-"+tmdbid+"}"
def carpetaPeli = localize.Spanish.plex.name + tmdb + '/'
def nomPrincipal = nombrePelicula_formatoPlex + bloqueMediainfo
def tracker = fn.find(/(?i)\bHDO(limpo)?\b/)
def nomPrincipal = nombrePelicula_formatoPlex + bloqueVideo + bloqueAudio + bloqueSubs
def tracker = fn.find(/(?i)\bHDO(limpo)?\b|\bRedBits\b/)
def extras = tracker != null ? ' ['+tracker.replace("HDOlimpo", "HDO")+']' : ''
return ruta + inicial + carpetaPeli + nomPrincipal + extras + tmdb

View File

@ -38,8 +38,8 @@ def normalLang(langs) {
return !langs.isEmpty() ? {try { for (lan in languages) langs.add(lan.toString()) } catch(err) {langs}}() : langs
}
def sanityCheck(newId) {
def oldId = fn.find(/\{tmdb-\d+\}/).find(/\d+/)
return oldId == newId.toString()
def oldId = fn.find(/\{tmdb-\d+\}/)?.find(/\d+/)
oldId!=null ? oldId == newId.toString() : true
}
//*****************************************************************************************/
//*****************************************************************************************/