[![Contributors][contributors-shield]][contributors-url] [![Forks][forks-shield]][forks-url] [![Stargazers][stars-shield]][stars-url] [![Issues][issues-shield]][issues-url] [![MIT License][license-shield]][license-url]
Logo

Falion

An open source, programmed in rust, privacy focused tool for reading programming resources (like stackoverflow) fast, efficient and asynchronous from the terminal.
Report Bug | Request Feature

Table of Contents
  1. About The Project
  2. Getting Started
  3. Usage
  4. Roadmap
  5. Contributing
  6. License
  7. Contact

About The Project

An open source, programmed in rust, privacy focused tool for reading programming resources (like stackoverflow) fast, efficient and asynchronous from the terminal. By the time the results appear most of the pages are fully loaded, meaning when going through them you don't have to await for the page to load like in a browser, it just loads instantly, and the pages are parsed in way to make it easier to view them from the terminal. All the searches are done through DuckDuckGO (only through https), and the requests to the respective pages are done only for getting the html of it and nothing else, making this tool a privacy focused one. For a demo just watch the video under here, and for informations about the keybinds go to key binds

Supported programming resources (for now, more to come):

These are generic resources and work for most languages, in the future i may add language specific ones, but for now this is what I am focusing on.

Video showcase

https://user-images.githubusercontent.com/59087558/164259195-416191d5-07c6-4b7d-8af6-aecb3ef53537.mp4

Built with

The stock libraries and these awesome 3rd party ones:

Getting Started

Running The Program

  1. There are prebuilt binaries in the releases tab so you can download those or compile it yourself. So either way get a binary. For now there is no like installer to get it in your global path, but go to add to path and follow the steps to manually add it.

  2. Then from the terminal (regardless of the os) you can use it by running these commands.

    For getting help about the program falion -h For getting a list of the keybinds, also available on this readme at key binds falion -k For doing a search falion rust how to print Or if you want to do a search and see all the warnings (like parsing problems of text etc) run it in verbose mode falion -v rust how to print

Compilation

This program only uses crossplatform libraries, but I have problems compiling it for windows from linux, when I have time I will spin up a VM to see if it compiles in windows. The following steps require that you have rust installed, check their official installation page.

  1. Clone this repo on your pc, you can use "git clone", if you have git installed, like this:

git clone https://github.com/Obscurely/falion.git

Otherwise in the right up side of the repo page you will see a download button, download the repo as zip and extract it in a folder

  1. Open a new terminal/cmd window in the folder you extracted the repo in, if you can't rightclick on the folder and open it there do:

On Linux and windows: cd the/path and you will get there.

  1. From there run this compile command in the terminal: cargo build --release It will take a bit depending on your system because of executable size optimizations, but be patient.

  2. Done, navigate to target/release and grabe only "falion" file from there.

Add to path

  1. Copy the falion executable to a location you want (it will have to stay there), usually in linux you would create a folder in /opt called falion and put the executable there, or you can place anywhere else in the home dir. As for windows wherever, it's bloated anyway.
  2. On linux modify your .zshrc / .bashrc / .fishrc , the hell you use, and add this line to it: (without quotation marks) "alias falion=your/path". On windows you will have to modify your path variable, here is a guide.
  3. After you are done, you should be able to just type "falion" in cmd and you should see something pop up.

Usage

Key binds

Key Binds list for falion!

Note: where '..' is used it means from that to that like '1..5' would mean from 1 to 5.

Main menu:

[1..5] = Access that resource.
SHIFT + [1..5] = Go to the next element in the list of that resource.
ALT + [1..5] = Go to the previous element in the list of that resource.
CTRL + n = Move to the next element in the list of every resource.
CTRL + b = Move back to the previous element in the list of every resource.
CTRL + c = Clear terminal and exit.

Sub menus for the resources:

CTRL + n = Move to the next element in the content list (like questions & answers).
CTRL + b = Move back to the previous element in the content list.
CTRL + q = Go back to the main menu.
CTRL + c = Clear terminal and exit.

These were all the key binds, enjoy using Falion!

Roadmap

Adding more generic resources, but also maybe add lanaguage related one that get enabled based on the first word in the query. And also just improve it in general.

Contributing

Edit a file you want, do a pull request, I will look at it and if the change makes sense and is a good one I will accept it and that's it.

License

Is under GPL-3.0 so stick to the license conditions and have fun :)

Contact

Either post an issue in the Issues Tab or contact me at this email adddress if you have more to say: obscurely.social@protonmail.com