tpmmld
is the ThinkPad Mute-Mic Light Daemon. If you have a certain
ThinkPad where you have a mute-mic indicator led on the F4
button, this
daemon will control it, based on the current PulseAudio mute state of all
input sources (So all input sources mute, all input sources unmute).
You can directly mute
, unmute
or toggle
the mute states of all sources
by using the -m
, -u
or -t
arguments. This mode is essentially a one-shot
where the process exits after doing the requested state change.
When no options are specified (run as daemon in foreground) or when passing
-d
to run in background (daemonized), tpmmld
will monitor the ThinkPad
Extra Buttons input device for keypresses of the mute-mic button.
-
To read input from the micmute key, you need to be a member of the
input
group, or specifically, whichever group owns the device files under the/dev/input
directory. -
To enable/disable the led, the
sudo
andtee
commands are used. You have to configuresudo
in such a way that you can runecho 1 | sudo tee /sys/class/leds/platform\:\:micmute/brightness
non-interactively (i.e., without a password prompt).
tpmmld
is published in pypi, so you can
simply install using pip
:
pip install tpmmld
However, If it's not available there for whatever reason, or if you would like to run it from source, you can also get it going yourself, directly from the git repository:
git clone https://github.com/rubin55/tpmmld
cd tpmmld
python -m venv .venv
. .venv/bin/activate
pip instal -r requirements.txt
bin/tpmmld.sh -s # shows available input source devices, with index number
bin/tpmmld.sh -t # toggle mute state on/off
bin/tpmmld.sh -m # explicitly mute all sources
bin/tpmmld.sh -u # explicitly unmute all sources
bin/tpmmld.sh # run tpmmld in foreground
bin/tpmmld.sh -d # run tpmmld in background
$ tpmmld -h
usage: tpmmld [-h] [-d] [-s] [-t] [-m] [-u] [-l {INFO,ERROR,WARNING,DEBUG}]
[-v]
options:
-h, --help show this help message and exit
-d, --daemonize run in background (daemonized mode). If not specified,
the process will run in the foreground output to stdin
-s, --sources show list of sources, with index numbers
-t, --toggle toggle mute/unmute of all sources directly and exit
-m, --mute mute all sources directly and exit
-u, --unmute unmute all sources directly and exit
-l {INFO,ERROR,WARNING,DEBUG}, --loglevel {INFO,ERROR,WARNING,DEBUG}
specify the loglevel to use, defaults to 'INFO'
-v, --version show program's version number and exit
Since this is a python package, you don't really need to build, but if you would like to build the pip packages, you can do that as follows:
python -m build
You will then find the pip package binaries in dist/
. You can install
them using pip
.
I use twine to publish tpmmld
on pypi. To
deploy, make sure you first run the build stage. After that you can deploy the
artifacts in the dist
directory as follows:
twine upload dist/*
Note that you need valid for this project pypi credentials to do so .