2023-05-14 16:51:32 -04:00
|
|
|
# minrss, a lightweight feed reader
|
|
|
|
|
|
|
|
2023-05-14
|
|
|
|
|
|
|
|
![](/public/img/minrss-mrss.jpg)
|
|
|
|
|
|
|
|
## purpose
|
|
|
|
|
|
|
|
If you want to read content online from many different websites, the best way is to subscribe to RSS or Atom feeds.
|
|
|
|
It's a simple, universal format for getting content onto your screen.
|
|
|
|
|
|
|
|
I personally enjoy living in the terminal.
|
|
|
|
One of the more popular RSS readers for this environment is [Newsboat](https://newsboat.org/).
|
|
|
|
Newsboat has tons of useful features and a pretty TUI, and I did use it for a while.
|
|
|
|
|
|
|
|
However, I thought that it was too complex for what I needed in an RSS reader.
|
|
|
|
Therefore, I decided to write a new one: MinRSS.
|
|
|
|
|
|
|
|
## concept
|
|
|
|
|
|
|
|
MinRSS is a small binary that "does one thing and does it well":
|
|
|
|
it downloads RSS articles to disk.
|
|
|
|
|
|
|
|
Essentially, every feed is represented as a
|
|
|
|
folder, and individual articles are files in these folders.
|
|
|
|
|
|
|
|
Every time the binary is run, it creates a structure like this in the current working
|
|
|
|
directory:
|
|
|
|
|
|
|
|
rss
|
|
|
|
|--news
|
|
|
|
| |--article1
|
|
|
|
| `--article2
|
|
|
|
`--blog
|
|
|
|
|--post
|
|
|
|
`--other_post
|
|
|
|
|
|
|
|
If an article is new (it wasn't on disk already), its filename is printed to standard output.
|
|
|
|
|
|
|
|
The goal of doing things this way is to make writing scripts as easy as possible.
|
|
|
|
If you're familiar with shell scripting, all you need is `jq`
|
|
|
|
and you can now parse RSS and implement any custom feature you want.
|
|
|
|
|
|
|
|
If you felt masochistic, you could even read RSS feeds using only your shell, `minrss`, `ls`, `head` and `w3m`.
|
|
|
|
|
|
|
|
This sort of structure is inspired by suckless.org's
|
|
|
|
[ii](http://tools.suckless.org/ii/) and [sic](http://tools.suckless.org/sic/).
|
|
|
|
|
|
|
|
### wrapper script
|
|
|
|
|
|
|
|
I wrote my own wrapper script around MinRSS, called `mrss`.
|
|
|
|
It has the following features:
|
|
|
|
|
|
|
|
- Update feeds using MinRSS
|
|
|
|
- Show all new articles using `fzf` as an interface (as seen in the screenshot above)
|
|
|
|
- Mark articles as read
|
|
|
|
- Mark articles as "watch later"
|
|
|
|
- Custom handler for opening videos and podcasts in `mpv`
|
|
|
|
|
|
|
|
## installation
|
|
|
|
|
|
|
|
First, ensure you have the requirements:
|
|
|
|
|
|
|
|
- libcurl
|
|
|
|
- libxml2
|
|
|
|
- json-c
|
|
|
|
- xdg-open
|
|
|
|
|
|
|
|
Clone the repo:
|
|
|
|
|
|
|
|
git clone https://github.com/dogeystamp/minrss
|
|
|
|
cd minrss
|
|
|
|
|
|
|
|
Edit the config file.
|
|
|
|
The comments in `config.h` should guide you:
|
|
|
|
|
|
|
|
cp config.def.h config.h
|
|
|
|
vim config.h
|
|
|
|
|
|
|
|
MinRSS outputs human-readable output by default.
|
|
|
|
The wrapper script will only work with these options set:
|
|
|
|
|
|
|
|
static const enum outputFormats outputFormat = OUTPUT_JSON;
|
|
|
|
static const enum summaryFormats summaryFormat = SUMMARY_FILES;
|
|
|
|
|
|
|
|
Then, build and install MinRSS:
|
|
|
|
|
|
|
|
make install
|
|
|
|
|
|
|
|
Install the wrapper script:
|
|
|
|
|
|
|
|
cp contrib/mrss.sh ~/.local/bin/mrss
|
|
|
|
chmod 755 ~/.local/bin/mrss
|
|
|
|
|
|
|
|
## usage
|
|
|
|
|
|
|
|
For complete help, run `mrss -h`.
|
|
|
|
|
|
|
|
To get started, all you need is `mrss update` to update feeds, then `mrss fzf` to view articles.
|
2023-06-18 15:48:23 -04:00
|
|
|
Articles are, by default, saved to `~/rss`, but you can set `$MRSS_DIR` to change this.
|
2023-05-14 16:51:32 -04:00
|
|
|
|
|
|
|
#### fzf shortcuts
|
2023-06-18 15:48:23 -04:00
|
|
|
In `mrss fzf`'s interface, the following commands are available:
|
2023-05-14 16:51:32 -04:00
|
|
|
|
|
|
|
| Command | Shortcut | Description |
|
|
|
|
| ------- | -------- | ----------- |
|
|
|
|
| `/read` | `Enter` | Opens link in the browser or `mpv` |
|
|
|
|
| `/purge` | `Ctrl-D` | Mark article as read |
|
|
|
|
| `/purge-all` | `Ctrl-Alt-D` | Mark all articles as read |
|
|
|
|
| `/watch-later` | `Ctrl-W` | Send article to the watch-later folder |
|
|
|
|
| `/queue` | `Ctrl-E` | Queues link to be opened after leaving `fzf` |
|
|
|
|
|
|
|
|
You can also use `Tab` and `Shift-Tab` to select multiple articles to be acted upon.
|
|
|
|
|
|
|
|
#### viewing specific folders
|
|
|
|
|
|
|
|
The `mrss fzf` command can be used to view a specific folder's contents.
|
2023-06-18 15:48:23 -04:00
|
|
|
|
|
|
|
To read all null-program articles (regardless of if they are marked read or not):
|
2023-05-14 16:51:32 -04:00
|
|
|
|
|
|
|
mrss fzf null-program
|
|
|
|
|
2023-06-18 15:48:23 -04:00
|
|
|
To view new null-program articles:
|
|
|
|
|
|
|
|
mrss fzf new/null-program
|
|
|
|
|
|
|
|
To see articles you've marked as "watch later":
|
2023-05-14 16:51:32 -04:00
|
|
|
|
|
|
|
mrss fzf watch-later
|
|
|
|
|
2023-06-18 15:48:23 -04:00
|
|
|
#### creating meta-feeds
|
|
|
|
|
|
|
|
In the latest version of mrss, you can create tags to categorize your feeds.
|
|
|
|
First, create a directory for your tag under `$MRSS_DIR`:
|
|
|
|
|
|
|
|
mkdir ~/rss/tag
|
|
|
|
|
|
|
|
To include new articles for a given feed:
|
|
|
|
|
|
|
|
ln -sr ~/rss/new/feed ~/rss/tag/
|
|
|
|
|
|
|
|
To include all articles:
|
|
|
|
|
|
|
|
ln -sr ~/rss/feed ~/rss/tag/
|
|
|
|
|
|
|
|
To view this tag:
|
|
|
|
|
|
|
|
mrss fzf tag
|