Thanks to visit codestin.com
Credit goes to github.com

Skip to content

CrociDB/bulletty

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

bulletty

bulletty

The TUI RSS/Atom feed reader that lets you decide where to store your data.

bulletty

bulletty is a TUI feed reader and aggregator (RSS and Atom). Read your subscriptions directly in your terminal. It downloads the entries for offline reading so all the data is local and yours: your subscriptions, highlights, comments, etc. All in a universal format: Markdown. Back up and sync your data directory your own way.

It's in active development.

πŸ”¨ Features

  • Subscribe to RSS and Atom feed types
  • All your feed sources and entries are stored in Markdown in one place: $HOME/.local/share/bulletty/
  • Automatically download new entries
  • Add articles to the Read Later category
  • Read articles with the embedded cozy Markdown reader
  • Import/export OPML feed list
  • Supports multiple beautiful colorful themes

πŸš€ Install

Download bulletty pre-built binaries

🚚 Through Cargo

It requires cargo 1.90+:

cargo install bulletty

β˜‚οΈ Pre-requisites

bulletty runs in most platforms, however there are some pre-requisites to have it run the best way possible:

  • Use a modern terminal emulator such as Kitty, Ghostty, Alacritty, WezTerm, Windows Terminal, etc. They provide modern features and true color support, and are usually very fast and hardware-rendered
  • Use a NerdFont. They are patched versions of common coding fonts with several icons

πŸš„ Usage

πŸ—žοΈ Adding new feed sources

For now, you can only add new feed sources via the CLI:

bulletty add https://crocidb.com/index.xml [Category]

If no category is passed, the feed source will be added to the General category. bulletty will synchronize all your sources when you open the TUI, by just invoking bulletty.

More on the CLI commands with:

bulletty help

🧩 TUI

On any screen, you can press question mark ? and it will show you the available commands for that screen. Also, on the bottom right, it shows the most important commands for that context.

In general, it supports j/k/up/down to select items, navigate and scroll, as well as g/G/Home/End to go to the beginning/end of a list or file and Enter and q/Esc to navigate into and out of Categories and Entries. In order to open an Entry externally, press o.

πŸ’Œ Don't know what to subscribe to?

HN Personal Websites is a good repository of blogs that constantly show up on Hacker News. Subscribing to all of them is simple:

wget https://hnpwd.github.io/pwd.opml
bulletty import pwd.opml

🏫 Philosophy

The whole idea is to help bring back the decentralized internet. You subscribe to the sources you like the most and you get their content whenever it's available. When you get it, it's local, it's yours. bulletty will generate a Markdown file of each entry from each source. You can read through the embedded reader, directly in your terminal, or using any text editor.

All your feed data will be at $HOME/.local/share/bulletty/, in this structure:

[~/.local/share/bulletty]$ tree
.
└── categories
    β”œβ”€β”€ Programming
    β”‚Β Β  β”œβ”€β”€ bruno-croci
    β”‚Β Β  β”‚Β Β  β”œβ”€β”€ .feed.toml
    β”‚Β Β  β”‚Β Β  β”œβ”€β”€ about.md
    β”‚Β Β  β”‚Β Β  β”œβ”€β”€ demystifying-the-shebang-kernel-adventures.md
    β”‚Β Β  β”‚Β Β  β”œβ”€β”€ from-ides-to-the-terminal.md
    β”‚Β Β  β”‚Β Β  β”œβ”€β”€ i-wrote-a-webserver-in-haskell.md
    β”‚Β Β  β”‚Β Β  β”œβ”€β”€ ...
    β”œβ”€β”€ General
    β”‚Β Β  β”œβ”€β”€ another-website
    β”‚Β Β  β”‚Β Β  β”œβ”€β”€ .feed.toml
    β”‚Β Β  β”‚Β Β  β”œβ”€β”€ some-post.md
    β”‚Β Β  β”‚Β Β  β”œβ”€β”€ ...

All that needs to be done is to synchronize the bulletty directory to save your data, similar to an Obsidian vault.

βœ‚οΈ Third Party Tools

One of the nice things about this open data structure is that people can build external tools that interact with the bulletty feed library.

πŸ“œ Feature Roadmap

  • Highlight
  • Notes
  • Web view
  • Mouse support
  • Image support
  • PDF/Epub article export

πŸ’» Build

git clone https://github.com/CrociDB/bulletty.git
cd bulletty
cargo build --release

Notes on building on Windows

bulletty requires the openssl crate to build, but it's known to be a little complicated to build on Windows. If it fails on a regular build, it's probably because whatever perl version it's trying to use is not suitable to build it. In that case, try installing Strawberry Perl and make sure that openssl uses the one you just install to build:

$env:OPENSSL_SRC_PERL = "C:\Strawberry\perl\bin\perl.exe"

Then cargo build should work normally.

πŸ‘©β€πŸ’» Contributing to bulletty

I am very open to contributions to help make bulletty the best feed reader out there. For more information on how to contribute, refer to the CONTRIBUTING.md.

πŸ“ƒ License

Copyright (c) Bruno Croci

This project is licensed under the MIT license (LICENSE or http://opensource.org/licenses/MIT)

About

bulletty is a pretty feed reader for the terminal that stores the articles as Markdown

Topics

Resources

License

Contributing

Stars

Watchers

Forks

Contributors 9

Languages