33 releases
0.9.7 | Sep 13, 2024 |
---|---|
0.9.4 | Jul 27, 2024 |
0.7.13 | Mar 29, 2024 |
0.6.1 | Dec 2, 2023 |
0.6.0 | Nov 14, 2023 |
#164 in Asynchronous
305KB
8K
SLoC
Brush leetcode under the terminal
- 【中文文档】
🪶Features
- Open the editor of your choice for editing.
- Filter based on the category of the question.
- Fuzzy search.
- Test and submit the code.
- Modify the test case.
- Automatically get cookies to eliminate the need for manual copying from the browser, power by decrypt-cookies.
💄Install
dependencies:
sqlite
libsecret
(Linux Optional)libdbus
(Linux notify)mdcat
(render markdown)
build-dependencies:
gcc
pkg-config
(when without cross feature)libdbus-1-dev
(when without cross feature)
You can use any of the following methods to install
[!NOTE]
add
~/.cargo/bin
to your$PATH
- Install binaries directly using cargo-binstall
cargo binstall lcode
- Archlinux can use AUR helper install
AUR contains completion scripts packaged for bash, zsh, and fish.
yay -S lcode-bin
# or
paru -S lcode-bin
- Download from release
- Build by yourself
rustup default nightly
cargo install --locked --force lcode
# or
# cargo install --features cross --locked --force lcode
Update lcode
use cargo-update
cargo install-update --all
🔧Usage
Generate configuration, manual modification of the configuration is also possible, and it will be automatically generated at runtime. Without -c, it will be generated in English.
lcode gencon -c
Synchronize basic data first.
lcode S
View the documentation for assistance.
lcode -h
Begin selecting a question.
lcode fzy <edit>
Shell completion
# zsh
echo 'eval $(lcode --generate zsh)' >>~/.zshrc
# bash
echo 'eval $(lcode --generate bash)' >>~/.bashrc
# ...
- Use zi
zi ice lucid wait as'completion' blockf has'lcode'
zi snippet https://github.com/saying121/lcode/blob/main/completions/_lcode
📼Videos
https://github.com/saying121/lcode/assets/74663483/57a633e5-6bae-4816-a224-d7d61d2141af
https://github.com/saying121/lcode/assets/74663483/9ad6ad58-b401-42f6-b8dc-359f78a37729
Configuration
The configuration located
- Linux:
~/.config/lcode/
- macos:
~/.config/lcode/
- Windows:
C:\Users\user\AppData\Roaming\lcode
The code default located
- Linux:
~/.local/share/lcode/
- macOS:
~/Library/Application Support/lcode
- Windows:
C:\Users\user\AppData\Local\lcode
code layout:
1_two-sum/
├── 1.cpp*
├── 1.rs*
├── 1_detail_cn.md*
├── 1_detail_en.md*
└── 1_test_case.txt*
The cache located
- Linux:
~/.local/share/lcode/
- macOS:
~/Library/Caches/lcode
- Windows:
C:\Users\user\AppData\Local\lcode
Cookies (Important)
[First, login leetcode in browser for generate cookies]
General you just need filled browser at ~/.config/lcode/config.toml
.
When use the section,be careful not to clear cookies when closing the browser.
browser = "edge" # `chrome`, `edge`, `firefox`, `librewolf` etc.
# Not casesensitive, `eDgE` also ok.
The detail: decrypt-cookies
~/.config/lcode/cookies.toml
csrf = ""
session = ""
[cookies]
section
-
If the two fields are not empty, use the content filled by the user. And not use other method to get cookies。
-
Fill in manually:
Press F12 on the browser's
leetcode.com/com
page, click network. Find the Cookie field, copy thecsrftoken
=<$content>; andLEETCODE_SESSION
=<$content>; copy the $content into the configuration.
-
-
If filled
browser
, will try to use the browser to get cookies. -
If neither of the above two items is filled in, and then use this order
Firefox
->Librewolf
->Chrome
->Edge
->Chromium
->Brave
->Yandex
->Vivaldi
->Opera
->OperaGX
->CocCoc
try to get cookies.
Keymap
LANGS
CONFIG
Execute lcode gencon
for create new cofnig and lcode C
edit.
# Show translated content or not.
translate = false
# Fill in `com` or `cn`, for set `leetcode.com` or `leetcode.cn`.
url_suffix = "com"
# When retrieving the **submissionlist**, how many columns should be displayed.
column = 4
# How many recent entries of the submissionlist information should be displayed.
num_sublist = 10
# How many questions should be displayed at once when interactively selecting a question.
page_size = 25
# Fill in your editor, it will attempt to retrieve it from
# the environment variables `$EDITOR` and `$VISUAL`,
# otherwise it will default to `vim`.
#
# Specifically, when the editor is one of the ones below,
# will vert split question and code.
#
# - vim
# - nvim
# - helix
#
# You can add additional parameters at the end.
# like `editor = ["vim", "--noplugin"]`
editor = ["vim"]
# Set your selected programming language.
lang = "rust"
# Set the location for storing code and test cases.
# You can also starting with `~`
# like `code_dir = "~/.local/share/lcode"`
code_dir = "/home/user/.local/share/lcode"
# Checkout the [Cookies (Important)](#cookies-important) section above.
browser = ""
# For better rust coding. It will add a `Cargo.toml` file
cargo_integr = true
# use frontend id create code dir or not
dir_with_frontend_id = true
You can checkout the info/tab3 in tui for ensure cookies is valid.
Todo
- Cache cookies.
Dependencies
~59–99MB
~1.5M SLoC