Functor Lastfm_generic.Radio_generic

module Radio_generic: 
functor (Http : Http_t) -> Radio_t

Generic implementation of the Radio API, independant from the Http request.

Parameters:
Http : Http_t

API for using lastfm radios

No protocol documentation avaible for now...

Types

type track = (string * string) list * string 

Type for track datas

A track is a list of "field","value" metadatas and an uri

type error = 
| Http of string
| Auth of string
| Adjust of string * string
| Playlist
| Empty

Various errors

exception Error of error
val string_of_error : error -> string

Get meaning of Error e

val base_host : string Stdlib.ref

Base host. Default: "ext.last.fm"

Basic API

val get : ?timeout:float -> string -> track list

get uri performs whole process and outputs a list of metadatas,uri from given lastfm uri.

This function cannot handle well multiple anonymous requests.

If you plan to play simultaneously several anonymous radios, you better use the advanced API to keep track of every opened session.

Advanced API

Using this API you shall call:

  1. parse: get required parts of the uri
  2. init: initiate a session
  3. adjust: adjust station

Then you can use any of the following:

After each of those calls, you shall use *only* one of the songs from the playlist.

The module will cache session informations and avoid redundant requests, so you might always call init and adjust.

If you call playlist, and anything went bad, you have to call clear to remove cached data about this session.

In any case you may also give another try, in case of inconsistent cached session data. See get source for details

val parse : string -> Lastfm_generic.login * string * string option

parse uri parse the given lastfm:// uri

returns login,station,options

val init : ?timeout:float -> Lastfm_generic.login -> string

init login initiate lastfm session

Returns the session id

val adjust : ?timeout:float -> string -> string -> (string * string) list

adjust id station adjusts lastfm station for given session ID

Returns a list of (variable,value) as returned by the server. Contains settings for adjusted radio.

val playlist : ?timeout:float -> string -> string option -> string

playlist id returns the raw xml content of the playlist

val tracks : ?timeout:float ->
string -> string option -> track list

tracks id returns a list of metadatas,uri

val clear : string -> unit

clear id closes and clear all informations about the given session ID