Slightly better basic type detection.
[sxemacs] / info / new-users-guide / modes.texi
1 @comment  node-name,  next,  previous,  up
2 @node Modes, Files, Help, Top
3 @chapter Major and Minor Modes
4 @cindex modes
5
6 SXEmacs is @dfn{language sensitive}. It has several @dfn{major} and
7 @dfn{minor} modes.  The major modes customize Emacs to edit text of a
8 particular sort. There are major modes for C, Lisp, Emacs Lisp, LaTeX,
9 English etc. Within each major mode, certain functions and keys are
10 redefined to "suit" that particular sort of text. The minor modes
11 provide certain features which can be turned off or on at any
12 time. Emacs can only be in one major mode at any time, but it can turn
13 on several minor modes at the same time. After you have selected any
14 major or minor mode, you can select @b{Describe Mode} from the @b{Help}
15 menu and you will get documentation about those modes. 
16
17 @comment  node-name,  next,  previous,  up
18 @menu
19 * Major Modes::                 Choosing Major Modes
20 * Minor Modes::                 Auto-Fill, Abbrev and other minor modes
21 @end menu
22
23 @node Major Modes, Minor Modes, Modes, Modes
24 @section Major Modes
25 @cindex major modes
26
27 Emacs has several major modes which customize Emacs to edit text of
28 various sorts. You can have only one major mode at any time. Within each
29 major mode, Emacs redefines certain functions (like cursor movement,
30 indentation and text killing) to suit the needs of the text being
31 edited. When you are editing a specific type of text you should switch
32 to the appropriate mode. If you are working with C code, you should
33 switch to C mode; if you are working with Lisp code, then switch to lisp
34 mode and if you are working with English text switch to Text mode.
35
36         When you open a file to work on, Emacs usually selects the
37 appropriate mode. For example, if you open a file called @file{guide.c}
38 then Emacs will select the C mode because of the ".c" extension of the
39 file. To explicitly select a mode type the following command:
40
41 @example
42 ;;; selects lisp mode
43 M-x lisp-mode
44
45 ;;; selects C mode
46 M-x c-mode
47 @end example
48
49 @noindent
50 To select any other mode, just add the major mode name before the
51 '-mode'. The current mode in which you are in will be displayed in
52 parenthesis in the mode-line at the bottom of the frame. All major
53 modes have some special keybindings and you can get a listing of those
54 keybindings by selecting @b{List Keybindings} from the @b{Help} menu on
55 the menu bar.
56
57         Some of the available modes in SXEmacs are :
58
59 @table @b
60 @item fundamental-mode 
61 @cindex fundamental-mode
62 When you start SXEmacs, usually you start with the default "Fundamental"
63 mode. This mode has no special definitions or settings.   
64
65 @item nroff-mode
66 @cindex nroff-mode
67 Use this mode when you have to format a text with nroff before it can be
68 available in readable form. It redefines some indentation
69 commands. @xref{Nroff Mode,,,sxemacs,SXEmacs User's Manual}, for information
70 on this mode.
71
72 @item tex-mode
73 @cindex tex-mode
74 Use this mode if you are using the LaTeX text-formatter. It provides
75 commands for insertion of quotes, braces and other characters. It also
76 allows you to format the buffer for printing. @xref{TeX
77 Mode,,,sxemacs,SXEmacs User's Manual}, for information on this mode.
78
79 @item texinfo-mode
80 @cindex texinfo-mode
81 Texinfo is a documentation system that uses a single source file to
82 produce both printed output and on-line documentation. When you use this
83 mode, there will be some special keybindings for inserting some
84 characters and executing some commands.
85
86 @ifinfo
87 This info file which you are reading right now is produced by 'Texinfo'
88 @end ifinfo
89 @iftex
90 This manual itself is produced by 'Texinfo'
91 @end iftex
92
93 @item outline-mode
94 @cindex outline-mode
95 Use this mode for editing outlines. When you enable this mode, you can
96 make part of the text temporarily invisible so that you can see the
97 overall structure of the outline. @xref{Outline Mode,,,sxemacs,SXEmacs User's
98 Manual}, for information on this mode.
99
100 @item c-mode
101 @cindex c-mode
102 Use this mode for C programs. It will redefine some indentation
103 commands. @xref{C Indent,,,sxemacs,SXEmacs User's Manual}.
104
105 @item lisp-mode
106 @cindex lisp-mode
107 Use this mode for Lisp programs. Look at the SXEmacs User's Manual for
108 more information.
109
110 @item fortran-mode
111 @cindex fortran-mode
112 Use this mode for Fortran programs. This mode provides special commands
113 to move around and some other indentation commands.  For more
114 information on this mode, @xref{Fortran,,,sxemacs,SXEmacs User's Manual}.
115
116 @item edit-picture
117 @cindex edit-picture
118 This is the picture mode which you can use to create a picture out of
119 text characters. @xref{Picture,,,sxemacs,SXEmacs User's Manual}, for more
120 information.
121
122 @end table
123
124 There are some other modes and commands for working with other kinds of
125 text or programs. Emacs also provides commands for reading and sending
126 Mail. For more information on these features look at the SXEmacs
127 Manual. Emacs also provides the functions of a desk calendar, with a
128 diary of past or planned events. For more information on the calendar
129 mode look at the manual for Calendar Mode and Diary.
130
131 @comment  node-name,  next,  previous,  up
132 @node Minor Modes,  , Major Modes, Modes
133 @section Minor Modes
134 @cindex minor modes
135
136 The minor modes in Emacs provide some optional features which you can
137 turn on or off. Any number of minor modes can be active at the same time
138 with any major mode. You can enable a minor mode in one buffer and
139 disable it in other mode. To enable a minor mode, for example the
140 font-lock mode type the following command: 
141
142 @example
143 M-x font-lock-mode
144 @end example
145 @noindent
146 To enable the other minor modes, replace the "font-lock" with the
147 name of the minor mode. To disable the mode type the command again. A
148 positive argument will always turn the mode on. Whenever you type this
149 command, it will turn the mode on if it was off, OR it will turn it off
150 if it was on i.e. it toggles. Look at the mode-line at the bottom of the
151 frame. If it says FLock in parentheses, then it means that this
152 mode is on, otherwise it is off. 
153
154 The following are some of the minor modes available in SXEmacs. To enable
155 any one of them type "M-x" in front of them.
156
157 @table @b
158 @item font-lock-mode
159 @cindex font-lock-mode
160
161 You can also choose this mode by selecting the @b{Syntax Highlighting}
162 menu item from the @b{Options} menu on the menu-bar at the
163 top. If you wish to have this mode enabled permanently, choose 
164 @b{Save Options} from the @b{Options} menu. @xref{Options Menu}, for
165 more information on the Options menu.  You can also add statements in
166 your @file{init.el} file. For each major mode in which you wish to
167 enable this minor mode, you need a statement in your @file{init.el}
168 file. The following example shows how to enable the font-lock mode when
169 the major mode is c-mode. 
170
171 @example
172 (add-hook 'c-mode-hook          'turn-on-font-lock)
173 @end example
174
175 @noindent
176 @xref{Other Customizations}.
177
178 When you enable this mode, the text will be displayed in
179 different colors and fonts depending on the type of the text. This makes
180 the text very easy to read and understand. For example, comments might
181 be displayed in red, variables in black, functions in blue and other
182 keywords in different colors and fonts. When you select @b{More} from
183 the @b{Syntax Highlighting} option, you get very detailed display of
184 colors and fonts; function names within comments themselves might appear
185 in a different font and color.  
186
187 @item auto-fill-mode
188 @findex auto-fill-mode
189 Enabling this mode will provide automatic word-wrapping. The @key{SPC}
190 key will break lines i.e. insert newlines as you type to prevent lines
191 from becoming too long. 
192
193 @item overwrite-mode
194 @cindex overwrite-mode
195 When you enable this mode, the text that you type will replace the
196 existing text rather than moving it to the right (the default case). You
197 can enable this mode by selecting @b{Overstrike} menu-item from the
198 @b{Options} menu from the menu-bar. 
199
200 @item abbrev-mode
201 @cindex abbrev-mode
202 After you enable this mode, you can define words which will expand into
203 some different text i.e. you can define abbreviations. For example, you
204 might define "expand" to "expand will eventually expand to this
205 text". After this definition you will be able to get "expand will
206 eventually expand to this text" simply by typing 
207
208 @example
209 expand @key{SPC} 
210 @end example
211
212 @noindent
213  @xref{Abbrevs,,,sxemacs,SXEmacs User's Manual}, for more information on this
214 mode and on defining abbreviations.
215
216 @item auto-save-mode
217 @cindex auto-save-mode
218 After you enable this mode in a buffer, the contents of that buffer will
219 be saved periodically. This will reduce the amount you might lose in
220 case of a system crash.
221
222 @item line-number-mode
223 @cindex line-number-mode
224 After you enable this mode, the line number at which your cursor is
225 present will be displayed continuously in the mode line. 
226
227 @item blink-paren
228 @cindex blink-paren
229 To enable this command, just type 
230 @example
231 M-x blink-paren
232 @end example
233
234 @noindent
235 Do not add the "-mode" to it.  You can also select the @b{Paren
236 Highlighting} option from the @b{Options} menu. After you enable this
237 command, put your cursor on one of the left parenthesis. The other
238 matching parenthesis will start blinking. @xref{Options Menu}, for more
239 information on the @b{Paren Highlighting} option.
240 @end table
241
242 For information on some other modes, look at the SXEmacs User's Manual
243 and the associated files.
244