Verificare l'integrità dei dati del blocco d'intestazione di un file Midi

Da Gambas-it.org - Wikipedia.

Il blocco d'intestazione del file Midi (Header Chunk) è costituito da 14 byte e contiene informazioni generali sul file medesimo.

Il particolare esso è composto da dai seguenti dati:

  • l'identificatore del blocco medesimo;
  • la lunghezza della sua parte contenente i byte delle informazioni generali;
  • il tipo di file Midi;
  • il numero di Tracce Midi presenti nel file;
  • la risoluzione del Tempo-Delta.


Per sapere se il blocco d'intestazione è integro, ed anche per conoscere i suddetti cinque tipi di dati, possiamo utilizzare il seguente codice:

Public Sub Main()

 Dim midi, s As String
 Dim fl As File
 Dim sh As Short
 
  midi = "/percorso/del/file.mid"
  Print "File Midi: "; midi

  fl = Open midi For Read
  
  Print "\n==== Analisi del blocco d'intestazione ====\n"
  Read #fl, s, 4
  If s <> "MThd" Then Error.Raise("Identificatore 'MThd' del blocco d'intestazione mancante !")
  Print "Identificativo blocco: "; s

  sh = Legge_Big_Endian(fl, 4)
  If sh <> 6 Then Error.Raise("Lunghezza blocco MThd non valida !")
  Print "Lunghezza blocco MThd: "; sh

  sh = Legge_Big_Endian(fl, 2)
  If (sh < 0) Or (sh > 2) Then Error.Raise("Formato di file non valido !")
  Print "Formato del file: "; sh

  sh = Legge_Big_Endian(fl, 2)
  If sh = 0 Then Error.Raise("Numero di Tracce Midi non valido !")
  Print "Numero di Tracce Midi: "; sh

  sh = Legge_Big_Endian(fl, 2)
  If sh Mod 8 <> 0 Then Error.Raise("Risoluzione del Tempo Delta non valido !")
  Print "Risoluzione del Tempo Delta: "; sh

  Print "\nIl blocco d'intestazione 'MThd' appare essere corretto."

  fl.Close

End


Private Function Legge_Big_Endian(md As File, b As Byte) As Short
 
 Dim c As Byte 
 Dim j As Short
 
  Do
    Read #md, c
    j = (j * CInt(2 ^ 8)) Or c
    Dec b
  Loop Until b = 0
 
  Return j
 
End