2012-03-22 21:14:52 +04:00
|
|
|
.TH MCEDIT 1 "%DATE_OF_MAN_PAGE%" "MC Version %DISTR_VERSION%" "GNU Midnight Commander"
|
1998-02-27 07:54:42 +03:00
|
|
|
.SH NAME
|
2003-02-12 00:46:19 +03:00
|
|
|
mcedit \- Internal file editor of GNU Midnight Commander.
|
1998-02-27 07:54:42 +03:00
|
|
|
.SH USAGE
|
|
|
|
.B mcedit
|
2008-12-18 15:21:23 +03:00
|
|
|
[\-bcCdfhstVx?] [+lineno] file
|
|
|
|
.PP
|
|
|
|
.B mcedit
|
|
|
|
[\-bcCdfhstVx?] file:lineno[:]
|
1998-02-27 07:54:42 +03:00
|
|
|
.SH DESCRIPTION
|
|
|
|
.LP
|
2003-01-19 20:47:50 +03:00
|
|
|
mcedit is a link to
|
|
|
|
.BR mc ,
|
|
|
|
the main GNU Midnight Commander executable. Executing GNU Midnight
|
|
|
|
Commander under this name requests staring the internal editor and
|
|
|
|
opening the
|
|
|
|
.I file
|
|
|
|
specified on the command line. The editor is based on the terminal
|
|
|
|
version of
|
|
|
|
.B cooledit
|
|
|
|
\- standalone editor for X Window System.
|
1998-02-27 07:54:42 +03:00
|
|
|
.SH OPTIONS
|
|
|
|
.TP
|
2008-12-18 15:21:23 +03:00
|
|
|
.I "+lineno"
|
|
|
|
Go to the line specified by number (do not put a space between the
|
2003-01-20 16:58:36 +03:00
|
|
|
.I "+"
|
|
|
|
sign and the number).
|
1999-12-09 01:15:13 +03:00
|
|
|
.TP
|
1998-02-27 07:54:42 +03:00
|
|
|
.I "\-b"
|
2003-01-19 20:47:50 +03:00
|
|
|
Force black and white display.
|
1998-02-27 07:54:42 +03:00
|
|
|
.TP
|
|
|
|
.I "\-c"
|
2003-01-28 23:03:11 +03:00
|
|
|
Force ANSI color mode on terminals that don't seem to have color
|
|
|
|
support.
|
1998-02-27 07:54:42 +03:00
|
|
|
.TP
|
2010-12-29 12:58:10 +03:00
|
|
|
.I "\-C <keyword>=<fgcolor>,<bgcolor>,<attributes>:<keyword>= ..."
|
2003-01-19 20:47:50 +03:00
|
|
|
Specify a different color set. See the
|
|
|
|
.B Colors
|
|
|
|
section in mc(1) for more information.
|
1998-02-27 07:54:42 +03:00
|
|
|
.TP
|
|
|
|
.I "\-d"
|
2003-01-19 20:47:50 +03:00
|
|
|
Disable mouse support.
|
1998-02-27 07:54:42 +03:00
|
|
|
.TP
|
|
|
|
.I "\-f"
|
2009-08-21 16:14:02 +04:00
|
|
|
Display the compiled\-in search path for GNU Midnight Commander data
|
2003-01-20 16:58:36 +03:00
|
|
|
files.
|
1998-02-27 07:54:42 +03:00
|
|
|
.TP
|
|
|
|
.I "\-t"
|
2003-01-28 23:03:11 +03:00
|
|
|
Force using termcap database instead of terminfo. This option is only
|
2009-08-21 16:14:02 +04:00
|
|
|
applicable if GNU Midnight Commander was compiled with S\-Lang library
|
2003-01-28 23:03:11 +03:00
|
|
|
with terminfo support.
|
1998-02-27 07:54:42 +03:00
|
|
|
.TP
|
|
|
|
.I "\-V"
|
2003-01-19 20:47:50 +03:00
|
|
|
Display the version of the program.
|
1998-02-27 07:54:42 +03:00
|
|
|
.TP
|
|
|
|
.I "\-x"
|
2009-08-21 16:14:02 +04:00
|
|
|
Force xterm mode. Used when running on xterm\-capable terminals (two
|
1998-02-27 07:54:42 +03:00
|
|
|
screen modes, and able to send mouse escape sequences).
|
2003-01-19 20:47:50 +03:00
|
|
|
.SH FEATURES
|
2009-08-21 16:14:02 +04:00
|
|
|
The internal file editor is a full\-featured full screen editor. It can
|
2003-01-28 23:03:11 +03:00
|
|
|
edit files up to 64 megabytes. It is possible to edit binary files.
|
|
|
|
The features it presently supports are: block copy, move, delete, cut,
|
2009-08-21 16:14:02 +04:00
|
|
|
paste; key for key undo; pull\-down menus; file insertion; macro
|
2003-01-28 23:03:11 +03:00
|
|
|
commands; regular expression search and replace (and our own
|
2009-08-21 16:14:02 +04:00
|
|
|
scanf\-printf search and replace); shift\-arrow text highlighting (if
|
|
|
|
supported by the terminal); insert\-overwrite toggle; word wrap;
|
2003-01-28 23:03:11 +03:00
|
|
|
autoindent; tunable tab size; syntax highlighting for various file
|
|
|
|
types; and an option to pipe text blocks through shell commands like
|
|
|
|
indent and ispell.
|
2003-01-19 20:47:50 +03:00
|
|
|
.SH KEYS
|
2003-01-28 23:03:11 +03:00
|
|
|
The editor is easy to use and can be used without learning. The
|
2009-08-21 16:14:02 +04:00
|
|
|
pull\-down menu is invoked by pressing F9. You can learn other keys from
|
2003-01-28 23:43:10 +03:00
|
|
|
the menu and from the button bar labels.
|
2003-01-28 23:03:11 +03:00
|
|
|
.PP
|
|
|
|
In addition to that, Shift combined with arrows does text highlighting
|
|
|
|
(if supported by the terminal):
|
2009-08-21 16:14:02 +04:00
|
|
|
.B Ctrl\-Ins
|
2003-01-19 20:47:50 +03:00
|
|
|
copies to the file
|
2010-12-30 22:10:20 +03:00
|
|
|
.BR ~/.cache/mc/mcedit/mcedit.clip ,
|
2009-08-21 16:14:02 +04:00
|
|
|
.B Shift\-Ins
|
2003-01-19 20:47:50 +03:00
|
|
|
pastes from
|
2010-12-30 22:10:20 +03:00
|
|
|
.BR ~/.cache/mc/mcedit/mcedit.clip ,
|
2009-08-21 16:14:02 +04:00
|
|
|
.B Shift\-Del
|
2003-01-19 20:47:50 +03:00
|
|
|
cuts to
|
2010-12-30 22:10:20 +03:00
|
|
|
.BR ~/.cache/mc/mcedit/mcedit.clip ,
|
2003-01-19 20:47:50 +03:00
|
|
|
and
|
2009-08-21 16:14:02 +04:00
|
|
|
.B Ctrl\-Del
|
2003-01-28 23:03:11 +03:00
|
|
|
deletes highlighted text. Mouse highlighting also works on some
|
|
|
|
terminals. To use the standard mouse support provided by your terminal,
|
2003-01-28 23:43:10 +03:00
|
|
|
hold the Shift key. Please note that the mouse support in the terminal
|
|
|
|
doesn't share the clipboard with
|
2003-01-28 23:03:11 +03:00
|
|
|
.BR mcedit .
|
2002-09-20 19:42:46 +04:00
|
|
|
.PP
|
|
|
|
The completion key (usually
|
2009-08-21 16:14:02 +04:00
|
|
|
.B "Meta\-Tab"
|
2002-09-20 19:42:46 +04:00
|
|
|
or
|
2003-01-28 23:03:11 +03:00
|
|
|
.BR "Escape Tab" )
|
2002-09-20 19:42:46 +04:00
|
|
|
completes the word under the cursor using the words used earlier in the
|
|
|
|
file.
|
2011-01-28 11:59:18 +03:00
|
|
|
.SH MACRO
|
2002-09-20 19:42:46 +04:00
|
|
|
.PP
|
2003-01-19 20:47:50 +03:00
|
|
|
To define a macro, press
|
2009-08-21 16:14:02 +04:00
|
|
|
.B Ctrl\-R
|
2003-01-28 23:03:11 +03:00
|
|
|
and then type out the keys you want to be executed. Press
|
2009-08-21 16:14:02 +04:00
|
|
|
.B Ctrl\-R
|
2011-01-28 11:59:18 +03:00
|
|
|
again when finished. The macro can be assigned to any key by pressing that key.
|
|
|
|
The macro is executed when you press the assigned key.
|
|
|
|
.PP
|
|
|
|
The macro commands are stored in section
|
|
|
|
.B [editor]
|
|
|
|
it the file
|
|
|
|
.BR ~/.local/share/mc/mc.macros .
|
|
|
|
.PP
|
|
|
|
External scripts (filters) can be assigned into the any hotkey by edit
|
|
|
|
.B mc.macros
|
|
|
|
like following:
|
|
|
|
.PP
|
|
|
|
.nf
|
|
|
|
[editor]
|
2011-02-20 18:23:32 +03:00
|
|
|
ctrl\-W=ExecuteScript:25;
|
2011-01-28 11:59:18 +03:00
|
|
|
.fi
|
|
|
|
.PP
|
|
|
|
This means that ctrl\-W hotkey initiates the
|
2011-02-20 18:23:32 +03:00
|
|
|
.I ExecuteScript(25)
|
|
|
|
action, then editor handler translates this into execution of
|
2011-01-28 11:59:18 +03:00
|
|
|
.B ~/.local/share/mc/mcedit/macros.d/macro.25.sh
|
|
|
|
shell script.
|
|
|
|
.PP
|
2011-02-20 18:23:32 +03:00
|
|
|
External scripts are stored in
|
2011-01-28 11:59:18 +03:00
|
|
|
.B ~/.local/share/mc/mcedit/macros.d/
|
2011-02-20 18:23:32 +03:00
|
|
|
directory and must be named as
|
2011-01-28 11:59:18 +03:00
|
|
|
.B macro.XXXX.sh
|
|
|
|
where
|
|
|
|
.B XXXX
|
|
|
|
is the number from 0 to 9999.
|
|
|
|
See
|
|
|
|
.B Menu File Edit
|
|
|
|
for more detail about format of the script.
|
|
|
|
.PP
|
2011-02-01 01:08:15 +03:00
|
|
|
Following macro definition and directives can be used:
|
|
|
|
.TP
|
2011-03-14 16:10:35 +03:00
|
|
|
.I #silent
|
|
|
|
If this directive is set, then script starts without interactive subshell.
|
2011-01-28 11:59:18 +03:00
|
|
|
.TP
|
|
|
|
.I %c
|
|
|
|
The cursor column position number.
|
|
|
|
.TP
|
|
|
|
.I %i
|
|
|
|
The indent of blank space, equal the cursor column.
|
|
|
|
.TP
|
|
|
|
.I %y
|
|
|
|
The syntax type of current file.
|
|
|
|
.TP
|
|
|
|
.I %b
|
|
|
|
The block file name.
|
|
|
|
.TP
|
|
|
|
.I %f
|
|
|
|
The current file name.
|
|
|
|
.TP
|
|
|
|
.I %n
|
|
|
|
Only the current file name without extension.
|
|
|
|
.TP
|
|
|
|
.I %x
|
|
|
|
The extension of current file name.
|
|
|
|
.TP
|
|
|
|
.I %d
|
|
|
|
The current directory name.
|
|
|
|
.TP
|
|
|
|
.I %F
|
|
|
|
The current file in the unselected panel.
|
|
|
|
.TP
|
|
|
|
.I %D
|
|
|
|
The directory name of the unselected panel.
|
|
|
|
.TP
|
|
|
|
.I %t
|
|
|
|
The currently tagged files.
|
|
|
|
.TP
|
|
|
|
.I %T
|
|
|
|
The tagged files in the unselected panel.
|
|
|
|
.TP
|
|
|
|
.I %u
|
|
|
|
and
|
|
|
|
.I %U
|
|
|
|
Similar to the
|
|
|
|
.I %t
|
|
|
|
and
|
|
|
|
.I %T
|
|
|
|
macros, but in addition the files are untagged. You can use this macro
|
|
|
|
only once per menu file entry or extension file entry, because next time
|
|
|
|
there will be no tagged files.
|
|
|
|
.TP
|
|
|
|
.I %s
|
|
|
|
and
|
|
|
|
.I %S
|
|
|
|
The selected files: The tagged files if there are any. Otherwise the
|
|
|
|
current file.
|
|
|
|
.PP
|
|
|
|
Feel free to edit this files, if you need.
|
|
|
|
Here is a sample external script:
|
|
|
|
.PP
|
|
|
|
.nf
|
|
|
|
l comment selection
|
|
|
|
TMPFILE=`mktemp ${MC_TMPDIR:\-/tmp}/up.XXXXXX` || exit 1
|
|
|
|
echo #if 0 > $TMPFILE
|
|
|
|
cat %b >> $TMPFILE
|
|
|
|
echo #endif >> $TMPFILE
|
|
|
|
cat $TMPFILE > %b
|
|
|
|
rm \-f $TMPFILE
|
|
|
|
.fi
|
1998-02-27 07:54:42 +03:00
|
|
|
.PP
|
2003-01-28 23:03:11 +03:00
|
|
|
If some keys don't work, you can use
|
|
|
|
.B Learn Keys
|
|
|
|
in the
|
|
|
|
.B Options
|
|
|
|
menu.
|
2009-06-23 13:50:58 +04:00
|
|
|
.SH CODE NAVIGATION
|
|
|
|
.B mcedit
|
|
|
|
can be used to navigation through code with tags files created by etags
|
|
|
|
or ctags commands. If there is no file TAGS code navigation would not work.
|
2009-08-21 16:14:02 +04:00
|
|
|
In example, in case of exuberant\-ctags for C language command will be:
|
2009-06-23 13:50:58 +04:00
|
|
|
.PP
|
2009-08-21 16:14:02 +04:00
|
|
|
ctags \-e \-\-language\-force=C \-R ./
|
2009-06-23 13:50:58 +04:00
|
|
|
.PP
|
2009-08-21 16:14:02 +04:00
|
|
|
.B Meta\-Enter
|
2009-06-23 13:50:58 +04:00
|
|
|
show list box to select item under cursor (cusor should stand at end of
|
|
|
|
word).
|
|
|
|
.PP
|
2009-08-21 16:14:02 +04:00
|
|
|
.B Meta\-Minus
|
|
|
|
where minus is symbol "\-" go to previous function in navigation list (like a browser
|
2009-06-23 13:50:58 +04:00
|
|
|
Back).
|
|
|
|
.PP
|
2009-08-21 16:14:02 +04:00
|
|
|
.B Meta\-Equal
|
2009-06-23 13:50:58 +04:00
|
|
|
where equal is symbol "=" go to next function in navigation list (like a browser
|
|
|
|
Forward).
|
|
|
|
.PP
|
1998-04-24 19:18:08 +04:00
|
|
|
.SH SYNTAX HIGHLIGHTING
|
2003-01-20 16:58:36 +03:00
|
|
|
.B mcedit
|
2003-01-19 20:47:50 +03:00
|
|
|
supports syntax highlighting. This means that keywords and contexts
|
|
|
|
(like C comments, string constants, etc) are highlighted in different
|
|
|
|
colors. The following section explains the format of the file
|
2011-12-01 18:30:02 +04:00
|
|
|
.BR ~/.config/mc/mcedit/Syntax .
|
2009-08-21 16:14:02 +04:00
|
|
|
If this file is missing, system\-wide
|
2012-03-22 21:14:52 +04:00
|
|
|
.B %prefix%/share/mc/syntax/Syntax
|
2003-03-04 13:34:28 +03:00
|
|
|
is used.
|
2003-01-19 20:47:50 +03:00
|
|
|
The file
|
2011-12-01 18:30:02 +04:00
|
|
|
.B ~/.config/mc/mcedit/Syntax
|
2003-01-19 20:47:50 +03:00
|
|
|
is rescanned on opening of a any new editor file. The file contains
|
|
|
|
rules for highlighting, each of which is given on a separate line, and
|
2003-01-28 23:03:11 +03:00
|
|
|
define which keywords will be highlighted to what color.
|
|
|
|
.PP
|
|
|
|
The file is divided into sections, each beginning with a line with the
|
2003-01-19 20:47:50 +03:00
|
|
|
.B file
|
2003-01-28 23:03:11 +03:00
|
|
|
command. The sections are normally put into separate files using the
|
|
|
|
.B include
|
|
|
|
command.
|
2003-01-19 20:47:50 +03:00
|
|
|
.PP
|
2003-01-28 23:03:11 +03:00
|
|
|
The
|
|
|
|
.B file
|
|
|
|
command has three arguments. The first argument is a regular expression
|
|
|
|
that is applied to the file name to determine if the following section
|
|
|
|
applies to the file. The second argument is the description of the file
|
|
|
|
type. It is used in
|
|
|
|
.BR cooledit ;
|
|
|
|
future versions of
|
|
|
|
.B mcedit
|
|
|
|
may use it as well. The third optional argument is a regular expression
|
|
|
|
to match the first line of text of the file. The rules in the following
|
|
|
|
section apply if either the file name or the first line of text matches.
|
|
|
|
.PP
|
|
|
|
A section ends with the start of another section. Each section is
|
|
|
|
divided into contexts, and each context contains rules. A context is a
|
|
|
|
scope within the text that a particular set of rules belongs to. For
|
|
|
|
instance, the text within a C style comment (i.e. between
|
2003-01-19 20:47:50 +03:00
|
|
|
.B /*
|
|
|
|
and
|
|
|
|
.BR */ )
|
2003-01-28 23:03:11 +03:00
|
|
|
has its own color. This is a context, although it has no further rules
|
|
|
|
inside it because there is probably nothing that we want highlighted
|
|
|
|
within a C comment.
|
2003-01-19 20:47:50 +03:00
|
|
|
.PP
|
1998-04-24 19:18:08 +04:00
|
|
|
A trivial C programming section might look like this:
|
|
|
|
.PP
|
|
|
|
.nf
|
1998-12-11 01:14:10 +03:00
|
|
|
file .\\*\\\\.c C\\sProgram\\sFile (#include|/\\\\\\*)
|
1998-04-24 19:18:08 +04:00
|
|
|
|
|
|
|
wholechars abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_
|
|
|
|
|
|
|
|
# default colors
|
2003-03-04 13:34:28 +03:00
|
|
|
define comment brown
|
1998-04-24 19:18:08 +04:00
|
|
|
context default
|
2003-01-28 23:43:10 +03:00
|
|
|
keyword whole if yellow
|
|
|
|
keyword whole else yellow
|
|
|
|
keyword whole for yellow
|
|
|
|
keyword whole while yellow
|
|
|
|
keyword whole do yellow
|
|
|
|
keyword whole switch yellow
|
|
|
|
keyword whole case yellow
|
|
|
|
keyword whole static yellow
|
|
|
|
keyword whole extern yellow
|
|
|
|
keyword { brightcyan
|
|
|
|
keyword } brightcyan
|
|
|
|
keyword '*' green
|
1998-04-24 19:18:08 +04:00
|
|
|
|
|
|
|
# C comments
|
2003-03-04 13:34:28 +03:00
|
|
|
context /\\* \\*/ comment
|
1998-04-24 19:18:08 +04:00
|
|
|
|
|
|
|
# C preprocessor directives
|
2003-01-28 23:43:10 +03:00
|
|
|
context linestart # \\n red
|
|
|
|
keyword \\\\\\n brightred
|
1998-04-24 19:18:08 +04:00
|
|
|
|
|
|
|
# C string constants
|
2003-01-28 23:43:10 +03:00
|
|
|
context " " green
|
|
|
|
keyword %d brightgreen
|
|
|
|
keyword %s brightgreen
|
|
|
|
keyword %c brightgreen
|
|
|
|
keyword \\\\" brightgreen
|
1998-04-24 19:18:08 +04:00
|
|
|
.fi
|
|
|
|
.PP
|
|
|
|
Each context starts with a line of the form:
|
2003-01-28 23:43:10 +03:00
|
|
|
.PP
|
2003-01-20 16:58:36 +03:00
|
|
|
.B context
|
|
|
|
.RB [ exclusive ]
|
|
|
|
.RB [ whole | wholeright | wholeleft ]
|
|
|
|
.RB [ linestart ]
|
|
|
|
.I delim
|
|
|
|
.RB [ linestart ]
|
|
|
|
.I delim
|
|
|
|
.RI [ foreground ]
|
|
|
|
.RI [ background ]
|
2010-12-29 12:58:10 +03:00
|
|
|
.RI [ attributes ]
|
2003-01-28 23:43:10 +03:00
|
|
|
.PP
|
|
|
|
The first context is an exception. It must start with the command
|
|
|
|
.PP
|
2003-03-04 13:34:28 +03:00
|
|
|
.B context default
|
2003-01-20 16:58:36 +03:00
|
|
|
.RI [ foreground ]
|
|
|
|
.RI [ background ]
|
2010-12-29 12:58:10 +03:00
|
|
|
.RI [ attributes ]
|
2003-01-28 23:43:10 +03:00
|
|
|
.PP
|
|
|
|
otherwise
|
2003-01-20 16:58:36 +03:00
|
|
|
.B mcedit
|
|
|
|
will report an error. The
|
|
|
|
.B linestart
|
2003-01-28 23:43:10 +03:00
|
|
|
option specifies that
|
2003-01-20 16:58:36 +03:00
|
|
|
.I delim
|
|
|
|
must start at the beginning of a line. The
|
|
|
|
.B whole
|
2003-01-28 23:43:10 +03:00
|
|
|
option tells that
|
|
|
|
.I delim
|
|
|
|
must be a whole word. To specify that a word must begin on the word
|
|
|
|
boundary only on the left side, you can use the
|
2003-01-20 16:58:36 +03:00
|
|
|
.B wholeleft
|
2003-01-28 23:43:10 +03:00
|
|
|
option, and similarly a word that must end on the word boundary is specified by
|
|
|
|
.BR wholeright .
|
|
|
|
.PP
|
|
|
|
The set of characters that constitute a whole word can be changed at any
|
|
|
|
point in the file with the
|
|
|
|
.B wholechars
|
|
|
|
command. The left and right set of characters can be set separately
|
|
|
|
with
|
|
|
|
.PP
|
2003-01-20 16:58:36 +03:00
|
|
|
.B wholechars
|
|
|
|
.RB [ left | right ]
|
|
|
|
.I characters
|
|
|
|
.PP
|
|
|
|
The
|
|
|
|
.B exclusive
|
|
|
|
option causes the text between the delimiters to be highlighted, but not
|
|
|
|
the delimiters themselves.
|
|
|
|
.PP
|
1998-04-24 19:18:08 +04:00
|
|
|
Each rule is a line of the form:
|
2003-01-28 23:43:10 +03:00
|
|
|
.PP
|
2003-01-20 16:58:36 +03:00
|
|
|
.B keyword
|
|
|
|
.RB [ whole | wholeright | wholeleft ]
|
|
|
|
.RB [ linestart ]
|
2003-03-04 13:34:28 +03:00
|
|
|
.I string foreground
|
2003-01-20 16:58:36 +03:00
|
|
|
.RI [ background ]
|
2010-12-29 12:58:10 +03:00
|
|
|
.RI [ attributes ]
|
2003-01-28 23:43:10 +03:00
|
|
|
.PP
|
|
|
|
Context or keyword strings are interpreted, so that you can include tabs
|
|
|
|
and spaces with the sequences \\t and \\s. Newlines and backslashes are
|
2001-09-03 22:01:45 +04:00
|
|
|
specified with \\n and \\\\ respectively. Since whitespace is used as a
|
|
|
|
separator, it may not be used as is. Also, \\* must be used to specify
|
2003-01-28 23:43:10 +03:00
|
|
|
an asterisk. The * itself is a wildcard that matches any length of
|
|
|
|
characters. For example,
|
|
|
|
.PP
|
1998-04-24 19:18:08 +04:00
|
|
|
.nf
|
2003-01-28 23:43:10 +03:00
|
|
|
keyword '*' green
|
1998-04-24 19:18:08 +04:00
|
|
|
.fi
|
2003-01-28 23:43:10 +03:00
|
|
|
.PP
|
|
|
|
colors all C single character constants green. You also could use
|
|
|
|
.PP
|
1998-04-24 19:18:08 +04:00
|
|
|
.nf
|
2003-01-28 23:43:10 +03:00
|
|
|
keyword "*" green
|
1998-04-24 19:18:08 +04:00
|
|
|
.fi
|
2003-01-28 23:43:10 +03:00
|
|
|
.PP
|
|
|
|
to color string constants, but the matched string would not be allowed
|
|
|
|
to span across multiple newlines. The wildcard may be used within
|
|
|
|
context delimiters as well, but you cannot have a wildcard as the last
|
|
|
|
or first character.
|
2003-01-20 16:58:36 +03:00
|
|
|
.PP
|
1998-04-24 19:18:08 +04:00
|
|
|
Important to note is the line
|
2003-01-28 23:43:10 +03:00
|
|
|
.PP
|
1998-04-24 19:18:08 +04:00
|
|
|
.nf
|
2003-01-28 23:43:10 +03:00
|
|
|
keyword \\\\\\n brightgreen
|
1998-04-24 19:18:08 +04:00
|
|
|
.fi
|
2003-01-20 16:58:36 +03:00
|
|
|
.PP
|
2003-01-28 23:43:10 +03:00
|
|
|
This line defines a keyword containing the backslash and newline
|
|
|
|
characters. Since the keywords are matched before the context
|
|
|
|
delimiters, this keyword prevents the context from ending at the end of
|
|
|
|
the lines that end in a backslash, thus allowing C preprocessor
|
|
|
|
directive to continue across multiple lines.
|
2003-01-19 20:47:50 +03:00
|
|
|
.PP
|
2003-01-20 16:58:36 +03:00
|
|
|
The possible colors are: black, gray, red, brightred, green,
|
|
|
|
brightgreen, brown, yellow, blue, brightblue, magenta, brightmagenta,
|
2010-12-29 12:58:10 +03:00
|
|
|
cyan, brightcyan, lightgray and white. The special keyword "default" means
|
|
|
|
the terminal's default. Another special keyword "base" means mc's main
|
|
|
|
colors, it is useful as a placeholder if you want to specify attributes
|
|
|
|
without modifying the background color. When 256 colors are available,
|
|
|
|
they can be specified either as color16 to color255, or as rgb000 to rgb555
|
|
|
|
and gray0 to gray23.
|
|
|
|
.PP
|
|
|
|
If the syntax file is shared with
|
2003-01-28 23:43:10 +03:00
|
|
|
.BR cooledit ,
|
|
|
|
it is possible to specify different colors for
|
|
|
|
.B mcedit
|
|
|
|
and
|
|
|
|
.B cooledit
|
|
|
|
by separating them with a slash, e.g.
|
|
|
|
.PP
|
|
|
|
.nf
|
|
|
|
keyword #include red/Orange
|
|
|
|
.fi
|
|
|
|
.PP
|
|
|
|
.B mcedit
|
|
|
|
uses the color before the slash. See cooledit(1) for supported
|
|
|
|
.B cooledit
|
|
|
|
colors.
|
2003-01-19 20:47:50 +03:00
|
|
|
.PP
|
2010-12-29 12:58:10 +03:00
|
|
|
Attributes can be any of bold, underline, reverse and blink, appended by a
|
|
|
|
plus sign if more than one are desired.
|
|
|
|
.PP
|
2003-01-20 16:58:36 +03:00
|
|
|
Comments may be put on a separate line starting with the hash sign (#).
|
2003-01-19 20:47:50 +03:00
|
|
|
.PP
|
2010-03-04 18:51:20 +03:00
|
|
|
If you are describing case insensitive language you need to use
|
|
|
|
.B caseinsensitive
|
2012-04-30 11:10:28 +04:00
|
|
|
directive. It should be specified at the beginning of syntax file.
|
2010-03-04 18:51:20 +03:00
|
|
|
.PP
|
1998-04-24 19:18:08 +04:00
|
|
|
Because of the simplicity of the implementation, there are a few
|
2003-01-20 16:58:36 +03:00
|
|
|
intricacies that will not be dealt with correctly but these are a minor
|
|
|
|
irritation. On the whole, a broad spectrum of quite complicated
|
|
|
|
situations are handled with these simple rules. It is a good idea to
|
1998-04-24 19:18:08 +04:00
|
|
|
take a look at the syntax file to see some of the nifty tricks you can
|
2003-01-28 23:43:10 +03:00
|
|
|
do with a little imagination. If you cannot get by with the rules I
|
|
|
|
have coded, and you think you have a rule that would be useful, please
|
|
|
|
email me with your request. However, do not ask for regular expression
|
1998-12-11 01:14:10 +03:00
|
|
|
support, because this is flatly impossible.
|
2003-01-19 20:47:50 +03:00
|
|
|
.PP
|
2003-01-20 16:58:36 +03:00
|
|
|
A useful hint is to work with as much as possible with the things you
|
2003-01-28 23:43:10 +03:00
|
|
|
can do rather than try to do things that this implementation cannot deal
|
2003-01-20 16:58:36 +03:00
|
|
|
with. Also remember that the aim of syntax highlighting is to make
|
|
|
|
programming less prone to error, not to make code look pretty.
|
2010-07-07 13:50:03 +04:00
|
|
|
.PP
|
|
|
|
The syntax highlighting can be toggled using Ctrl\-s shortcut.
|
1998-12-11 01:14:10 +03:00
|
|
|
.SH COLORS
|
|
|
|
The default colors may be changed by appending to the
|
2003-01-20 16:58:36 +03:00
|
|
|
.B MC_COLOR_TABLE
|
|
|
|
environment variable. Foreground and background colors pairs may be
|
|
|
|
specified for example with:
|
1998-12-11 01:14:10 +03:00
|
|
|
.PP
|
|
|
|
.nf
|
2001-09-20 05:42:57 +04:00
|
|
|
MC_COLOR_TABLE="$MC_COLOR_TABLE:\\
|
|
|
|
editnormal=lightgray,black:\\
|
|
|
|
editbold=yellow,black:\\
|
1998-12-11 01:14:10 +03:00
|
|
|
editmarked=black,cyan"
|
|
|
|
.fi
|
1998-02-27 07:54:42 +03:00
|
|
|
.SH OPTIONS
|
2003-01-28 23:43:10 +03:00
|
|
|
Most options can now be set from the editors options dialog box. See
|
|
|
|
the
|
2003-01-20 16:58:36 +03:00
|
|
|
.B Options
|
|
|
|
menu. The following options are defined in
|
2010-12-30 22:10:20 +03:00
|
|
|
.B ~/.config/mc/ini
|
2003-01-20 16:58:36 +03:00
|
|
|
and have obvious counterparts in the dialog box. You can modify them to
|
|
|
|
change the editor behavior, by editing the file. Unless specified, a 1
|
|
|
|
sets the option to on, and a 0 sets it to off, as is usual.
|
1998-02-27 07:54:42 +03:00
|
|
|
.TP
|
|
|
|
.I use_internal_edit
|
2003-01-19 20:47:50 +03:00
|
|
|
This option is ignored when invoking
|
2003-01-20 16:58:36 +03:00
|
|
|
.BR mcedit .
|
1998-02-27 07:54:42 +03:00
|
|
|
.TP
|
|
|
|
.I editor_tab_spacing
|
|
|
|
Interpret the tab character as being of this length.
|
|
|
|
Default is 8. You should avoid using
|
|
|
|
other than 8 since most other editors and text viewers
|
2003-01-19 20:47:50 +03:00
|
|
|
assume a tab spacing of 8. Use
|
|
|
|
.B editor_fake_half_tabs
|
1998-02-27 07:54:42 +03:00
|
|
|
to simulate a smaller tab spacing.
|
|
|
|
.TP
|
|
|
|
.I editor_fill_tabs_with_spaces
|
|
|
|
Never insert a tab space. Rather insert spaces (ascii 20h) to fill to the
|
|
|
|
desired tab size.
|
|
|
|
.TP
|
|
|
|
.I editor_return_does_auto_indent
|
|
|
|
Pressing return will tab across to match the indentation
|
|
|
|
of the first line above that has text on it.
|
|
|
|
.TP
|
|
|
|
.I editor_backspace_through_tabs
|
|
|
|
Make a single backspace delete all the space to the left
|
|
|
|
margin if there is no text between the cursor and the left
|
|
|
|
margin.
|
|
|
|
.TP
|
|
|
|
.I editor_fake_half_tabs
|
|
|
|
This will emulate a half tab for those who want to program
|
|
|
|
with a tab spacing of 4, but do not want the tab size changed
|
|
|
|
from 8 (so that the code will be formatted the same when displayed
|
2003-01-19 20:47:50 +03:00
|
|
|
by other programs). When editing between text and the left
|
1998-02-27 07:54:42 +03:00
|
|
|
margin, moving and tabbing will be as though a tab space were
|
|
|
|
4, while actually using spaces and normal tabs for an optimal fill.
|
|
|
|
When editing anywhere else, a normal tab is inserted.
|
|
|
|
.TP
|
|
|
|
.I editor_option_save_mode
|
2003-01-20 16:58:36 +03:00
|
|
|
Possible values 0, 1 and 2. The save mode (see the options menu also)
|
|
|
|
allows you to change the method of saving a file. Quick save (0) saves
|
|
|
|
the file by immediately, truncating the disk file to zero length (i.e.
|
|
|
|
erasing it) and the writing the editor contents to the file. This
|
|
|
|
method is fast, but dangerous, since a system error during a file save
|
|
|
|
will leave the file only partially written, possibly rendering the data
|
|
|
|
irretrievable. When saving, the safe save (1) option enables creation
|
|
|
|
of a temporary file into which the file contents are first written. In
|
|
|
|
the event of an problem, the original file is untouched. When the
|
|
|
|
temporary file is successfully written, it is renamed to the name of the
|
|
|
|
original file, thus replacing it. The safest method is create backups
|
|
|
|
(2). Where a backup file is created before any changes are made. You
|
|
|
|
can specify your own backup file extension in the dialog. Note that
|
|
|
|
saving twice will replace your backup as well as your original file.
|
2009-06-23 13:50:58 +04:00
|
|
|
.TP
|
|
|
|
.I editor_word_wrap_line_length
|
|
|
|
line length to wrap. 72 default.
|
|
|
|
.TP
|
|
|
|
.I editor_backup_extension
|
|
|
|
symbol for add extension to name of backup files. Default "~".
|
|
|
|
.TP
|
|
|
|
.I editor_line_state
|
|
|
|
show state line of editor now it show number of file line (in future it
|
2009-08-21 16:14:02 +04:00
|
|
|
can show things like folding, breakpoints, etc.). M\-n toglle this option.
|
2009-06-23 13:50:58 +04:00
|
|
|
.TP
|
|
|
|
.I editor_visible_spaces
|
|
|
|
Toggle show visible trailing spaces (TWS), if editor_visible_spaces=1 TWS
|
|
|
|
showed as '.'
|
|
|
|
.TP
|
|
|
|
.I editor_visible_tabs
|
2009-08-21 16:14:02 +04:00
|
|
|
Toggle show visible tabs, if editor_visible_tabs=1 tabs showed as '<\-\-\-\->'
|
2009-06-23 13:50:58 +04:00
|
|
|
.TP
|
|
|
|
.I editor_persistent_selections
|
|
|
|
Do not remove block selection after moving the cursor.
|
|
|
|
.TP
|
2009-08-20 17:28:40 +04:00
|
|
|
.I editor_cursor_beyond_eol
|
|
|
|
Allow moving cursor beyond the end of line.
|
|
|
|
.TP
|
2009-06-23 13:50:58 +04:00
|
|
|
.I editor_syntax_highlighting
|
|
|
|
enable syntax highlighting.
|
|
|
|
.TP
|
|
|
|
.I editor_edit_confirm_save
|
|
|
|
show confirm dialog on save.
|
|
|
|
.TP
|
|
|
|
.I editor_option_typewriter_wrap
|
|
|
|
to be described
|
|
|
|
.TP
|
|
|
|
.I editor_option_auto_para_formatting
|
|
|
|
to be described
|
|
|
|
.TP
|
|
|
|
.I editor_option_save_position
|
|
|
|
save file position on exit.
|
|
|
|
.TP
|
|
|
|
.I source_codepage
|
2009-08-21 16:14:02 +04:00
|
|
|
symbol representation of codepage name for file (i.e. CP1251, ~ \- default).
|
2009-09-23 16:07:55 +04:00
|
|
|
.TP
|
2010-12-17 00:23:01 +03:00
|
|
|
.I editor_group_undo
|
|
|
|
do UNDO for several of the same type of action (inserting/overwriting,
|
|
|
|
deleting, navigating, typing)
|
|
|
|
.TP
|
2009-09-23 16:07:55 +04:00
|
|
|
.I editor_wordcompletion_collect_entire_file
|
|
|
|
Search autocomplete candidates in entire of file or just from
|
|
|
|
begin of file to cursor position (0)
|
|
|
|
|
2003-01-19 20:47:50 +03:00
|
|
|
.SH MISCELLANEOUS
|
|
|
|
You can use scanf search and replace to search and replace a C format
|
2003-01-20 16:58:36 +03:00
|
|
|
string. First take a look at the
|
2003-01-19 20:47:50 +03:00
|
|
|
.B sscanf
|
|
|
|
and
|
|
|
|
.B sprintf
|
|
|
|
man pages to see what a format string is and how it works. Here's an
|
|
|
|
example: suppose that you want to replace all occurrences of an open
|
|
|
|
bracket, three comma separated numbers, and a close bracket, with the
|
|
|
|
word
|
|
|
|
.IR apples ,
|
|
|
|
the third number, the word
|
1998-02-27 07:54:42 +03:00
|
|
|
.I oranges
|
2003-01-19 20:47:50 +03:00
|
|
|
and then the second number. You would fill in the Replace dialog box as
|
|
|
|
follows:
|
|
|
|
.PP
|
1998-02-27 07:54:42 +03:00
|
|
|
.nf
|
|
|
|
.B Enter search string
|
|
|
|
(%d,%d,%d)
|
|
|
|
.B Enter replace string
|
|
|
|
apples %d oranges %d
|
|
|
|
.B Enter replacement argument order
|
|
|
|
3,2
|
|
|
|
.fi
|
2003-01-19 20:47:50 +03:00
|
|
|
.PP
|
|
|
|
The last line specifies that the third and then the second number are to
|
|
|
|
be used in place of the first and second.
|
|
|
|
.PP
|
2003-01-28 23:43:10 +03:00
|
|
|
It is advisable to use this feature with Prompt On Replace on, because a
|
|
|
|
match is thought to be found whenever the number of arguments found
|
1998-02-27 07:54:42 +03:00
|
|
|
matches the number given, which is not always a real match. Scanf also
|
|
|
|
treats whitespace as being elastic. Note that the scanf format %[ is
|
|
|
|
very useful for scanning strings, and whitespace.
|
2003-01-19 20:47:50 +03:00
|
|
|
.PP
|
2009-08-21 16:14:02 +04:00
|
|
|
The editor also displays non\-us characters (160+). When editing
|
2003-01-19 20:47:50 +03:00
|
|
|
binary files, you should set
|
|
|
|
.B display bits
|
2003-01-28 23:43:10 +03:00
|
|
|
to 7 bits in the Midnight Commander options menu to keep the spacing
|
|
|
|
clean.
|
1998-02-27 07:54:42 +03:00
|
|
|
.SH FILES
|
2012-03-22 21:14:52 +04:00
|
|
|
.I %prefix%/share/mc/mc.hlp
|
1998-02-27 07:54:42 +03:00
|
|
|
.IP
|
|
|
|
The help file for the program.
|
|
|
|
.PP
|
2012-03-22 21:14:52 +04:00
|
|
|
.I %prefix%/share/mc/mc.ini
|
1998-02-27 07:54:42 +03:00
|
|
|
.IP
|
2009-08-21 16:14:02 +04:00
|
|
|
The default system\-wide setup for GNU Midnight Commander, used only if
|
2010-12-30 22:10:20 +03:00
|
|
|
the user's own ~/.config/mc/ini file is missing.
|
1998-02-27 07:54:42 +03:00
|
|
|
.PP
|
2012-03-22 21:14:52 +04:00
|
|
|
.I %prefix%/share/mc/mc.lib
|
2003-01-19 20:47:50 +03:00
|
|
|
.IP
|
|
|
|
Global settings for the Midnight Commander. Settings in this file
|
2010-12-30 22:10:20 +03:00
|
|
|
affect all users, whether they have ~/.config/mc/ini or not.
|
2003-01-19 20:47:50 +03:00
|
|
|
.PP
|
2012-03-22 21:14:52 +04:00
|
|
|
.I %prefix%/share/mc/syntax/*
|
1998-02-27 07:54:42 +03:00
|
|
|
.IP
|
2009-08-21 16:14:02 +04:00
|
|
|
The default system\-wide syntax files for mcedit, used only if
|
2010-12-30 22:10:20 +03:00
|
|
|
the corresponding user's own ~/.local/share/mc/mcedit/ file is missing.
|
1998-02-27 07:54:42 +03:00
|
|
|
.PP
|
2010-12-30 22:10:20 +03:00
|
|
|
.I ~/.config/mc/ini
|
1998-02-27 07:54:42 +03:00
|
|
|
.IP
|
2003-03-04 13:34:28 +03:00
|
|
|
User's own setup. If this file is present then the setup is loaded
|
2009-08-21 16:14:02 +04:00
|
|
|
from here instead of the system\-wide setup file.
|
1998-02-27 07:54:42 +03:00
|
|
|
.PP
|
2010-12-30 22:10:20 +03:00
|
|
|
.I ~/.local/share/mc/mcedit/
|
1998-02-27 07:54:42 +03:00
|
|
|
.IP
|
2003-03-04 13:34:28 +03:00
|
|
|
User's own directory where block commands are processed and saved and
|
|
|
|
user's own syntax files are located.
|
1998-02-27 07:54:42 +03:00
|
|
|
.SH LICENSE
|
|
|
|
This program is distributed under the terms of the GNU General Public
|
2009-08-21 16:14:02 +04:00
|
|
|
License as published by the Free Software Foundation. See the built\-in
|
1998-02-27 07:54:42 +03:00
|
|
|
help of the Midnight Commander for details on the License and the lack
|
|
|
|
of warranty.
|
|
|
|
.SH AVAILABILITY
|
2003-01-19 20:47:50 +03:00
|
|
|
The latest version of this program can be found at
|
2009-08-21 16:14:02 +04:00
|
|
|
http://midnight\-commander.org/.
|
1998-02-27 07:54:42 +03:00
|
|
|
.SH SEE ALSO
|
|
|
|
cooledit(1), mc(1), gpm(1), terminfo(1), scanf(3).
|
|
|
|
.SH AUTHORS
|
2003-01-28 23:43:10 +03:00
|
|
|
Paul Sheer (psheer@obsidian.co.za) is the original author of
|
1998-02-27 07:54:42 +03:00
|
|
|
the Midnight Commander's internal editor.
|
|
|
|
.SH BUGS
|
2009-08-21 16:14:02 +04:00
|
|
|
Bugs should be reported to mc\-devel@gnome.org
|