.\"                                      Hey, EMACS: -*- nroff -*-
.\" First parameter, NAME, should be all caps
.\" Second parameter, SECTION, should be 1-8, maybe w/ subsection
.\" other parameters are allowed: see man(7), man(1)
.TH LSMI-MOUSE 1 "May 15, 2012"
.\" Please adjust this date whenever revising the manpage.
.\"
.\" Some roff macros, for reference:
.\" .nh        disable hyphenation
.\" .hy        enable hyphenation
.\" .ad l      left justify
.\" .ad b      justify to both left and right margins
.\" .nf        disable filling
.\" .fi        enable filling
.\" .br        insert line break
.\" .sp <n>    insert n+1 empty lines
.\" for manpage-specific macros, see man(7)
.SH NAME

lsmi-mouse \- Linux Pseudo MIDI Input -- Mouse
.SH SYNOPSIS
.B lsmi-mouse
.RI [ options ] " files" ...
.SH DESCRIPTION

This driver is capable of generating a stream of MIDI controller and/or note
events from the state of mouse buttons. I have a MouseSystems serial mouse
controller board with footswitches wired to each of its three buttons. You
must have evdev and the kernel driver for your mouse type loaded (in my
case, this is sermouse). Mouse axes, wheels, or additional buttons are not
used (if you can think of something to do with them [rotary encoders for
filter and resonance?], then, by all means, let me know).

I use this device to control Freewheeling and various softsynths. Much
cheaper than a real MIDI pedalboard, of this I assure you.

.SH EXAMPLE

Use mouse device "/dev/input/event4", mapping left button
to Controller #64, middle button to Note #36, and
right button to Note #37 (all on Channel #1):
.br
.B lsmi-mouse -d /dev/input/event4 -1 c:1:64 -2 n:1:36 -3 n:1:37

.SH USAGE

Distribution specific init scripts are not included. The drivers may be
started from init, your .bashrc, by qjackctl, etc. In order to be run by a
non-root user the drivers must have access to the device files in /dev/input.
This may be accomplished by adding a group 'input', adding desired users to
this group, and configuring udev to assign the appropriate ownership to files
in /dev/input. It should be perfectly safe to run the drivers as root,
however.

For realtime scheduling (the \-R option), either use set_rlimits, or set the
appropriate POSIX capabilities on the executable:
.P
/sbin/setcap cap_ipc_lock,cap_sys_nice=ep /usr/bin/lsmi-joystick
.P
The lsmi.SlackBuild script already includes RT scheduling support.

.SH OPTIONS
.TP
.B \-h, \-\-help
Show summary of options.
.TP
.B \-d, \-\-device specialfile
Event device to use (instead of event0).
.TP
.B \-R, \-\-realtime rtprio 
Use realtime priority 'rtprio' (requires privs).
.TP
.B \-v, \-\-verbose
Be verbose (show note events).
.TP
.B \-p, \-\-port client:port
Connect to ALSA Sequencer client on startup.
.TP
.B \-1, \-\-button-one 'c'|'n':n:n
Button mapping.
.TP
.B \-2, \-\-button-two 'c'|'n':n:n
Button mapping.
.TP
.B \-3, \-\-button-thrree 'c'|'n':n:n 
Button mapping.
.TP
.B \-z, \-\-daemon
Fork and don't print anything to stdout.
.SH SEE ALSO
.BR lsmi-joystick (1),
.BR lsmi-keyhack (1),
.BR lsmi-monterey (1).
.br
.SH AUTHOR
lsmi was written by Jonathan Moore Liles.
.PP
This manual page was written by Ariel Errera <ariel@musix.org.ar>,
for the Debian project (but may be used by others). It was then modified
by B. Watson for the SlackBuilds.org project.