A chatty, distracting, and flexible workout timer.
Run through a seven-minute workout while your computer reads aloud trivia from Wikipedia, reports on the weather, and tells dumb jokes:
sweat
Run through a seven-minute workout, but without any of that other stuff:
sweat --no-entertainment
Run through a seven-minute workout with semi-randomized drills:
sweat --shuffle
Have the program read news headlines instead of clicking around Wikipedia:
sweat --newsapi-key=MyNewsApiKey12345
Sweat is a workout timer that helps distract you from the pain of exercise by chatting incessantly, using your computer's text-to-speech capabilities to read news headlines, crack strange old-man jokes, talk about the weather, and still manage to call out workout prompts when necessary.
Sweat is optimized for the so-called Seven-Minute Workout (7MW), which leads you through twelve 30-second drills, with 10-second rests in between. These focus on four types of exercise: aerobic, lower-body, upper-body, and core. While it has sensible and widely accepted defaults, you can change or expand its list of drills if you really want, or adjust how many drills each workout entails, or the timing involved.
Sweat features a friendly pause function, and a shuffle mode that will randomize the drills you receive within each type while keeping the types themselves in order, ensuring you get a varied and balanced workout.
Sweat assumes you already know how to perform the drills it calls out, and trusts you to get through them in whatever way works best for you. Sweat will never judge you.
Yes, Sweat is a command-line program. Get your butt off the chair once in a while and onto the floor, fellow hackers. It's good for you.
Sweat's major features that most other 7MW timers don't have:
Sweat guides you through voice alone (with a simple text transcription in its terminal window).
Sweat will (unless you ask it not to) click through a randomly chosen thread of related Wikipedia articles while you work out and read aloud what it finds. The workout takes priority, so this intentionally distracting chatter will not make you miss any exercise cues.
With a little extra configuration, you can have Sweat instead read you current news headlines from a variety of sources.
Sweat will also tell you the local weather during certain drills, and end by reading aloud the output of the `fortune` program (if available).
For variety's sake, you can shuffle the drills out of their standard order. While you still get three rounds of aerobic, lower-body, upper-body, and core drills in that order, Sweat will randomize the order of the three drills within each category.
Halfway through the side-plank drill, Sweat gives you a few seconds to adjust yourself. (For some reason, few if any other timers seems to bother with this.)
A no-chair mode substitutes other drills when you find yourself in a space (e.g. a hotel room) with no suitably stable chair to exercise with.
A no-jumping mode is also available when you want to avoid stomping around on your downstairs neighbor's ceiling.
It's a command-line Unixish program, so of course it's far too configurable. Happily, its defaults should fit most needs...
You can install Sweat as a stand-alone binary program, as a distribution of Perl software via the CPAN, or from source using the code found at this very repository.
The latest binaries for macOS (Darwin) and Linux are available at Sweat's homepage: https://jmac.org/sweat. Just download and run! (Noting, of course, any platform-specific caveats listed on that page.)
First, make sure you have the cpanm
program on your machine. It is likely
available as "cpanminus" in your favorite package manager. (Or install it from
source, through the instructions at http://cpanmin.us.)
Then, run this command:
cpanm Sweat
If you run into issues due to failing dependencies, try this instead:
cpanm --notest Sweat
Alternately, you can run these commands under `sudo` to install Sweat at the system level.
Clone this repository locally, and then run these commands:
cpanm --installdeps --notest .
perl Build.PL
perl Build build
perl Build install # run under sudo to install at system-level
Once installed, you can get a quick-reference guide like this:
sweat --help
Or far more thorough instructions this way:
man sweat
Please report issues at the module's GitHub site. Code and documentation pull requests are very welcome!
Jason McIntosh (jmac@jmac.org)
This software is Copyright (c) 2019-2020 by Jason McIntosh.
This is free software, licensed under:
The MIT (X11) License