wb5/posts/minrss.md

149 lines
4.0 KiB
Markdown

# 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.
Articles are, by default, saved to `~/rss`, but you can set `$MRSS_DIR` to change this.
#### fzf shortcuts
In `mrss fzf`'s interface, the following commands are available:
| 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.
To read all null-program articles (regardless of if they are marked read or not):
mrss fzf null-program
To view new null-program articles:
mrss fzf new/null-program
To see articles you've marked as "watch later":
mrss fzf watch-later
#### 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