Karya, built on 2018-05-31T02:46:59 (patch 0a1a35479c514820d77330ae8a978975ba22a47a)

Safe HaskellNone

Instrument.Parse

Contents

Description

Functions to parse MIDI patch files.

Synopsis

Documentation

type Parser st a = Parsec.Parsec Text st a Source #

annotation file

parse_annotations :: FilePath -> IO (Either String (Map InstTypes.Qualified [Annotation])) Source #

Format is synth/inst-name tag1=x tag2=y.

TODO other attributes are not supported, but if there were, they could look like *pb-range=12 *flag=pressure

lexeme :: Parser st a -> Parser st a Source #

p_eol :: Parser st () Source #

patch file

patch_file :: FilePath -> IO [Sysex.Patch] Source #

Parse a simple ad-hoc text file format to describe a synth's built-in patches.

Each line should look like inst-name, tag=val, tag=val, .... The instrument name can contain any character except a comma, but the tags are restricted to [a-z0-9-]. The category tag is treated specially: if not set it will be inherited from the previous category.

The patch's program change is incremented for each patch. A line like *bank num sets the bank number and resets the program change to 0.

Comments start with #, and blank lines are ignored.

data State Source #

Constructors

State 
Instances
Show State # 
Instance details

Defined in Instrument.Parse

Methods

showsPrec :: Int -> State -> ShowS #

show :: State -> String #

showList :: [State] -> ShowS #

data PatchLine Source #

Instances
Show PatchLine # 
Instance details

Defined in Instrument.Parse