/usr/share/doc/jed-common/html/jed012.html is in jed-common 1:0.99.19-2.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"
"http://www.w3.org/TR/REC-html40/loose.dtd">
<HTML>
<HEAD>
<META http-equiv="Content-Type" content="text/html; charset=US-ASCII">
<META name="GENERATOR" content="hevea 1.10">
<LINK rel="stylesheet" type="text/css" href="jed.css">
<TITLE>Modes</TITLE>
</HEAD>
<BODY >
<A HREF="jed011.html"><IMG SRC="previous_motif.gif" ALT="Previous"></A>
<A HREF="index.html"><IMG SRC="contents_motif.gif" ALT="Up"></A>
<A HREF="jed013.html"><IMG SRC="next_motif.gif" ALT="Next"></A>
<HR>
<H2 CLASS="section"><A NAME="htoc23">11</A>  Modes</H2><P><B>jed</B> supports two internal modes as well as user defined modes. The two
internal modes consist of a “C” mode for C Language programming and a
“Wrap” mode for ordinary text editing. Examples of user defined modes
are Fortran mode and DCL mode.</P><P>Online documentation is provided for nearly every mode <B>jed</B> defines.
For help on the current mode, press <SPAN STYLE="font-variant:small-caps">Esc X</SPAN> and enter
<CODE>describe_mode</CODE>. A window will appear with a short description of the
special features of the mode as well as a description of the variables
affecting the mode.</P><H3 CLASS="subsection"><A NAME="toc13"></A><A NAME="htoc24">11.1</A>  Wrap Mode</H3><P>In this mode, text is wrapped at the column given by the <CODE>WRAP</CODE>
variable. The default is 78. The text does not wrap until the cursor goes
beyond the wrap column and a space is inserted.</P><H4 CLASS="subsubsection"><A NAME="htoc25">11.1.1</A>  Formatting paragraphs</H4><P>Paragraph delimiters are: blank lines, lines that begin with either a
percent character, <TT>%</TT>, or a backslash character <CODE>\</CODE>. This
definition is ideally suited for editing L<sup>A</sup>T<sub>E</sub>X documents. However, it
is possible for the user to change this definition. See the discussion of
the hook, <CODE>is_paragraph_separator</CODE>, in the section on hooks for
explicit details on how to do this.</P><P>The paragraph is formatted according to the indentation of the current
line. If the current line is indented, the paragraph will be given the
same indentation. The default binding for this function is <SPAN STYLE="font-variant:small-caps">Esc q</SPAN>.</P><P>In addition, a paragraph may be “narrowed” by the
<CODE>narrow_paragraph</CODE> function which is bound to <SPAN STYLE="font-variant:small-caps">Esc N</SPAN> by default.
This differs from the ordinary <CODE>format_paragraph</CODE> function described
above in that the right margin is reduced by an amount equal to the
indentation of the current line. For example:
</P><PRE CLASS="verbatim"> This paragraph is the result of using the
function ``narrow_paragraph''. Note how the
right margin is less here than in the above
paragraph.
</PRE><P>Finally, if either of these functions is called from the keyboard with a
prefix argument, the paragraph will be justified as well. For example,
pressing <SPAN STYLE="font-variant:small-caps">Esc 1 Esc N</SPAN> on the previous paragraph yields:
</P><PRE CLASS="verbatim"> This paragraph is the result of using the
function ``narrow_paragraph''. Note how the
right margin is less here than in the above
paragraph.
</PRE><P>See the discussion of <CODE>format_paragraph_hook</CODE> in the section on hooks
for details on how this is implemented.</P><H3 CLASS="subsection"><A NAME="toc14"></A><A NAME="htoc26">11.2</A>  Smart Quotes</H3><P>You have probably noticed that many key words in this document are quoted
in double quotes like “this is double quoted” and ‘this is single
quoted’. By default, the double quote key (") and single quote key (’) are
bound to the function <CODE>text_smart_quote</CODE>. With this binding and in
wrap mode, the single quote key inserts a single quote with the “proper”
orientation and the double quote key inserts two single quotes of the
“proper” direction. To turn this off, rebind the keys to
<CODE>self_insert_cmd</CODE>. Some modes already do this (e.g., EDT).</P><P>This brings up the question: if the double quote key is bound to
<CODE>text_smart_quote</CODE> then how does one insert the character (")? The
most common way is to use the <CODE>quoted_insert</CODE> function which, by
default, is bound to the single backquote (<SPAN STYLE="font-variant:small-caps">‘</SPAN>) key. This is the same
mechanism that is used to insert control characters. The other method is
to use the fact that if the preceding character is a backslash, <CODE>\</CODE>,
the character simply self inserts. Again, this is ideal for writing
T<sub>E</sub>X documents.</P><H3 CLASS="subsection"><A NAME="toc15"></A><A NAME="htoc27">11.3</A>  C Mode</H3><P>C Mode facilitates the editing of C files. Much of the latter part of the
development of the <B>jed</B> editor was done using this mode. This mode may be
customized by a judicious choice of the variables <CODE>C_INDENT</CODE> and
<CODE>C_BRACE</CODE> as well as the bindings of the curly brace keys <TT>{</TT>
and <SPAN STYLE="font-variant:small-caps">}</SPAN>. Experiment to find what you like or write your own using the
<B>S-Lang</B> interface.</P><P>By default, the <SPAN STYLE="font-variant:small-caps">Enter</SPAN> key is bound to the function
<CODE>newline_and_indent</CODE>. This does what its name suggests: inserts a
newline and indents. Again, some modes may rebind this key. In addition,
the keys <TT>{</TT>, <TT>}</TT>, and <SPAN STYLE="font-variant:small-caps">Tab</SPAN> are also special in this mode.
The <SPAN STYLE="font-variant:small-caps">Tab</SPAN> key indents the current line and the <TT>{</TT> and <TT>}</TT>
keys insert themselves and reindent. If you do not like any of these
bindings, simply rebind the offending one to <CODE>self_insert_cmd</CODE>.</P><P>Finally, the key sequence <SPAN STYLE="font-variant:small-caps">Esc ;</SPAN> is bound to a function called
<CODE>c_make_comment</CODE>. This function makes and indents a C comment to the
column specified by the value of the variable <CODE>C_Comment_Column</CODE>. If
a comment is already present on the line, it is indented.</P><H3 CLASS="subsection"><A NAME="toc16"></A><A NAME="htoc28">11.4</A>  Fortran Mode</H3><P>Fortran Mode is written entirely in <B>S-Lang</B> and is designed to facilitate
the writing of Fortran programs. It features automatic indentation of
Fortran code as well as automatic placement of Fortran statement Labels.</P><P>In this mode, the keys <SPAN STYLE="font-variant:small-caps">0</SPAN>-<SPAN STYLE="font-variant:small-caps">9</SPAN> are bound to a function
<CODE>for_elebel</CODE> which does the following:
</P><OL CLASS="enumerate" type=1><LI CLASS="li-enumerate">
Inserts the calling character (0-9) into the buffer.</LI><LI CLASS="li-enumerate">If the character is preceded by only other digit characters, it
assumes the character is for a label and moves it to the appropriate
position.</LI><LI CLASS="li-enumerate">Reindents the line.
</LI></OL><P>This function is very similar to the one Emacs uses for labels.</P><HR>
<A HREF="jed011.html"><IMG SRC="previous_motif.gif" ALT="Previous"></A>
<A HREF="index.html"><IMG SRC="contents_motif.gif" ALT="Up"></A>
<A HREF="jed013.html"><IMG SRC="next_motif.gif" ALT="Next"></A>
</BODY>
</HTML>
|