Partially synced with the branch.
[MacVim.git] / runtime / doc / os_beos.txt
blobe5f54b8c06f66a6a79e9ecc99d85de35ce3efa4a
1 *os_beos.txt*   For Vim version 7.2c.  Last change: 2005 Mar 29
4                   VIM REFERENCE MANUAL    by Bram Moolenaar
7                                                         *BeOS* *BeBox*
8 This is a port of Vim 5.1 to the BeOS Preview Release 2 (also known as PR2)
9 or later.
11 This file contains the particularities for the BeBox/BeOS version of Vim.  For
12 matters not discussed in this file, Vim behaves very much like the Unix
13 |os_unix.txt| version.
15  1. General                     |beos-general|
16  2. Compiling Vim               |beos-compiling|
17  3. Timeout in the Terminal     |beos-timeout|
18  4. Unicode vs. Latin1          |beos-unicode|
19  5. The BeOS GUI                |beos-gui|
20  6. The $VIM directory          |beos-vimdir|
21  7. Drag & Drop                 |beos-dragndrop|
22  8. Single Launch vs. Multiple
23     Launch                      |beos-launch|
24  9. Fonts                       |beos-fonts|
25 10. The meta key modifier       |beos-meta|
26 11. Mouse key mappings          |beos-mouse|
27 12. Color names                 |beos-colors|
28 13. Compiling with Perl         |beos-perl|
31 1. General                                              *beos-general*
33 The default syntax highlighting mostly works with different foreground colors
34 to highlight items.  This works best if you set your Terminal window to a
35 darkish background and light letters.  Some middle-grey background (for
36 instance (r,g,b)=(168,168,168)) with black letters also works nicely.  If you
37 use the default light background and dark letters, it may look better to
38 simply reverse the notion of foreground and background color settings.  To do
39 this, add this to your .vimrc file (where <Esc> may need to be replaced with
40 the escape character): >
42   :if &term == "beos-ansi"
43   :    set t_AB=<Esc>[3%dm
44   :    set t_AF=<Esc>[4%dm
45   :endif
48 2. Compiling Vim                                        *beos-compiling*
50 From the Advanced Access Preview Release (AAPR) on, Vim can be configured with
51 the standard configure script.  To get the compiler and its flags right, use
52 the following command-line in the shell (you can cut and paste it in one go):
54 CC=$BE_C_COMPILER CFLAGS="$BE_DEFAULT_C_FLAGS -O7" \
55     ./configure --prefix=/boot/home/config
57 $BE_C_COMPILER is usually "mwcc", $BE_DEFAULT_C_FLAGS is usually "-I- -I."
59 When configure has run, and you wish to enable GUI support, you must edit the
60 config.mk file so that the lines with GUI_xxx refer to $(BEOSGUI_xxx) instead
61 of $(NONE_xxx).
62 Alternatively you can make this change in the Makefile; it will have a
63 more permanent effect.  Search for "NONE_".
65 After compilation you need to add the resources to the binary.  Add the
66 following few lines near the end (before the line with "exit $exit_value") of
67 the link.sh script to do this automatically.
69     rmattr BEOS:TYPE vim
70     copyres os_beos.rsrc vim
71     mimeset vim
73 Also, create a dummy file "strip":
75     #!/bin/sh
76     mimeset $1
77     exit 0
79 You will need it when using "make install" to install Vim.
81 Now type "make" to compile Vim, then "make install" to install it.
83 If you want to install Vim by hand, you must copy Vim to $HOME/config/bin, and
84 create a bunch of symlinks to it ({g,r,rg}{vim,ex,view}).  Furthermore you must
85 copy Vim's configuration files to $HOME/config/share/vim:
86 vim-5.0s/{*.vim,doc,syntax}.  For completeness, you should also copy the nroff
87 manual pages to $HOME/config/man/man1.  Don't forget ctags/ctags and xxd/xxd!
89 Obviously, you need the unlimited linker to actually link Vim.  See
90 http://www.metrowerks.com for purchasing the CodeWarrior compiler for BeOS.
91 There are currently no other linkers that can do the job.
93 This won't be able to include the Perl or Python interfaces even if
94 you have the appropriate files installed. |beos-perl|
97 3. Timeout in the Terminal                              *beos-timeout*
99 Because some POSIX/UNIX features are still missing[1], there is no direct OS
100 support for read-with-timeout in the Terminal.  This would mean that you cannot
101 use :mappings of more than one character, unless you also :set notimeout.
102 |'timeout'|
104 To circumvent this problem, I added a workaround to provide the necessary
105 input with timeout by using an extra thread which reads ahead one character.
106 As a side effect, it also makes Vim recognize when the Terminal window
107 resizes.
109 Function keys are not supported in the Terminal since they produce very
110 indistinctive character sequences.
112 These problems do not exist in the GUI.
114 [1]: there is no select() on file descriptors; also the termios VMIN and VTIME
115 settings do not seem to work properly.  This has been the case since DR7 at
116 least and still has not been fixed as of PR2.
118                                                         *beos-unicode*
119 4. Unicode vs. Latin1                                   *beos-utf8*
121 BeOS uses Unicode and UTF-8 for text strings (16-bit characters encoded to
122 8-bit characters).  Vim assumes ISO-Latin1 or other 8-bit character codes.
123 This does not produce the desired results for non-ASCII characters.  Try the
124 command :digraphs to see.  If they look messed up, use :set isprint=@ to
125 (slightly) improve the display of ISO-Latin1 characters 128-255.  This works
126 better in the GUI, depending on which font you use (below).
128 You may also use the /boot/bin/xtou command to convert UTF-8 files from (xtou
129 -f iso1 filename) or to (xtou -t iso1 filename) ISO-Latin1 characters.
132 5. The BeOS GUI                                         *beos-gui*
134 Normally Vim starts with the GUI if you start it as gvim or vim -g.  The BeOS
135 version tries to determine if it was started from the Tracker instead of the
136 Terminal, and if so, use the GUI anyway.  However, the current detection scheme
137 is fooled if you use the command "vim - </dev/null" or "vim filename &".  The
138 latter can be called a feature but probably only works because there is no
139 BSD-style job control.
141 Stuff that does not work yet:
143 - Running external commands from the GUI does not work 100% (again due to lack
144   of support for select()).  There was a choice between seeing the command's
145   output, or being able to interrupt it.  I chose for seeing the output.  Even
146   now the command sometimes crashes mysteriously, apparently in Be's
147   malloc_internal() called from the putenv() function, after fork()ing.  (data
148   access exception occurred, ec01b0ec:  90e80000 *stw r7, 0x0000 (r8)).  (:!ls
149   works usually, :r !ls usually doesn't).  This has been reported as bug
150   # 971215-083826.
151 - The window title.
152 - Starting the GUI from the Terminal version with :gui always acts as if
153   :gui -f were used.  There is no way to fix this that I can see.
154 - There are some small display glitches here and there that I hope to clean up
155   later.  Most of them occur when the window is partially obscured.  Some of
156   them seem to be bugs in BeOS, because the Terminal has similar glitches.
157 - Mouse up events are not generated when outside the window.  This is a bug in
158   BeOS.  You can notice this when selecting text and moving the cursor outside
159   the window, then letting go of the mouse button.  Another way is when you
160   drag the scrollbar and do the same thing.  Because Vim still thinks you are
161   still playing with the scrollbar it won't change it itself.  I provided a
162   workaround which kicks in when the window is activated or deactivated (so it
163   works best with focus- follows-mouse (/boot/bin/ffm) turned on).
164 - The cursor does not flash (very low priority; I'm not sure I even like it
165   when it flashes)
168 6. The $VIM directory                                   *beos-vimdir*
170 $VIM is the symbolic name for the place where Vims support files are stored.
171 The default value for $VIM is set at compile time and can be determined with >
173   :version
175 The normal value is /boot/home/config/share/vim.  If you don't like it you can
176 set the VIM environment variable to override this, or set 'helpfile' in your
177 .vimrc: >
179   :if version >= 500
180   :    set helpfile=~/vim/vim54/doc/help.txt
181   :    syntax on
182   :endif
185 7. Drag & Drop                                          *beos-dragndrop*
187 You can drop files and directories on either the Vim icon (starts a new Vim
188 session, unless you use the File Types application to set Vim to be "Single
189 Launch") or on the Vim window (starts editing the files).  Dropping a folder
190 sets Vim's current working directory. |:cd| |:pwd| If you drop files or
191 folders with either SHIFT key pressed, Vim changes directory to the folder
192 that contains the first item dropped.  When starting Vim, there is no need to
193 press shift: Vim behaves as if you do.
195 Files dropped set the current argument list. |argument-list|
198 8. Single Launch vs. Multiple Launch                    *beos-launch*
200 As distributed Vim's Application Flags (as seen in the FileTypes preference)
201 are set to Multiple Launch.  If you prefer, you can set them to Single Launch
202 instead.  Attempts to start a second copy of Vim will cause the first Vim to
203 open the files instead.  This works from the Tracker but also from the command
204 line.  In the latter case, non-file (option) arguments are not supported.
206 NB: Only the GUI version has a BApplication (and hence Application Flags).
207 This section does not apply to the GUI-less version, should you compile one.
210 9. Fonts                                                *beos-fonts*
212 Set fonts with >
214   :set guifont=Courier10_BT/Roman/10
216 where the first part is the font family, the second part the style, and the
217 third part the size.  You can use underscores instead of spaces in family and
218 style.
220 Best results are obtained with monospaced fonts (such as Courier).  Vim
221 attempts to use all fonts in B_FIXED_SPACING mode but apparently this does not
222 work for proportional fonts (despite what the BeBook says).
224 Vim also tries to use the B_ISO8859_1 encoding, also known as ISO Latin 1.
225 This also does not work for all fonts.  It does work for Courier, but not for
226 ProFontISOLatin1/Regular (strangely enough).  You can verify this by giving the >
228   :digraphs
230 command, which lists a bunch of characters with their ISO Latin 1 encoding.
231 If, for instance, there are "box" characters among them, or the last character
232 isn't a dotted-y, then for this font the encoding does not work.
234 If the font you specify is unavailable, you get the system fixed font.
236 Standard fixed-width system fonts are:
238               ProFontISOLatin1/Regular
239                   Courier10_BT/Roman
240                   Courier10_BT/Italic
241                   Courier10_BT/Bold
242                   Courier10_BT/Bold_Italic
244 Standard proportional system fonts are:
246                     Swis721_BT/Roman
247                     Swis721_BT/Italic
248                     Swis721_BT/Bold
249                     Swis721_BT/Bold_Italic
250                 Dutch801_Rm_BT/Roman
251                 Dutch801_Rm_BT/Italic
252                 Dutch801_Rm_BT/Bold
253                 Dutch801_Rm_BT/Bold_Italic
254                    Baskerville/Roman
255                    Baskerville/Italic
256                    Baskerville/Bold
257                    Baskerville/Bold_Italic
258                  SymbolProp_BT/Regular
260 Try some of them, just for fun.
263 10. The meta key modifier                               *beos-meta*
265 The META key modifier is obtained by the left or right OPTION keys.  This is
266 because the ALT (aka COMMAND) keys are not passed to applications.
269 11. Mouse key mappings                                  *beos-mouse*
271 Vim calls the various mouse buttons LeftMouse, MiddleMouse and RightMouse.  If
272 you use the default Mouse preference settings these names indeed correspond to
273 reality.  Vim uses this mapping:
275     Button 1 -> LeftMouse,
276     Button 2 -> RightMouse,
277     Button 3 -> MiddleMouse.
279 If your mouse has fewer than 3 buttons you can provide your own mapping from
280 mouse clicks with modifier(s) to other mouse buttons.  See the file
281 vim-5.x/macros/swapmous.vim for an example.             |gui-mouse-mapping|
284 12. Color names                                         *beos-colors*
286 Vim has a number of color names built-in.  Additional names are read from the
287 file $VIMRUNTIME/rgb.txt, if present.  This file is basically the color
288 database from X.  Names used from this file are cached for efficiency.
291 13. Compiling with Perl                                 *beos-perl*
293 Compiling with Perl support enabled is slightly tricky.  The Metrowerks
294 compiler has some strange ideas where to search for include files.  Since
295 several include files with Perl have the same names as some Vim header
296 files, the wrong ones get included.  To fix this, run the following Perl
297 script while in the vim-5.0/src directory: >
299    preproc.pl > perl.h
301     #!/bin/env perl
302     # Simple #include expander, just good enough for the Perl header files.
304     use strict;
305     use IO::File;
306     use Config;
308     sub doinclude
309     {
310         my $filename = $_[0];
311         my $fh = new IO::File($filename, "r");
312         if (defined $fh) {
313             print "/* Start of $filename */\n";
315             while (<$fh>) {
316                 if (/^#include "(.*)"/) {
317                     doinclude($1);
318                     print "/* Back in $filename */\n";
319                 } else {
320                     print $_;
321                 }
322             }
323             print "/* End of $filename */\n";
325             undef $fh;
326         } else {
327             print "/* Cannot open $filename */\n";
328             print "#include \"$filename\"\n";
329         }
330     }
332     chdir     $Config{installarchlib}."/CORE";
333     doinclude "perl.h";
335 It expands the "perl.h" header file, using only other Perl header files.
337 Now you can configure & make Vim with the --enable-perlinterp option.
338 Be warned though that this adds about 616 kilobytes to the size of Vim!
339 Without Perl, Vim with default features and GUI is about 575K, with Perl
340 it is about 1191K.
342 -Olaf Seibert
344 [Note: these addresses no longer work:]
345 <rhialto@polder.ubc.kun.nl>
346 http://polder.ubc.kun.nl/~rhialto/be
348  vim:tw=78:ts=8:ft=help:norl: