Skip to content

🍴 Fork of Denys Dovhan's Dotfiles

Notifications You must be signed in to change notification settings

developerkevin/dotfiles

Β 
Β 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Denys Dovhan’s dotfiles

Spaceship with Hyper and One Dark

There are tons of useful things in here:

  • The usefulness of β€œOh My ZSH!” is already built–in.
  • πŸš€β­οΈ Spaceships as a prompt.
  • 🐟 Fish-like autosuggestions.
  • Syntax highlighting of commands while they are typed.
  • Automatically closing and deleting of quotes and brackets when you type them.
  • Browser-like substring search for history.
  • zgen for dependency management.
  • Useful aliases.
  • Git config, global .gitignore file and aliases.
  • Dotfiles synchronization (sync.py) with backup.
  • Restoring old dotfiles (restore.py) from backup.
  • A lot of useful bins.
  • update script for updating dotfiles, npm, brew, gems, etc.

Missing feature? 🍴 Fork this repo and make it better!

Installation

Dotfiles are installed by running one of the following commands in your terminal, just copy one of the following commands and execute in the terminal:

Tell Git who you are using these commands:

git config -f ~/.gitlocal user.email "[email protected]"
git config -f ~/.gitlocal user.name "Name Lastname"

Clone dotfiles repo:

# Clone dotfiles repo
git clone https://github.com/denysdovhan/dotfiles.git $HOME/.dotfiles

# Go to the dotfiles directory
cd $HOME/.dotfiles

# Install dotfiles
./install

Updating

Use single command to get latest updates:

update

This command will update dotfiles, their dependencies, brew or apt-get packages, global npm dependencies, gems, apm plugins.

Under the hood

Note: You may put your custom settings into ~/.zshlocal.

Projects tree

I suggest you to organize project folder as follows:

~/Projects
β”œβ”€β”€ Forks       # for GitHub fork
β”œβ”€β”€ Job         # for job projects
β”œβ”€β”€ Playground  # for short-term experiments
└── Repos       # for long-term projects

Aliases

Aliases are gonna make your work fast and enjoyable. See code in $DOTFILES/lib/aliases.zsh. Here is what's included:

  • Aliases from Oh-My-Zsh. See Oh-My-Zsh Cheatsheet for more.
  • Easier navigation
    • .. β†’ cd ..
    • ... β†’ cd ../..
    • .... β†’ cd ../../..
    • ..... β†’ cd ../../../..
    • ~ β†’ cd ~
    • - β†’ cd -
  • Folders shortcuts
    • dl β†’ cd ~/Downloads
    • dt β†’ cd ~/Desktop
    • pj β†’ cd ~/Projects
    • pjr β†’ cd ~/Projects/_Repos
    • pjf β†’ cd ~/Projects/_Forks
    • pl β†’ cd ~/Projects/_Playground/
  • Commands Shortcuts
    • e β†’ $EDITOR
    • +x β†’ chmod +x
    • x+ β†’ chmod +x
    • ll β†’ ls -alF
    • la β†’ ls -A
    • l β†’ ls -CF
  • Open
    • open <FILE> β€” open file from terminal.
    • o <FILE> β€” open file from terminal.
    • oo β€” open current folder.
  • Misc
    • update β€” get updates (Runs $DOTFILES/scripts/update.zsh).
    • dotfiles β€” jump quickly into dotfiles folder.
    • myip β€” my local IP address.
    • password β€” generate random password, copies it into clipboard and outputs it to terminal.
    • path β€” print $PATH in readable view.
    • getpage β€” download web page with all assets.
    • get β€” download file with original filename.

Oh-My-Zsh plugins

These OMZ plugins are included:

  • git β€” git aliases and functions.
  • npm β€” provides completion as well as adding many useful aliases.
  • yarn β€” the same as for npm, but for yarn
  • nvm β€” auto-sourcing nvm.
  • sudo β€” [Esc] [Esc] to re-run previous command with sudo.
  • ssh-agent β€” automatically starts ssh-agent to set up and load whichever credentials you want for ssh connections.
  • gpg-agent β€” enables gpg-agent if it is not running.
  • More are listed in .zshrc (it's hard to keep the list updated).

Bin

Dotfiles also include some functions that will make your life easier. See code in bin/.

  • emptytrash β€” empty the Trash on all mounted volumes and the main HDD.
  • git-cleanup β€” removes old Git branches and does other cleanup.
  • git-fork β€” add remote upsteam.
  • git-upstream β€” sync branch with upstream.
  • gz β€” get gzipped file size
  • n β€” runs given command using binary in node_modules/.bin of the current project.
  • nyan β€” print nyan cat.
  • server β€” start an HTTP server from a directory.

Git

Note: Add your git user data and custom settings to ~/.gitlocal.

Configuration

  • UI color is auto.
  • Diff colors are:
    • white bold for meta information;
    • cyan bold for frag;
    • red bold for old lines;
    • green bold for new lines.
  • Default editor is Vim instead of Vi.
  • push.default set as current.
  • Automatic replacement git://github.com/, gh:, github: addresses as [email protected]: for GitHub.
  • Automatic replacement git://gist.github.com/, gst:, gist: addresses as [email protected]: for Gists.
  • User custom settings gets from a ~/.gitlocal file.

Git Aliases

  • git a β†’ git add β€” patch mode for specified files.
  • git ua β†’ git reset HEAD β€” unstage files.
  • git b β†’ git branch β€” list, create, or delete branches.
  • git c β†’ git commit β€” record changes to the repository.
  • git co β†’ git checkout β€” checkout a branch or paths to the working tree.
  • git ap β†’ git add -p β€” add file contents to the index.
  • git ca β†’ git commit -a β€” commit with automatically stage files that have been modified and deleted.
  • git cm β†’ git commit -m β€” commit with commit message.
  • git cam β†’ git commit -am β€” add all files and commit with message.
  • git s β†’ git status -sb β€” short status with current branch.
  • git master β€” go to master branch and pull from remote.
  • git develop β€” go to develop branch and pull from remote.
  • git git β€” do not complain about git git.
  • git l β€” commits log with pretty single line format.
  • git ll β€” log with list of changed files for each commit.
  • git ignore β€” ignore files: append file to .gitignore.
  • git this β€” initialize, add all files and commit.
  • git amend β€” amend last commit.
  • git redo β€” amend last commit with its original message.
  • git undo β†’ reset --mixed HEAD^ β€” reset index changes, but not the working tree.
  • git discard β†’ checkout -- β€” discard changes.
  • git contrib β€” list of contributors and how many commits each person has.
  • git today β€” see how many lines of code you have written today.
  • git stat β€” how many lines of code in repo.
  • git sync β€” pull and push changes from/to remote.
  • git-root β€” go to repo root.
  • git-cleanup [--force] β€” removes old Git branches.
  • git-fork <original-author> β€” add remote upstream.
  • git-upstream [branch] β€” sync branch with upstream (as default master).

Resources

Resources that I used to make these dotfiles better:

License

MIT Β© Denys Dovhan

Packages

No packages published

Languages

  • Shell 84.8%
  • Ruby 9.1%
  • Vim Script 6.1%