ブラウザ上で長文テキストを編集すること、
キモいですよね、クソです!
data:image/s3,"s3://crabby-images/41bef/41bef7aed88cb16d17fe1bd21abfee226febf717" alt="github gist edit browser"
GitHub 公式のコマンドラインツールは便利です。
👉 cli/cli: GitHub’s official command line tool data:image/s3,"s3://crabby-images/69133/69133824e372790785528e902ec680d5f43aba27" alt="hatena-bookmark"
$ gh gist -h
Work with GitHub gists.
USAGE
gh gist <command> [flags]
CORE COMMANDS
clone: Clone a gist locally
create: Create a new gist
delete: Delete a gist
edit: Edit one of your gists
list: List your gists
view: View a gist
INHERITED FLAGS
--help Show help for command
ARGUMENTS
A gist can be supplied as argument in either of the following formats:
- by ID, e.g. 5b0e0062eb8e9654adad7bb1d81cc75f
- by URL, e.g. "https://gist.github.com/OWNER/5b0e0062eb8e9654adad7bb1d81cc75f"
LEARN MORE
Use 'gh <command> <subcommand> --help' for more information about a command.
Read the manual at https://cli.github.com/manual
エディタを変える
このデフォルトのエディタ nano って誰が推してるんすかね。
$ gh gist edit f49d4d7a9963b77d00c89d1a3dbb6976
data:image/s3,"s3://crabby-images/e1622/e1622fe995445a1ab5702effdb61d84023676fe9" alt="github gh gist edit nano"
変えます、emacs に。
$ EDITOR=emacs gh gist edit f49d4d7a9963b77d00c89d1a3dbb6976
いいですね。
data:image/s3,"s3://crabby-images/9025e/9025ecb40cde7e5fe93bd87e0e8ffddf7501659e" alt="EDITOR=emacs gh gist edit"
ということは、
「gh gist edit」 は、
シェル変数 EDITOR に反応するアプリケーションですね !
ファイルを上書き更新する
とはいえ、
いまどきはもろGUIなIDEで豊富な機能を使ってコードは書いていきます。
なので、
パソコン上のIDEで書いたコードを Gist に更新していきたいですよね !
「更新」とは同じIDの Gist の上書きのことを言っています。
$ EDITOR="cp ~/ide/path/to/script/new.js" \
gh gist edit f49d4d7a9963b77d00c89d1a3dbb6976
想像できてましたか?
GitHub 公式アプリ内のシェル変数 EDITOR の処理を。
[ -z "$EDITOR" ] && EDITOR=nano
$EDITOR TEMP_FILE
通常、エディタの起動コマンドを入力する文字列に
cp src-file
をセットすることで
vi tmp-file
が
cp src-file tmp-file
となり実行されます。
👉 linux - How do I edit /etc/sudoers from a script? - Stack Overflow data:image/s3,"s3://crabby-images/1e20f/1e20fc3dbbb9c0ce1d75c3faa700d332ac3708ec" alt="hatena-bookmark"
実際、言語は Go で書かれていますが、処理の内容はそういうことです。
標準入力から更新する
こんなの公開されてる方がいます。
$ echo "edit a gist from output piped from another command" | \
EDITOR="cp "<(cat -) gh gist edit {<gist ID> | <gist URL>} [flags]
👉 GitHub CLI の gist edit へパイプを接続し、gist を編集する data:image/s3,"s3://crabby-images/389f8/389f899a41334a8b0e110c097189bda069ee6dcd" alt="hatena-bookmark"
「プロセス置換 (Process Substitution)」を使って処理しています。
「コマンド出力をファイル化して、そのパスを返す。」という使えるやつ。
$ cat <(date)
Thu Jul 21 12:40:53 EEST 2011
$ echo <(date)
/proc/self/fd/11
👉 プロセス置換 (Process Substitution)について - 一から勉強させてください data:image/s3,"s3://crabby-images/e5166/e516685e6448dff236fb43b6b3186c6625c565a5" alt="hatena-bookmark"
👉 shell - Process substitution and pipe - Unix & Linux Stack Exchange data:image/s3,"s3://crabby-images/1c408/1c408c00028412980113ad895268078089fe5835" alt="hatena-bookmark"
まとめ
この先人たちの作ったコマンドラインツールの素晴らしさよ。
「ノーコード」とか言うてるやつな。
👉 GitHub Gist に置いた Javascript をブックマークレットとして実行する data:image/s3,"s3://crabby-images/dc551/dc551ec8c0d2f6ae05d21e35a8fcb995f86aa3ab" alt="hatena-bookmark"