Flac.Decoder
Decode native FLAC data
A typical use of the FLAC decoder is the following: * *
(* Raise this when streams has ended. *) * exception End_of_stream * (* Define a read function *) * let input = (..a function of type read..) in * (* Define a write function *) * let output = (..a function of type write..) in * (* Create callbacks *) * let callbacks = Flac.Decoder.get_callbacks input write in * (* Create an unitialized decoder *) * let decoder = Flac.Decoder.create callbacks in * (* Initialize decoder *) * let decoder,info,comments = Flac.Decoder.init decoder callbacks in * (..do something with info and comments..) * (* Decode data *) * match Flac.Decoder.state decoder c with * | `Search_for_metadata * | `Read_metadata * | `Search_for_frame_sync * | `Read_frame -> * Flac.Decoder.process decoder callbacks * | _ -> raise End_of_stream
* * Some remarks: * - Exceptions raised by callbacks should be treated * as fatal errors. The dehaviour of the flac library * after being interrupted by an exception is unknown. * The only notable exception is Ogg/flac decoding, where * the read callback raises Ogg.Not_enough_data
. * - The state of the decoder should be checked prior to calling * process
. Termination may not be detected nor raise an * exception so it is the caller's responsibility to check * on this. * - See FLAC documentation for the information on the * callbacks. * - The variant type for decoder and callbacks is used * to make sure that different type of decoders * (generic, file, ogg) are only used with the same * type of callbacks.
type state = [
| `Search_for_metadata
| `Read_metadata
| `Search_for_frame_sync
| `Read_frame
| `End_of_stream
| `Ogg_error
| `Seek_error
| `Aborted
| `Memory_allocation_error
| `Uninitialized
]
Possible states of a decoder.
val create :
?seek:(int64 -> unit) ->
?tell:(unit -> int64) ->
?length:(unit -> int64) ->
?eof:(unit -> bool) ->
read:(bytes -> int -> int -> int) ->
write:(float array array -> unit) ->
unit ->
t * info * comments option
Create a decoder. The decoder will be used to decode * all metadata. Initial audio data shall be immediatly available * after this call.
val process : t -> unit
Decode one frame of audio data.
val seek : t -> Stdlib.Int64.t -> bool
Flush the input and seek to an absolute sample. * Decoding will resume at the given sample. Note * that because of this, the next write callback may * contain a partial block. The client must support seeking * the input or this function will fail and return false
. * Furthermore, if the decoder state is `Seek_error
* then the decoder must be flushed or reset * before decoding can continue.
val flush : t -> bool
Flush the stream input. * The decoder's input buffer will be cleared and the state set to * `Search_for_frame_sync
. This will also turn * off MD5 checking.
val reset : t -> bool
Reset the decoding process. * The decoder's input buffer will be cleared and the state set to * `Search_for_metadata
. MD5 checking will be restored to its original * setting. * * If the decoder is seekable, the decoder will also attempt to seek to * the beginning of the stream. If this rewind fails, this function will * return false
. It follows that reset
cannot be used when decoding * from stdin
. * * If the decoder is not seekable (i.e. no seek callback was provided) * it is the duty of the client to start feeding data from the beginning * of the stream on the next process
.
Convert an audio array to a S16LE string for * decoding FLAC to WAV and raw PCM
module File : sig ... end
Local file decoding.