#!/bin/sh # # This shell script passes all its arguments to the binary inside the Vim.app # application bundle. If you make links to this script as view, gvim, etc., # then it will peek at the name used to call it and set options appropriately. # # Based on a script by Wout Mertens and suggestions from Laurent Bihanic. # This version is the fault of Benji Fisher, 16 May 2005. # First, check "All the Usual Suspects" for the location of the Vim.app bundle. # You can short-circuit this by setting the VIM_APP_DIR environment variable # or by un-commenting and editing the following line: # VIM_APP_DIR=/Applications binary="/Applications/MacPorts/Vim/Vim.app/Contents/MacOS/Vim" # Next, peek at the name used to invoke this script, and set options # accordingly. name="`basename "$0"`" gui= opts= # GUI mode, implies forking case "$name" in g*|rg*) gui=true ;; esac # Restricted mode case "$name" in r*) opts="$opts -Z";; esac # vimdiff and view case "$name" in *vimdiff) opts="$opts -dO" ;; *view) opts="$opts -R" ;; esac # Last step: fire up vim. # GUI mode will always create a new Vim instance, because Vim can't have # more than one graphic window yet. # The program should fork by default when started in GUI mode, but it does # not; we work around this when this script is invoked as "gvim" or "rgview" # etc., but not when it is invoked as "vim -g". if [ "$gui" ]; then # Note: this isn't perfect, because any error output goes to the # terminal instead of the console log. # But if you use open instead, you will need to fully qualify the # path names for any filenames you specify, which is hard. if [[ "$1" == "-" ]]; then cat | exec "$binary" -g $opts ${1:+"$@"} & else exec "$binary" -g $opts ${1:+"$@"} & fi else exec "$binary" $opts ${1:+"$@"} fi