Differenze tra le versioni di "Conoscere in tempo reale con "proc...fdinfo" la quantità dei dati elaborati di un file audio"
Riga 8: | Riga 8: | ||
Tale risorsa, rappresentata dalla sottodirectory "''/proc/[pid]/fdinfo/''", può essere utilizzata anche in Gambas per conoscere in tempo reale la quantità di dati elaborati di un file audio da un'applicazione Gambas con le specifiche risorse di un apposto Componente, oppure da un programma esterno multimediale, lanciato dall'applicazione Gambas mediante ''Shell'' e gestito con le risorse della Classe ''Process''. | Tale risorsa, rappresentata dalla sottodirectory "''/proc/[pid]/fdinfo/''", può essere utilizzata anche in Gambas per conoscere in tempo reale la quantità di dati elaborati di un file audio da un'applicazione Gambas con le specifiche risorse di un apposto Componente, oppure da un programma esterno multimediale, lanciato dall'applicazione Gambas mediante ''Shell'' e gestito con le risorse della Classe ''Process''. | ||
− | |||
==Caso in cui il file audio è eseguito con le risorse native di Gambas== | ==Caso in cui il file audio è eseguito con le risorse native di Gambas== | ||
− | + | Mostriamo un esempio con un'applicazione a ''riga di comando'': | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
'''Public''' Sub Main() | '''Public''' Sub Main() | ||
Riga 56: | Riga 16: | ||
Dim med, prc, s, dati, dt As String | Dim med, prc, s, dati, dt As String | ||
Dim byte, i As Integer | Dim byte, i As Integer | ||
+ | Dim ii As New Integer[2] | ||
Dim fl As File | Dim fl As File | ||
Riga 76: | Riga 37: | ||
<FONT Color=gray>' ''...allora viene eseguito il ciclo per leggere il corrispondente file nella sottodirectory "/proc/[pid]/fdinfo/":''</font> | <FONT Color=gray>' ''...allora viene eseguito il ciclo per leggere il corrispondente file nella sottodirectory "/proc/[pid]/fdinfo/":''</font> | ||
Repeat | Repeat | ||
+ | ii[1] = ii[0] | ||
fl = Open prc &/ "fdinfo" &/ s For Read | fl = Open prc &/ "fdinfo" &/ s For Read | ||
Line Input #fl, dati | Line Input #fl, dati | ||
<FONT Color=gray>' ''Estrapola la parte della stringa afferente ai byte processati:''</font> | <FONT Color=gray>' ''Estrapola la parte della stringa afferente ai byte processati:''</font> | ||
dt = Scan(dati, "*\t*")[1] | dt = Scan(dati, "*\t*")[1] | ||
− | Write "\r \e[31m" & dt | + | Write "\r \e[31m" & dt |
+ | Flush | ||
fl.Close | fl.Close | ||
− | + | ii[0] = Val(dt) | |
− | <FONT Color=gray>' '' | + | <FONT Color=gray>' ''Si impone un attesa NON inferiore a 1 secondo, per consentire che venga letto e restituito un valore ogni secondo, altrimenti non sarà garantita durante l'esecuzione la differenziazione fra "Val(dt)" e "ii[1]":''</font> |
− | Until Val(dt) >= | + | Wait 1 |
+ | <FONT Color=gray>' ''Quando il valore letto e il precedente, memorizzato in "ii[1]" sono identici, vuol dire che l'elaborazione dei dati audio e quindi l'esecuzione del file audio sono terminate:''</font> | ||
+ | Until Val(dt) >= ii[1] | ||
pl.Stop | pl.Stop | ||
Riga 90: | Riga 55: | ||
'''End''' | '''End''' | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
==Caso in cui il file audio è eseguito da un programma lanciato con Gambas mediante Shell== | ==Caso in cui il file audio è eseguito da un programma lanciato con Gambas mediante Shell== |
Versione delle 07:43, 30 giu 2021
Indice
Introduzione
La sottodirectory "/fdinfo/", posta sotto la gerarchia "/proc/[pid]/fdinfo/", contiene un riferimento per ogni file che il processo ha aperto, chiamato dal suo descrittore di file. Il contenuto di ogni file può essere letto per ottenerne le informazioni sul descrittore di file corrispondente.
Ovviamente la cartella "[pid]" del percorso "/proc/[pid]/fdinfo/" rappresenta il numero identificativo del processo del programma Gambas che sta elaborando il file audio.
In particolare, se un programma Gambas oppure un multimediale esegue un file audio, viene generato nella sottodirectory "/proc/[pid]/fd/" un collegamento al file audio in esecuzione. Così nella sottodirectory "/proc/[pid]/fdinfo/" viene generato un file che fa riferimento al file-descriptor, posto in "/proc/[pid]/fd/", collegato con il file audio eseguito.
Il file di riferimento, posto in "/proc/[pid]/fdinfo/", fornisce tre righe (campi) di informazioni. La riga che per l'argomento, trattato in questa pagina, ci interessa, è la prima. Tale primo campo di informazioni è chiamato "pos", e rappresenta un numero intero decimale che mostra l'offset del file in esecuzione, ossia la quantità di byte del file audio sino a quel momento elaborati dal programma lanciato.
Tale risorsa, rappresentata dalla sottodirectory "/proc/[pid]/fdinfo/", può essere utilizzata anche in Gambas per conoscere in tempo reale la quantità di dati elaborati di un file audio da un'applicazione Gambas con le specifiche risorse di un apposto Componente, oppure da un programma esterno multimediale, lanciato dall'applicazione Gambas mediante Shell e gestito con le risorse della Classe Process.
Caso in cui il file audio è eseguito con le risorse native di Gambas
Mostriamo un esempio con un'applicazione a riga di comando:
Public Sub Main() Dim pl As MediaPipeline Dim med, prc, s, dati, dt As String Dim byte, i As Integer Dim ii As New Integer[2] Dim fl As File med = "/percorso/del/file/audio" byte = Stat(med).Size Print "File audio: "; File.Name(med) Print "Dimensione: "; byte; " byte\n" pl = New MediaPipeline(Null, "playbin") pl["uri"] = Media.URL(med) pl.Play() prc = "/proc" &/ CStr(Application.Handle) Repeat Inc i s = Dir(prc &/ "fd", "*", gb.Device)[i] Until Stat(prc &/ "fd" &/ s).Link == med ' Se il file descriptor è un link al file audio eseguito,... ' ...allora viene eseguito il ciclo per leggere il corrispondente file nella sottodirectory "/proc/[pid]/fdinfo/": Repeat ii[1] = ii[0] fl = Open prc &/ "fdinfo" &/ s For Read Line Input #fl, dati ' Estrapola la parte della stringa afferente ai byte processati: dt = Scan(dati, "*\t*")[1] Write "\r \e[31m" & dt Flush fl.Close ii[0] = Val(dt) ' Si impone un attesa NON inferiore a 1 secondo, per consentire che venga letto e restituito un valore ogni secondo, altrimenti non sarà garantita durante l'esecuzione la differenziazione fra "Val(dt)" e "ii[1]": Wait 1 ' Quando il valore letto e il precedente, memorizzato in "ii[1]" sono identici, vuol dire che l'elaborazione dei dati audio e quindi l'esecuzione del file audio sono terminate: Until Val(dt) >= ii[1] pl.Stop pl.Close End
Caso in cui il file audio è eseguito da un programma lanciato con Gambas mediante Shell
Mostriamo un esempio in ambiente grafico, nel quale si lancerà il programma multimediale VLC, passandogli un file audio da eseguire, e si mostrerà in una ProgressBar la percentuale corrente dei dati di un file audio eseguiti.
Public Sub Button1_Click() Dim pr As Process Dim fl As File Dim media, prc, s, dati As String Dim byte, i As Integer media = "/percorso/del/file/audio" byte = Stat(media).Size Me.Caption = "File media: " & media & " - dimensione: " & CStr(byte) & " byte" ' Lancia il programma VLC passandogli il percorso del file audio da eseguire: pr = Shell "cvlc " & media ' Individua con precisione il numero del processo del programma VLC dalla proprietà ".Handle" della variabile "Process", aumentato di un'unità: prc = "/proc" &/ CStr(pr.Handle + 1) Wait 0.3 Repeat Inc i s = Dir(prc &/ "fd", "*", gb.Device)[i] Until Stat(prc &/ "fd" &/ s).Link == media ' Se il file descriptor è un link al file audio eseguito,... Wait 0.3 ' ...allora viene eseguito il ciclo per leggere il corrispondente file nella sottodirectory "/proc/[pid]/fdinfo/": Repeat fl = Open prc &/ "fdinfo" &/ s For Read Line Input #fl, dati ' Aggiorna la proprietà ".value" della "ProgressBar": ProgressBar1.Value = Val(Scan(dati, "*\t*")[1]) / byte fl.Close Wait 0.01 ' Se è stato chiuso manualmente il Form, allora si esce dal ciclo "Repeat...Until": If Object.IsValid(Me) = False Then Break ' Il ciclo di norma dura sino a quando non sono stati elaborati tutti i dati del file audio: Until ProgressBar1.Value = 1.00 pr.Close End Public Sub Form_Close() ' Se è stato comunque chiuso il Form, allora viene terminato il processo del programma multimediale: Shell "killall vlc" End