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 del blocco..... "; s sh = Legge_Big_Endian(fl, 4) If sh <> 6 Then Error.Raise("Lunghezza blocco MThd non valida !") Print "Lunghezza del 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......... "; Format(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... "; Format(sh, "###") Print "\nIl blocco d'intestazione 'MThd' appare essere corretto." fl.Close End Private Function Legge_Big_Endian(md As File, n As Byte) As Short Dim b As Byte Dim c As Short Repeat Read #md, b c = (c * CInt(2 ^ 8)) Or b Dec n Until n == 0 Return c End