SlideShare a Scribd company logo
1 of 75
Download to read offline
VIM for (PHP)
Programmers
        Andrei Zmievski
         Outspark, Inc

ZendCon ⁓ September 17, 2008
help

~   learn how to get help effectively
~   :help is your friend
~   use CTRL-V before a CTRL sequence command
~   use i_ and v_ prefixes to get help for CTRL
    sequences in Insert and Visual modes
~   use CTRL-] (jump to tag) and CTRL-T (go back)
    in help window
intro
~   how well do you know vim’s language?
~   what is the alphabet?
~   look at your keyboard
~   can you name what every key does?
~   modes - what are they?
~   how many do you know?
~   how many do you use?
intro
if you don’t like the language, change it
example: how do you quit vim quickly?
  ZZ (exit with saving)
  ZQ (exit without save)
  or
  :nmap ,w :x<CR>
  :nmap ,q :q!<CR>
tip: set showcmd to see partial commands as
you type them
where am i?

How do you tell where you are?
~   simple - CTRL-G
~   detailed - gCTRL-G
~   do yourself a favor and set ruler
~   shows line, column, and percentage in status line
~   or configure it however you want with
    ‘rulerformat’
moving

~   do you us h/j/k/l for moving?
~   or are you stuck in GUIarrowy world?
~   if you are, re-learn
~   save yourself countless miles of movement
    between home row and arrows
moving

How do you move to:
~   start/end of buffer? gg and G
~   line n? nG or ngg
~   n% into the file? n%
~   the first non-blank character in the line? ^
~   first non-blank character on next line? <CR>
~   first non-blank character on previous line? -
marks
~   we can bookmark locations in the buffer
~   m<letter> sets mark named <letter> at
    current location
~   `<letter> jumps precisely to that mark
~   ‘<letter> jumps to the line with the mark
~   lowercase letter: mark is local to the buffer
~   uppercase letter: mark is global, your buffer will
    be switched to the file with the mark
~   :marks shows you your current marks
marks

~   marks are very handy for changing text
~   set a mark (let’s say ma)
~   then you can do:
    ~   c`a - change text from cursor to mark a
    ~   d`a - delete text from cursor to mark a
    ~   =’a - reformat lines from current one to the one
        with mark a
marks
~   let’s say you jump somewhere
~   how do you go back?
~   `` moves you between the last two locations
~   you can set ` (the context mark) explicitly:
    ~   m`, jump elsewhere, then come back with ``
    tip: CTRL-O and CTRL-I move between
    positions in the full jump history, but can’t be
    used as motions
    ‘. and `. - jump to the line or exact location of
    the last modification
insert


~   gi - incredibly handy
~   goes to Insert mode where you left it last time
~   scenario: edit something, exit Insert, go look at
    something else, then gi back to restart editing
insert
Some more goodies:
~   CTRL-Y and CTRL-E (avoid work if you can)
    ~   inserts chars from above or below the cursor
~   CTRL-A (oops, i want to do that again)
    ~   inserts previously inserted text
~   CTRL-R=<expr> (built-in calculator)
    ~   inserts anything vim can calculate
~   CTRL-T and CTRL-D (tab and de-tab)
    ~   inserts or deletes one shiftwidth of indent at the start of
        the line
delete


set your <Backspace> free
:set backspace=start,indent,eol
lets you backspace past the start of edit, auto-
indenting, and even start of the line
search

~   searching is essential
~   movement and information
~   how do you search?
~   f/F/t/T anyone?
~   how about * and #?
search
Search within the line:
~   f/F<char> jumps to the first <char> to the
    right/left and places cursor on it
~   t/T<char> jumps does the same, but stops
    one character short of it
~   df; - delete text from cursor to the first ; to
    the right
~   cT$ - change text from cursor up to the first
    $ to the left
search
~   often you want to find other instances of word
    under the cursor
    ~   */# - find next/previous instance of whole word
    ~   g*/g# - find next/previous instance of partial word
