Compare commits
16 Commits
master
..
1a3d439586
| Author | SHA1 | Date | |
|---|---|---|---|
| 1a3d439586 | |||
| e0875add3c | |||
| c9a470b116 | |||
| c4057d5f67 | |||
| cd430addd0 | |||
| c870497f0b | |||
| 1fd0a07b13 | |||
| f9b82413d6 | |||
| 53005db9e8 | |||
| cc0af0c824 | |||
| ab6b0917bd | |||
| e116f88a1c | |||
| aa11300a43 | |||
| 5df7b363c4 | |||
| 077d5065c2 | |||
| 510730c73b |
+41
-47
@@ -34,8 +34,7 @@ function config_update {
|
|||||||
}
|
}
|
||||||
|
|
||||||
# Editor
|
# Editor
|
||||||
alias c='code'
|
alias c='codium'
|
||||||
alias e='micro'
|
|
||||||
|
|
||||||
# Find
|
# Find
|
||||||
alias find='find . -name'
|
alias find='find . -name'
|
||||||
@@ -77,22 +76,18 @@ alias vpn="sudo openvpn --config $HOME/Nextcloud/#\ -\ Configs/rguiheneuf.ovpn"
|
|||||||
|
|
||||||
alias gs='git status'
|
alias gs='git status'
|
||||||
alias gc='git checkout'
|
alias gc='git checkout'
|
||||||
|
alias gcm='git checkout master'
|
||||||
alias gpl='git pull'
|
alias gpl='git pull'
|
||||||
alias gph='git push'
|
alias gph='git push'
|
||||||
alias gsu='git submodule update --init'
|
alias gsu='git submodule update --init'
|
||||||
alias gcp='git cherry-pick'
|
alias gcp='git cherry-pick'
|
||||||
|
|
||||||
function gcm {
|
|
||||||
( git rev-parse --verify origin/master > /dev/null 2>&1 ) && git checkout master
|
|
||||||
( git rev-parse --verify origin/main > /dev/null 2>&1 ) && git checkout main
|
|
||||||
}
|
|
||||||
|
|
||||||
alias add='git add'
|
alias add='git add'
|
||||||
alias commit='git commit -m "To fixup"'
|
alias commit='git commit -m "To fixup"'
|
||||||
alias cont='git rebase --continue'
|
alias cont='git rebase --continue'
|
||||||
|
|
||||||
# Git cleaners
|
# Git cleaners
|
||||||
alias branch_clean='git branch --merged | egrep -v "(^\*|master|main|dev)" | xargs git branch -d'
|
alias branch_clean='git branch --merged | egrep -v "(^\*|master|dev)" | xargs git branch -d'
|
||||||
alias tag_clean='git tag -l | xargs git tag -d && git fetch -t'
|
alias tag_clean='git tag -l | xargs git tag -d && git fetch -t'
|
||||||
|
|
||||||
function git_parent {
|
function git_parent {
|
||||||
@@ -156,16 +151,13 @@ function grbm {
|
|||||||
# Save current branch
|
# Save current branch
|
||||||
BRANCH=$(git branch | grep \* | cut -d ' ' -f2)
|
BRANCH=$(git branch | grep \* | cut -d ' ' -f2)
|
||||||
|
|
||||||
# Checkout master/main & pull
|
# Checkout master & pull
|
||||||
gcm
|
git checkout master
|
||||||
git pull
|
git pull
|
||||||
|
|
||||||
# Save parent branch
|
|
||||||
PARENT=$(git branch | grep \* | cut -d ' ' -f2)
|
|
||||||
|
|
||||||
# Back to previous branch
|
# Back to previous branch
|
||||||
git checkout ${BRANCH}
|
git checkout ${BRANCH}
|
||||||
git rebase --interactive ${PARENT}
|
git rebase --interactive master
|
||||||
}
|
}
|
||||||
|
|
||||||
function grbi {
|
function grbi {
|
||||||
@@ -179,7 +171,7 @@ function grbi {
|
|||||||
git checkout ${PARENT}
|
git checkout ${PARENT}
|
||||||
git pull
|
git pull
|
||||||
|
|
||||||
echo "Rebasing on ${PARENT}"
|
echo "Rebasing on" ${PARENT}
|
||||||
|
|
||||||
# Back to previous branch
|
# Back to previous branch
|
||||||
git checkout ${BRANCH}
|
git checkout ${BRANCH}
|
||||||
@@ -196,23 +188,15 @@ function ga {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function gam {
|
function gam {
|
||||||
# Checkout master/main & pull
|
git autofixup master
|
||||||
gcm
|
git rebase --interactive --autosquash master
|
||||||
|
|
||||||
# Save parent branch
|
|
||||||
PARENT=$(git branch | grep \* | cut -d ' ' -f2)
|
|
||||||
|
|
||||||
git checkout -
|
|
||||||
|
|
||||||
git autofixup ${PARENT}
|
|
||||||
git rebase --interactive --autosquash ${PARENT}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function gai {
|
function gai {
|
||||||
# Save parent branch
|
# Save parent branch
|
||||||
PARENT=$(git_parent)
|
PARENT=$(git_parent)
|
||||||
|
|
||||||
echo "Rebasing with autofixup on ${PARENT}"
|
echo "Rebasing with autofixup on" ${PARENT}
|
||||||
|
|
||||||
git autofixup ${PARENT}
|
git autofixup ${PARENT}
|
||||||
git rebase --interactive --autosquash ${PARENT}
|
git rebase --interactive --autosquash ${PARENT}
|
||||||
@@ -222,39 +206,43 @@ function gai {
|
|||||||
# ║ ╦│ │ ╠═╝├┬┘│ │├┤ ││ ├┤
|
# ║ ╦│ │ ╠═╝├┬┘│ │├┤ ││ ├┤
|
||||||
# ╚═╝┴ ┴ ╩ ┴└─└─┘└ ┴┴─┘└─┘
|
# ╚═╝┴ ┴ ╩ ┴└─└─┘└ ┴┴─┘└─┘
|
||||||
|
|
||||||
function git_config {
|
|
||||||
echo "User: $(git config user.name)"
|
|
||||||
echo "Mail: $(git config user.email)"
|
|
||||||
}
|
|
||||||
|
|
||||||
function git_pro {
|
function git_pro {
|
||||||
git config --global user.name "Robin-Charles GUIHENEUF"
|
git config --global user.name "Robin-Charles GUIHENEUF"
|
||||||
git config --global user.email rguiheneuf@netatmo.com
|
git config --global user.email rguiheneuf@netatmo.com
|
||||||
git_config
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function git_perso {
|
function git_perso {
|
||||||
git config --global user.name "Robin-Charles Guihéneuf"
|
git config --global user.name "Robin-Charles Guihéneuf"
|
||||||
git config --global user.email robin-charles@hotmail.fr
|
git config --global user.email robin-charles@hotmail.fr
|
||||||
git_config
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# ╔═╗┬┌┬┐ ╔═╗┌┬┐┌─┐┌┐┌┌┬┐
|
# ╔═╗┬┌┬┐ ╔═╗┌┬┐┌─┐┌┐┌┌┬┐
|
||||||
# ║ ╦│ │ ╠═╣│││├┤ │││ ││
|
# ║ ╦│ │ ╠═╣│││├┤ │││ ││
|
||||||
# ╚═╝┴ ┴ ╩ ╩┴ ┴└─┘┘└┘─┴┘
|
# ╚═╝┴ ┴ ╩ ╩┴ ┴└─┘┘└┘─┴┘
|
||||||
|
|
||||||
alias amend_pro="GIT_EDITOR=true git rebase --rebase-merges --exec 'git commit --amend --author=\"Robin-Charles GUIHENEUF <rguiheneuf@netatmo.com>\"' $1"
|
alias amend_pro="GIT_EDITOR=true git rebase --preserve-merges --exec 'git commit --amend --author=\"Robin-Charles GUIHENEUF <rguiheneuf@netatmo.com>\"' $1"
|
||||||
alias amend_perso="GIT_EDITOR=true git rebase --rebase-merges --exec 'git commit --amend --author=\"Robin-Charles Guihéneuf <robin-charles@hotmail.fr>\"' $1"
|
alias amend_perso="GIT_EDITOR=true git rebase --preserve-merges --exec 'git commit --amend --author=\"Robin-Charles Guihéneuf <robin-charles@hotmail.fr>\"' $1"
|
||||||
|
|
||||||
# ╦═╗┌─┐┌─┐┌─┐┌─┐┬┌┬┐┌─┐┬─┐┬┌─┐┌─┐
|
# ╦═╗┌─┐┌─┐┌─┐┌─┐┬┌┬┐┌─┐┬─┐┬┌─┐┌─┐
|
||||||
# ╠╦╝├┤ ├─┘│ │└─┐│ │ │ │├┬┘│├┤ └─┐
|
# ╠╦╝├┤ ├─┘│ │└─┐│ │ │ │├┬┘│├┤ └─┐
|
||||||
# ╩╚═└─┘┴ └─┘└─┘┴ ┴ └─┘┴└─┴└─┘└─┘
|
# ╩╚═└─┘┴ └─┘└─┘┴ ┴ └─┘┴└─┴└─┘└─┘
|
||||||
|
|
||||||
alias mulot='cd $HOME/mulot'
|
alias bc='cd $HOME/Netatmo/embedded/firmware-bitcloud'
|
||||||
alias moki='cd $HOME/mulot/moki'
|
alias fw='cd $HOME/Netatmo/embedded/firmware'
|
||||||
|
alias nmr='cd $HOME/Netatmo/embedded/nmr'
|
||||||
|
alias py='cd $HOME/Netatmo/core/python-emb-tools'
|
||||||
|
alias mag='cd $HOME/Netatmo/embedded/magellan'
|
||||||
|
alias nsp='cd $HOME/Netatmo/embedded/nsp'
|
||||||
|
alias mulot='cd $HOME/mulot/firmware'
|
||||||
|
|
||||||
# In editor
|
# In editor
|
||||||
alias c_moki='c $HOME/mulot/moki.code-workspace'
|
alias c_bc='c $HOME/Netatmo/firmware-bitcloud.code-workspace'
|
||||||
|
alias c_fw='c $HOME/Netatmo/firmware.code-workspace'
|
||||||
|
alias c_nmr='c $HOME/Netatmo/nmr.code-workspace'
|
||||||
|
alias c_py='c $HOME/Netatmo/python-emb-tools.code-workspace'
|
||||||
|
alias c_mag='c $HOME/Netatmo/magellan.code-workspace'
|
||||||
|
alias c_nsp='c $HOME/Netatmo/nsp.code-workspace'
|
||||||
|
alias c_mulot='c $HOME/mulot/mulot.code-workspace'
|
||||||
|
|
||||||
# SSH keygen
|
# SSH keygen
|
||||||
function ssh_keygen {
|
function ssh_keygen {
|
||||||
@@ -270,7 +258,7 @@ function ssh_keygen {
|
|||||||
|
|
||||||
# Flash sniffer nRF52
|
# Flash sniffer nRF52
|
||||||
function nrf52 {
|
function nrf52 {
|
||||||
arm-none-eabi-objcopy -O ihex build/bin/$1 $1.hex
|
arm-none-eabi-objcopy -O ihex output/nrf52840/bin/$1 $1.hex
|
||||||
nrfutil pkg generate --hw-version 52 --sd-req=0x00 --application $1.hex --application-version 1 $1.zip
|
nrfutil pkg generate --hw-version 52 --sd-req=0x00 --application $1.hex --application-version 1 $1.zip
|
||||||
|
|
||||||
if [ -z "$2" ]
|
if [ -z "$2" ]
|
||||||
@@ -317,18 +305,21 @@ fi
|
|||||||
# ║╣ ┌┴┬┘├─┘│ │├┬┘ │
|
# ║╣ ┌┴┬┘├─┘│ │├┬┘ │
|
||||||
# ╚═╝┴ └─┴ └─┘┴└─ ┴
|
# ╚═╝┴ └─┴ └─┘┴└─ ┴
|
||||||
|
|
||||||
|
export PATH=$PATH:~/Netatmo/core/embedded-tools/Linux/flasher
|
||||||
|
export PATH=$PATH:~/Netatmo/core/generic-embedded/stm32_sbm
|
||||||
|
export PATH=$PATH:~/Netatmo/core/generic-embedded/stm32_dfu
|
||||||
|
export PATH=$PATH:~/Netatmo/embedded/firmware-bitcloud/toolchain/arm-none-eabi/bin
|
||||||
|
export PATH=$PATH:~/Netatmo/embedded/nmr/scripts/flash
|
||||||
|
|
||||||
# Autofixup
|
# Autofixup
|
||||||
export PATH=$PATH:$HOME/.git-autofixup
|
export PATH=$PATH:$HOME/.git-autofixup
|
||||||
|
|
||||||
|
# Netatmo
|
||||||
|
export NETATMO_WORK_DIR=$HOME/Netatmo
|
||||||
|
|
||||||
# Cargo binaries (navi)
|
# Cargo binaries (navi)
|
||||||
export PATH=$PATH:$HOME/.cargo/bin
|
export PATH=$PATH:$HOME/.cargo/bin
|
||||||
|
|
||||||
# Python
|
|
||||||
export PATH=$PATH:$HOME/.local/bin
|
|
||||||
|
|
||||||
# User bin
|
|
||||||
export PATH=$HOME/bin:$PATH
|
|
||||||
|
|
||||||
# Navi
|
# Navi
|
||||||
if [ -z "${ZSH}" ]; then
|
if [ -z "${ZSH}" ]; then
|
||||||
source <(navi widget bash)
|
source <(navi widget bash)
|
||||||
@@ -336,5 +327,8 @@ else
|
|||||||
source <(navi widget zsh)
|
source <(navi widget zsh)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
export ANDROID_HOME=~/Android/Sdk
|
# Zephyr
|
||||||
export ANDROID_NDK_HOME=~/Android/Sdk/ndk-bundle
|
[ -f $HOME/mulot/firmware/zephyr/zephyr-env.sh ] && source $HOME/mulot/firmware/zephyr/zephyr-env.sh
|
||||||
|
|
||||||
|
# West
|
||||||
|
export WEST_DIR=$HOME/mulot/firmware/.west/west
|
||||||
|
|||||||
+6
-7
@@ -61,16 +61,15 @@ cargo install navi
|
|||||||
mkdir -p $HOME/.local/share/navi/cheats
|
mkdir -p $HOME/.local/share/navi/cheats
|
||||||
ln -sfn $HOME/.dotfiles/navi/ $HOME/.local/share/navi/cheats/vulporuza
|
ln -sfn $HOME/.dotfiles/navi/ $HOME/.local/share/navi/cheats/vulporuza
|
||||||
|
|
||||||
|
# Update pip
|
||||||
|
pip3 install --upgrade pip
|
||||||
|
|
||||||
|
# Install undervolt
|
||||||
|
sudo pip3 install undervolt
|
||||||
|
|
||||||
# Update npm
|
# Update npm
|
||||||
sudo npm install -g npm
|
sudo npm install -g npm
|
||||||
|
|
||||||
# Install rebase-editor
|
# Install rebase-editor
|
||||||
sudo npm install -g rebase-editor
|
sudo npm install -g rebase-editor
|
||||||
git config --global sequence.editor rebase-editor
|
git config --global sequence.editor rebase-editor
|
||||||
|
|
||||||
# Install micro
|
|
||||||
curl https://getmic.ro | bash
|
|
||||||
mkdir -p $HOME/.config/micro
|
|
||||||
ln -sfn $HOME/.dotfiles/micro/bindings.json $HOME/.config/micro/bindings.json
|
|
||||||
ln -sfn $HOME/.dotfiles/micro/settings.json $HOME/.config/micro/settings.json
|
|
||||||
sudo mv micro /usr/bin
|
|
||||||
|
|||||||
+11
-4
@@ -7,11 +7,18 @@ fi
|
|||||||
# CLI Tools
|
# CLI Tools
|
||||||
$HOME/.dotfiles/auto-config-cli.sh
|
$HOME/.dotfiles/auto-config-cli.sh
|
||||||
|
|
||||||
sudo apt install terminator fonts-firacode
|
# Codium
|
||||||
|
if [ ! -f "/etc/apt/sources.list.d/vscodium.list" ]
|
||||||
|
then
|
||||||
|
wget -qO - https://gitlab.com/paulcarroty/vscodium-deb-rpm-repo/raw/master/pub.gpg | gpg --dearmor | sudo dd of=/etc/apt/trusted.gpg.d/vscodium-archive-keyring.gpg
|
||||||
|
echo 'deb [signed-by=/etc/apt/trusted.gpg.d/vscodium-archive-keyring.gpg] https://paulcarroty.gitlab.io/vscodium-deb-rpm-repo/debs/ vscodium main' | sudo tee /etc/apt/sources.list.d/vscodium.list
|
||||||
|
fi
|
||||||
|
|
||||||
mkdir -p $HOME/.config/Code/User/
|
sudo apt install terminator codium
|
||||||
ln -sf $HOME/.dotfiles/codium/keybindings.json $HOME/.config/Code/User/keybindings.json
|
|
||||||
ln -sf $HOME/.dotfiles/codium/settings.json $HOME/.config/Code/User/settings.json
|
mkdir -p $HOME/.config/VSCodium/User/
|
||||||
|
ln -sf $HOME/.dotfiles/codium/keybindings.json $HOME/.config/VSCodium/User/keybindings.json
|
||||||
|
ln -sf $HOME/.dotfiles/codium/settings.json $HOME/.config/VSCodium/User/settings.json
|
||||||
|
|
||||||
mkdir -p $HOME/.config/terminator/
|
mkdir -p $HOME/.config/terminator/
|
||||||
ln -sf $HOME/.dotfiles/terminator/config $HOME/.config/terminator/config
|
ln -sf $HOME/.dotfiles/terminator/config $HOME/.config/terminator/config
|
||||||
|
|||||||
@@ -8,10 +8,6 @@
|
|||||||
"key": "ctrl+alt+u",
|
"key": "ctrl+alt+u",
|
||||||
"command": "editor.action.transformToUppercase"
|
"command": "editor.action.transformToUppercase"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"key": "ctrl+alt+l",
|
|
||||||
"command": "editor.action.transformToLowercase"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"key": "ctrl+[BracketRight]",
|
"key": "ctrl+[BracketRight]",
|
||||||
"command": "workbench.action.navigateForward"
|
"command": "workbench.action.navigateForward"
|
||||||
@@ -31,9 +27,5 @@
|
|||||||
{
|
{
|
||||||
"key": "ctrl+w",
|
"key": "ctrl+w",
|
||||||
"command": "-editor.action.addSelectionToNextFindMatch"
|
"command": "-editor.action.addSelectionToNextFindMatch"
|
||||||
},
|
|
||||||
{
|
|
||||||
"key": "ctrl+w",
|
|
||||||
"command": "-editor.action.smartSelect.expand"
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|||||||
+20
-34
@@ -9,21 +9,24 @@
|
|||||||
"editor.renderWhitespace": "all",
|
"editor.renderWhitespace": "all",
|
||||||
"files.trimTrailingWhitespace": true,
|
"files.trimTrailingWhitespace": true,
|
||||||
"files.insertFinalNewline": true,
|
"files.insertFinalNewline": true,
|
||||||
"files.watcherExclude":{
|
|
||||||
"**/.git/objects/**": true,
|
|
||||||
"**/.git/subtree-cache/**": true,
|
|
||||||
"**/build/**": true,
|
|
||||||
"**/.venv": true
|
|
||||||
},
|
|
||||||
"C_Cpp.formatting": "Disabled",
|
"C_Cpp.formatting": "Disabled",
|
||||||
"C_Cpp.updateChannel": "Default",
|
"C_Cpp.updateChannel": "Default",
|
||||||
"powermode.enabled": false,
|
"powermode.enabled": true,
|
||||||
|
"powermode.enableShake": false,
|
||||||
"powermode.enableExplosions": true,
|
"powermode.enableExplosions": true,
|
||||||
"powermode.maxExplosions": 1,
|
"powermode.maxExplosions": 1,
|
||||||
|
"powermode.explosionSize": 10,
|
||||||
|
"powermode.explosionOffset": 0.5,
|
||||||
|
"powermode.explosionFrequency": 1,
|
||||||
|
"powermode.explosionOrder": "random",
|
||||||
|
"powermode.gifMode": "continue",
|
||||||
|
"powermode.explosionDuration": 415,
|
||||||
|
"powermode.backgroundMode": "image",
|
||||||
|
"powermode.customExplosions": ["data:image/gif;base64,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"],
|
||||||
"editor.rulers": [
|
"editor.rulers": [
|
||||||
100
|
100
|
||||||
],
|
],
|
||||||
"telemetry.telemetryLevel": "off",
|
"telemetry.enableTelemetry": false,
|
||||||
"explorer.confirmDragAndDrop": false,
|
"explorer.confirmDragAndDrop": false,
|
||||||
"explorer.confirmDelete": false,
|
"explorer.confirmDelete": false,
|
||||||
"window.titleBarStyle": "custom",
|
"window.titleBarStyle": "custom",
|
||||||
@@ -35,36 +38,19 @@
|
|||||||
"suppressFileNotUnderSourceControlWarning": false,
|
"suppressFileNotUnderSourceControlWarning": false,
|
||||||
"suppressGitVersionWarning": false,
|
"suppressGitVersionWarning": false,
|
||||||
"suppressLineUncommittedWarning": false,
|
"suppressLineUncommittedWarning": false,
|
||||||
"suppressNoRepositoryWarning": false
|
"suppressNoRepositoryWarning": false,
|
||||||
|
"suppressResultsExplorerNotice": false,
|
||||||
|
"suppressShowKeyBindingsNotice": true
|
||||||
},
|
},
|
||||||
|
"gitlens.views.fileHistory.enabled": true,
|
||||||
|
"gitlens.views.lineHistory.enabled": true,
|
||||||
|
"terminal.integrated.rendererType": "dom",
|
||||||
"workbench.colorTheme": "Monokai",
|
"workbench.colorTheme": "Monokai",
|
||||||
"editor.largeFileOptimizations": false,
|
"editor.largeFileOptimizations": false,
|
||||||
"editor.suggestSelection": "first",
|
"editor.suggestSelection": "first",
|
||||||
"vsintellicode.modify.editor.suggestSelection": "automaticallyOverrodeDefaultValue",
|
"vsintellicode.modify.editor.suggestSelection": "automaticallyOverrodeDefaultValue",
|
||||||
"C_Cpp.intelliSenseEngine": "Tag Parser",
|
"C_Cpp.intelliSenseEngine": "Tag Parser",
|
||||||
"diffEditor.ignoreTrimWhitespace": true,
|
"diffEditor.ignoreTrimWhitespace": false,
|
||||||
"git.autorefresh": false,
|
"python.languageServer": "Microsoft",
|
||||||
"editor.fontFamily": "'Fira Code Retina', 'Droid Sans Mono' , 'monospace', 'Droid Sans Fallback'",
|
"gitlab.instanceUrl":"https://gitlab.corp.netatmo.com"
|
||||||
"editor.fontLigatures": true,
|
|
||||||
"editor.fontSize": 14,
|
|
||||||
"editor.lineHeight": 20,
|
|
||||||
"autoDocstring.docstringFormat": "sphinx",
|
|
||||||
"security.workspace.trust.untrustedFiles": "open",
|
|
||||||
"workbench.editorAssociations": {
|
|
||||||
"*.ipynb": "jupyter.notebook.ipynb"
|
|
||||||
},
|
|
||||||
"cmake.configureOnOpen": true,
|
|
||||||
"editor.guides.bracketPairs": true,
|
|
||||||
"devicetree.zephyr": "zephyr",
|
|
||||||
"powermode.shake.enabled": false,
|
|
||||||
"powermode.explosions.size": 10,
|
|
||||||
"powermode.explosions.frequency": 1,
|
|
||||||
"powermode.explosions.offset": 0.5,
|
|
||||||
"powermode.explosions.customExplosions": [
|
|
||||||
"data:image/gif;base64,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"
|
|
||||||
],
|
|
||||||
"powermode.explosions.backgroundMode": "image",
|
|
||||||
"powermode.explosions.gifMode": "continue",
|
|
||||||
"powermode.explosions.explosionOrder": "random",
|
|
||||||
"powermode.explosions.duration": 415
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +0,0 @@
|
|||||||
{
|
|
||||||
"Alt-/": "lua:comment.comment",
|
|
||||||
"CtrlUnderscore": "lua:comment.comment"
|
|
||||||
}
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
{}
|
|
||||||
+9
-13
@@ -1,24 +1,20 @@
|
|||||||
% compression
|
% compression
|
||||||
|
|
||||||
# Create a tar archive
|
# Create a tar containing files
|
||||||
tar cf <name>.tar <files>
|
tar cf <name>.tar <files>
|
||||||
|
|
||||||
# Extract a tar archive
|
# Extract the files from a tar
|
||||||
tar xf <tar_file>
|
tar xf <tar_file>
|
||||||
|
|
||||||
# Create a tar archive with gz compression
|
# Create a tar with Gzip compression
|
||||||
tar czf <name>.tar.gz <files>
|
tar czf <name>.tar.gz <files>
|
||||||
|
|
||||||
# Extract a tar using gz compression
|
# Compress file and appends .gz to its name
|
||||||
tar xzf <targz_file>
|
gzip <path>
|
||||||
|
|
||||||
# Create a gz archive
|
# Decompress compressed file
|
||||||
gzip -9 -c <files> > <name>.gz
|
|
||||||
|
|
||||||
# Extract a gz archive
|
|
||||||
gzip -d <gz_file>
|
gzip -d <gz_file>
|
||||||
|
|
||||||
$ files: ls | awk -F: '{ print $1}'
|
$ path: ls
|
||||||
$ tar_file: ls *.tar | awk -F: '{ print $1}'
|
$ tar_file: ls *.{tar,tar.*} 2>/dev/null
|
||||||
$ targz_file: ls *.tar.gz | awk -F: '{ print $1}'
|
$ gz_file: ls *.gz
|
||||||
$ gz_file: ls *.gz | awk -F: '{ print $1}'
|
|
||||||
|
|||||||
@@ -1,21 +0,0 @@
|
|||||||
% docker-compose
|
|
||||||
|
|
||||||
# Up a compose YAML
|
|
||||||
sudo docker compose -f <file> up
|
|
||||||
|
|
||||||
# Up and daemonze a compose YAML
|
|
||||||
sudo docker compose -f <file> up -d
|
|
||||||
|
|
||||||
# Up and daemonze a compose YAML (force)
|
|
||||||
sudo docker compose -f <file> up -d --force-recreate
|
|
||||||
|
|
||||||
# Down a compose YAML
|
|
||||||
sudo docker compose -f <file> down
|
|
||||||
|
|
||||||
# Print the last lines of compose YAML logs
|
|
||||||
sudo docker compose -f <file> logs --tail 100
|
|
||||||
|
|
||||||
# Print the last lines of compose YAML logs and following its logs
|
|
||||||
sudo docker compose -f <file> logs --tail 100 -f
|
|
||||||
|
|
||||||
$ file: ls *.yaml | awk '{print $1}'
|
|
||||||
@@ -1,46 +0,0 @@
|
|||||||
% docker
|
|
||||||
|
|
||||||
# Create a volume
|
|
||||||
sudo docker volume create <name>
|
|
||||||
|
|
||||||
# List all volumes
|
|
||||||
sudo docker volume ls
|
|
||||||
|
|
||||||
# Remove volume
|
|
||||||
sudo docker volume rm <volume>
|
|
||||||
|
|
||||||
$ volume: sudo docker volume ls --format "{{.Name}}" | awk '{print $1}'
|
|
||||||
|
|
||||||
# Create new network
|
|
||||||
docker network create <name>
|
|
||||||
|
|
||||||
# List the networks
|
|
||||||
sudo docker network ls
|
|
||||||
|
|
||||||
# Remove volume
|
|
||||||
sudo docker volume rm <network>
|
|
||||||
|
|
||||||
$ network: sudo docker network ls --format "{{.Name}}" | awk '{print $1}'
|
|
||||||
|
|
||||||
# List the running containers
|
|
||||||
sudo docker ps
|
|
||||||
|
|
||||||
# Stop a running container through SIGTERM
|
|
||||||
sudo docker stop <container>
|
|
||||||
|
|
||||||
# Stop a running container through SIGKILL
|
|
||||||
sudo docker kill <container>
|
|
||||||
|
|
||||||
# Execute bash on a running container
|
|
||||||
sudo docker exec -it <container> bash
|
|
||||||
|
|
||||||
# Execute a command on a running container
|
|
||||||
sudo docker exec -it <container> sh -c '<command>'
|
|
||||||
|
|
||||||
# Print the last lines of a container's logs
|
|
||||||
sudo docker logs --tail 100 <container>
|
|
||||||
|
|
||||||
# Print the last lines of a container's logs and following its logs
|
|
||||||
sudo docker logs --tail 100 <container> -f
|
|
||||||
|
|
||||||
$ container: sudo docker container ls --format "{{.Names}}" | awk '{print $1}'
|
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
% freqtrade
|
|
||||||
|
|
||||||
# Backtest a strategy on timerange
|
|
||||||
sudo docker-compose run --rm freqtrade backtesting --timerange=20200901-20201001 -s <strategy>
|
|
||||||
|
|
||||||
# Download data on timerange
|
|
||||||
sudo docker-compose run --rm freqtrade download-data --timerange=20200901-20201001
|
|
||||||
|
|
||||||
# Plot data on timerange
|
|
||||||
sudo docker-compose run --rm freqtrade plot-dataframe --timerange=20200901-20201001 -s <strategy>
|
|
||||||
|
|
||||||
# List strategies
|
|
||||||
sudo docker-compose run --rm freqtrade list-strategies
|
|
||||||
|
|
||||||
$ strategy: ls user_data/strategies | grep "\.py" | sed -e "s/\.py//g" | awk '{print $1}'
|
|
||||||
@@ -1,71 +0,0 @@
|
|||||||
% git
|
|
||||||
|
|
||||||
# Initializes a git repository
|
|
||||||
git init
|
|
||||||
|
|
||||||
# Clone a git repository
|
|
||||||
git clone <repository> <clone_directory>
|
|
||||||
|
|
||||||
# Rebase upstream master into local/origin master
|
|
||||||
git fetch <remote_name>
|
|
||||||
git checkout master
|
|
||||||
git rebase <remote_name>/master
|
|
||||||
git fetch origin
|
|
||||||
git push -f origin master
|
|
||||||
|
|
||||||
# Merge upstream master into local/origin master
|
|
||||||
git fetch <remote_name>
|
|
||||||
git checkout master
|
|
||||||
git merge <remote_name>/master
|
|
||||||
git fetch origin
|
|
||||||
git push -f origin master
|
|
||||||
|
|
||||||
# Adds a remote for a git repository
|
|
||||||
git remote add <remote_name> <remote_url>
|
|
||||||
|
|
||||||
# Renames a remote for a git repository
|
|
||||||
git remote rename <old_remote_name> <new_remote_name>
|
|
||||||
|
|
||||||
# Remove a remote for a git repository
|
|
||||||
git remote remove <remote_name>
|
|
||||||
|
|
||||||
# Saves the changes to a file in a commit
|
|
||||||
git commit -m <message>
|
|
||||||
|
|
||||||
# Pushes committed changes to remote repository
|
|
||||||
git push --set-upstream <remote_name> <branch_name>
|
|
||||||
|
|
||||||
# Displays formatted log of commits for a repo
|
|
||||||
git log --all --decorate --oneline --graph
|
|
||||||
|
|
||||||
# Clear everything
|
|
||||||
git clean -dxf
|
|
||||||
|
|
||||||
# Add a new module
|
|
||||||
git submodule add <repository> <path>
|
|
||||||
|
|
||||||
# Update module
|
|
||||||
git submodule update --init
|
|
||||||
|
|
||||||
# Update module without init
|
|
||||||
git submodule update
|
|
||||||
|
|
||||||
# Pull all submodules
|
|
||||||
git submodule foreach git pull origin master
|
|
||||||
|
|
||||||
# Skip git hooks
|
|
||||||
git commit --no-verify
|
|
||||||
|
|
||||||
# Create new branch from current HEAD
|
|
||||||
git checkout -b <new_branch_name>
|
|
||||||
|
|
||||||
# Create and push tag
|
|
||||||
git tag <name>
|
|
||||||
git push origin <name>
|
|
||||||
|
|
||||||
# Delete and push tag
|
|
||||||
git tag -d <tag_name>
|
|
||||||
git push -d origin <tag_name>
|
|
||||||
|
|
||||||
# Variables
|
|
||||||
$ tag_name: git tag -l | awk '{print $1}'
|
|
||||||
@@ -1,42 +0,0 @@
|
|||||||
% gpg
|
|
||||||
|
|
||||||
# GPG version
|
|
||||||
gpg --version
|
|
||||||
|
|
||||||
# GPG generate key
|
|
||||||
gpg --gen-key
|
|
||||||
|
|
||||||
# List keys
|
|
||||||
gpg --list-keys
|
|
||||||
|
|
||||||
# Export public key
|
|
||||||
gpg --output <filename> --export <gpg_public_keys>
|
|
||||||
|
|
||||||
# Export public key as ASCII
|
|
||||||
gpg --output <filename> --export --armor <gpg_public_keys>
|
|
||||||
|
|
||||||
# Import public key
|
|
||||||
gpg --import <gpg_files>
|
|
||||||
|
|
||||||
# Encrypt document
|
|
||||||
gpg --output <filename> --encrypt --recipient <gpg_public_keys> <files>
|
|
||||||
|
|
||||||
# Decrypt document
|
|
||||||
gpg --output <filename> --decrypt <files>
|
|
||||||
|
|
||||||
# Make a signature
|
|
||||||
gpg --output <signature_file> --sign <files>
|
|
||||||
|
|
||||||
# Verify signature
|
|
||||||
gpg --verify <files>
|
|
||||||
|
|
||||||
# Clearsign documents
|
|
||||||
gpg --clearsign <filename>
|
|
||||||
|
|
||||||
# Detach signature
|
|
||||||
gpg --output <filename_sig> --detach-sig <filename>
|
|
||||||
|
|
||||||
$ files: ls * | awk '{print $1}'
|
|
||||||
$ gpg_files: ls *.gpg | awk '{print $1}'
|
|
||||||
$ gpg_public_keys: gpg --list-keys | grep uid | sed 's/.*<\(.*\)>.*/\1/' | awk '{print $1}'
|
|
||||||
|
|
||||||
@@ -1,69 +0,0 @@
|
|||||||
% misc
|
|
||||||
|
|
||||||
# Update system
|
|
||||||
sudo apt update && sudo apt upgrade
|
|
||||||
|
|
||||||
# Clean APT
|
|
||||||
sudo apt autoclean && sudo apt autoremove
|
|
||||||
|
|
||||||
# Reinstall package
|
|
||||||
sudo apt reinstall ./<deb>
|
|
||||||
|
|
||||||
# List users
|
|
||||||
cat /etc/passwd | awk -F: '{ print $1}'
|
|
||||||
|
|
||||||
# User information
|
|
||||||
sudo id <user>
|
|
||||||
|
|
||||||
# Change user password
|
|
||||||
sudo passwd <user>
|
|
||||||
|
|
||||||
# Create user with home
|
|
||||||
sudo useradd -m <username>
|
|
||||||
|
|
||||||
# Create user without home
|
|
||||||
sudo useradd <username>
|
|
||||||
|
|
||||||
# Delete an user
|
|
||||||
sudo deluser <user>
|
|
||||||
|
|
||||||
# List all groups
|
|
||||||
cat /etc/group
|
|
||||||
|
|
||||||
# Add user to group
|
|
||||||
sudo usermod -a -G <group> <user>
|
|
||||||
|
|
||||||
# Remove user from a group
|
|
||||||
sudo deluser <user> <group>
|
|
||||||
|
|
||||||
# List port bindings
|
|
||||||
sudo lsof -i -P -n | grep LISTEN
|
|
||||||
|
|
||||||
# Show binding on a port
|
|
||||||
sudo lsof -i:<port>
|
|
||||||
|
|
||||||
# Get IP on interface
|
|
||||||
ip addr show dev <interface> | grep "inet " | sed "s/ *inet \([^ ]*\) .*/\1/" | awk -F: '{ print $1}'
|
|
||||||
|
|
||||||
# Get devices on interface
|
|
||||||
nmap -sP <ip>
|
|
||||||
|
|
||||||
# Compare 2 files (meld)
|
|
||||||
meld <(hexdump -C <file_1>) <(hexdump -C <file_2>)
|
|
||||||
|
|
||||||
# Compare 2 files (bcompare)
|
|
||||||
bcompare <file_1> <file_2>
|
|
||||||
|
|
||||||
# Replace expression in files
|
|
||||||
ack -rl "<expression>" | xargs sed -i 's#<expression>#<replace_expression>#g'
|
|
||||||
|
|
||||||
# Disable Bluetooth ERTM
|
|
||||||
sudo bash -c "echo Y > /sys/module/bluetooth/parameters/disable_ertm"
|
|
||||||
|
|
||||||
$ user: cat /etc/passwd | awk -F: '{ print $1}'
|
|
||||||
$ group: cat /etc/group | awk -F: '{ print $1}'
|
|
||||||
$ interface: ip link | grep "^[0-9]*:" | sed "s/[0-9]*: \(.*\):.*/\1/" | awk -F: '{ print $1}'
|
|
||||||
$ ip: ip addr show dev <interface> | grep "inet " | sed "s/ *inet \([^ ]*\) .*/\1/" | awk -F: '{ print $1}'
|
|
||||||
$ file_1: ls | awk -F: '{ print $1}'
|
|
||||||
$ file_2: ls | awk -F: '{ print $1}'
|
|
||||||
$ deb: ls *.deb | awk -F: '{ print $1}'
|
|
||||||
@@ -1,10 +0,0 @@
|
|||||||
% mysql
|
|
||||||
|
|
||||||
# Create database
|
|
||||||
mysql -u <user> -p -e "create database <database> character set UTF8mb4 collate utf8mb4_bin"
|
|
||||||
|
|
||||||
# Export databse
|
|
||||||
mysqldump -u <user> -p -x -A <database> > <file>
|
|
||||||
|
|
||||||
# Import database
|
|
||||||
mysql -u <user> -p <database> <path>
|
|
||||||
@@ -1,32 +1,18 @@
|
|||||||
% flasher
|
% flasher
|
||||||
|
|
||||||
# Set server
|
# Set server
|
||||||
flasher -setserver nv2 <server>
|
flasher -setserver nv2 <server>
|
||||||
|
|
||||||
$ server: echo "netcomv2.inte.netatmo.net nv2-nlg.netatmo.net nv2-nmg.netatmo.net upp.netatmo.net" | tr " " "\n"
|
$ server: echo "netcomv2.inte.netatmo.net nv2-nlg.netatmo.net nv2-nmg.netatmo.net upp.netatmo.net" | tr " " "\n"
|
||||||
|
|
||||||
|
|
||||||
% jlink
|
% jlink
|
||||||
|
|
||||||
# JLinkExe
|
# JLinkExe
|
||||||
JLinkExe -if SWD -speed 1000 -device <target>
|
JLinkExe -if SWD -speed 1000 -device <target>
|
||||||
|
|
||||||
# JLinkGDBServer
|
# JLinkGDBServer
|
||||||
JLinkGDBServer -if SWD -device <target>
|
JLinkGDBServer -if SWD -device <target>
|
||||||
|
|
||||||
# Variables
|
# Variables
|
||||||
$ target: echo "ATSAMR21E19A nRF52" | tr " " "\n"
|
$ target: echo "ATSAMR21E19A nRF52" | tr " " "\n"
|
||||||
|
|
||||||
|
|
||||||
% zigbee
|
|
||||||
|
|
||||||
# Sniffer Zigbee
|
# Sniffer Zigbee
|
||||||
<pyet>/zigbee/python_zigbee_interface.py -c <channel>
|
<pyet>/zigbee/python_zigbee_interface.py -c <channel>
|
||||||
|
|
||||||
$ pyet: echo "$HOME/Netatmo/core/python-emb-tools/python/bin"
|
$ pyet: echo "$HOME/Netatmo/core/python-emb-tools/python/bin"
|
||||||
|
|
||||||
|
|
||||||
% mac
|
|
||||||
|
|
||||||
# Get MAC infos
|
|
||||||
curl 'https://www.macvendorlookup.com/oui.php?mac=<mac>' | jq
|
|
||||||
|
|||||||
@@ -1,4 +0,0 @@
|
|||||||
% nextcloud
|
|
||||||
|
|
||||||
# Execute occ command
|
|
||||||
sudo -u nextcloud php /var/www/nextcloud/occ <command>
|
|
||||||
+2
-2
@@ -1,10 +1,10 @@
|
|||||||
% nginx
|
% nginx
|
||||||
|
|
||||||
# Enable site
|
# Enable site
|
||||||
sudo ln -s /etc/nginx/sites-available/<ls_site> /etc/nginx/sites-enabled/<ls_site>
|
ln -s /etc/nginx/sites-available/<ls_site> /etc/nginx/sites-enabled/<ls_site>
|
||||||
|
|
||||||
# Disable site
|
# Disable site
|
||||||
sudo rm /etc/nginx/sites-enabled/<rm_site>
|
rm /etc/nginx/sites-enabled/<rm_site>
|
||||||
|
|
||||||
$ ls_site: ls /etc/nginx/sites-available/ | awk '{print $1}'
|
$ ls_site: ls /etc/nginx/sites-available/ | awk '{print $1}'
|
||||||
$ rm_site: ls /etc/nginx/sites-enabled/ | awk '{print $1}'
|
$ rm_site: ls /etc/nginx/sites-enabled/ | awk '{print $1}'
|
||||||
|
|||||||
+6
-6
@@ -1,22 +1,22 @@
|
|||||||
% syncapi
|
% syncapi
|
||||||
|
|
||||||
# SyncAPI Muller
|
# SyncAPI Muller
|
||||||
<syncapi_path>/syncapiadmin.py --project muller -s <server> --endpoint <endpoint> --mac <gateway_mac>
|
<syncapi_path>/syncapiadmin.py --project muller -s <server> --endpoint <endpoint> -c <syncapi_path>/muller_<server>.swp --mac <gateway_mac>
|
||||||
|
|
||||||
# SyncAPI Legrand
|
# SyncAPI Legrand
|
||||||
<syncapi_path>/syncapiadmin.py --project legrand -s <server> --endpoint <endpoint> --mac <gateway_mac>
|
<syncapi_path>/syncapiadmin.py --project legrand -s <server> --endpoint <endpoint> -c <syncapi_path>/legrand_<server>.swp --mac <gateway_mac>
|
||||||
|
|
||||||
# Debug parser Legrand
|
# Debug parser Legrand
|
||||||
<debug_path>/debug_parser.py --project legrand -s <server> -r -pp -g <gateway_mac>
|
<debug_path>/debug_parser.py --project legrand -s <server> -c <syncapi_path>/legrand_<server>.swp -r -pp -g <gateway_mac>
|
||||||
|
|
||||||
# Enable debug mode Legrand
|
# Enable debug mode Legrand
|
||||||
<debug_path>/debug_config_setter.py --project legrand -s <server> -g <gateway_mac> -t NLG -ke debug_enabled
|
<debug_path>/debug_config_setter.py --project legrand -s <server> -c <syncapi_path>/legrand_<server>.swp -g <gateway_mac> -t NLG -ke debug_enabled
|
||||||
|
|
||||||
# Disable debug mode Legrand
|
# Disable debug mode Legrand
|
||||||
<debug_path>/debug_config_setter.py --project legrand -s <server> -g <gateway_mac> -t NLG -kd debug_enabled
|
<debug_path>/debug_config_setter.py --project legrand -s <server> -c <syncapi_path>/legrand_<server>.swp -g <gateway_mac> -t NLG -kd debug_enabled
|
||||||
|
|
||||||
# Analyse diagnosis
|
# Analyse diagnosis
|
||||||
<syncapi_path>/syncapiadmin.py --project legrand -s <server> --endpoint getdebuginfo --mac <gateway_mac> | jq -r .body.diagnosis_content | <release_path>/decode_diagnosis.py
|
<syncapi_path>/syncapiadmin.py --project legrand -s <server> --endpoint getdebuginfo -c <syncapi_path>/legrand_<server>.swp --mac <gateway_mac> | jq -r .body.diagnosis_content | <release_path>/decode_diagnosis.py
|
||||||
|
|
||||||
# Paths
|
# Paths
|
||||||
$ syncapi_path: echo "$HOME/Netatmo/core/python-emb-tools/python/bin/syncapiadmin"
|
$ syncapi_path: echo "$HOME/Netatmo/core/python-emb-tools/python/bin/syncapiadmin"
|
||||||
|
|||||||
+6
-2
@@ -1,15 +1,19 @@
|
|||||||
[global_config]
|
[global_config]
|
||||||
window_state = maximise
|
window_state = maximise
|
||||||
scroll_tabbar = True
|
scroll_tabbar = True
|
||||||
|
title_inactive_bg_color = "#000000"
|
||||||
inactive_color_offset = 1.0
|
inactive_color_offset = 1.0
|
||||||
enabled_plugins = TerminalShot, LaunchpadCodeURLHandler, APTURLHandler, LaunchpadBugURLHandler
|
enabled_plugins = TerminalShot, LaunchpadCodeURLHandler, APTURLHandler, LaunchpadBugURLHandler
|
||||||
suppress_multiple_term_dialog = True
|
suppress_multiple_term_dialog = True
|
||||||
|
title_use_system_font = False
|
||||||
|
title_font = Sans 11
|
||||||
[keybindings]
|
[keybindings]
|
||||||
[profiles]
|
[profiles]
|
||||||
[[default]]
|
[[default]]
|
||||||
background_darkness = 0.7
|
background_darkness = 0.6
|
||||||
background_type = transparent
|
background_type = transparent
|
||||||
font = Fira Code weight=453 11
|
cursor_color = "#908c8c"
|
||||||
|
font = Monospace 11
|
||||||
foreground_color = "#ffffff"
|
foreground_color = "#ffffff"
|
||||||
scrollback_infinite = True
|
scrollback_infinite = True
|
||||||
palette = "#000000:#aa0000:#00aa00:#f57900:#55ffff:#ff006e:#00aaaa:#aaaaaa:#555555:#ff5555:#55ff55:#ffff55:#55ffff:#ff006e:#00aaaa:#ffffff"
|
palette = "#000000:#aa0000:#00aa00:#f57900:#55ffff:#ff006e:#00aaaa:#aaaaaa:#555555:#ff5555:#55ff55:#ffff55:#55ffff:#ff006e:#00aaaa:#ffffff"
|
||||||
|
|||||||
Reference in New Issue
Block a user