Nächstes Suchergebnis in Vim automatisch zentrieren

Wer öffter mal mittels Vim in Logfiles unterwegs ist oder aber in einer großen Datei etwas sucht und hierbei einige Suchergebnisse erwartet dem ist sicherlich der Normal Command n bzw. N bekannt.

Mittels n springt man zum nächsten Suchergbenis und falls eingestellt, wird das Ergebnis auch in der Datei farblich hervorgehoben.

Gerade bei Logfiles kann einem das hin- und hergespringe in den Zeilen etwas nerven. Schöner wäre es, wenn das nächste Ergebnis einfach – wenn möglich – immer mittig im Fenster dargestellt wird.

Hierfür kann man nach n einfach den Befehl zz verwenden, welcher die Zeile mittig im Fenster anzeigt.

Da ich das aber nicht immer manuell machen möchte, es jedoch auch nicht als Standardverhalten mappen wollte, habe ich mir eine kurze Funktion geschrieben, welche ich in meine .vimrc eingebunden habe.

Gemappt habe ich mir das ganze auf „Leader nz“ was bei mir die Tastenkombination <space>nz ist.

Nachfolgend die recht kurze vimscript-Funktion:

let g:ncttoggle = 1
function! NextCenterToggle()
  if g:ncttoggle
    nmap n nzz
    nmap N Nzz
    let g:ncttoggle = 0
  else
    nun n
    nun N
    let g:ncttoggle = 1
  endif
endfunc

nnoremap <silent> <leader>nz :call NextCenterToggle()<CR>

Kurz und bündig mappe ich n und N im Normal Mode einfach um und wenn ich es wieder deaktivere lösche ich auch das Mapping um das Standardverhalten wieder herzustellen.

vi-style line editing in der Shell

Auch unter OS X kann im Terminal mittels Emacs-Komandos die Commandline verändert werden. So springt z. B. Ctrl-a an den Anfang der Zeile und Ctrl-e an das Ende. Als vi-Nutzer ist man 0 (zum Anfang) und $ (zum Ende) gewohnt.

Ein Blick auf die Hilfe von Set zeigt folgendes:

$ help set
set: set [--abefhkmnptuvxBCHP] [-o option] [arg ...]
        -a  Mark variables which are modified or created for export.
        -b  Notify of job termination immediately.
        -e  Exit immediately if a command exits with a non-zero status.
        -f  Disable file name generation (globbing).
        -h  Remember the location of commands as they are looked up.
        -k  All assignment arguments are placed in the environment for a
            command, not just those that precede the command name.
        -m  Job control is enabled.
        -n  Read commands but do not execute them.
        -o option-name
            Set the variable corresponding to option-name:
                allexport    same as -a
                braceexpand  same as -B
                emacs        use an emacs-style line editing interface
                errexit      same as -e
                errtrace     same as -E
                functrace    same as -T
                hashall      same as -h
                histexpand   same as -H
                history      enable command history
                ignoreeof    the shell will not exit upon reading EOF
                interactive-comments
                             allow comments to appear in interactive commands
                keyword      same as -k
                monitor      same as -m
                noclobber    same as -C
                noexec       same as -n
                noglob       same as -f
                nolog        currently accepted but ignored
                notify       same as -b
                nounset      same as -u
                onecmd       same as -t
                physical     same as -P
                pipefail     the return value of a pipeline is the status of
                             the last command to exit with a non-zero status,
                             or zero if no command exited with a non-zero status
                posix        change the behavior of bash where the default
                             operation differs from the 1003.2 standard to
                             match the standard
                privileged   same as -p
                verbose      same as -v
                vi           use a vi-style line editing interface
                xtrace       same as -x
        -p  Turned on whenever the real and effective user ids do not match.
            Disables processing of the $ENV file and importing of shell
            functions.  Turning this option off causes the effective uid and
            gid to be set to the real uid and gid.
        -t  Exit after reading and executing one command.
        -u  Treat unset variables as an error when substituting.
        -v  Print shell input lines as they are read.
        -x  Print commands and their arguments as they are executed.
        -B  the shell will perform brace expansion
        -C  If set, disallow existing regular files to be overwritten
            by redirection of output.
        -E  If set, the ERR trap is inherited by shell functions.
        -H  Enable ! style history substitution.  This flag is on
            by default when the shell is interactive.
        -P  If set, do not follow symbolic links when executing commands
            such as cd which change the current directory.
        -T  If set, the DEBUG trap is inherited by shell functions.
        -   Assign any remaining arguments to the positional parameters.
            The -x and -v options are turned off.

    Using + rather than - causes these flags to be turned off.  The
    flags can also be used upon invocation of the shell.  The current
    set of flags may be found in $-.  The remaining n ARGs are positional
    parameters and are assigned, in order, to $1, $2, .. $n.  If no
    ARGs are given, all shell variables are printed.

Man muss – sofern man Bash als Shell benutzt – also nur eine Zeile zur eigenen .profile-Datei hinzufügen:

set -o vi

und schon kann man die gewohnten vi-Keybindings nutzen, wie der nachfolgende Screencast zeigt.

Screencast vi-style line editing in der Shell

Vimlinks

Schnell mal auskommentieren in JavaScript und CSS

Der Trick der JavaScript Kommentare aus dem vorherigen Artikel lässt sich entsprechend so anpassen, dass er auch in CSS-Dateien verwendet werden kann.

In diesem Beispiel soll Funktion test1 auskommentiert werden.

function test() {
  
}
/**/
function test1() {
  
}
/**/
function test2() {
  
}

Durch einfaches entfernen des 2. Sternes in Zeile 4 wird der Code bis einschließlich Zeile 8 auskommentiert.

function test() {
  
}
/*/
function test1() {
  
}
/**/

Schnell mal auskommentieren in JavaScript

Ich habe einen alten Kommentar-Trick aus einer noch älteren Flash-Datei gefunden. Bekanntlich war die interne IDE nicht die Beste und zur damaligen Zeit war noch kein Shortcut zum auskommentieren verfügbar.

Das Prinzip lässt sich jedoch auch schön in JavaScript-Sourcecode verwenden.

In diesem Beispiel soll Funktion test1 auskommentiert werden.

function test() {
  
}
//*/
function test1() {
  
}
//*/
function test2() {
  
}

Durch einfaches entfernen des 1. Slashes in Zeile 4 wird der Code bis einschließlich Zeile 8 auskommentiert.

function test() {
  
}
/*/
function test1() {
  
}
//*/
function test2() {
  
}

Heute könnte es auch mal nützlich sein, wenn man unterwegs via Tablet/Smartphone per FTP eine JavaScript-Datei editiert und doch mal größere Bereiche auskommentieren möchte.