class: middle, center # `:e vim-tmux-talk.md` --- ### Florenz? .left[data:image/s3,"s3://crabby-images/a58ae/a58ae387302542bcd42687691f18148c4f175d00" alt="@track02"] * Florenz Heldermann * Frontend Developer * bei [hmmh.de](http://hmmh.de) * bei [flore.nz](http://flore.nz) * Twitter: [@track02](http://twitter.com/track02) ??? Sehr nett dass ihr nicht den Apple Livestream guckt -- * Podcast: [Gefährliches Halbwissen](http://halbwissen.co) --- background-image: url(images/retro-80s.jpg) class: middle, center, cover, bg-head-white # Vim, Tmux, Ftw --- .image-centered[data:image/s3,"s3://crabby-images/41b51/41b5154cf0540e7eeb5428eff7c183e5ab6e8ca2" alt="@iamdevloper"] --- background-image: url(images/retro-80s.jpg) class: middle, center, cover, bg-head-white ## Oder: "Oh nein, jetzt hat sich Vim geöffnet, wie schliesse ich den Mist denn jetzt wieder?jjkk:wq" ??? Vortrag ist Englisch!!! Wer ist Entwickler? Apple Livestream Wer kennt Vim? Wer nutzt vim? Wer hasst vim? --- .image-centered[data:image/s3,"s3://crabby-images/6cf32/6cf32e170af54ddc7b31eb2d8581e4fad0bebd6d" alt="@iamdevloper"] --- .image-centered[data:image/s3,"s3://crabby-images/80e11/80e111c2d6b22370721df92af43bdf91fb052fb4" alt="Phase 5"] --- .image-centered[data:image/s3,"s3://crabby-images/5ef39/5ef39711ab243789d38e716b560275af5d63a901" alt="Frontpage"] --- .image-centered[data:image/s3,"s3://crabby-images/5a610/5a610444eb18a5ad2daf5e279e3dc57d95802ac7" alt="Dreamweaver"] --- .image-centered[data:image/s3,"s3://crabby-images/ade76/ade762f0fc857e82df23ca6987b3e191c64ab532" alt="sublime text 2"] --- .image-centered[data:image/s3,"s3://crabby-images/0511b/0511bd9bf5c49d3098f6872a3e70067bfe2a1754" alt="VIM"] --- .image-centered[data:image/s3,"s3://crabby-images/bc6e8/bc6e8e1cea2de94b7ed9140fa25c57c8fa17e239" alt="Vim Basic"] --- .image-centered[data:image/s3,"s3://crabby-images/fc1df/fc1df2566d617dd2da550eeaca07f3c16a1cf540" alt="Vim Basic"] --- ### What is Vim? > Vim is a highly configurable text editor built to enable efficient text editing. It is an improved version of the vi editor distributed with most UNIX systems. > —
vim.org
-- * Modal editor * Based on vi * *Vi* fork by Bram Moolenaar * First release in 1991 as **V**i **Im**itation for Amiga systems * Since 1993: **V**i **Im**proved * Usable in the command line and standalone (gVim) --- ### Why? * Available almost everywhere * Preinstalled on almost every *nix operating systems * Heavy focus on keyboard input -- * Sorry Windows, try gVim or [CMDer](http://cmder.net/) --- class: middle, center # No, seriously... Why? --- class: middle, center, cover, bg-head-white background-image: url(images/tennis.gif) # Hint --- .image-centered[data:image/s3,"s3://crabby-images/0339a/0339a9c948c88ee2af486b117db74de16777ff7e" alt="Tennisarm"] ??? Schmerzen im Ellenbogen "Kannst ja Linkshaender werden" --- class: middle, center # Learning Curve --- .image-centered[data:image/s3,"s3://crabby-images/e62f2/e62f2177d082f3ca0f256e7ce23a2b8dcda7f95c" alt="Quelle: https://pascalprecht.github.io/2014/03/18/why-i-use-vim/"] .figcaption[Source: [http://pascalprecht.github.io](https://pascalprecht.github.io/2014/03/18/why-i-use-vim/)] ??? Eine Wand Irgendwann wird es ploetzlich gut --- ### Learning Curve > Vim isn't an editor designed to hold its users' hands. It is a tool, the use of which must be learned.
> —
actual quote from
vim.org
-- * Modal behaviour -- * Shortcuts -- * Compositions -- * Even more shortcuts -- * Plugins -- * Did I mention shortcuts? --- class: middle, center # The ultimative ## "Shit, somehow I entered vim - WTF, no - I just want to leave - $#@@% this S$@t" # Survival Guide --- ### Survival Guide / Cheatsheet * Press `i` to insert text * Hit `Esc` after you're done with inserting * Type `:w` to save your file * Finally press `:q` to quit vim forever --- class: middle, center # type `vimtutor` --- .image-centered[data:image/s3,"s3://crabby-images/d440c/d440c00cd0e747c54962a10612a4426954fe8f61" alt="Vimtutor"] .figcaption[Vimtutor: Interactive Tutorial in vim] --- ### Vim Modes Vim has different modes (or function layers) for different work ??? Modal Editor -- * **Insert:** Insert text * **Normal:** Magic, Dragons and stuff * **Visual:** Mark and highlight text * **Command:** Commands -- * **Ex:** ???? --- class: middle, center # Insert Mode --- .image-centered[data:image/s3,"s3://crabby-images/15181/151818d762b0d36465f4f00237ac47525b57ac20" alt="Troy McClure"] --- class: middle, center # `I` `i` `a` `O` `o` `A` --- ### Insert Mode * `i` - insert * `I` - insert at beginning of current line * `a` - insert after word * `O` - insert above current line * `o` - insert below current line * `A` - insert at end of current line * Depends on cursor position --- class: middle, center # `:help inserting` --- class: middle, center # TL;DR --- ### How to use insert mode: * Step 1: Insert text --- ### How to use insert mode: * Step 1: Insert text * Step 2: GTFO --- class: middle, center # Normal Mode --- class: middle, center # Most of the time you are *editing* text, not *inserting* --- class: middle, center # *Edit*or. --- class: middle, center # Not *Insert*or. --- background-image: url(images/suprise.gif) class: cover --- class: middle, center # TL;DR --- .image-centered[data:image/s3,"s3://crabby-images/7b021/7b0214e39e7e230cb39e394fe44a5a494a411f44" alt=""] --- .image-centered[data:image/s3,"s3://crabby-images/f60bc/f60bc65ce3c2ab61452b6fb6d8b0c3dbb4ae05d4" alt=""] --- .image-centered[data:image/s3,"s3://crabby-images/3380d/3380dc2bc8eb4445622844a6959b739a7531f5a8" alt=""] --- .image-centered[data:image/s3,"s3://crabby-images/855fd/855fd553749d7a0b8c87b920c32ab5a5122d6a8b" alt=""] --- class: middle, center # Motions --- class: middle, center # Say goodbye to some friends --- class: middle, center # Mouse? --- class: middle, center
--- class: middle, center # Arrow Keys? --- class: middle, center .image-centered[data:image/s3,"s3://crabby-images/2408f/2408f652a2fbebd0a086203a6d117b457f67e4e5" alt=""] --- class: middle, center # hjkl --- class: middle, center .image-centered[data:image/s3,"s3://crabby-images/9d1c4/9d1c48951bb6a4aedc9df967f7d87cf668006617" alt=""] .figcaption[Lear Sieger ADM-3A(1974) Quelle:[Wikipedia](https://en.wikipedia.org/wiki/ADM-3A)] --- class: middle, center # Stay on the Home Row --- ### Motions * `h` `j` `k` `l` : Arrow keys * `gg` `G`: Top or bottom of document * `H` `M` `L`: Top, middle or bottom of current screen * `0` `_` `$`: Beginning, first non-blank character, end of current line * `w`: First letter of next word * `e`: Last letter of next word * `b`: First letter of previous word * `f{char}` `t{char}`: Find next occurrence of letter -- * And many more --- class: middle, center #`:help cursor-motions` --- ### Commands * `y`/ `yy` - Yank / Yank line
(*yank* means *copy*) * `d` / `dd` - Delete / Delete line
(similar to *cut*) * `p` - Paste * `c` - Change --- .image-centered[data:image/s3,"s3://crabby-images/4ddba/4ddba4d23c1bccf9d418cad9e31e8c07d9d5c62f" alt="Quelle:http://www.viemu.com/vi-vim-cheat-sheet.gi"] --- class: middle, center # Compositions --- class: middle, center # `daw` -- ## Delete A Word ??? Command + Motion / Textobject --- class: middle, center # Text Objects --- ### Text Objects * `w` - Word * `s` - Sentence * `p` - Paragraph * `t` - Tag --- ### Motions * `a` - Around / All * `i` - In * `t` - 'til * `f` - Find forward * `F` - Find backward --- ### Text Objects * `aw` - Around Word * `iw` - Inner Word * `as` - Around Sentence * `is` - Inner Sentence * `ap` - Around Paragraph * `ip` - Inner Paragraph * `at` - Around Tag * `it` - Inner Tag --- class: middle, center
--- class: middle, center # [COMMAND] [MOTION or TEXT OBJECT] --- class: middle, center # `daw` -- ## Delete a word --- class: middle, center # `cl` -- ## Change letter --- class: middle, center # `y$` -- ## Copy till end of line --- class: middle, center # `di"` -- ## Delete in "" --- class: middle, center # `gUe` -- ## Go uppercase to the end of the current word --- class: middle, center # `d2fn` -- ## Delete till you encounter a second time the letter n --- class: middle, center # `2yy10p` -- ## Yank 2 lines, paste it 10 times --- class: middle, center # `.` -- ## Repeat the last command --- background-image: url(images/hanks-typing.gif) class: cover --- class: middle, center # Muscle Memory! --- class: middle, center # Repeat. Repeat. Repeat. ## Eventually you stop thinking about it. ## Then repeat again --- class: middle, center # type `vimtutor` --- .image-centered[data:image/s3,"s3://crabby-images/062e4/062e4d0e65a8c2811cd4515651ad3de43eff09e5" alt=""] ---
--- background-image: url(images/cool-typing.gif) class: cover --- class: middle, center # Macros --- ### Record Macros 1. `q{Register}` * 2. (command composition) 3. `q`
* A register can be any letter, number or symbol. Register are a huge thing in vim. Right now, see it as clipboard manager.
--- ### Play Macros # `@{Register}` --- class: middle, center
.figcaption[Saving a macro in register `r`, play it with `@r`, repeat with `@@`] --- class: middle, center, cover, bg-head-white background-image: url(images/urkel.gif) # But ... I have an IDE! Why on earth should I use this? --- class: middle, center # Plugin-a-palooza --- ### Plugin Manager * Basically you don't need a plugin manager. * Just drop any plugin into your `.vim/plugin/` folder. * Plugin managers have the advantage of easy installation, update and configuration. -- * **Recommendations:** * [Vim-Plug](https://github.com/junegunn/vim-plug), [Vundle](https://github.com/VundleVim/Vundle.vim) or [Pathogen](https://github.com/tpope/vim-pathogen) * You can find many vim plugins at [VimAwesome.com](http://vimawesome.com) --- .image-centered[data:image/s3,"s3://crabby-images/39a12/39a121569254fa08a392531843eb253b2005a33f" alt=""] .figcaption[Example installation with vim-plug. Type `:plugInstall`
Gif Source: https://github.com/junegunn/vim-plug] --- class: middle, center # File Navigaton --- class: middle, center # NERDtree --- .image-centered[data:image/s3,"s3://crabby-images/7a973/7a973d2d956a52f0401d232034870849ad02aaaf" alt=""] .figcaption[https://github.com/scrooloose/nerdtree] --- ### NERDTree * Sidedrawer style * Beginner friendly * Similar to *Sublime Text*, *Atom*, *Visual Studio Code* etc * https://blog.mozhu.info/vimmers-you-dont-need-nerdtree-18f627b561c3 --- class: middle, center # netrw ## the built-in solution --- .image-centered[data:image/s3,"s3://crabby-images/896a3/896a35ca6b52ac2f6fb90b66ed91dfd135a05ef1" alt=""] --- ### netrw * In VIM there are many ways for file navigation
e.g. the native netrw `:Explore` * SSH support * Unintuitive for beginners * Buggy * Vim-Vinegar: https://github.com/tpope/vim-vinegar --- class: middle, center # Syntastic ## https://github.com/scrooloose/syntastic ??? code linter --- .image-centered[data:image/s3,"s3://crabby-images/9707e/9707ec06fba01b15bd749584879c2734b5c71bda" alt="Quelle:https://github.com/scrooloose/syntastic"] .figcaption[Additional read: http://usevim.com/2016/03/07/linting/] --- class: middle, center # Gundo ## Undo Management ## https://github.com/sjl/gundo.vim --- ### Gundo * Vim has a built-in `:earlier` command. * e.g. `:earlier 5min` / `:earlier 24h` * Gundo is a graphical interface for `:earlier` --- class: middle, center
.figcaption[Starting Gundo with `:GundoToggle`] --- class: middle, center # Goyo ## Distraction-free writing --- class: middle, center
.figcaption[Loving iA Writer? Type `:Goyo`. Stay focused.
https://github.com/junegunn/goyo.vim] --- class: middle, center # Vim Fugitive ## A git wrapper for vim --- ### Vim Fugitive * https://github.com/tpope/vim-fugitive * Powerful git wrapper * Add / remove files within vim * `:Gstatus` - Show status, add / remove files with `-` * `:Gdiff` - Diff Viewer * `:Gcommit` - I guess you can imagine * Many many more --- class: middle, center
--- class: middle, center .image-centered[data:image/s3,"s3://crabby-images/5161f/5161f64a0234bd29c8fc31eb8e4a346edc40dac7" alt=""] .figcaption[`:Gblame`] --- class: middle, center # Tmux --- class: middle, center .image-centered[data:image/s3,"s3://crabby-images/53b80/53b80188237b86c736d4d26eb8322f3439c711c1" alt=""] --- ### Tmux * **T**erminal**mu**ltiple**x**er * Allows to run several programms and scripts in one terminal window * Quickly change working enviroments and projects * Split sessions in *windows* and *panes* * https://tmux.github.io/ --- class: middle, center # Default prefix: `CTRL-B` --- class: middle, center # Better prefix: `CTRL-A` ## in your tmux.conf: `set-option -g prefix C-a` --- class: middle, center .image-centered[data:image/s3,"s3://crabby-images/4476d/4476da0219bfedf12d02e81b86dc6bfd489d0aed" alt=""] --- class: middle, center # New session ## `tmux new -s
` --- .image-centered[data:image/s3,"s3://crabby-images/79efc/79efcf34e9a037a2f6fa618cc3bc01b37506a2d1" alt="New Tmux session"] --- class: middle, center # Split window horizontal ## `
"` --- .image-centered[data:image/s3,"s3://crabby-images/caedc/caedc2e5f9f6755f42ed89d4406c130e83800755" alt=""] --- class: middle, center # Split window vertical ## `
%` --- .image-centered[data:image/s3,"s3://crabby-images/af182/af182d1960ac0d7f7708935243b9dc2b6bc7b4e9" alt=""] --- .image-centered[data:image/s3,"s3://crabby-images/489d7/489d7bad1434bf7b4c81309c958fd7c096d769bc" alt=""] --- .image-centered[data:image/s3,"s3://crabby-images/67647/67647ff32205289badbd33d0dca8e6fea5951cba" alt=""] --- .image-centered[data:image/s3,"s3://crabby-images/f6025/f6025c476988756adb6aafbdd07fac8625caedec" alt=""] --- .image-centered[data:image/s3,"s3://crabby-images/2e210/2e210ae6e6a107151cfc216b8dc401097da21f39" alt=""] --- class: middle, center # Switch between sessions ## `
s` --- class: middle, center # Detach tmux ... ## `
d` --- class: middle, center # ... and attach it again ## `tmux a` --- class: middle, center # Vim + Tmux = Awesome --- class: middle, center # There are so many possibilities. ## I could talk for hours. --- background-image: url(images/borinmg.gif) class: cover --- class: middle, center # ... but I won't --- class: middle, center # FZF ## https://github.com/junegunn/fz --- .image-centered[data:image/s3,"s3://crabby-images/4a961/4a9617ae5a4c01297b43a9474ff96055efb1bae6" alt=""] --- ### FZF * Fuzzy search is awesome * Alfred, Spotlight, Sublime Text, etc * There are a lot of good solutions for a vim fuzzy search
e.g.: Unite or CTRL-P * Requires a lot of configuration * Can be very slow (depends on project size) --- class: middle, center # FZF is blazingly fast --- ### FZF & VIM * You can configure fzf with your own shortcuts * Or just use the fzf.vim wrapper * https://github.com/junegunn/fzf.vim --- class: middle, center # `:Files` --- class: middle, center # `:Buffers` --- class: middle, center # `:Commits` --- class: middle, center # `:Ag` --- class: middle, center # `:History` --- ### Commands * `:Files` - Search in all project files * `:GitFiles` - Similar, but respects *.gitignore* * `:Buffers` - Search in all open buffers * `:Commits` - Search in all commits * `:BCommits` - Search in all commits of a buffer * `:History` - Search in recent files * `:History:` - Search in recent commands * `:History/` - Search in recent file searches * `:Ag` - Search a pattern in project
(*Ag* is a very fast *grep* alternative) * `:Colors` - Search and switch a color scheme * And more: https://github.com/junegunn/fzf.vim#commands --- class: middle, center # Dotfiles --- ### Dotfiles * Make your own *.vimrc*, *.tmux.conf*, etc * Steal configuration from other people * Share! * https://github.com/heroheman/dotfiles ??? understand what it does --- class: middle, center # Questions? --- ### Notes Heavy Inspiration from two talks about vim: * Nick Nisi: [vim + tmux](https://www.youtube.com/watch?v=5r6yzFEXajQ) * Jorge Morante: [Unleash your Vim-Fu](https://vimeo.com/156750085) You can find this talk later at: > http://heroheman.github.io/slides/index.html or > http://presentedby.flore.nz Feel free to write me on twitter: [@track02](http://twitter.com/track02)