Emre AKYÜZ 42a76893c2
Drastically Improve Tutorialvids
The script performs the following tasks:
    - Checks if a local cache file containing YouTube video titles and URLs exists.
    - If the file does not exist, it fetches video titles and URLs using yt-dlp and saves them to the local cache file.
    - Prompts the user whether to update the database (local cache file) using dmenu.
    - If the user chooses to update the database, the script fetches the latest video titles and URLs and updates the cache file.
    - Displays the video titles in dmenu for the user to select.
    - Once a video is selected, the script plays the video using the mpv video player.

Detailed Explanation of Commands:
- CHANNEL_URL="https://www.youtube.com/c/CHANNEL_NAME/videos": Sets the YouTube channel URL to be fetched.
- DATA_FILE="$HOME/.cache/yt_channel_data.tsv": Sets the file path for storing the fetched video titles and URLs.
- [ ! -f "$DATA_FILE" ] && yt-dlp -j --flat-playlist --skip-download "$CHANNEL_URL" | jq -r '[.title, .id] | @tsv' > "$DATA_FILE": Checks if the cache file exists. If not, it uses yt-dlp to fetch the video titles and URLs in JSON format, then pipes the JSON to jq to extract the title and URL, formats them as tab-separated values (TSV), and saves the output to the cache file.
- [ "$(echo -e "No\nYes" | dmenu -i -l 2 -p "Update?")" == "Yes" ] && yt-dlp -j --flat-playlist --skip-download "$CHANNEL_URL" | jq -r '[.title, .id] | @tsv' > "$DATA_FILE": Asks the user if they want to update the database using dmenu. If the user selects "Yes", the script fetches the latest video titles and URLs and updates the cache file.
- video_info=$(cat "$DATA_FILE"): Reads the contents of the cache file and stores them in the video_info variable.
- selected_title=$(echo "$video_info" | cut -f1 | dmenu -i -l 20 -p "Video:"): Displays the video titles in dmenu for the user to select and stores the selected title in the selected_title variable.
- [ -n "$selected_title" ] && mpv "https://www.youtube.com/watch?v=$(echo "$video_info" | grep -Fw "$selected_title" | cut -f2)": If a title is selected, it finds the corresponding URL from the video_info variable and plays the video using the mpv video player.

Justification for the script:

- Highly Minimalistic: The script is concise and straightforward, making it easy to understand and maintain.
- Caching: The script stores the fetched video titles and URLs in a local cache file, reducing the need to fetch data repeatedly, which saves time and bandwidth.
- User-friendly: The script uses dmenu to provide a simple and intuitive interface for the user to interact with, allowing them to update the database and select videos with ease.
- Versatility: The script works with any YouTube channel by simply changing the CHANNEL_URL variable.
- Modular: The script is organized into separate tasks, which can be easily modified or extended to accommodate additional features or requirements.
2023-04-26 12:14:31 +03:00
2023-04-26 12:14:31 +03:00
2022-03-11 18:32:19 -05:00
2020-11-16 18:06:41 -05:00
2020-11-16 18:06:41 -05:00
2021-03-07 15:07:41 -05:00
2018-08-02 00:29:58 -04:00
2023-01-23 00:18:01 +00:00

The Voidrice (Luke Smith https://lukesmith.xyz's dotfiles)

These are the dotfiles deployed by LARBS and as seen on my YouTube channel.

  • Very useful scripts are in ~/.local/bin/
  • Settings for:
    • vim/nvim (text editor)
    • zsh (shell)
    • lf (file manager)
    • mpd/ncmpcpp (music)
    • sxiv (image/gif viewer)
    • mpv (video player)
    • other stuff like xdg default programs, inputrc and more, etc.
  • I try to minimize what's directly in ~ so:
    • All configs that can be in ~/.config/ are.
    • Some environmental variables have been set in ~/.zprofile to move configs into ~/.config/
  • Bookmarks in text files used by various scripts (like ~/.local/bin/shortcuts)
    • File bookmarks in ~/.config/shell/bm-files
    • Directory bookmarks in ~/.config/shell/bm-dirs

Usage

These dotfiles are intended to go with numerous suckless programs I use:

I also recommend trying out mutt-wizard, which additionally works with this setup. It gives you an easy-to-install terminal-based email client regardless of your email provider. It is integrated into these dotfiles as well.

Install these dotfiles and all dependencies

Use LARBS to autoinstall everything:

curl -LO larbs.xyz/larbs.sh

or clone the repo files directly to your home directory and install the dependencies.

Default Desktop Artwork

Thomas Thiemeyer's The Road to Samarkand (fb, insta, shop)

Description
No description provided
Readme GPL-3.0 94 MiB
Languages
Shell 92.8%
Vim Script 5.3%
JavaScript 1.5%
Perl 0.2%
Lua 0.2%