~   or find lines with a certain word:
    ~   [I and ]I - list lines with word under the cursor
    ~   more convenient to use a mapping to jump to a line:
         :map ,f [I:let nr = input(quot;Which one: quot;)<Bar>exe
         quot;normal quot; . nr .quot;[tquot;<CR>
search

~   of course, there’s always regexp search
~   /<pattern> - search forward for <pattern>
~   ?<pattern> - search backward for <pattern>
~   n repeats the last search
~   N repeats it in the opposite direction
~   vim regexp language is too sophisticated to be
    covered here
search

Control your search options
~   :set wrapscan - to make search wrap around
~   :set incsearch - incremental search, <Enter>
    accepts, <Esc> cancels
~   :set ignorecase - case-insensitive search, or use
    this within the pattern:
    ~   c - force case-insensitive search
    ~   C - force case-sensitive search
search

~   remember that every search/jump can be used
    as a motion argument
~   d/^# - delete everything up to the next
    comment
~   y/^class/;?function - copy everything from
    current point to the first function before the
    first class
replace
~   :[range]s/<pattern>/<replace>/{flags}
    is the substitute command
~   used mainly with range addresses
~   range addresses are very powerful (read the
    manual)
~   but who wants to count out lines and do
    something like :-23,’ts/foo/bar/
~   in reality you almost always use a couple of
    shortcuts and Visual mode for the rest
replace
~   useful range addresses:
    ~   % - equal to 1,$ (the entire file)
    ~   . - current line
    ~   /<pattern>/ or ?<pattern>? - line where
        <pattern> matches
~   :%s/foo/bar/   - replace first foo in each
    matching line with bar in the entire file
~   :.,/</body>/s,<br>,<br/>,gc        - fix br tags
    from current line until the one with </body> in
    it, asking for confirmation (c - ‘cautious’ mode)
replace


~   & - repeat last substitution on current line
~   :&& - repeat it with the flags that were used
~   g& - repeat substitution globally, with flags
text objects

~   better know what they are
~   since they are fantastically handy
~   can be used after an operator or in Visual mode
~   come in “inner” and “ambient” flavors
~   inner ones always select less text than ambient
    ones
text objects
~   aw, aW - ambient word or WORD (see docs)
~   iw, iW - inner word or WORD (see docs)
~   as, is - ambient or inner sentence
~   ap, ip - ambient or inner paragraph
~   a{, i{ - whole {..} block or text inside it
~   a(, i( - whole (..) block or just text inside it
~   a<, i< - whole <..> block or just text inside it
text objects
~   there are some cooler ones
~   a’, i’    - single-quoted string or just the text
    inside
~   a”, i”    - double-quoted string or just the text
    inside
    ~   note that these are smart about escaped quotes
        inside strings
~   at, it- whole tag block or just text inside
    (HTML and XML tags)
text objects

examples:
 das - delete the sentence, including whitespace after
 ci( - change text inside (..) block
 yat - copy the entire closest tag block the cursor is
 inside
 gUi’ - uppercase text inside the single-quoted string
 vip - select the paragraph in Visual mode, without
 whitespace after
copy/delete/paste
~   you should already know these
~   y - yank (copy), d - delete, p - paste after, P -
    paste before
~   ]p, ]P - paste after/before but adjust the
    indent
~   Useful mappings to paste and reformat/reindent
     :nnoremap <Esc>P        P'[v']=
     :nnoremap <Esc>p        p'[v']=
registers

~   registers: your multi-purpose clipboard
~   you use them without even knowing
~   every y or d command copies to a register
~   unnamed or named
~   “<char> before a copy/delete/paste specifies
    register named <char>
registers
~   copying to uppercase registers append to their
    contents
    ~   useful for picking out bits from the buffers and
        pasting as a chunk
~   “wyy - copy current line into register w
~   “WD - cut the rest of the line and append it to
    the contents of register W
~   “wp - paste the contents of register w
~   CTRL-Rw - insert the contents of register w (in
    Insert mode)
registers

~   you can record macros into registers
    ~   q<char> - start recording typed text into register
        <char>
    ~   next q stops recording
    ~   @<char> executes macro <char>
    ~   @@ repeats last executed macro
~   use :reg to see what’s in your registers
undo

~   original vi had only one level of undo
~   yikes!
~   vim has unlimited (limited only by memory)
~   set ‘undolevels’ to what you need (1000
    default)
undo

~   simple case: u - undo, CTRL-R - redo
~   vim 7 introduces branched undo
~   if you undo something, and make a change, a
    new branch is created
~   g-, g+ - go to older/newer text state (through
    branches)
undo

~   you can travel through time
    ~   :earlier Ns,m,h - go to text state as it was N
        seconds, minutes, hours ago
    ~   :later Ns,m,h - go to a later text state similarly
~   :earlier 10m   - go back 10 minutes, before I
    drank a can of Red Bull and made all these crazy
    changes. Whew.
visual mode
~   use it, it's much easier than remembering
    obscure range or motion commands
~   start selection with:
    ~   v - characterwise,
    ~   V - linewise
    ~   CTRL-V - blockwise
~   use any motion command to change selection
~   can execute any normal or : command on the
    selection
visual mode
~   Visual block mode is awesome
~   especially for table-like text
    tip: o switches cursor to the other corner,
    continue selection from there
~   Once you are in block mode:
    ~   I<text><Esc> - insert <text> before block on every
        line
    ~   A<text><Esc> - append <text> after block on every line
    ~   c<text><Esc> - change every line in block to <text>
    ~   r<char><Esc> - replace every character with <char>
abbreviations

~   Real-time string replacement
~   Expanded when a non-keyword character is
    typed
    ~   :ab tempalte template - fix misspellings
    ~   more complicated expansion:
    ~   :iab techo <?php echo ?><Left><Left><Left>
windows

~   learn how to manipulate windows
~   learn how to move between them
~   :new, :sp should be at your fingertips
~   CTRL-W commands - learn essential ones for
    resizing and moving between windows
tab pages

~   vim 7 supports tab pages
~   :tabe <file> to edit file in a new tab
~   :tabc to close
~   :tabn, :tabp (or gt, gT to switch)
~   probably want to map these for easier
    navigation (if gt, gT are too difficult)
completion
~   vim is very completion friendly
~   just use <Tab> on command line
    ~   for filenames, set ‘wildmenu’ and ‘wildmode’ (I
        like quot;list:longest,fullquot;)
    ~   :new ~/dev/fo<Tab> - complete filename
    ~   :help ‘comp<Tab> - complete option name
    ~   :re<Tab> - complete command
    ~   hit <Tab> again to cycle, CTRL-N for next match,
        CTRL-P for previous
completion

~   CTRL-X starts completion mode in Insert mode
~   follow with CTRL- combos (:help ins-
    completion)
~   i mostly use filename, identifier, and omni
    completion
~   when there are multiple matches, a nice
    completion windows pops up
completion
~   CTRL-X CTRL-F     to complete filenames
~   CTRL-X CTRL-N     to complete identifiers
~   hey, that’s so useful I’ll remap <Tab>

      “ Insert <Tab> or complete identifier
      “ if the cursor is after a keyword character
      function MyTabOrComplete()
          let col = col('.')-1
          if !col || getline('.')[col-1] !~ 'k'
               return quot;<tab>quot;
          else
               return quot;<C-N>quot;
          endif
      endfunction

      inoremap <Tab> <C-R>=MyTabOrComplete()<CR>
completion


~   omni completion is heuristics-based
~   guesses what you want to complete
~   specific to the file type you’re editing
~   more on it later
maps
~   maps for every mode and then some
~   tired of changing text inside quotes?
     :nmap X ciquot;
~   make vim more browser-like?
     :nmap <Space> <PageDown>
~   insert your email quickly?
     :imap ;EM me@mydomain.com
~   make <Backspace> act as <Delete> in Visual
    mode?
     :vmap <BS> x
options

~   vim has hundreds of options
~   learn to control the ones you need
~   :options lets you change options interactively
~   :options | resize is better (since there are
    so many)
sessions
~   a session keeps the views for all windows, plus
    the global settings
~   you can save a session and when you restore it
    later, the window layout looks the same.
~   :mksession <file> to write out session to a
    file
~   :source <file> to load session from a file
~   vim -S <file> to start editing a session
miscellaneous
~   gf - go to file under cursor (CTRL-W CTRL-F
    for new window)
~   :read in contents of file or process
    ~   :read foo.txt - read in foo.txt
    ~   :read !wc %:h - run wc on current file and insert
        result into the text
~   filter text: :%!sort, :%!grep, or use :! in visual
    mode
    ~   i like sorting lists like this: vip:!sort
miscellaneous

~   use command-line history
~   : and / followed by up/down arrows move
    through history
~   : and / followed by prefix and arrows restrict
    history to that prefix
~   q: and q/ for editable history (<Enter>
    executes, CTRL-C copies to command line)
miscellaneous
~   CTRL-A and CTRL-X to increment/decrement
    numbers under the cursor (hex and octal too)
~   ga   - what is this character under my cursor?
~   :set number to turn line numbers on
~   or use this to toggle line numbers:
     :nmap <silent> <F6> set number!<CR>
~   :set autowrite - stop vim asking if you want
    to write the file before leaving buffer
~   CTRL-E/CTRL-Y - scroll window down/up
    without moving cursor
miscellaneous
~   :set scroloff=N to start scrolling when
    cursor is N lines from the top/bottom edge
~   :set updatecount=50 to write swap file to
    disk after 50 keystrokes
~   :set showmatch matchtime=3 - when
    bracket is inserted, briefly jump to the matching
    one
~   in shell: fc invokes vim on last command, and
    runs it after vim exits (or fc N to edit
    command N in history)
~   vimdiff in shell (:help vimdiff)
miscellaneous


~   map CTRL-L to piece-wise copying of the line
    above the current one
     imap <C-L> @@@<ESC>hhkywjl?@@@<CR>P/@@@<CR>3s
customization
~   customize vim by placing files in you ~/.vim dir
~   filetype plugin on, filetype indent on
.vimrc - global settings
.vim/
	

 after/	

            	

 	

 - files that are loaded at the very end
	

 	

 ftplugin/
	

 	

 plugin/
	

 	

 syntax/
	

 	

 ...
	

 autoload/	

	

 - automatically loaded scripts
	

 colors/ 	

 	

 - custom color schemes
	

 doc/	

 	

 	

 - plugin documentation
	

 ftdetect/	

	

 - filetype detection scripts
	

 ftplugin/	

	

 - filetype plugins
	

 indent/	

 	

 - indent scripts
	

 plugin/	

 	

 - plugins
	

 syntax/	

 	

 - syntax scripts
php: linting
~   vim supports arbitrary build/lint commands
~   if we set 'makeprg' and 'errorformat'
    appropriately..
     :set makeprg=php -l %
     :set errorformat=%m in %f on line %l
~   now we just type :make (and <Enter> a couple
    of times)
~   cursor jumps to line with syntax error
php: match pairs
~   you should be familiar with % command (moves
    cursor to matching item)
~   used with (), {}, [], etc
~   but can also be used to jump between PHP and
    HTML tags
~   use matchit.vim plugin
~   but syntax/php.vim has bugs and typos in the
    matching rule
~   i provide my own
php: block objects
~   similar to vim's built-in objects
    ~   aP - PHP block including tags
    ~   iP - text inside PHP block
    examples:
    ~   vaP - select current PHP block (with tags)
    ~   ciP - change text inside current PHP block
    ~   yaP - copy entire PHP block (with tags)
~   provided in my .vim/ftplugin/php.vim file
php: syntax options
~   vim comes with a very capable syntax plugin for
    PHP
~   provides a number of options
    ~   let php_sql_query=1 to highlight SQL syntax in
        strings
    ~   let php_htmlInStrings=1 to highlight HTML in
        string
    ~   let php_noShortTags = 1 to disable short tags
    ~   let php_folding = 1 to enable folding for
        classes and functions
php: folding

~   learn to control folding
    ~   zo - open fold (if the cursor is on the fold line)
    ~   zc - close closest fold
    ~   zR - open all folds
    ~   zM - close all folds
    ~   zj - move to the start of the next fold
    ~   zk - move to the end of the previous fold
php: tags
~   for vim purposes, tags are PHP identifiers
    (classes, functions, constants)
~   you can quickly jump to the definition of each
    tag, if you have a tags file
~   install Exuberant Ctags
~   it can scan your scripts and output tags file,
    containing identifier info
~   currently does not support class membership
    info (outputs methods as functions)
~   have to apply a third-party patch to fix
php: tags

~   use mapping to re-build tags file after editing
     nmap <silent> <F4>
              :!ctags-ex -f ./tags
              --langmap=quot;php:+.incquot;
              -h quot;.php.incquot; -R --totals=yes
              --tag-relative=yes --PHP-kinds=+cf-v .<CR>

     set tags=./tags,tags

~   all PHP files in current directory and under it
    recursively will be scanned
php: tags
~   CTRL-] - jump to tag under cursor
~   CTRL-W CTRL-] - jump to tag in a new window
~   :tag <ident> - jump to an arbitrary tag
~   :tag /<regexp> - jump to or list tags matching
    <regexp>
~   if multiple matches - select one from a list
~   :tselect <ident> or /<regexp> - list tags instead
    of jumping
~   CTRL-T - return to where you were
~   See also taglist.vim plugin
php: completion

~   vim 7 introduces powerful heuristics-based
    omni completion
~   CTRL-X CTRL-O starts the completion (i map it
    to CTRL-F)
~   completes classes, variables, methods in a smart
    manner, based on context
php: completion

~   completes built-in functions too
~   function completion shows prototype preview
    ~   array_<CTRL-X><CTRL-O> shows list of array
        functions
    ~   select one from the list, and the prototype shows in
        a preview window
    ~   CTRL-W CTRL-Z to close preview window
php: completion

~   switches to HTML/CSS/Javascript completion
    outside PHP blocks
~   see more:
    ~   :help ins-completion
    ~   :help popupmenu-completion
    ~   :help popupmenu-keys
plugins

~   vim can be infinitely customized and expanded
    via plugins
~   there are thousands already written
~   installation is very easy, usually just drop them
    into .vim/plugin
~   read instructions first though
netrw
~   makes it possible to read, write, and browse remote
    directories and files
~   i usually use it over ssh connections via scp
~   need to run ssh-agent to avoid continuous prompts for
    passphrase
~   don't use passphrase-less keys!
~   once set up:
    ~   vim scp://hostname/path/to/file
    ~   :new scp://hostname/path/to/dir/
NERDTree


~   similar to netrw browser but looks more like a
    hierarchical explorer
~   does not support remote file operations
    ~   :nmap <silent> <F7> :NERDTreeToggle<CR>
taglist

~   provides an overview of the source code
~   provides quick access to classes, functions,
    constants
~   automatically updates window when switching
    buffers
~   can display prototype and scope of a tag
~   requires Exuberant Ctags
taglist
~   stick this in ~/.vim/after/plugin/general.vim
let Tlist_Ctags_Cmd = quot;/usr/local/bin/ctags-exquot;
let Tlist_Inc_Winwidth = 1
let Tlist_Exit_OnlyWindow = 1
let Tlist_File_Fold_Auto_Close = 1
let Tlist_Process_File_Always = 1
let Tlist_Enable_Fold_Column = 0
let tlist_php_settings = 'php;c:class;d:constant;f:function'
if exists('loaded_taglist')
    nmap <silent> <F8> :TlistToggle<CR>
endif
snippetsEmu
~   emulates some of the functionality of TextMate
    snippets
~   supports many languages, including PHP/HTML/
    CSS/Javascript
~   by default binds to <Tab> but that's annoying
~   need to remap the key after it's loaded
~   put this in ~/.vim/after/plugin/general.vim
      if exists('loaded_snippet')
          imap <C-B> <Plug>Jumper
      endif
      inoremap <Tab> <C-R>=MyTabOrComplete()<CR>
php documentor
~   inserts PHP Documentor blocks automatically
~   works in single or multi-line mode
~   doesn’t provide mappings by default
~   read documentation to set up default variables
    for copyright, package, etc
~   put this in ~/.vim/ftplugin/php.vim
inoremap <buffer> <C-P> <Esc>:call PhpDocSingle()<CR>i
nnoremap <buffer> <C-P> :call PhpDocSingle()<CR>
vnoremap <buffer> <C-P> :call PhpDocRange()<CR>
let g:pdv_cfg_Uses = 1
xdebug-ger

~   allows debugging with xdebug through DBGp
    protocol
~   fairly basic, but does the job
~   vim needs to be compiled with +python feature
~   see resources section for documentation links
vcscommand



~   provides interface to CVS/SVN
~   install it, then :help vcscommand
conclusion

~   vim rules
~   this has been only a partial glimpse
~   from my very subjective point of view
~   don’t be stuck in an editor rut
~   keep reading and trying things out
resources
~   vim tips: http://www.vim.org/tips/
~   vim scripts: http://www.vim.org/scripts/index.php
~   Exuberant Ctags: http://ctags.sourceforge.net
~   PHP patch for ctags: http://www.live-emotion.com/memo/index.php?
    plugin=attach&refer=%CA%AA%C3%D6&openfile=ctags-5.6j-php.zip
~   article on xdebug and vim: http://2bits.com/articles/using-vim-and-
    xdebug-dbgp-for-debugging-drupal-or-any-php-application.html
~   more cool plugins:
    ~   Surround: http://www.vim.org/scripts/script.php?script_id=1697
    ~   ShowMarks: http://www.vim.org/scripts/script.php?script_id=152
    ~   Vim Outliner: http://www.vim.org/scripts/script.php?script_id=517
    ~   Tetris: http://www.vim.org/scripts/script.php?script_id=172
quot;As with everything, best not to
  look too deeply into this.quot;
Thank You!


  http://outspark.com/

http://gravitonic.com/talks/

More Related Content

What's hot

Seismic Design of Buried Structures in PH and NZ
Seismic Design of Buried Structures in PH and NZSeismic Design of Buried Structures in PH and NZ
Seismic Design of Buried Structures in PH and NZLawrence Galvez
 
Course 102: Lecture 5: File Handling Internals
Course 102: Lecture 5: File Handling Internals Course 102: Lecture 5: File Handling Internals
Course 102: Lecture 5: File Handling Internals Ahmed El-Arabawy
 
BIOS basic input output system
BIOS basic input output systemBIOS basic input output system
BIOS basic input output systemVipul Buchade
 
Course 101: Lecture 5: Linux & GNU
Course 101: Lecture 5: Linux & GNU Course 101: Lecture 5: Linux & GNU
Course 101: Lecture 5: Linux & GNU Ahmed El-Arabawy
 
VI editor in unix
VI editor in unix VI editor in unix
VI editor in unix Ahmed Fayyaz
 
Embedded Systems: Lecture 11: Introduction to Git & GitHub (Part 2)
Embedded Systems: Lecture 11: Introduction to Git & GitHub (Part 2)Embedded Systems: Lecture 11: Introduction to Git & GitHub (Part 2)
Embedded Systems: Lecture 11: Introduction to Git & GitHub (Part 2)Ahmed El-Arabawy
 
Lecture 3 - Processors, Memory and I/O devices
Lecture 3 - Processors, Memory and I/O devicesLecture 3 - Processors, Memory and I/O devices
Lecture 3 - Processors, Memory and I/O devicesMd. Imran Hossain Showrov
 
Course 102: Lecture 2: Unwrapping Linux
Course 102: Lecture 2: Unwrapping Linux Course 102: Lecture 2: Unwrapping Linux
Course 102: Lecture 2: Unwrapping Linux Ahmed El-Arabawy
 
Behaviour and Analysis of Large Diameter Laterally Loaded Piles
Behaviour and Analysis of Large Diameter Laterally Loaded PilesBehaviour and Analysis of Large Diameter Laterally Loaded Piles
Behaviour and Analysis of Large Diameter Laterally Loaded PilesHenry Pik Yap Sia
 
How to recover password on a cisco 2950, 2960 switch
How to recover password on a cisco 2950, 2960 switchHow to recover password on a cisco 2950, 2960 switch
How to recover password on a cisco 2950, 2960 switchIT Tech
 
Foundation (2)
Foundation (2)Foundation (2)
Foundation (2)topukuet
 
Verilog-HDL Tutorial (14)
Verilog-HDL Tutorial (14)Verilog-HDL Tutorial (14)
Verilog-HDL Tutorial (14)Hiroki Nakahara
 
Complete Guide for Linux shell programming
Complete Guide for Linux shell programmingComplete Guide for Linux shell programming
Complete Guide for Linux shell programmingsudhir singh yadav
 
Partitioning a Hard Drive
Partitioning a Hard DrivePartitioning a Hard Drive
Partitioning a Hard DriveJamaica Olazo
 
BIOS__Power-On-Self-Test.pptx
BIOS__Power-On-Self-Test.pptxBIOS__Power-On-Self-Test.pptx
BIOS__Power-On-Self-Test.pptxSamiWhoo
 
Course 102: Lecture 6: Seeking Help
Course 102: Lecture 6: Seeking HelpCourse 102: Lecture 6: Seeking Help
Course 102: Lecture 6: Seeking HelpAhmed El-Arabawy
 
Vi Editor Cheat Sheet
Vi Editor Cheat SheetVi Editor Cheat Sheet
Vi Editor Cheat SheetLoiane Groner
 

What's hot (20)

Seismic Design of Buried Structures in PH and NZ
Seismic Design of Buried Structures in PH and NZSeismic Design of Buried Structures in PH and NZ
Seismic Design of Buried Structures in PH and NZ
 
Course 102: Lecture 5: File Handling Internals
Course 102: Lecture 5: File Handling Internals Course 102: Lecture 5: File Handling Internals
Course 102: Lecture 5: File Handling Internals
 
Bios
BiosBios
Bios
 
BIOS basic input output system
BIOS basic input output systemBIOS basic input output system
BIOS basic input output system
 
Course 101: Lecture 5: Linux & GNU
Course 101: Lecture 5: Linux & GNU Course 101: Lecture 5: Linux & GNU
Course 101: Lecture 5: Linux & GNU
 
VI editor in unix
VI editor in unix VI editor in unix
VI editor in unix
 
U-Boot - An universal bootloader
U-Boot - An universal bootloader U-Boot - An universal bootloader
U-Boot - An universal bootloader
 
Embedded Systems: Lecture 11: Introduction to Git & GitHub (Part 2)
Embedded Systems: Lecture 11: Introduction to Git & GitHub (Part 2)Embedded Systems: Lecture 11: Introduction to Git & GitHub (Part 2)
Embedded Systems: Lecture 11: Introduction to Git & GitHub (Part 2)
 
Lecture 3 - Processors, Memory and I/O devices
Lecture 3 - Processors, Memory and I/O devicesLecture 3 - Processors, Memory and I/O devices
Lecture 3 - Processors, Memory and I/O devices
 
Course 102: Lecture 2: Unwrapping Linux
Course 102: Lecture 2: Unwrapping Linux Course 102: Lecture 2: Unwrapping Linux
Course 102: Lecture 2: Unwrapping Linux
 
Behaviour and Analysis of Large Diameter Laterally Loaded Piles
Behaviour and Analysis of Large Diameter Laterally Loaded PilesBehaviour and Analysis of Large Diameter Laterally Loaded Piles
Behaviour and Analysis of Large Diameter Laterally Loaded Piles
 
How to recover password on a cisco 2950, 2960 switch
How to recover password on a cisco 2950, 2960 switchHow to recover password on a cisco 2950, 2960 switch
How to recover password on a cisco 2950, 2960 switch
 
Foundation (2)
Foundation (2)Foundation (2)
Foundation (2)
 
Verilog-HDL Tutorial (14)
Verilog-HDL Tutorial (14)Verilog-HDL Tutorial (14)
Verilog-HDL Tutorial (14)
 
Design notes for seismic design of building accordance to Eurocode 8
Design notes for seismic design of building accordance to Eurocode 8 Design notes for seismic design of building accordance to Eurocode 8
Design notes for seismic design of building accordance to Eurocode 8
 
Complete Guide for Linux shell programming
Complete Guide for Linux shell programmingComplete Guide for Linux shell programming
Complete Guide for Linux shell programming
 
Partitioning a Hard Drive
Partitioning a Hard DrivePartitioning a Hard Drive
Partitioning a Hard Drive
 
BIOS__Power-On-Self-Test.pptx
BIOS__Power-On-Self-Test.pptxBIOS__Power-On-Self-Test.pptx
BIOS__Power-On-Self-Test.pptx
 
Course 102: Lecture 6: Seeking Help
Course 102: Lecture 6: Seeking HelpCourse 102: Lecture 6: Seeking Help
Course 102: Lecture 6: Seeking Help
 
Vi Editor Cheat Sheet
Vi Editor Cheat SheetVi Editor Cheat Sheet
Vi Editor Cheat Sheet
 

Viewers also liked

Habits 2007
Habits 2007Habits 2007
Habits 2007Dang Tan
 
Code analysis tools (for PHP)
Code analysis tools (for PHP)Code analysis tools (for PHP)
Code analysis tools (for PHP)Karlen Kishmiryan
 
8080 8085 assembly language_programming manual programando
8080 8085 assembly  language_programming manual programando 8080 8085 assembly  language_programming manual programando
8080 8085 assembly language_programming manual programando Universidad de Tarapaca
 
10 SQL Tricks that You Didn't Think Were Possible
10 SQL Tricks that You Didn't Think Were Possible10 SQL Tricks that You Didn't Think Were Possible
10 SQL Tricks that You Didn't Think Were PossibleLukas Eder
 
Laravel Beginners Tutorial 1
Laravel Beginners Tutorial 1Laravel Beginners Tutorial 1
Laravel Beginners Tutorial 1Vikas Chauhan
 
Software Design Patterns in Laravel by Phill Sparks
Software Design Patterns in Laravel by Phill SparksSoftware Design Patterns in Laravel by Phill Sparks
Software Design Patterns in Laravel by Phill SparksPhill Sparks
 
8085 Paper Presentation slides,ppt,microprocessor 8085 ,guide, instruction set
8085 Paper Presentation slides,ppt,microprocessor 8085 ,guide, instruction set8085 Paper Presentation slides,ppt,microprocessor 8085 ,guide, instruction set
8085 Paper Presentation slides,ppt,microprocessor 8085 ,guide, instruction setSaumitra Rukmangad
 
Assembly Language Programming Of 8085
Assembly Language Programming Of 8085Assembly Language Programming Of 8085
Assembly Language Programming Of 8085techbed
 
Visual Design with Data
Visual Design with DataVisual Design with Data
Visual Design with DataSeth Familian
 

Viewers also liked (11)

Habits 2007
Habits 2007Habits 2007
Habits 2007
 
Code analysis tools (for PHP)
Code analysis tools (for PHP)Code analysis tools (for PHP)
Code analysis tools (for PHP)
 
8080 8085 assembly language_programming manual programando
8080 8085 assembly  language_programming manual programando 8080 8085 assembly  language_programming manual programando
8080 8085 assembly language_programming manual programando
 
Vim Rocks!
Vim Rocks!Vim Rocks!
Vim Rocks!
 
10 SQL Tricks that You Didn't Think Were Possible
10 SQL Tricks that You Didn't Think Were Possible10 SQL Tricks that You Didn't Think Were Possible
10 SQL Tricks that You Didn't Think Were Possible
 
Laravel Beginners Tutorial 1
Laravel Beginners Tutorial 1Laravel Beginners Tutorial 1
Laravel Beginners Tutorial 1
 
Software Design Patterns in Laravel by Phill Sparks
Software Design Patterns in Laravel by Phill SparksSoftware Design Patterns in Laravel by Phill Sparks
Software Design Patterns in Laravel by Phill Sparks
 
List of 8085 programs
List of 8085 programsList of 8085 programs
List of 8085 programs
 
8085 Paper Presentation slides,ppt,microprocessor 8085 ,guide, instruction set
8085 Paper Presentation slides,ppt,microprocessor 8085 ,guide, instruction set8085 Paper Presentation slides,ppt,microprocessor 8085 ,guide, instruction set
8085 Paper Presentation slides,ppt,microprocessor 8085 ,guide, instruction set
 
Assembly Language Programming Of 8085
Assembly Language Programming Of 8085Assembly Language Programming Of 8085
Assembly Language Programming Of 8085
 
Visual Design with Data
Visual Design with DataVisual Design with Data
Visual Design with Data
 

Similar to VIM for (PHP) Programmers

DevChatt 2010 - *nix Cmd Line Kung Foo
DevChatt 2010 - *nix Cmd Line Kung FooDevChatt 2010 - *nix Cmd Line Kung Foo
DevChatt 2010 - *nix Cmd Line Kung Foobrian_dailey
 
Beginning with vi text editor
Beginning with vi text editorBeginning with vi text editor
Beginning with vi text editorJose Pla
 
Tuffarsi in vim
Tuffarsi in vimTuffarsi in vim
Tuffarsi in vimsambismo
 
Linux fundamental - Chap 06 regx
Linux fundamental - Chap 06 regxLinux fundamental - Chap 06 regx
Linux fundamental - Chap 06 regxKenny (netman)
 
101 3.8.2 vim reference card
101 3.8.2 vim reference card101 3.8.2 vim reference card
101 3.8.2 vim reference cardAcácio Oliveira
 
VI Editors
VI EditorsVI Editors
VI EditorsDeivanai
 
Cheatsheet: Hex file headers and regex
Cheatsheet: Hex file headers and regexCheatsheet: Hex file headers and regex
Cheatsheet: Hex file headers and regexKasper de Waard
 
Hex file and regex cheat sheet
Hex file and regex cheat sheetHex file and regex cheat sheet
Hex file and regex cheat sheetMartin Cabrera
 

Similar to VIM for (PHP) Programmers (20)

Vim For Php
Vim For PhpVim For Php
Vim For Php
 
VIM for Programmers
VIM for ProgrammersVIM for Programmers
VIM for Programmers
 
Vim and Python
Vim and PythonVim and Python
Vim and Python
 
DevChatt 2010 - *nix Cmd Line Kung Foo
DevChatt 2010 - *nix Cmd Line Kung FooDevChatt 2010 - *nix Cmd Line Kung Foo
DevChatt 2010 - *nix Cmd Line Kung Foo
 
n
nn
n
 
Beginning with vi text editor
Beginning with vi text editorBeginning with vi text editor
Beginning with vi text editor
 
Tuffarsi in vim
Tuffarsi in vimTuffarsi in vim
Tuffarsi in vim
 
Linux fundamental - Chap 06 regx
Linux fundamental - Chap 06 regxLinux fundamental - Chap 06 regx
Linux fundamental - Chap 06 regx
 
Vim
VimVim
Vim
 
101 3.8.2 vim reference card
101 3.8.2 vim reference card101 3.8.2 vim reference card
101 3.8.2 vim reference card
 
3.8.b vim reference card
3.8.b vim reference card3.8.b vim reference card
3.8.b vim reference card
 
Vim Hacks
Vim HacksVim Hacks
Vim Hacks
 
Vim Hacks
Vim HacksVim Hacks
Vim Hacks
 
How To VIM
How To  VIMHow To  VIM
How To VIM
 
Vim Cheat Sheet.pdf
Vim Cheat Sheet.pdfVim Cheat Sheet.pdf
Vim Cheat Sheet.pdf
 
VI Editors
VI EditorsVI Editors
VI Editors
 
Perl Presentation
Perl PresentationPerl Presentation
Perl Presentation
 
Cheatsheet: Hex file headers and regex
Cheatsheet: Hex file headers and regexCheatsheet: Hex file headers and regex
Cheatsheet: Hex file headers and regex
 
Hex file and regex cheat sheet
Hex file and regex cheat sheetHex file and regex cheat sheet
Hex file and regex cheat sheet
 
vim-cheatsheet.pdf
vim-cheatsheet.pdfvim-cheatsheet.pdf
vim-cheatsheet.pdf
 

More from ZendCon

Framework Shootout
Framework ShootoutFramework Shootout
Framework ShootoutZendCon
 
Zend_Tool: Practical use and Extending
Zend_Tool: Practical use and ExtendingZend_Tool: Practical use and Extending
Zend_Tool: Practical use and ExtendingZendCon
 
PHP on IBM i Tutorial
PHP on IBM i TutorialPHP on IBM i Tutorial
PHP on IBM i TutorialZendCon
 
PHP on Windows - What's New
PHP on Windows - What's NewPHP on Windows - What's New
PHP on Windows - What's NewZendCon
 
PHP and Platform Independance in the Cloud
PHP and Platform Independance in the CloudPHP and Platform Independance in the Cloud
PHP and Platform Independance in the CloudZendCon
 
I18n with PHP 5.3
I18n with PHP 5.3I18n with PHP 5.3
I18n with PHP 5.3ZendCon
 
Cloud Computing: The Hard Problems Never Go Away
Cloud Computing: The Hard Problems Never Go AwayCloud Computing: The Hard Problems Never Go Away
Cloud Computing: The Hard Problems Never Go AwayZendCon
 
Planning for Synchronization with Browser-Local Databases
Planning for Synchronization with Browser-Local DatabasesPlanning for Synchronization with Browser-Local Databases
Planning for Synchronization with Browser-Local DatabasesZendCon
 
Magento - a Zend Framework Application
Magento - a Zend Framework ApplicationMagento - a Zend Framework Application
Magento - a Zend Framework ApplicationZendCon
 
Enterprise-Class PHP Security
Enterprise-Class PHP SecurityEnterprise-Class PHP Security
Enterprise-Class PHP SecurityZendCon
 
PHP and IBM i - Database Alternatives
PHP and IBM i - Database AlternativesPHP and IBM i - Database Alternatives
PHP and IBM i - Database AlternativesZendCon
 
Zend Core on IBM i - Security Considerations
Zend Core on IBM i - Security ConsiderationsZend Core on IBM i - Security Considerations
Zend Core on IBM i - Security ConsiderationsZendCon
 
Application Diagnosis with Zend Server Tracing
Application Diagnosis with Zend Server TracingApplication Diagnosis with Zend Server Tracing
Application Diagnosis with Zend Server TracingZendCon
 
Insights from the Experts: How PHP Leaders Are Transforming High-Impact PHP A...
Insights from the Experts: How PHP Leaders Are Transforming High-Impact PHP A...Insights from the Experts: How PHP Leaders Are Transforming High-Impact PHP A...
Insights from the Experts: How PHP Leaders Are Transforming High-Impact PHP A...ZendCon
 
Solving the C20K problem: Raising the bar in PHP Performance and Scalability
Solving the C20K problem: Raising the bar in PHP Performance and ScalabilitySolving the C20K problem: Raising the bar in PHP Performance and Scalability
Solving the C20K problem: Raising the bar in PHP Performance and ScalabilityZendCon
 
Joe Staner Zend Con 2008
Joe Staner Zend Con 2008Joe Staner Zend Con 2008
Joe Staner Zend Con 2008ZendCon
 
Tiery Eyed
Tiery EyedTiery Eyed
Tiery EyedZendCon
 
Make your PHP Application Software-as-a-Service (SaaS) Ready with the Paralle...
Make your PHP Application Software-as-a-Service (SaaS) Ready with the Paralle...Make your PHP Application Software-as-a-Service (SaaS) Ready with the Paralle...
Make your PHP Application Software-as-a-Service (SaaS) Ready with the Paralle...ZendCon
 
DB2 Storage Engine for MySQL and Open Source Applications Session
DB2 Storage Engine for MySQL and Open Source Applications SessionDB2 Storage Engine for MySQL and Open Source Applications Session
DB2 Storage Engine for MySQL and Open Source Applications SessionZendCon
 
Digital Identity
Digital IdentityDigital Identity
Digital IdentityZendCon
 

More from ZendCon (20)

Framework Shootout
Framework ShootoutFramework Shootout
Framework Shootout
 
Zend_Tool: Practical use and Extending
Zend_Tool: Practical use and ExtendingZend_Tool: Practical use and Extending
Zend_Tool: Practical use and Extending
 
PHP on IBM i Tutorial
PHP on IBM i TutorialPHP on IBM i Tutorial
PHP on IBM i Tutorial
 
PHP on Windows - What's New
PHP on Windows - What's NewPHP on Windows - What's New
PHP on Windows - What's New
 
PHP and Platform Independance in the Cloud
PHP and Platform Independance in the CloudPHP and Platform Independance in the Cloud
PHP and Platform Independance in the Cloud
 
I18n with PHP 5.3
I18n with PHP 5.3I18n with PHP 5.3
I18n with PHP 5.3
 
Cloud Computing: The Hard Problems Never Go Away
Cloud Computing: The Hard Problems Never Go AwayCloud Computing: The Hard Problems Never Go Away
Cloud Computing: The Hard Problems Never Go Away
 
Planning for Synchronization with Browser-Local Databases
Planning for Synchronization with Browser-Local DatabasesPlanning for Synchronization with Browser-Local Databases
Planning for Synchronization with Browser-Local Databases
 
Magento - a Zend Framework Application
Magento - a Zend Framework ApplicationMagento - a Zend Framework Application
Magento - a Zend Framework Application
 
Enterprise-Class PHP Security
Enterprise-Class PHP SecurityEnterprise-Class PHP Security
Enterprise-Class PHP Security
 
PHP and IBM i - Database Alternatives
PHP and IBM i - Database AlternativesPHP and IBM i - Database Alternatives
PHP and IBM i - Database Alternatives
 
Zend Core on IBM i - Security Considerations
Zend Core on IBM i - Security ConsiderationsZend Core on IBM i - Security Considerations
Zend Core on IBM i - Security Considerations
 
Application Diagnosis with Zend Server Tracing
Application Diagnosis with Zend Server TracingApplication Diagnosis with Zend Server Tracing
Application Diagnosis with Zend Server Tracing
 
Insights from the Experts: How PHP Leaders Are Transforming High-Impact PHP A...
Insights from the Experts: How PHP Leaders Are Transforming High-Impact PHP A...Insights from the Experts: How PHP Leaders Are Transforming High-Impact PHP A...
Insights from the Experts: How PHP Leaders Are Transforming High-Impact PHP A...
 
Solving the C20K problem: Raising the bar in PHP Performance and Scalability
Solving the C20K problem: Raising the bar in PHP Performance and ScalabilitySolving the C20K problem: Raising the bar in PHP Performance and Scalability
Solving the C20K problem: Raising the bar in PHP Performance and Scalability
 
Joe Staner Zend Con 2008
Joe Staner Zend Con 2008Joe Staner Zend Con 2008
Joe Staner Zend Con 2008
 
Tiery Eyed
Tiery EyedTiery Eyed
Tiery Eyed
 
Make your PHP Application Software-as-a-Service (SaaS) Ready with the Paralle...
Make your PHP Application Software-as-a-Service (SaaS) Ready with the Paralle...Make your PHP Application Software-as-a-Service (SaaS) Ready with the Paralle...
Make your PHP Application Software-as-a-Service (SaaS) Ready with the Paralle...
 
DB2 Storage Engine for MySQL and Open Source Applications Session
DB2 Storage Engine for MySQL and Open Source Applications SessionDB2 Storage Engine for MySQL and Open Source Applications Session
DB2 Storage Engine for MySQL and Open Source Applications Session
 
Digital Identity
Digital IdentityDigital Identity
Digital Identity
 

Recently uploaded

Progress Report - Oracle Database Analyst Summit
Progress  Report - Oracle Database Analyst SummitProgress  Report - Oracle Database Analyst Summit
Progress Report - Oracle Database Analyst SummitHolger Mueller
 
Call Girls in Gomti Nagar - 7388211116 - With room Service
Call Girls in Gomti Nagar - 7388211116  - With room ServiceCall Girls in Gomti Nagar - 7388211116  - With room Service
Call Girls in Gomti Nagar - 7388211116 - With room Servicediscovermytutordmt
 
Pharma Works Profile of Karan Communications
Pharma Works Profile of Karan CommunicationsPharma Works Profile of Karan Communications
Pharma Works Profile of Karan Communicationskarancommunications
 
MONA 98765-12871 CALL GIRLS IN LUDHIANA LUDHIANA CALL GIRL
MONA 98765-12871 CALL GIRLS IN LUDHIANA LUDHIANA CALL GIRLMONA 98765-12871 CALL GIRLS IN LUDHIANA LUDHIANA CALL GIRL
MONA 98765-12871 CALL GIRLS IN LUDHIANA LUDHIANA CALL GIRLSeo
 
Socio-economic-Impact-of-business-consumers-suppliers-and.pptx
Socio-economic-Impact-of-business-consumers-suppliers-and.pptxSocio-economic-Impact-of-business-consumers-suppliers-and.pptx
Socio-economic-Impact-of-business-consumers-suppliers-and.pptxtrishalcan8
 
Grateful 7 speech thanking everyone that has helped.pdf
Grateful 7 speech thanking everyone that has helped.pdfGrateful 7 speech thanking everyone that has helped.pdf
Grateful 7 speech thanking everyone that has helped.pdfPaul Menig
 
Mysore Call Girls 8617370543 WhatsApp Number 24x7 Best Services
Mysore Call Girls 8617370543 WhatsApp Number 24x7 Best ServicesMysore Call Girls 8617370543 WhatsApp Number 24x7 Best Services
Mysore Call Girls 8617370543 WhatsApp Number 24x7 Best ServicesDipal Arora
 
Call Girls Pune Just Call 9907093804 Top Class Call Girl Service Available
Call Girls Pune Just Call 9907093804 Top Class Call Girl Service AvailableCall Girls Pune Just Call 9907093804 Top Class Call Girl Service Available
Call Girls Pune Just Call 9907093804 Top Class Call Girl Service AvailableDipal Arora
 
Keppel Ltd. 1Q 2024 Business Update Presentation Slides
Keppel Ltd. 1Q 2024 Business Update  Presentation SlidesKeppel Ltd. 1Q 2024 Business Update  Presentation Slides
Keppel Ltd. 1Q 2024 Business Update Presentation SlidesKeppelCorporation
 
Vip Dewas Call Girls #9907093804 Contact Number Escorts Service Dewas
Vip Dewas Call Girls #9907093804 Contact Number Escorts Service DewasVip Dewas Call Girls #9907093804 Contact Number Escorts Service Dewas
Vip Dewas Call Girls #9907093804 Contact Number Escorts Service Dewasmakika9823
 
Catalogue ONG NUOC PPR DE NHAT .pdf
Catalogue ONG NUOC PPR DE NHAT      .pdfCatalogue ONG NUOC PPR DE NHAT      .pdf
Catalogue ONG NUOC PPR DE NHAT .pdfOrient Homes
 
Monthly Social Media Update April 2024 pptx.pptx
Monthly Social Media Update April 2024 pptx.pptxMonthly Social Media Update April 2024 pptx.pptx
Monthly Social Media Update April 2024 pptx.pptxAndy Lambert
 
A DAY IN THE LIFE OF A SALESMAN / WOMAN
A DAY IN THE LIFE OF A  SALESMAN / WOMANA DAY IN THE LIFE OF A  SALESMAN / WOMAN
A DAY IN THE LIFE OF A SALESMAN / WOMANIlamathiKannappan
 
Insurers' journeys to build a mastery in the IoT usage
Insurers' journeys to build a mastery in the IoT usageInsurers' journeys to build a mastery in the IoT usage
Insurers' journeys to build a mastery in the IoT usageMatteo Carbone
 
It will be International Nurses' Day on 12 May
It will be International Nurses' Day on 12 MayIt will be International Nurses' Day on 12 May
It will be International Nurses' Day on 12 MayNZSG
 
Best VIP Call Girls Noida Sector 40 Call Me: 8448380779
Best VIP Call Girls Noida Sector 40 Call Me: 8448380779Best VIP Call Girls Noida Sector 40 Call Me: 8448380779
Best VIP Call Girls Noida Sector 40 Call Me: 8448380779Delhi Call girls
 
M.C Lodges -- Guest House in Jhang.
M.C Lodges --  Guest House in Jhang.M.C Lodges --  Guest House in Jhang.
M.C Lodges -- Guest House in Jhang.Aaiza Hassan
 
GD Birla and his contribution in management
GD Birla and his contribution in managementGD Birla and his contribution in management
GD Birla and his contribution in managementchhavia330
 

Recently uploaded (20)

Progress Report - Oracle Database Analyst Summit
Progress  Report - Oracle Database Analyst SummitProgress  Report - Oracle Database Analyst Summit
Progress Report - Oracle Database Analyst Summit
 
Call Girls in Gomti Nagar - 7388211116 - With room Service
Call Girls in Gomti Nagar - 7388211116  - With room ServiceCall Girls in Gomti Nagar - 7388211116  - With room Service
Call Girls in Gomti Nagar - 7388211116 - With room Service
 
Pharma Works Profile of Karan Communications
Pharma Works Profile of Karan CommunicationsPharma Works Profile of Karan Communications
Pharma Works Profile of Karan Communications
 
MONA 98765-12871 CALL GIRLS IN LUDHIANA LUDHIANA CALL GIRL
MONA 98765-12871 CALL GIRLS IN LUDHIANA LUDHIANA CALL GIRLMONA 98765-12871 CALL GIRLS IN LUDHIANA LUDHIANA CALL GIRL
MONA 98765-12871 CALL GIRLS IN LUDHIANA LUDHIANA CALL GIRL
 
Socio-economic-Impact-of-business-consumers-suppliers-and.pptx
Socio-economic-Impact-of-business-consumers-suppliers-and.pptxSocio-economic-Impact-of-business-consumers-suppliers-and.pptx
Socio-economic-Impact-of-business-consumers-suppliers-and.pptx
 
Grateful 7 speech thanking everyone that has helped.pdf
Grateful 7 speech thanking everyone that has helped.pdfGrateful 7 speech thanking everyone that has helped.pdf
Grateful 7 speech thanking everyone that has helped.pdf
 
Nepali Escort Girl Kakori \ 9548273370 Indian Call Girls Service Lucknow ₹,9517
Nepali Escort Girl Kakori \ 9548273370 Indian Call Girls Service Lucknow ₹,9517Nepali Escort Girl Kakori \ 9548273370 Indian Call Girls Service Lucknow ₹,9517
Nepali Escort Girl Kakori \ 9548273370 Indian Call Girls Service Lucknow ₹,9517
 
Mysore Call Girls 8617370543 WhatsApp Number 24x7 Best Services
Mysore Call Girls 8617370543 WhatsApp Number 24x7 Best ServicesMysore Call Girls 8617370543 WhatsApp Number 24x7 Best Services
Mysore Call Girls 8617370543 WhatsApp Number 24x7 Best Services
 
Call Girls Pune Just Call 9907093804 Top Class Call Girl Service Available
Call Girls Pune Just Call 9907093804 Top Class Call Girl Service AvailableCall Girls Pune Just Call 9907093804 Top Class Call Girl Service Available
Call Girls Pune Just Call 9907093804 Top Class Call Girl Service Available
 
Keppel Ltd. 1Q 2024 Business Update Presentation Slides
Keppel Ltd. 1Q 2024 Business Update  Presentation SlidesKeppel Ltd. 1Q 2024 Business Update  Presentation Slides
Keppel Ltd. 1Q 2024 Business Update Presentation Slides
 
Vip Dewas Call Girls #9907093804 Contact Number Escorts Service Dewas
Vip Dewas Call Girls #9907093804 Contact Number Escorts Service DewasVip Dewas Call Girls #9907093804 Contact Number Escorts Service Dewas
Vip Dewas Call Girls #9907093804 Contact Number Escorts Service Dewas
 
Best Practices for Implementing an External Recruiting Partnership
Best Practices for Implementing an External Recruiting PartnershipBest Practices for Implementing an External Recruiting Partnership
Best Practices for Implementing an External Recruiting Partnership
 
Catalogue ONG NUOC PPR DE NHAT .pdf
Catalogue ONG NUOC PPR DE NHAT      .pdfCatalogue ONG NUOC PPR DE NHAT      .pdf
Catalogue ONG NUOC PPR DE NHAT .pdf
 
Monthly Social Media Update April 2024 pptx.pptx
Monthly Social Media Update April 2024 pptx.pptxMonthly Social Media Update April 2024 pptx.pptx
Monthly Social Media Update April 2024 pptx.pptx
 
A DAY IN THE LIFE OF A SALESMAN / WOMAN
A DAY IN THE LIFE OF A  SALESMAN / WOMANA DAY IN THE LIFE OF A  SALESMAN / WOMAN
A DAY IN THE LIFE OF A SALESMAN / WOMAN
 
Insurers' journeys to build a mastery in the IoT usage
Insurers' journeys to build a mastery in the IoT usageInsurers' journeys to build a mastery in the IoT usage
Insurers' journeys to build a mastery in the IoT usage
 
It will be International Nurses' Day on 12 May
It will be International Nurses' Day on 12 MayIt will be International Nurses' Day on 12 May
It will be International Nurses' Day on 12 May
 
Best VIP Call Girls Noida Sector 40 Call Me: 8448380779
Best VIP Call Girls Noida Sector 40 Call Me: 8448380779Best VIP Call Girls Noida Sector 40 Call Me: 8448380779
Best VIP Call Girls Noida Sector 40 Call Me: 8448380779
 
M.C Lodges -- Guest House in Jhang.
M.C Lodges --  Guest House in Jhang.M.C Lodges --  Guest House in Jhang.
M.C Lodges -- Guest House in Jhang.
 
GD Birla and his contribution in management
GD Birla and his contribution in managementGD Birla and his contribution in management
GD Birla and his contribution in management
 

VIM for (PHP) Programmers

  • 1. VIM for (PHP) Programmers Andrei Zmievski Outspark, Inc ZendCon ⁓ September 17, 2008
  • 2. help ~ learn how to get help effectively ~ :help is your friend ~ use CTRL-V before a CTRL sequence command ~ use i_ and v_ prefixes to get help for CTRL sequences in Insert and Visual modes ~ use CTRL-] (jump to tag) and CTRL-T (go back) in help window
  • 3. intro ~ how well do you know vim’s language? ~ what is the alphabet? ~ look at your keyboard ~ can you name what every key does? ~ modes - what are they? ~ how many do you know? ~ how many do you use?
  • 4. intro if you don’t like the language, change it example: how do you quit vim quickly? ZZ (exit with saving) ZQ (exit without save) or :nmap ,w :x<CR> :nmap ,q :q!<CR> tip: set showcmd to see partial commands as you type them
  • 5. where am i? How do you tell where you are? ~ simple - CTRL-G ~ detailed - gCTRL-G ~ do yourself a favor and set ruler ~ shows line, column, and percentage in status line ~ or configure it however you want with ‘rulerformat’
  • 6. moving ~ do you us h/j/k/l for moving? ~ or are you stuck in GUIarrowy world? ~ if you are, re-learn ~ save yourself countless miles of movement between home row and arrows
  • 7. moving How do you move to: ~ start/end of buffer? gg and G ~ line n? nG or ngg ~ n% into the file? n% ~ the first non-blank character in the line? ^ ~ first non-blank character on next line? <CR> ~ first non-blank character on previous line? -
  • 8. marks ~ we can bookmark locations in the buffer ~ m<letter> sets mark named <letter> at current location ~ `<letter> jumps precisely to that mark ~ ‘<letter> jumps to the line with the mark ~ lowercase letter: mark is local to the buffer ~ uppercase letter: mark is global, your buffer will be switched to the file with the mark ~ :marks shows you your current marks
  • 9. marks ~ marks are very handy for changing text ~ set a mark (let’s say ma) ~ then you can do: ~ c`a - change text from cursor to mark a ~ d`a - delete text from cursor to mark a ~ =’a - reformat lines from current one to the one with mark a
  • 10. marks ~ let’s say you jump somewhere ~ how do you go back? ~ `` moves you between the last two locations ~ you can set ` (the context mark) explicitly: ~ m`, jump elsewhere, then come back with `` tip: CTRL-O and CTRL-I move between positions in the full jump history, but can’t be used as motions ‘. and `. - jump to the line or exact location of the last modification
  • 11. insert ~ gi - incredibly handy ~ goes to Insert mode where you left it last time ~ scenario: edit something, exit Insert, go look at something else, then gi back to restart editing
  • 12. insert Some more goodies: ~ CTRL-Y and CTRL-E (avoid work if you can) ~ inserts chars from above or below the cursor ~ CTRL-A (oops, i want to do that again) ~ inserts previously inserted text ~ CTRL-R=<expr> (built-in calculator) ~ inserts anything vim can calculate ~ CTRL-T and CTRL-D (tab and de-tab) ~ inserts or deletes one shiftwidth of indent at the start of the line
  • 13. delete set your <Backspace> free :set backspace=start,indent,eol lets you backspace past the start of edit, auto- indenting, and even start of the line
  • 14. search ~ searching is essential ~ movement and information ~ how do you search? ~ f/F/t/T anyone? ~ how about * and #?
  • 15. search Search within the line: ~ f/F<char> jumps to the first <char> to the right/left and places cursor on it ~ t/T<char> jumps does the same, but stops one character short of it ~ df; - delete text from cursor to the first ; to the right ~ cT$ - change text from cursor up to the first $ to the left
  • 16. search ~ often you want to find other instances of word under the cursor ~ */# - find next/previous instance of whole word ~ g*/g# - find next/previous instance of partial word ~ or find lines with a certain word: ~ [I and ]I - list lines with word under the cursor ~ more convenient to use a mapping to jump to a line: :map ,f [I:let nr = input(quot;Which one: quot;)<Bar>exe quot;normal quot; . nr .quot;[tquot;<CR>
  • 17. search ~ of course, there’s always regexp search ~ /<pattern> - search forward for <pattern> ~ ?<pattern> - search backward for <pattern> ~ n repeats the last search ~ N repeats it in the opposite direction ~ vim regexp language is too sophisticated to be covered here
  • 18. search Control your search options ~ :set wrapscan - to make search wrap around ~ :set incsearch - incremental search, <Enter> accepts, <Esc> cancels ~ :set ignorecase - case-insensitive search, or use this within the pattern: ~ c - force case-insensitive search ~ C - force case-sensitive search
  • 19. search ~ remember that every search/jump can be used as a motion argument ~ d/^# - delete everything up to the next comment ~ y/^class/;?function - copy everything from current point to the first function before the first class
  • 20. replace ~ :[range]s/<pattern>/<replace>/{flags} is the substitute command ~ used mainly with range addresses ~ range addresses are very powerful (read the manual) ~ but who wants to count out lines and do something like :-23,’ts/foo/bar/ ~ in reality you almost always use a couple of shortcuts and Visual mode for the rest
  • 21. replace ~ useful range addresses: ~ % - equal to 1,$ (the entire file) ~ . - current line ~ /<pattern>/ or ?<pattern>? - line where <pattern> matches ~ :%s/foo/bar/ - replace first foo in each matching line with bar in the entire file ~ :.,/</body>/s,<br>,<br/>,gc - fix br tags from current line until the one with </body> in it, asking for confirmation (c - ‘cautious’ mode)
  • 22. replace ~ & - repeat last substitution on current line ~ :&& - repeat it with the flags that were used ~ g& - repeat substitution globally, with flags
  • 23. text objects ~ better know what they are ~ since they are fantastically handy ~ can be used after an operator or in Visual mode ~ come in “inner” and “ambient” flavors ~ inner ones always select less text than ambient ones
  • 24. text objects ~ aw, aW - ambient word or WORD (see docs) ~ iw, iW - inner word or WORD (see docs) ~ as, is - ambient or inner sentence ~ ap, ip - ambient or inner paragraph ~ a{, i{ - whole {..} block or text inside it ~ a(, i( - whole (..) block or just text inside it ~ a<, i< - whole <..> block or just text inside it
  • 25. text objects ~ there are some cooler ones ~ a’, i’ - single-quoted string or just the text inside ~ a”, i” - double-quoted string or just the text inside ~ note that these are smart about escaped quotes inside strings ~ at, it- whole tag block or just text inside (HTML and XML tags)
  • 26. text objects examples: das - delete the sentence, including whitespace after ci( - change text inside (..) block yat - copy the entire closest tag block the cursor is inside gUi’ - uppercase text inside the single-quoted string vip - select the paragraph in Visual mode, without whitespace after
  • 27. copy/delete/paste ~ you should already know these ~ y - yank (copy), d - delete, p - paste after, P - paste before ~ ]p, ]P - paste after/before but adjust the indent ~ Useful mappings to paste and reformat/reindent :nnoremap <Esc>P P'[v']= :nnoremap <Esc>p p'[v']=
  • 28. registers ~ registers: your multi-purpose clipboard ~ you use them without even knowing ~ every y or d command copies to a register ~ unnamed or named ~ “<char> before a copy/delete/paste specifies register named <char>
  • 29. registers ~ copying to uppercase registers append to their contents ~ useful for picking out bits from the buffers and pasting as a chunk ~ “wyy - copy current line into register w ~ “WD - cut the rest of the line and append it to the contents of register W ~ “wp - paste the contents of register w ~ CTRL-Rw - insert the contents of register w (in Insert mode)
  • 30. registers ~ you can record macros into registers ~ q<char> - start recording typed text into register <char> ~ next q stops recording ~ @<char> executes macro <char> ~ @@ repeats last executed macro ~ use :reg to see what’s in your registers
  • 31. undo ~ original vi had only one level of undo ~ yikes! ~ vim has unlimited (limited only by memory) ~ set ‘undolevels’ to what you need (1000 default)
  • 32. undo ~ simple case: u - undo, CTRL-R - redo ~ vim 7 introduces branched undo ~ if you undo something, and make a change, a new branch is created ~ g-, g+ - go to older/newer text state (through branches)
  • 33. undo ~ you can travel through time ~ :earlier Ns,m,h - go to text state as it was N seconds, minutes, hours ago ~ :later Ns,m,h - go to a later text state similarly ~ :earlier 10m - go back 10 minutes, before I drank a can of Red Bull and made all these crazy changes. Whew.
  • 34. visual mode ~ use it, it's much easier than remembering obscure range or motion commands ~ start selection with: ~ v - characterwise, ~ V - linewise ~ CTRL-V - blockwise ~ use any motion command to change selection ~ can execute any normal or : command on the selection
  • 35. visual mode ~ Visual block mode is awesome ~ especially for table-like text tip: o switches cursor to the other corner, continue selection from there ~ Once you are in block mode: ~ I<text><Esc> - insert <text> before block on every line ~ A<text><Esc> - append <text> after block on every line ~ c<text><Esc> - change every line in block to <text> ~ r<char><Esc> - replace every character with <char>
  • 36. abbreviations ~ Real-time string replacement ~ Expanded when a non-keyword character is typed ~ :ab tempalte template - fix misspellings ~ more complicated expansion: ~ :iab techo <?php echo ?><Left><Left><Left>
  • 37. windows ~ learn how to manipulate windows ~ learn how to move between them ~ :new, :sp should be at your fingertips ~ CTRL-W commands - learn essential ones for resizing and moving between windows
  • 38. tab pages ~ vim 7 supports tab pages ~ :tabe <file> to edit file in a new tab ~ :tabc to close ~ :tabn, :tabp (or gt, gT to switch) ~ probably want to map these for easier navigation (if gt, gT are too difficult)
  • 39. completion ~ vim is very completion friendly ~ just use <Tab> on command line ~ for filenames, set ‘wildmenu’ and ‘wildmode’ (I like quot;list:longest,fullquot;) ~ :new ~/dev/fo<Tab> - complete filename ~ :help ‘comp<Tab> - complete option name ~ :re<Tab> - complete command ~ hit <Tab> again to cycle, CTRL-N for next match, CTRL-P for previous
  • 40. completion ~ CTRL-X starts completion mode in Insert mode ~ follow with CTRL- combos (:help ins- completion) ~ i mostly use filename, identifier, and omni completion ~ when there are multiple matches, a nice completion windows pops up
  • 41. completion ~ CTRL-X CTRL-F to complete filenames ~ CTRL-X CTRL-N to complete identifiers ~ hey, that’s so useful I’ll remap <Tab> “ Insert <Tab> or complete identifier “ if the cursor is after a keyword character function MyTabOrComplete() let col = col('.')-1 if !col || getline('.')[col-1] !~ 'k' return quot;<tab>quot; else return quot;<C-N>quot; endif endfunction inoremap <Tab> <C-R>=MyTabOrComplete()<CR>
  • 42. completion ~ omni completion is heuristics-based ~ guesses what you want to complete ~ specific to the file type you’re editing ~ more on it later
  • 43. maps ~ maps for every mode and then some ~ tired of changing text inside quotes? :nmap X ciquot; ~ make vim more browser-like? :nmap <Space> <PageDown> ~ insert your email quickly? :imap ;EM me@mydomain.com ~ make <Backspace> act as <Delete> in Visual mode? :vmap <BS> x
  • 44. options ~ vim has hundreds of options ~ learn to control the ones you need ~ :options lets you change options interactively ~ :options | resize is better (since there are so many)
  • 45. sessions ~ a session keeps the views for all windows, plus the global settings ~ you can save a session and when you restore it later, the window layout looks the same. ~ :mksession <file> to write out session to a file ~ :source <file> to load session from a file ~ vim -S <file> to start editing a session
  • 46. miscellaneous ~ gf - go to file under cursor (CTRL-W CTRL-F for new window) ~ :read in contents of file or process ~ :read foo.txt - read in foo.txt ~ :read !wc %:h - run wc on current file and insert result into the text ~ filter text: :%!sort, :%!grep, or use :! in visual mode ~ i like sorting lists like this: vip:!sort
  • 47. miscellaneous ~ use command-line history ~ : and / followed by up/down arrows move through history ~ : and / followed by prefix and arrows restrict history to that prefix ~ q: and q/ for editable history (<Enter> executes, CTRL-C copies to command line)
  • 48. miscellaneous ~ CTRL-A and CTRL-X to increment/decrement numbers under the cursor (hex and octal too) ~ ga - what is this character under my cursor? ~ :set number to turn line numbers on ~ or use this to toggle line numbers: :nmap <silent> <F6> set number!<CR> ~ :set autowrite - stop vim asking if you want to write the file before leaving buffer ~ CTRL-E/CTRL-Y - scroll window down/up without moving cursor
  • 49. miscellaneous ~ :set scroloff=N to start scrolling when cursor is N lines from the top/bottom edge ~ :set updatecount=50 to write swap file to disk after 50 keystrokes ~ :set showmatch matchtime=3 - when bracket is inserted, briefly jump to the matching one ~ in shell: fc invokes vim on last command, and runs it after vim exits (or fc N to edit command N in history) ~ vimdiff in shell (:help vimdiff)
  • 50. miscellaneous ~ map CTRL-L to piece-wise copying of the line above the current one imap <C-L> @@@<ESC>hhkywjl?@@@<CR>P/@@@<CR>3s
  • 51. customization ~ customize vim by placing files in you ~/.vim dir ~ filetype plugin on, filetype indent on .vimrc - global settings .vim/ after/ - files that are loaded at the very end ftplugin/ plugin/ syntax/ ... autoload/ - automatically loaded scripts colors/ - custom color schemes doc/ - plugin documentation ftdetect/ - filetype detection scripts ftplugin/ - filetype plugins indent/ - indent scripts plugin/ - plugins syntax/ - syntax scripts
  • 52. php: linting ~ vim supports arbitrary build/lint commands ~ if we set 'makeprg' and 'errorformat' appropriately.. :set makeprg=php -l % :set errorformat=%m in %f on line %l ~ now we just type :make (and <Enter> a couple of times) ~ cursor jumps to line with syntax error
  • 53. php: match pairs ~ you should be familiar with % command (moves cursor to matching item) ~ used with (), {}, [], etc ~ but can also be used to jump between PHP and HTML tags ~ use matchit.vim plugin ~ but syntax/php.vim has bugs and typos in the matching rule ~ i provide my own
  • 54. php: block objects ~ similar to vim's built-in objects ~ aP - PHP block including tags ~ iP - text inside PHP block examples: ~ vaP - select current PHP block (with tags) ~ ciP - change text inside current PHP block ~ yaP - copy entire PHP block (with tags) ~ provided in my .vim/ftplugin/php.vim file
  • 55. php: syntax options ~ vim comes with a very capable syntax plugin for PHP ~ provides a number of options ~ let php_sql_query=1 to highlight SQL syntax in strings ~ let php_htmlInStrings=1 to highlight HTML in string ~ let php_noShortTags = 1 to disable short tags ~ let php_folding = 1 to enable folding for classes and functions
  • 56. php: folding ~ learn to control folding ~ zo - open fold (if the cursor is on the fold line) ~ zc - close closest fold ~ zR - open all folds ~ zM - close all folds ~ zj - move to the start of the next fold ~ zk - move to the end of the previous fold
  • 57. php: tags ~ for vim purposes, tags are PHP identifiers (classes, functions, constants) ~ you can quickly jump to the definition of each tag, if you have a tags file ~ install Exuberant Ctags ~ it can scan your scripts and output tags file, containing identifier info ~ currently does not support class membership info (outputs methods as functions) ~ have to apply a third-party patch to fix
  • 58. php: tags ~ use mapping to re-build tags file after editing nmap <silent> <F4> :!ctags-ex -f ./tags --langmap=quot;php:+.incquot; -h quot;.php.incquot; -R --totals=yes --tag-relative=yes --PHP-kinds=+cf-v .<CR> set tags=./tags,tags ~ all PHP files in current directory and under it recursively will be scanned
  • 59. php: tags ~ CTRL-] - jump to tag under cursor ~ CTRL-W CTRL-] - jump to tag in a new window ~ :tag <ident> - jump to an arbitrary tag ~ :tag /<regexp> - jump to or list tags matching <regexp> ~ if multiple matches - select one from a list ~ :tselect <ident> or /<regexp> - list tags instead of jumping ~ CTRL-T - return to where you were ~ See also taglist.vim plugin
  • 60. php: completion ~ vim 7 introduces powerful heuristics-based omni completion ~ CTRL-X CTRL-O starts the completion (i map it to CTRL-F) ~ completes classes, variables, methods in a smart manner, based on context
  • 61. php: completion ~ completes built-in functions too ~ function completion shows prototype preview ~ array_<CTRL-X><CTRL-O> shows list of array functions ~ select one from the list, and the prototype shows in a preview window ~ CTRL-W CTRL-Z to close preview window
  • 62. php: completion ~ switches to HTML/CSS/Javascript completion outside PHP blocks ~ see more: ~ :help ins-completion ~ :help popupmenu-completion ~ :help popupmenu-keys
  • 63. plugins ~ vim can be infinitely customized and expanded via plugins ~ there are thousands already written ~ installation is very easy, usually just drop them into .vim/plugin ~ read instructions first though
  • 64. netrw ~ makes it possible to read, write, and browse remote directories and files ~ i usually use it over ssh connections via scp ~ need to run ssh-agent to avoid continuous prompts for passphrase ~ don't use passphrase-less keys! ~ once set up: ~ vim scp://hostname/path/to/file ~ :new scp://hostname/path/to/dir/
  • 65. NERDTree ~ similar to netrw browser but looks more like a hierarchical explorer ~ does not support remote file operations ~ :nmap <silent> <F7> :NERDTreeToggle<CR>
  • 66. taglist ~ provides an overview of the source code ~ provides quick access to classes, functions, constants ~ automatically updates window when switching buffers ~ can display prototype and scope of a tag ~ requires Exuberant Ctags
  • 67. taglist ~ stick this in ~/.vim/after/plugin/general.vim let Tlist_Ctags_Cmd = quot;/usr/local/bin/ctags-exquot; let Tlist_Inc_Winwidth = 1 let Tlist_Exit_OnlyWindow = 1 let Tlist_File_Fold_Auto_Close = 1 let Tlist_Process_File_Always = 1 let Tlist_Enable_Fold_Column = 0 let tlist_php_settings = 'php;c:class;d:constant;f:function' if exists('loaded_taglist') nmap <silent> <F8> :TlistToggle<CR> endif
  • 68. snippetsEmu ~ emulates some of the functionality of TextMate snippets ~ supports many languages, including PHP/HTML/ CSS/Javascript ~ by default binds to <Tab> but that's annoying ~ need to remap the key after it's loaded ~ put this in ~/.vim/after/plugin/general.vim if exists('loaded_snippet') imap <C-B> <Plug>Jumper endif inoremap <Tab> <C-R>=MyTabOrComplete()<CR>
  • 69. php documentor ~ inserts PHP Documentor blocks automatically ~ works in single or multi-line mode ~ doesn’t provide mappings by default ~ read documentation to set up default variables for copyright, package, etc ~ put this in ~/.vim/ftplugin/php.vim inoremap <buffer> <C-P> <Esc>:call PhpDocSingle()<CR>i nnoremap <buffer> <C-P> :call PhpDocSingle()<CR> vnoremap <buffer> <C-P> :call PhpDocRange()<CR> let g:pdv_cfg_Uses = 1
  • 70. xdebug-ger ~ allows debugging with xdebug through DBGp protocol ~ fairly basic, but does the job ~ vim needs to be compiled with +python feature ~ see resources section for documentation links
  • 71. vcscommand ~ provides interface to CVS/SVN ~ install it, then :help vcscommand
  • 72. conclusion ~ vim rules ~ this has been only a partial glimpse ~ from my very subjective point of view ~ don’t be stuck in an editor rut ~ keep reading and trying things out
  • 73. resources ~ vim tips: http://www.vim.org/tips/ ~ vim scripts: http://www.vim.org/scripts/index.php ~ Exuberant Ctags: http://ctags.sourceforge.net ~ PHP patch for ctags: http://www.live-emotion.com/memo/index.php? plugin=attach&refer=%CA%AA%C3%D6&openfile=ctags-5.6j-php.zip ~ article on xdebug and vim: http://2bits.com/articles/using-vim-and- xdebug-dbgp-for-debugging-drupal-or-any-php-application.html ~ more cool plugins: ~ Surround: http://www.vim.org/scripts/script.php?script_id=1697 ~ ShowMarks: http://www.vim.org/scripts/script.php?script_id=152 ~ Vim Outliner: http://www.vim.org/scripts/script.php?script_id=517 ~ Tetris: http://www.vim.org/scripts/script.php?script_id=172
  • 74. quot;As with everything, best not to look too deeply into this.quot;
  • 75. Thank You! http://outspark.com/ http://gravitonic.com/talks/