Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 2aa689724c |
132
.zshrc
132
.zshrc
@@ -1,132 +0,0 @@
|
||||
# If you come from bash you might have to change your $PATH.
|
||||
# export PATH=$HOME/bin:$HOME/.local/bin:/usr/local/bin:$PATH
|
||||
|
||||
# Path to your Oh My Zsh installation.
|
||||
ZSH=/usr/share/oh-my-zsh/
|
||||
|
||||
# Set name of the theme to load --- if set to "random", it will
|
||||
# load a random theme each time Oh My Zsh is loaded, in which case,
|
||||
# to know which specific one was loaded, run: echo $RANDOM_THEME
|
||||
# See https://github.com/ohmyzsh/ohmyzsh/wiki/Themes
|
||||
# ZSH_THEME="robbyrussell"
|
||||
# ZSH_THEME="smt"
|
||||
# ZSH_THEME="dogenpunk"
|
||||
# ZSH_THEME="avit"
|
||||
ZSH_THEME="smd"
|
||||
|
||||
# Set list of themes to pick from when loading at random
|
||||
# Setting this variable when ZSH_THEME=random will cause zsh to load
|
||||
# a theme from this variable instead of looking in $ZSH/themes/
|
||||
# If set to an empty array, this variable will have no effect.
|
||||
# ZSH_THEME_RANDOM_CANDIDATES=( "robbyrussell" "agnoster" )
|
||||
|
||||
# Uncomment the following line to use case-sensitive completion.
|
||||
# CASE_SENSITIVE="true"
|
||||
|
||||
# Uncomment the following line to use hyphen-insensitive completion.
|
||||
# Case-sensitive completion must be off. _ and - will be interchangeable.
|
||||
# HYPHEN_INSENSITIVE="true"
|
||||
|
||||
# Uncomment one of the following lines to change the auto-update behavior
|
||||
# zstyle ':omz:update' mode disabled # disable automatic updates
|
||||
# zstyle ':omz:update' mode auto # update automatically without asking
|
||||
# zstyle ':omz:update' mode reminder # just remind me to update when it's time
|
||||
|
||||
# Uncomment the following line to change how often to auto-update (in days).
|
||||
# zstyle ':omz:update' frequency 13
|
||||
|
||||
# Uncomment the following line if pasting URLs and other text is messed up.
|
||||
# DISABLE_MAGIC_FUNCTIONS="true"
|
||||
|
||||
# Uncomment the following line to disable colors in ls.
|
||||
# DISABLE_LS_COLORS="true"
|
||||
|
||||
# Uncomment the following line to disable auto-setting terminal title.
|
||||
# DISABLE_AUTO_TITLE="true"
|
||||
|
||||
# Uncomment the following line to enable command auto-correction.
|
||||
# ENABLE_CORRECTION="true"
|
||||
|
||||
# Uncomment the following line to display red dots whilst waiting for completion.
|
||||
# You can also set it to another string to have that shown instead of the default red dots.
|
||||
# e.g. COMPLETION_WAITING_DOTS="%F{yellow}waiting...%f"
|
||||
# Caution: this setting can cause issues with multiline prompts in zsh < 5.7.1 (see #5765)
|
||||
# COMPLETION_WAITING_DOTS="true"
|
||||
|
||||
# Uncomment the following line if you want to disable marking untracked files
|
||||
# under VCS as dirty. This makes repository status check for large repositories
|
||||
# much, much faster.
|
||||
# DISABLE_UNTRACKED_FILES_DIRTY="true"
|
||||
|
||||
# Uncomment the following line if you want to change the command execution time
|
||||
# stamp shown in the history command output.
|
||||
# You can set one of the optional three formats:
|
||||
# "mm/dd/yyyy"|"dd.mm.yyyy"|"yyyy-mm-dd"
|
||||
# or set a custom format using the strftime function format specifications,
|
||||
# see 'man strftime' for details.
|
||||
# HIST_STAMPS="mm/dd/yyyy"
|
||||
HIST_STAMPS="yyyy-mm-dd"
|
||||
|
||||
# Would you like to use another custom folder than $ZSH/custom?
|
||||
# ZSH_CUSTOM=/path/to/new-custom-folder
|
||||
|
||||
# Which plugins would you like to load?
|
||||
# Standard plugins can be found in $ZSH/plugins/
|
||||
# Custom plugins may be added to $ZSH_CUSTOM/plugins/
|
||||
# Example format: plugins=(rails git textmate ruby lighthouse)
|
||||
# Add wisely, as too many plugins slow down shell startup.
|
||||
plugins=(git)
|
||||
|
||||
# User configuration
|
||||
|
||||
# export MANPATH="/usr/local/man:$MANPATH"
|
||||
|
||||
# You may need to manually set your language environment
|
||||
# export LANG=en_US.UTF-8
|
||||
|
||||
# Preferred editor for local and remote sessions
|
||||
# if [[ -n $SSH_CONNECTION ]]; then
|
||||
# export EDITOR='vim'
|
||||
# else
|
||||
# export EDITOR='nvim'
|
||||
# fi
|
||||
|
||||
# Compilation flags
|
||||
# export ARCHFLAGS="-arch $(uname -m)"
|
||||
|
||||
# Set personal aliases, overriding those provided by Oh My Zsh libs,
|
||||
# plugins, and themes. Aliases can be placed here, though Oh My Zsh
|
||||
# users are encouraged to define aliases within a top-level file in
|
||||
# the $ZSH_CUSTOM folder, with .zsh extension. Examples:
|
||||
# - $ZSH_CUSTOM/aliases.zsh
|
||||
# - $ZSH_CUSTOM/macos.zsh
|
||||
# For a full list of active aliases, run `alias`.
|
||||
#
|
||||
# Example aliases
|
||||
# alias zshconfig="mate ~/.zshrc"
|
||||
# alias ohmyzsh="mate ~/.oh-my-zsh"
|
||||
|
||||
ZSH_CACHE_DIR=$HOME/.cache/oh-my-zsh
|
||||
if [[ ! -d $ZSH_CACHE_DIR ]]; then
|
||||
mkdir $ZSH_CACHE_DIR
|
||||
fi
|
||||
|
||||
source $ZSH/oh-my-zsh.sh
|
||||
|
||||
### restricting hist_verify in zsh like !!
|
||||
accept-line() {
|
||||
if [[ ${BUFFER//![\$!]} = *!* ]]
|
||||
then
|
||||
set -o histverify
|
||||
else
|
||||
set +o histverify
|
||||
fi
|
||||
zle .$WIDGET
|
||||
}
|
||||
zle -N accept-line
|
||||
|
||||
## autostart with neofetch
|
||||
if [ -x "$(command -v neofetch)" ]
|
||||
then
|
||||
neofetch
|
||||
fi
|
||||
73
README.md
73
README.md
@@ -1,73 +0,0 @@
|
||||
# Installation of zsh (z-shell) with oh-my-zsh in Arch Linux
|
||||
|
||||
## Preparation
|
||||
|
||||
You would like to install the package manager `yay` instead of `pacman` first:
|
||||
|
||||
### Yay installation
|
||||
|
||||
```
|
||||
sudo pacman -S --needed git base-devel
|
||||
git clone https://aur.archlinux.org/yay.git
|
||||
cd yay
|
||||
makepkg -si
|
||||
```
|
||||
You can find support at https://github.com/Jguer/yay
|
||||
|
||||
### Installation
|
||||
|
||||
```
|
||||
yay oh-my-zsh
|
||||
```
|
||||
|
||||
## Configuration
|
||||
|
||||
You can either copy the theme from this repository or even more flexible
|
||||
when you first clone this repository and then make a link from the `themes` folder to this repository.
|
||||
|
||||
### Just copy the file
|
||||
|
||||
Copy the file `smd.zsh-theme` of this repository to the `themes` directory, like
|
||||
```
|
||||
sudo wget -P /usr/share/oh-my-zsh/themes https://git.kuschel.at/public/smd.zsh-theme/raw/branch/master/smd.zsh-theme
|
||||
```
|
||||
Then copy the zsh template `zshrc` to your home directory
|
||||
```
|
||||
cp /usr/share/oh-my-zsh/zshrc ~/.zshrc
|
||||
```
|
||||
|
||||
### Make a link from a cloned folder (the more experienced one)
|
||||
|
||||
Goto a new user folder e.g. `mkdir -p ~/gitea` and `cd ~/gitea`
|
||||
|
||||
Make a clone:
|
||||
```
|
||||
git clone https:\\https://git.kuschel.at/public/smd.zsh-theme.git
|
||||
```
|
||||
```
|
||||
cd /usr/share/oh-my-zsh/themes
|
||||
sudo ln -s $HOME/gitea/smd.zsh-theme/smd.zsh-theme
|
||||
```
|
||||
|
||||
### Further steps:
|
||||
|
||||
Now you have to edit this file with e.g. `nano -cl ~/.zshrc`
|
||||
and replace the line with ZSH_THEME to:
|
||||
```
|
||||
ZSH_THEME="smd"
|
||||
```
|
||||
In addition, I like to replace the HIST_STAMPS to:
|
||||
```
|
||||
HIST_STAMPS="yyyy-mm-dd"
|
||||
```
|
||||
|
||||
Last step change the shell and try to reload omz with:
|
||||
|
||||
```
|
||||
sudo chsh
|
||||
```
|
||||
Now you have to enter the new shell `/bin/zsh`
|
||||
|
||||
I would recommand to log out and log back into the system to see the zsh, as this is now your default shell for the future.
|
||||
|
||||
-- eof --
|
||||
@@ -1,5 +1,5 @@
|
||||
# smd.zsh-theme, based on smt.zsh-theme, based on dogenpunk by Matthew Nelson.
|
||||
REPORTTIME=3
|
||||
# smd.zsh-theme by Thomas Kuschel, based on smt.zsh-theme, based on dogenpunk by Matthew Nelson.
|
||||
|
||||
MODE_INDICATOR="%{$fg_bold[red]%}❮%{$reset_color%}%{$fg[red]%}❮❮%{$reset_color%}"
|
||||
local return_status="%{$fg[red]%}%(?..%?⏎)%{$reset_color%} "
|
||||
|
||||
@@ -34,7 +34,7 @@ ZSH_THEME_GIT_TIME_SINCE_COMMIT_NEUTRAL="%{$fg[cyan]%}"
|
||||
# use a neutral color, otherwise colors will vary according to time.
|
||||
function git_time_since_commit() {
|
||||
local COLOR MINUTES HOURS DAYS SUB_HOURS SUB_MINUTES
|
||||
local last_commit seconds_since_last_commit
|
||||
local last_commit now seconds_since_last_commit
|
||||
|
||||
# Only proceed if there is actually a commit
|
||||
if ! last_commit=$(command git -c log.showSignature=false log --pretty=format:'%at' -1 2>/dev/null); then
|
||||
@@ -43,7 +43,8 @@ function git_time_since_commit() {
|
||||
fi
|
||||
|
||||
# Totals
|
||||
seconds_since_last_commit=$(( $(date +%s) - last_commit ))
|
||||
now=$(date +%s)
|
||||
seconds_since_last_commit=$(( now - last_commit ))
|
||||
MINUTES=$(( seconds_since_last_commit / 60 ))
|
||||
HOURS=$(( MINUTES / 60 ))
|
||||
|
||||
@@ -74,6 +75,6 @@ function git_time_since_commit() {
|
||||
}
|
||||
|
||||
PROMPT='
|
||||
%(#.$fg[red].$fg[cyan])%(#.√@.)%m%{$reset_color%} 福 %{$fg[cyan]%}%~ %{$reset_color%}$(git_prompt_short_sha)$(git_prompt_info)
|
||||
%{$fg[red]%}%!%{$reset_color%} $(prompt_char) ⫸ '
|
||||
%{$fg[cyan]%}%m%{$reset_color%} 福 %{$fg[cyan]%}%~ %{$reset_color%}$(git_prompt_short_sha)$(git_prompt_info)
|
||||
%{$fg[red]%}%!%{$reset_color%} $(prompt_char) ❯ '
|
||||
RPROMPT='${return_status}$(git_time_since_commit)$(git_prompt_status)%{$reset_color%}'
|
||||
|
||||
Reference in New Issue
Block a user