summaryrefslogtreecommitdiff
path: root/usr.bin/vi/FAQ
blob: 79546d184c42093a9077f1839458faffd7cdb0b9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
@(#)FAQ	8.12 (Berkeley) 8/17/96

Q: How can I get vi to display my character set?
A: Vi uses the C library routine isprint(3) to determine if a character
   is printable, or should be displayed as an octal or hexadecimal value
   on the screen.  Generally, if vi is displaying printable characters
   in octal/hexadecimal forms, your environment is not configured correctly.
   Try looking at the man pages that allow you to configure your locale.
   For example, to configure an ISO 8859-1 locale under Solaris using csh,
   you would do:

	setenv LANG C
	setenv LC_CTYPE iso_8859_1

   Other LC_CTYPE systems/values that I'm told work:

   System	Value
   ======	=====
   FreeBSD	lt_LN.ISO_8859-1
   HP-UX  9.X	american.iso88591
   HP-UX 10.X	en_US.iso88591
   SunOS  4.X	iso_8859_1
   SunOS  5.X	iso_8859_1

   If there's no other solution, you can use the print and noprint edit
   options of vi to specify that a specific character is printable or not
   printable.
	
Q: My map won't work!
A: One thing that you should immediately check if a vi map doesn't work
   is if depends on the final cursor position after a P or p command.
   Historic vi's were inconsistent as to the final position of the cursor,
   and, to make matter worse, the final cursor position also depended on
   whether the put text came from a named or unnamed buffer!  Vi follows
   the POSIX 1003.2 standard on this one, and makes this consistent, always
   placing the cursor on the first character.

Q: I'm using ksh or csh as my vi edit option shell value, and file
   expansions don't work right!
A: The problem may be in your ksh or csh startup files, e.g., .cshrc.  Vi
   executes the shell to do name expansion, and the shell generally reads
   its startup files.  If the startup files are not correctly configured
   for non-interactive use, e.g., they always echo a prompt to the screen,
   vi will be unable to parse the output and things will not work
   correctly.

Q: How does the iclower edit option differ from the ignorecase (i.e. ic)
   edit option?
A: The difference is that the ignorecase edit option always ignores the
   case of letters in the Regular Expression (RE), and the iclower edit
   option only ignores the case if there are no upper-case letters in the
   RE.  If any upper-case letters appear in the Regular Expression, then
   it will be treated case-sensitively, as if the ignorecase edit option
   was not set.

Q: When I edit binary files, vi appends a <newline> to the last line!
A: This is historic practice for vi, and further, it's required by the
   POSIX 1003.2 standard.  My intent is to provide a command line and/or
   edit option to turn this behavior off when I switch to version 2.0 of
   the Berkeley DB package.

Q: My cursor keys don't work when I'm in text input mode!
A: A common problem over slow links is that the set of characters sent by
   the cursor keys don't arrive close enough together for vi to understand
   that they are a single keystroke, and not separate keystrokes.  Try
   increasing the value of the escapetime edit option, which will cause
   vi to wait longer before deciding that the <escape> character that
   starts cursor key sequences doesn't have any characters following it.

Q: When I edit some files, vi seems to hang forever, and I have to kill it.
A: Vi uses flock(2) and fcntl(2) to do file locking.  When it attempts to
   acquired a lock for a file on an NFS mounted filesystem, it can hang
   for a very long (perhaps infinite) period of time.  Turning off the
   "lock" edit option will keep vi from attempting to acquire any locks
   on the files you edit.

Q: When I compile vi I get lots of warnings about pointer assignments
   being incompatible!
A: Vi is partially written to support wide characters.  When this code
   interfaces with the code that doesn't yet support wide characters,
   the pointer types clash.  This will hopefully be fixed in the near
   future, but I've been saying that for awhile, now.

Q: I get jumpy scrolling behavior in the screen!
A: This is almost certainly a problem with the system's terminfo or
   termcap information for your terminal.  If the terminfo/termcap entry
   doesn't have the settable scrolling region capabilities, or the more
   powerful scrolling commands, these behaviors can result.  Historic
   implementations of vi, and some of the vi clones, don't suffer from
   this problem because they wrote their own screen support instead of
   using the curses library.

   The solution is to find a good terminfo or termcap entry for your
   terminal, which will fix the problem for all of the applications on
   your system, not just vi.  Eric Raymond maintains the freely
   redistributable termcap/terminfo entries.  They can be downloaded
   from http://www.ccil.org/~esr/ncurses.html, or you can contact him
   at esr@snark.thyrsus.com.

Q: The entire screen repaints on every keystroke!
A: Your system's curses implementation is broken.  You should use the
   curses implementation provided with vi or a curses replacement such
   as ncurses.  Eric Raymond is one of the maintainers of the freely
   redistributable ncurses package.  You can download ncurses from
   http://www.ccil.org/~esr/ncurses.html, or you can contact him at
   esr@snark.thyrsus.com.

Q: When I use vi on a Sun console (terminal type sun-34) the screen
   is occasionally trashed, usually when exiting vi!
A: The Sun console can't handle the 'al' capability of the termcap
   entry (the il1 capability of terminfo entries).  If you delete that
   entry from your terminfo/termcap information everything should work
   correctly.

Q: I don't have a version of ctags (or I have ctags, but it doesn't tag
   nearly enough things)!
A: There's a version of ctags available on the 4.4BSD-Lite distributions,
   as well as the FreeBSD, NetBSD, Linux and GNU distributions.  Or, you
   might want to try Exuberant Ctags:

	Title:		Exuberant Ctags
	Version:	1.3
	Entered-date:	16JUN96
	Description:
	    A better ctags which generates tags for all possible tag types:
	    macro definitions, enumerated values (values inside enum{...}),
	    function and method definitions, enum/struct/union tags, external
	    function prototypes (optional), typedefs, and variable
	    declarations. It is far less easily fooled by code containing #if
	    preprocessor conditional constructs, using a conditional path
	    selection algorithm to resolve complicated choices, and a
	    fall-back algorithm when this one fails. Can also be used to print
	    out a list of selected objects found in source files.
	Keywords:	ctags, tags, exuberant
	Author:		darren@sirsi.com (Darren Hiebert)
			darren@hiwaay.net (Darren Hiebert)
	Maintained-by:	darren@sirsi.com (Darren Hiebert)
			darren@hiwaay.net (Darren Hiebert)
	Primary-site:	sunsite.unc.edu /pub/Linux/devel/lang/c
			27kB ctags-1.3.tar.gz
	Alternate-site:	ftp.halcyon.com /local/gvr
			27kB ctags-1.3.tar.gz
	Original-site:
	Platforms:	UNIX, MSDOS, WindowsNT, Windows95, OS/2, Amiga
	Copying-policy:	Public domain

Q: When I update a file I already have open, and use :e to reread it, I
   get nul's for the rest of the file!
A: Your system's implementation of mmap(2) has a bug; you will have to
   exit vi and re-execute it.