Differenze tra le versioni di "Conoscere in tempo reale con "proc...fdinfo" la quantità dei dati elaborati di un file audio"

Da Gambas-it.org - Wikipedia.
Riga 57: Riga 57:
  
 
==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==
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.
+
Mostriamo un esempio in ambiente grafico, nel quale si lancerà il programma multimediale VLC, passandogli un file audio da eseguire, e si mostrerà nell'intestazione della finestra del "Form" la quantità corrente dei dati del file audio eseguiti.
 
  '''Public''' Sub Button1_Click()
 
  '''Public''' Sub Button1_Click()
 
    
 
    
Riga 74: Riga 74:
 
   prc = "/proc" &/ CStr(pr.Handle + 1)
 
   prc = "/proc" &/ CStr(pr.Handle + 1)
 
    
 
    
   Wait 0.3
+
   Wait 0.5
 
   Repeat
 
   Repeat
 
     Inc i
 
     Inc i
Riga 80: Riga 80:
 
   Until Stat(prc &/ "fd" &/ s).Link == media  <FONT Color=gray>' ''Se il file descriptor è un link al file audio eseguito,...''</font>
 
   Until Stat(prc &/ "fd" &/ s).Link == media  <FONT Color=gray>' ''Se il file descriptor è un link al file audio eseguito,...''</font>
 
    
 
    
  Wait 0.3
 
 
  <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
 
     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>' ''Aggiorna la proprietà ".value" della "ProgressBar":''</font>
+
  <FONT Color=gray>' ''Mostra i dati audio sino a questo momento processati:''</font>
     ProgressBar1.Value = Val(Scan(dati, "*\t*")[1]) / byte
+
     Me.Text = Scan(dati, "*\t*")[1]
 
     fl.Close
 
     fl.Close
     Wait 0.01
+
     Wait 0.1
 
  <FONT Color=gray>' ''Se è stato chiuso manualmente il Form, allora si esce dal ciclo "Repeat...Until":''</font>
 
  <FONT Color=gray>' ''Se è stato chiuso manualmente il Form, allora si esce dal ciclo "Repeat...Until":''</font>
    If Object.IsValid(Me) = False Then Break
+
  Until Object.IsValid(Me) = False
<FONT Color=gray>' ''Il ciclo di norma dura sino a quando non sono stati elaborati tutti i dati del file audio:''</font>
+
    
   Until ProgressBar1.Value = 1.00
 
 
   pr.Close
 
   pr.Close
 
    
 
    

Versione delle 13:24, 30 giu 2021

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à nell'intestazione della finestra del "Form" la quantità corrente dei dati del 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.5
 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,...
 
' ...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
' Mostra i dati audio sino a questo momento processati:
   Me.Text = Scan(dati, "*\t*")[1]
   fl.Close
   Wait 0.1
' Se è stato chiuso manualmente il Form, allora si esce dal ciclo "Repeat...Until":
 Until Object.IsValid(Me) = False
 
 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


Riferimenti