add descriptive comments to pretty much all functions and major

variables that don't have them, plus a few miscellaneous minor fixes


git-svn-id: svn://svn.savannah.gnu.org/nano/trunk/nano@3237 35c25a1d-7b9e-4130-9fde-d3aeb78583b8
master
David Lawrence Ramsey 2005-12-08 07:09:08 +00:00
parent 034b994eb5
commit 6d6a36c647
14 changed files with 672 additions and 350 deletions

View File

@ -1,5 +1,7 @@
CVS code - CVS code -
- General: - General:
- Miscellaneous comment fixes. (DLR)
- More int -> bool conversions. (DLR)
- Add the ability to scroll up or down single lines without - Add the ability to scroll up or down single lines without
scrolling the cursor, via Meta-- and Meta-+. Note that this scrolling the cursor, via Meta-- and Meta-+. Note that this
is disabled when NANO_SMALL is defined. New functions is disabled when NANO_SMALL is defined. New functions
@ -170,6 +172,9 @@ CVS code -
(DLR) (DLR)
- nano.h: - nano.h:
- Readd MIN_EDITOR_COLS #define, set to 4. (DLR) - Readd MIN_EDITOR_COLS #define, set to 4. (DLR)
- proto.h:
- Remove now-unused externs for currslen, shortcut_list,
fileinfo, syntaxfile_regexp, and synfilematches. (DLR)
- prompt.c: - prompt.c:
do_statusbar_input() do_statusbar_input()
- Fix misplaced break when handling NANO_VERBATIM_KEY. (DLR) - Fix misplaced break when handling NANO_VERBATIM_KEY. (DLR)
@ -183,12 +188,17 @@ CVS code -
do_rcfile() do_rcfile()
- Remove unneeded assert. (DLR) - Remove unneeded assert. (DLR)
- search.c: - search.c:
search_abort()
- Rename to search_replace_abort(). (DLR)
findnextstr() findnextstr()
- Remove parameter can_display_wrap, as it's always set to TRUE - Remove parameter can_display_wrap, as it's always set to TRUE
now, and rename parameter wholeword to whole_word, for now, and rename parameter wholeword to whole_word, for
consistency. (DLR) consistency. (DLR)
- Only include the whole_word parameter when DISABLE_SPELLER - Only include the whole_word parameter when DISABLE_SPELLER
isn't defined, as it's only used then. (DLR) isn't defined, as it's only used then. (DLR)
replace_abort()
- Replace with search_replace_abort(), since it does the same
things that this function does. (DLR)
do_replace_loop() do_replace_loop()
- Change order of parameters to more closely match those of - Change order of parameters to more closely match those of
findnextstr(), and rename parameter wholewords to whole_word, findnextstr(), and rename parameter wholewords to whole_word,
@ -244,6 +254,8 @@ CVS code -
- Fix test so that we scroll through the line in 8-character - Fix test so that we scroll through the line in 8-character
chunks when COLS is greater than 8, not when COLS is greater chunks when COLS is greater than 8, not when COLS is greater
than 9. (DLR) than 9. (DLR)
remove_magicline()
- Add assert. (DLR)
- winio.c: - winio.c:
nanoget_repaint() nanoget_repaint()
- Rename parameter inputbuf to buf, for consistency. (DLR) - Rename parameter inputbuf to buf, for consistency. (DLR)

View File

@ -31,6 +31,8 @@ static bool keep_cutbuffer = FALSE;
static filestruct *cutbottom = NULL; static filestruct *cutbottom = NULL;
/* Pointer to the end of the cutbuffer. */ /* Pointer to the end of the cutbuffer. */
/* Indicate that we should no longer keep the contents of the
* cutbuffer. */
void cutbuffer_reset(void) void cutbuffer_reset(void)
{ {
keep_cutbuffer = FALSE; keep_cutbuffer = FALSE;

View File

@ -336,6 +336,8 @@ filestruct *read_line(char *buf, filestruct *prevnode, bool
return fileptr; return fileptr;
} }
/* Read an open file into the current buffer. f should be set to the
* open file, and filename should be set to the name of the file. */
void read_file(FILE *f, const char *filename) void read_file(FILE *f, const char *filename)
{ {
size_t num_lines = 0; size_t num_lines = 0;
@ -665,6 +667,9 @@ char *get_next_filename(const char *name, const char *suffix)
return buf; return buf;
} }
/* Insert a file into a new buffer if the MULTIBUFFER flag is set, or
* into the current buffer if it isn't. If execute is TRUE, insert the
* output of an executed command instead of a file. */
void do_insertfile( void do_insertfile(
#ifndef NANO_TINY #ifndef NANO_TINY
bool execute bool execute
@ -871,6 +876,9 @@ void do_insertfile(
free(ans); free(ans);
} }
/* Insert a file into a new buffer or the current buffer, depending on
* whether the MULTIBUFFER flag is set. If we're in view mode, only
* allow inserting a file into a new buffer. */
void do_insertfile_void(void) void do_insertfile_void(void)
{ {
#ifdef ENABLE_MULTIBUFFER #ifdef ENABLE_MULTIBUFFER
@ -1687,6 +1695,10 @@ int write_marked_file(const char *name, FILE *f_open, bool tmp,
} }
#endif /* !NANO_TINY */ #endif /* !NANO_TINY */
/* Write the current file to disk. If the mark is on, write the current
* marked selection to disk. If exiting is TRUE, write the file to disk
* regardless of whether the mark is on, and without prompting if the
* TEMP_FILE flag is set. */
int do_writeout(bool exiting) int do_writeout(bool exiting)
{ {
int i, retval = 0; int i, retval = 0;
@ -1854,6 +1866,8 @@ int do_writeout(bool exiting)
return retval; return retval;
} }
/* Write the current file to disk. If the mark is on, write the current
* marked selection to disk. */
void do_writeout_void(void) void do_writeout_void(void)
{ {
do_writeout(FALSE); do_writeout(FALSE);
@ -2353,6 +2367,9 @@ void load_history(void)
} }
} }
/* Write the lines of a history list, starting with the line at h, to
* the open file at hist. Return TRUE if the write succeeded, and FALSE
* otherwise. */
bool writehist(FILE *hist, filestruct *h) bool writehist(FILE *hist, filestruct *h)
{ {
filestruct *p; filestruct *p;

View File

@ -25,132 +25,180 @@
/* Global variables */ /* Global variables */
#ifndef DISABLE_WRAPJUSTIFY #ifndef DISABLE_WRAPJUSTIFY
ssize_t fill = 0; /* The column where we will wrap ssize_t fill = 0;
* lines. */ /* The column where we will wrap lines. */
ssize_t wrap_at = -CHARS_FROM_EOL; ssize_t wrap_at = -CHARS_FROM_EOL;
/* The position where we will wrap /* The position where we will wrap lines. fill is equal to this
* lines. fill is equal to this if it's * if it's greater than zero, and equal to (COLS + this) if it
* greater than zero, and equal to * isn't. */
* (COLS + this) if it isn't. */
#endif #endif
char *last_search = NULL; /* Last string we searched for */ char *last_search = NULL;
char *last_replace = NULL; /* Last replacement string */ /* The last string we searched for. */
char *last_replace = NULL;
/* The last replacement string we searched for. */
long flags = 0; /* Our flag containing many options */ long flags = 0;
WINDOW *topwin; /* Top subwindow */ /* Our flag containing the states of all global options. */
WINDOW *edit; /* The file portion of the editor */ WINDOW *topwin;
WINDOW *bottomwin; /* Bottom subwindow */ /* The top portion of the window, where we display the version
* number of nano, the name of the current file, and whether the
* current file has been modified. */
WINDOW *edit;
/* The middle portion of the window, i.e, the edit window, where
* we display the current file we're editing. */
WINDOW *bottomwin;
/* The bottom portion of the window, where we display statusbar
* messages, the statusbar prompt, and a list of shortcuts. */
int editwinrows = 0;
/* How many rows does the edit window take up? */
int editwinrows = 0; /* How many rows long is the edit filestruct *cutbuffer = NULL;
window? */ /* The buffer where we store cut text. */
filestruct *cutbuffer = NULL; /* A place to store cut text */
#ifndef DISABLE_JUSTIFY #ifndef DISABLE_JUSTIFY
filestruct *jusbuffer = NULL; /* A place to store unjustified text */ filestruct *jusbuffer = NULL;
/* The buffer where we store unjustified text. */
#endif #endif
partition *filepart = NULL; /* A place to store a portion of the partition *filepart = NULL;
file struct */ /* The partition where we store a portion of the current
* file. */
openfilestruct *openfile = NULL; openfilestruct *openfile = NULL;
/* The list of open file buffers */ /* The list of all open file buffers. */
#if !defined(NANO_TINY) && defined(ENABLE_NANORC) #if !defined(NANO_TINY) && defined(ENABLE_NANORC)
char *whitespace = NULL; /* Characters used when displaying char *whitespace = NULL;
the first characters of tabs and /* The characters used when displaying the first characters of
spaces. */ * tabs and spaces. */
int whitespace_len[2]; /* The length of the characters. */ int whitespace_len[2];
/* The length of these characters. */
#endif #endif
#ifndef DISABLE_JUSTIFY #ifndef DISABLE_JUSTIFY
char *punct = NULL; /* Closing punctuation that can end char *punct = NULL;
sentences. */ /* The closing punctuation that can end sentences. */
char *brackets = NULL; /* Closing brackets that can follow char *brackets = NULL;
closing punctuation and can end /* The closing brackets that can follow closing punctuation and
sentences. */ * can end sentences. */
char *quotestr = NULL; /* Quote string. The default value is char *quotestr = NULL;
set in main(). */ /* The quoting string. The default value is set in main(). */
#ifdef HAVE_REGEX_H #ifdef HAVE_REGEX_H
regex_t quotereg; /* Compiled quotestr regular expression. */ regex_t quotereg;
int quoterc; /* Did it compile? */ /* The compiled regular expression from the quoting string. */
char *quoteerr = NULL; /* The error message. */ int quoterc;
/* Whether it actually compiled. */
char *quoteerr = NULL;
/* The error message, if it didn't. */
#else #else
size_t quotelen; /* strlen(quotestr) */ size_t quotelen;
/* The length of the quoting string in bytes. */
#endif #endif
#endif #endif
char *answer = NULL;
/* The answer string used in the statusbar prompt. */
ssize_t tabsize = -1;
/* The width of a tab in spaces. The default value is set in
* main(). */
#ifndef NANO_TINY #ifndef NANO_TINY
char *backup_dir = NULL; /* Backup directory. */ char *backup_dir = NULL;
/* The directory where we store backup files. */
#endif #endif
char *answer = NULL; /* The answer string for statusbar
* questions. */
ssize_t tabsize = -1; /* Our internal tabsize variable. The
default value is set in main(). */
#ifndef DISABLE_OPERATINGDIR #ifndef DISABLE_OPERATINGDIR
char *operating_dir = NULL; /* Operating directory, which we can't */ char *operating_dir = NULL;
char *full_operating_dir = NULL;/* go higher than */ /* The relative path to the operating directory, which we can't
* move outside of. */
char *full_operating_dir = NULL;
/* The full path to it. */
#endif #endif
#ifndef DISABLE_SPELLER #ifndef DISABLE_SPELLER
char *alt_speller = NULL; /* Alternative spell command */ char *alt_speller = NULL;
/* The command to use for the alternate spell checker. */
#endif #endif
shortcut *main_list = NULL; shortcut *main_list = NULL;
/* The main shortcut list. */
shortcut *whereis_list = NULL; shortcut *whereis_list = NULL;
/* The "Search" shortcut list. */
shortcut *replace_list = NULL; shortcut *replace_list = NULL;
shortcut *replace_list_2 = NULL; /* 2nd half of replace dialog */ /* The "Search (to replace)" shortcut list. */
shortcut *replace_list_2 = NULL;
/* The "Replace with" shortcut list. */
shortcut *gotoline_list = NULL; shortcut *gotoline_list = NULL;
/* The "Enter line number, column number" shortcut list. */
shortcut *writefile_list = NULL; shortcut *writefile_list = NULL;
/* The "File Name to Write" shortcut list. */
shortcut *insertfile_list = NULL; shortcut *insertfile_list = NULL;
/* The "File to insert" shortcut list. */
#ifndef NANO_TINY
shortcut *extcmd_list = NULL;
/* The "Command to execute" shortcut list. */
#endif
#ifndef DISABLE_HELP #ifndef DISABLE_HELP
shortcut *help_list = NULL; shortcut *help_list = NULL;
/* The help text shortcut list. */
#endif #endif
#ifndef DISABLE_SPELLER #ifndef DISABLE_SPELLER
shortcut *spell_list = NULL; shortcut *spell_list = NULL;
#endif /* The internal spell checker shortcut list. */
#ifndef NANO_TINY
shortcut *extcmd_list = NULL;
#endif #endif
#ifndef DISABLE_BROWSER #ifndef DISABLE_BROWSER
shortcut *browser_list = NULL; shortcut *browser_list = NULL;
/* The file browser shortcut list. */
shortcut *gotodir_list = NULL; shortcut *gotodir_list = NULL;
/* The "Go To Directory" shortcut list. */
#endif #endif
#ifdef ENABLE_COLOR #ifdef ENABLE_COLOR
syntaxtype *syntaxes = NULL; syntaxtype *syntaxes = NULL;
/* The global list of color syntaxes. */
char *syntaxstr = NULL; char *syntaxstr = NULL;
/* The color syntax name specified on the command line. */
#endif #endif
const shortcut *currshortcut; /* Current shortcut list we're using */ const shortcut *currshortcut;
/* The current shortcut list we're using. */
#ifndef NANO_TINY #ifndef NANO_TINY
toggle *toggles = NULL; toggle *toggles = NULL;
/* The global toggle list. */
#endif #endif
#ifndef NANO_TINY #ifndef NANO_TINY
filestruct *search_history = NULL; filestruct *search_history = NULL;
/* The search string history list. */
filestruct *searchage = NULL; filestruct *searchage = NULL;
/* The top of the search string history list. */
filestruct *searchbot = NULL; filestruct *searchbot = NULL;
/* The bottom of the search string history list. */
filestruct *replace_history = NULL; filestruct *replace_history = NULL;
/* The replace string history list. */
filestruct *replaceage = NULL; filestruct *replaceage = NULL;
/* The top of the replace string history list. */
filestruct *replacebot = NULL; filestruct *replacebot = NULL;
/* The bottom of the replace string history list. */
#endif #endif
/* Regular expressions */ /* Regular expressions */
#ifdef HAVE_REGEX_H #ifdef HAVE_REGEX_H
regex_t search_regexp; /* Global to store compiled search regexp */ regex_t search_regexp;
regmatch_t regmatches[10]; /* Match positions for parenthetical /* The compiled regular expression to use in searches. */
subexpressions, max of 10 */ regmatch_t regmatches[10];
/* The match positions for parenthetical subexpressions, 10
* maximum, used in regular expression searches. */
#endif #endif
bool curses_ended = FALSE; /* Indicates to statusbar() to simply bool curses_ended = FALSE;
* write to stderr, since endwin() has /* Whether endwin() has ended curses mode and statusbar()
* ended curses mode. */ * should hence write to stderr instead of displaying on the
* statusbar. */
char *homedir = NULL; /* $HOME or from /etc/passwd. */ char *homedir = NULL;
/* The user's home directory, from $HOME or
* /etc/passwd. */
/* Return the number of entries in the shortcut list s. */
size_t length_of_list(const shortcut *s) size_t length_of_list(const shortcut *s)
{ {
size_t i = 0; size_t i = 0;
@ -194,6 +242,8 @@ void sc_init_one(shortcut **shortcutage, int ctrlval, const char *desc,
s->next = NULL; s->next = NULL;
} }
/* Initialize all shortcut lists. If unjustify is TRUE, replace the
* Uncut shortcut in the main shortcut list with UnJustify. */
void shortcut_init(bool unjustify) void shortcut_init(bool unjustify)
{ {
const char *get_help_msg = N_("Get Help"); const char *get_help_msg = N_("Get Help");
@ -365,7 +415,7 @@ void shortcut_init(bool unjustify)
free_shortcutage(&main_list); free_shortcutage(&main_list);
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_HELP_KEY, get_help_msg, sc_init_one(&main_list, NANO_HELP_KEY, get_help_msg,
IFHELP(nano_help_msg, NANO_NO_KEY), NANO_HELP_FKEY, IFHELP(nano_help_msg, NANO_NO_KEY), NANO_HELP_FKEY,
NANO_NO_KEY, VIEW, NANO_NO_KEY, VIEW,
@ -376,7 +426,7 @@ void shortcut_init(bool unjustify)
#endif #endif
); );
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_EXIT_KEY, sc_init_one(&main_list, NANO_EXIT_KEY,
#ifdef ENABLE_MULTIBUFFER #ifdef ENABLE_MULTIBUFFER
openfile != NULL && openfile != openfile->next ? openfile != NULL && openfile != openfile->next ?
@ -385,12 +435,12 @@ void shortcut_init(bool unjustify)
exit_msg, IFHELP(nano_exit_msg, NANO_NO_KEY), NANO_EXIT_FKEY, exit_msg, IFHELP(nano_exit_msg, NANO_NO_KEY), NANO_EXIT_FKEY,
NANO_NO_KEY, VIEW, do_exit); NANO_NO_KEY, VIEW, do_exit);
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_WRITEOUT_KEY, N_("WriteOut"), sc_init_one(&main_list, NANO_WRITEOUT_KEY, N_("WriteOut"),
IFHELP(nano_writeout_msg, NANO_NO_KEY), NANO_WRITEOUT_FKEY, IFHELP(nano_writeout_msg, NANO_NO_KEY), NANO_WRITEOUT_FKEY,
NANO_NO_KEY, NOVIEW, do_writeout_void); NANO_NO_KEY, NOVIEW, do_writeout_void);
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_JUSTIFY_KEY, N_("Justify"), sc_init_one(&main_list, NANO_JUSTIFY_KEY, N_("Justify"),
IFHELP(nano_justify_msg, NANO_NO_KEY), IFHELP(nano_justify_msg, NANO_NO_KEY),
NANO_JUSTIFY_FKEY, NANO_NO_KEY, NOVIEW, NANO_JUSTIFY_FKEY, NANO_NO_KEY, NOVIEW,
@ -402,11 +452,12 @@ void shortcut_init(bool unjustify)
); );
/* We allow inserting files in view mode if multibuffers are /* We allow inserting files in view mode if multibuffers are
* available, so that we can view multiple files. */ * available, so that we can view multiple files. If we're using
/* If we're using restricted mode, inserting files is disabled since * restricted mode, inserting files is disabled, since it allows
* it allows reading from or writing to files not specified on the * reading from or writing to files not specified on the command
* command line. */ * line. */
/* Translators: try to keep this string under 10 characters long */
/* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_INSERTFILE_KEY, N_("Read File"), sc_init_one(&main_list, NANO_INSERTFILE_KEY, N_("Read File"),
IFHELP(nano_insert_msg, NANO_NO_KEY), NANO_INSERTFILE_FKEY, IFHELP(nano_insert_msg, NANO_NO_KEY), NANO_INSERTFILE_FKEY,
NANO_NO_KEY, NANO_NO_KEY,
@ -418,38 +469,38 @@ void shortcut_init(bool unjustify)
, !ISSET(RESTRICTED) ? do_insertfile_void : , !ISSET(RESTRICTED) ? do_insertfile_void :
nano_disabled_msg); nano_disabled_msg);
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_WHEREIS_KEY, N_("Where Is"), sc_init_one(&main_list, NANO_WHEREIS_KEY, N_("Where Is"),
IFHELP(nano_whereis_msg, NANO_NO_KEY), NANO_WHEREIS_FKEY, IFHELP(nano_whereis_msg, NANO_NO_KEY), NANO_WHEREIS_FKEY,
NANO_NO_KEY, VIEW, do_search); NANO_NO_KEY, VIEW, do_search);
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_PREVPAGE_KEY, prev_page_msg, sc_init_one(&main_list, NANO_PREVPAGE_KEY, prev_page_msg,
IFHELP(nano_prevpage_msg, NANO_NO_KEY), NANO_PREVPAGE_FKEY, IFHELP(nano_prevpage_msg, NANO_NO_KEY), NANO_PREVPAGE_FKEY,
NANO_NO_KEY, VIEW, do_page_up); NANO_NO_KEY, VIEW, do_page_up);
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_NEXTPAGE_KEY, next_page_msg, sc_init_one(&main_list, NANO_NEXTPAGE_KEY, next_page_msg,
IFHELP(nano_nextpage_msg, NANO_NO_KEY), NANO_NEXTPAGE_FKEY, IFHELP(nano_nextpage_msg, NANO_NO_KEY), NANO_NEXTPAGE_FKEY,
NANO_NO_KEY, VIEW, do_page_down); NANO_NO_KEY, VIEW, do_page_down);
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_CUT_KEY, N_("Cut Text"), sc_init_one(&main_list, NANO_CUT_KEY, N_("Cut Text"),
IFHELP(nano_cut_msg, NANO_NO_KEY), NANO_CUT_FKEY, IFHELP(nano_cut_msg, NANO_NO_KEY), NANO_CUT_FKEY,
NANO_NO_KEY, NOVIEW, do_cut_text); NANO_NO_KEY, NOVIEW, do_cut_text);
if (unjustify) if (unjustify)
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_UNJUSTIFY_KEY, N_("UnJustify"), sc_init_one(&main_list, NANO_UNJUSTIFY_KEY, N_("UnJustify"),
IFHELP(NULL, NANO_NO_KEY), NANO_UNJUSTIFY_FKEY, IFHELP(NULL, NANO_NO_KEY), NANO_UNJUSTIFY_FKEY,
NANO_NO_KEY, NOVIEW, NULL); NANO_NO_KEY, NOVIEW, NULL);
else else
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_UNCUT_KEY, N_("UnCut Txt"), sc_init_one(&main_list, NANO_UNCUT_KEY, N_("UnCut Txt"),
IFHELP(nano_uncut_msg, NANO_NO_KEY), NANO_UNCUT_FKEY, IFHELP(nano_uncut_msg, NANO_NO_KEY), NANO_UNCUT_FKEY,
NANO_NO_KEY, NOVIEW, do_uncut_text); NANO_NO_KEY, NOVIEW, do_uncut_text);
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_CURSORPOS_KEY, N_("Cur Pos"), sc_init_one(&main_list, NANO_CURSORPOS_KEY, N_("Cur Pos"),
IFHELP(nano_cursorpos_msg, NANO_NO_KEY), NANO_CURSORPOS_FKEY, IFHELP(nano_cursorpos_msg, NANO_NO_KEY), NANO_CURSORPOS_FKEY,
NANO_NO_KEY, VIEW, do_cursorpos_void); NANO_NO_KEY, VIEW, do_cursorpos_void);
@ -457,7 +508,7 @@ void shortcut_init(bool unjustify)
/* If we're using restricted mode, spell checking is disabled /* If we're using restricted mode, spell checking is disabled
* because it allows reading from or writing to files not specified * because it allows reading from or writing to files not specified
* on the command line. */ * on the command line. */
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_SPELL_KEY, N_("To Spell"), sc_init_one(&main_list, NANO_SPELL_KEY, N_("To Spell"),
IFHELP(nano_spell_msg, NANO_NO_KEY), NANO_SPELL_FKEY, IFHELP(nano_spell_msg, NANO_NO_KEY), NANO_SPELL_FKEY,
NANO_NO_KEY, NOVIEW, NANO_NO_KEY, NOVIEW,
@ -552,12 +603,12 @@ void shortcut_init(bool unjustify)
#endif #endif
#ifndef DISABLE_JUSTIFY #ifndef DISABLE_JUSTIFY
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_NO_KEY, beg_of_par_msg, sc_init_one(&main_list, NANO_NO_KEY, beg_of_par_msg,
IFHELP(nano_parabegin_msg, NANO_PARABEGIN_ALTKEY1), NANO_NO_KEY, IFHELP(nano_parabegin_msg, NANO_PARABEGIN_ALTKEY1), NANO_NO_KEY,
NANO_PARABEGIN_ALTKEY2, VIEW, do_para_begin_void); NANO_PARABEGIN_ALTKEY2, VIEW, do_para_begin_void);
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_NO_KEY, end_of_par_msg, sc_init_one(&main_list, NANO_NO_KEY, end_of_par_msg,
IFHELP(nano_paraend_msg, NANO_PARAEND_ALTKEY1), NANO_NO_KEY, IFHELP(nano_paraend_msg, NANO_PARAEND_ALTKEY1), NANO_NO_KEY,
NANO_PARAEND_ALTKEY2, VIEW, do_para_end_void); NANO_PARAEND_ALTKEY2, VIEW, do_para_end_void);
@ -578,14 +629,14 @@ void shortcut_init(bool unjustify)
NANO_NO_KEY, NOVIEW, do_verbatim_input); NANO_NO_KEY, NOVIEW, do_verbatim_input);
#ifndef NANO_TINY #ifndef NANO_TINY
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_NO_KEY, cut_till_end_msg, sc_init_one(&main_list, NANO_NO_KEY, cut_till_end_msg,
IFHELP(nano_cut_till_end_msg, NANO_CUTTILLEND_ALTKEY), IFHELP(nano_cut_till_end_msg, NANO_CUTTILLEND_ALTKEY),
NANO_NO_KEY, NANO_NO_KEY, NOVIEW, do_cut_till_end); NANO_NO_KEY, NANO_NO_KEY, NOVIEW, do_cut_till_end);
#endif #endif
#ifndef DISABLE_JUSTIFY #ifndef DISABLE_JUSTIFY
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&main_list, NANO_NO_KEY, fulljstify_msg, sc_init_one(&main_list, NANO_NO_KEY, fulljstify_msg,
IFHELP(nano_fulljustify_msg, NANO_FULLJUSTIFY_ALTKEY), IFHELP(nano_fulljustify_msg, NANO_FULLJUSTIFY_ALTKEY),
NANO_NO_KEY, NANO_NO_KEY, NOVIEW, do_full_justify); NANO_NO_KEY, NANO_NO_KEY, NOVIEW, do_full_justify);
@ -609,76 +660,76 @@ void shortcut_init(bool unjustify)
#endif #endif
); );
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&whereis_list, NANO_CANCEL_KEY, cancel_msg, sc_init_one(&whereis_list, NANO_CANCEL_KEY, cancel_msg,
IFHELP(nano_cancel_msg, NANO_NO_KEY), NANO_NO_KEY, IFHELP(nano_cancel_msg, NANO_NO_KEY), NANO_NO_KEY,
NANO_NO_KEY, VIEW, NULL); NANO_NO_KEY, VIEW, NULL);
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&whereis_list, NANO_FIRSTLINE_KEY, first_line_msg, sc_init_one(&whereis_list, NANO_FIRSTLINE_KEY, first_line_msg,
IFHELP(nano_firstline_msg, NANO_NO_KEY), NANO_FIRSTLINE_FKEY, IFHELP(nano_firstline_msg, NANO_NO_KEY), NANO_FIRSTLINE_FKEY,
NANO_NO_KEY, VIEW, do_first_line); NANO_NO_KEY, VIEW, do_first_line);
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&whereis_list, NANO_LASTLINE_KEY, last_line_msg, sc_init_one(&whereis_list, NANO_LASTLINE_KEY, last_line_msg,
IFHELP(nano_lastline_msg, NANO_NO_KEY), NANO_LASTLINE_FKEY, IFHELP(nano_lastline_msg, NANO_NO_KEY), NANO_LASTLINE_FKEY,
NANO_NO_KEY, VIEW, do_last_line); NANO_NO_KEY, VIEW, do_last_line);
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&whereis_list, NANO_TOOTHERSEARCH_KEY, replace_msg, sc_init_one(&whereis_list, NANO_TOOTHERSEARCH_KEY, replace_msg,
IFHELP(nano_replace_msg, NANO_NO_KEY), NANO_REPLACE_FKEY, IFHELP(nano_replace_msg, NANO_NO_KEY), NANO_REPLACE_FKEY,
NANO_NO_KEY, VIEW, NULL); NANO_NO_KEY, VIEW, NULL);
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&whereis_list, NANO_TOGOTOLINE_KEY, go_to_line_msg, sc_init_one(&whereis_list, NANO_TOGOTOLINE_KEY, go_to_line_msg,
IFHELP(nano_gotoline_msg, NANO_NO_KEY), NANO_GOTOLINE_FKEY, IFHELP(nano_gotoline_msg, NANO_NO_KEY), NANO_GOTOLINE_FKEY,
NANO_NO_KEY, VIEW, NULL); NANO_NO_KEY, VIEW, NULL);
#ifndef DISABLE_JUSTIFY #ifndef DISABLE_JUSTIFY
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&whereis_list, NANO_PARABEGIN_KEY, beg_of_par_msg, sc_init_one(&whereis_list, NANO_PARABEGIN_KEY, beg_of_par_msg,
IFHELP(nano_parabegin_msg, NANO_PARABEGIN_ALTKEY1), NANO_NO_KEY, IFHELP(nano_parabegin_msg, NANO_PARABEGIN_ALTKEY1), NANO_NO_KEY,
NANO_PARABEGIN_ALTKEY2, VIEW, do_para_begin_void); NANO_PARABEGIN_ALTKEY2, VIEW, do_para_begin_void);
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&whereis_list, NANO_PARAEND_KEY, end_of_par_msg, sc_init_one(&whereis_list, NANO_PARAEND_KEY, end_of_par_msg,
IFHELP(nano_paraend_msg, NANO_PARAEND_ALTKEY1), NANO_NO_KEY, IFHELP(nano_paraend_msg, NANO_PARAEND_ALTKEY1), NANO_NO_KEY,
NANO_PARAEND_ALTKEY2, VIEW, do_para_end_void); NANO_PARAEND_ALTKEY2, VIEW, do_para_end_void);
#endif #endif
#ifndef NANO_TINY #ifndef NANO_TINY
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&whereis_list, NANO_NO_KEY, case_sens_msg, sc_init_one(&whereis_list, NANO_NO_KEY, case_sens_msg,
IFHELP(nano_case_msg, TOGGLE_CASE_KEY), NANO_NO_KEY, IFHELP(nano_case_msg, TOGGLE_CASE_KEY), NANO_NO_KEY,
NANO_NO_KEY, VIEW, NULL); NANO_NO_KEY, VIEW, NULL);
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&whereis_list, NANO_NO_KEY, backwards_msg, sc_init_one(&whereis_list, NANO_NO_KEY, backwards_msg,
IFHELP(nano_reverse_msg, TOGGLE_BACKWARDS_KEY), NANO_NO_KEY, IFHELP(nano_reverse_msg, TOGGLE_BACKWARDS_KEY), NANO_NO_KEY,
NANO_NO_KEY, VIEW, NULL); NANO_NO_KEY, VIEW, NULL);
#endif #endif
#ifdef HAVE_REGEX_H #ifdef HAVE_REGEX_H
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&whereis_list, NANO_NO_KEY, regexp_msg, sc_init_one(&whereis_list, NANO_NO_KEY, regexp_msg,
IFHELP(nano_regexp_msg, NANO_REGEXP_KEY), NANO_NO_KEY, IFHELP(nano_regexp_msg, NANO_REGEXP_KEY), NANO_NO_KEY,
NANO_NO_KEY, VIEW, NULL); NANO_NO_KEY, VIEW, NULL);
#endif #endif
#ifndef NANO_TINY #ifndef NANO_TINY
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&whereis_list, NANO_PREVLINE_KEY, history_msg, sc_init_one(&whereis_list, NANO_PREVLINE_KEY, history_msg,
IFHELP(nano_history_msg, NANO_NO_KEY), NANO_NO_KEY, IFHELP(nano_history_msg, NANO_NO_KEY), NANO_NO_KEY,
NANO_NO_KEY, VIEW, NULL); NANO_NO_KEY, VIEW, NULL);
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&whereis_list, NANO_CUTTILLEND_KEY, cut_till_end_msg, sc_init_one(&whereis_list, NANO_CUTTILLEND_KEY, cut_till_end_msg,
IFHELP(nano_cut_till_end_msg, NANO_CUTTILLEND_ALTKEY), IFHELP(nano_cut_till_end_msg, NANO_CUTTILLEND_ALTKEY),
NANO_NO_KEY, NANO_NO_KEY, NOVIEW, do_cut_till_end); NANO_NO_KEY, NANO_NO_KEY, NOVIEW, do_cut_till_end);
#endif #endif
#ifndef DISABLE_JUSTIFY #ifndef DISABLE_JUSTIFY
/* Translators: try to keep this string under 10 characters long */ /* Translators: try to keep this string under 10 characters long. */
sc_init_one(&whereis_list, NANO_FULLJUSTIFY_KEY, fulljstify_msg, sc_init_one(&whereis_list, NANO_FULLJUSTIFY_KEY, fulljstify_msg,
IFHELP(nano_fulljustify_msg, NANO_FULLJUSTIFY_ALTKEY), IFHELP(nano_fulljustify_msg, NANO_FULLJUSTIFY_ALTKEY),
NANO_NO_KEY, NANO_NO_KEY, NOVIEW, do_full_justify); NANO_NO_KEY, NANO_NO_KEY, NOVIEW, do_full_justify);
@ -708,7 +759,7 @@ void shortcut_init(bool unjustify)
IFHELP(nano_lastline_msg, NANO_NO_KEY), NANO_LASTLINE_FKEY, IFHELP(nano_lastline_msg, NANO_NO_KEY), NANO_LASTLINE_FKEY,
NANO_NO_KEY, VIEW, do_last_line); NANO_NO_KEY, VIEW, do_last_line);
/* Translators: try to keep this string under 12 characters long */ /* Translators: try to keep this string under 12 characters long. */
sc_init_one(&replace_list, NANO_TOOTHERSEARCH_KEY, N_("No Replace"), sc_init_one(&replace_list, NANO_TOOTHERSEARCH_KEY, N_("No Replace"),
IFHELP(nano_whereis_msg, NANO_NO_KEY), NANO_REPLACE_FKEY, IFHELP(nano_whereis_msg, NANO_NO_KEY), NANO_REPLACE_FKEY,
NANO_NO_KEY, VIEW, NULL); NANO_NO_KEY, VIEW, NULL);
@ -797,34 +848,6 @@ void shortcut_init(bool unjustify)
N_("Go To Text"), IFHELP(nano_whereis_msg, NANO_NO_KEY), N_("Go To Text"), IFHELP(nano_whereis_msg, NANO_NO_KEY),
NANO_NO_KEY, NANO_NO_KEY, VIEW, NULL); NANO_NO_KEY, NANO_NO_KEY, VIEW, NULL);
#ifndef DISABLE_HELP
free_shortcutage(&help_list);
sc_init_one(&help_list, NANO_REFRESH_KEY, refresh_msg,
IFHELP(nano_refresh_msg, NANO_NO_KEY), NANO_NO_KEY,
NANO_NO_KEY, VIEW, NULL);
sc_init_one(&help_list, NANO_EXIT_KEY, exit_msg,
IFHELP(nano_exit_msg, NANO_NO_KEY), NANO_EXIT_FKEY,
NANO_NO_KEY, VIEW, NULL);
sc_init_one(&help_list, NANO_PREVPAGE_KEY, prev_page_msg,
IFHELP(nano_prevpage_msg, NANO_NO_KEY), NANO_PREVPAGE_FKEY,
NANO_NO_KEY, VIEW, NULL);
sc_init_one(&help_list, NANO_NEXTPAGE_KEY, next_page_msg,
IFHELP(nano_nextpage_msg, NANO_NO_KEY), NANO_NEXTPAGE_FKEY,
NANO_NO_KEY, VIEW, NULL);
sc_init_one(&help_list, NANO_PREVLINE_KEY, N_("Prev Line"),
IFHELP(nano_prevline_msg, NANO_NO_KEY), NANO_NO_KEY,
NANO_NO_KEY, VIEW, NULL);
sc_init_one(&help_list, NANO_NEXTLINE_KEY, N_("Next Line"),
IFHELP(nano_nextline_msg, NANO_NO_KEY), NANO_NO_KEY,
NANO_NO_KEY, VIEW, NULL);
#endif
free_shortcutage(&writefile_list); free_shortcutage(&writefile_list);
sc_init_one(&writefile_list, NANO_HELP_KEY, get_help_msg, sc_init_one(&writefile_list, NANO_HELP_KEY, get_help_msg,
@ -844,7 +867,8 @@ void shortcut_init(bool unjustify)
#ifndef DISABLE_BROWSER #ifndef DISABLE_BROWSER
/* If we're using restricted mode, the file browser is disabled. /* If we're using restricted mode, the file browser is disabled.
* It's useless since inserting files is disabled. */ * It's useless since inserting files is disabled. */
/* Translators: try to keep this string under 16 characters long */
/* Translators: try to keep this string under 16 characters long. */
if (!ISSET(RESTRICTED)) if (!ISSET(RESTRICTED))
sc_init_one(&writefile_list, NANO_TOFILES_KEY, to_files_msg, sc_init_one(&writefile_list, NANO_TOFILES_KEY, to_files_msg,
IFHELP(nano_tofiles_msg, NANO_NO_KEY), NANO_NO_KEY, IFHELP(nano_tofiles_msg, NANO_NO_KEY), NANO_NO_KEY,
@ -858,33 +882,34 @@ void shortcut_init(bool unjustify)
* and fourth are disabled because they allow writing to files not * and fourth are disabled because they allow writing to files not
* specified on the command line, and the fifth is useless since * specified on the command line, and the fifth is useless since
* backups are disabled. */ * backups are disabled. */
/* Translators: try to keep this string under 16 characters long */
/* Translators: try to keep this string under 16 characters long. */
if (!ISSET(RESTRICTED)) if (!ISSET(RESTRICTED))
sc_init_one(&writefile_list, NANO_NO_KEY, N_("DOS Format"), sc_init_one(&writefile_list, NANO_NO_KEY, N_("DOS Format"),
IFHELP(nano_dos_msg, TOGGLE_DOS_KEY), NANO_NO_KEY, IFHELP(nano_dos_msg, TOGGLE_DOS_KEY), NANO_NO_KEY,
NANO_NO_KEY, NOVIEW, NULL); NANO_NO_KEY, NOVIEW, NULL);
/* Translators: try to keep this string under 16 characters long */ /* Translators: try to keep this string under 16 characters long. */
if (!ISSET(RESTRICTED)) if (!ISSET(RESTRICTED))
sc_init_one(&writefile_list, NANO_NO_KEY, N_("Mac Format"), sc_init_one(&writefile_list, NANO_NO_KEY, N_("Mac Format"),
IFHELP(nano_mac_msg, TOGGLE_MAC_KEY), NANO_NO_KEY, IFHELP(nano_mac_msg, TOGGLE_MAC_KEY), NANO_NO_KEY,
NANO_NO_KEY, NOVIEW, NULL); NANO_NO_KEY, NOVIEW, NULL);
#endif #endif
/* Translators: try to keep this string under 16 characters long */ /* Translators: try to keep this string under 16 characters long. */
if (!ISSET(RESTRICTED)) if (!ISSET(RESTRICTED))
sc_init_one(&writefile_list, NANO_NO_KEY, N_("Append"), sc_init_one(&writefile_list, NANO_NO_KEY, N_("Append"),
IFHELP(nano_append_msg, NANO_APPEND_KEY), NANO_NO_KEY, IFHELP(nano_append_msg, NANO_APPEND_KEY), NANO_NO_KEY,
NANO_NO_KEY, NOVIEW, NULL); NANO_NO_KEY, NOVIEW, NULL);
/* Translators: try to keep this string under 16 characters long */ /* Translators: try to keep this string under 16 characters long. */
if (!ISSET(RESTRICTED)) if (!ISSET(RESTRICTED))
sc_init_one(&writefile_list, NANO_NO_KEY, N_("Prepend"), sc_init_one(&writefile_list, NANO_NO_KEY, N_("Prepend"),
IFHELP(nano_prepend_msg, NANO_PREPEND_KEY), NANO_NO_KEY, IFHELP(nano_prepend_msg, NANO_PREPEND_KEY), NANO_NO_KEY,
NANO_NO_KEY, NOVIEW, NULL); NANO_NO_KEY, NOVIEW, NULL);
#ifndef NANO_TINY #ifndef NANO_TINY
/* Translators: try to keep this string under 16 characters long */ /* Translators: try to keep this string under 16 characters long. */
if (!ISSET(RESTRICTED)) if (!ISSET(RESTRICTED))
sc_init_one(&writefile_list, NANO_NO_KEY, N_("Backup File"), sc_init_one(&writefile_list, NANO_NO_KEY, N_("Backup File"),
IFHELP(nano_backup_msg, TOGGLE_BACKUP_KEY), NANO_NO_KEY, IFHELP(nano_backup_msg, TOGGLE_BACKUP_KEY), NANO_NO_KEY,
@ -919,7 +944,8 @@ void shortcut_init(bool unjustify)
#ifndef NANO_TINY #ifndef NANO_TINY
/* If we're using restricted mode, command execution is disabled. /* If we're using restricted mode, command execution is disabled.
* It's useless since inserting files is disabled. */ * It's useless since inserting files is disabled. */
/* Translators: try to keep this string under 22 characters long */
/* Translators: try to keep this string under 22 characters long. */
if (!ISSET(RESTRICTED)) if (!ISSET(RESTRICTED))
sc_init_one(&insertfile_list, NANO_TOOTHERINSERT_KEY, sc_init_one(&insertfile_list, NANO_TOOTHERINSERT_KEY,
N_("Execute Command"), IFHELP(nano_execute_msg, N_("Execute Command"), IFHELP(nano_execute_msg,
@ -928,7 +954,8 @@ void shortcut_init(bool unjustify)
#ifdef ENABLE_MULTIBUFFER #ifdef ENABLE_MULTIBUFFER
/* If we're using restricted mode, the multibuffer toggle is /* If we're using restricted mode, the multibuffer toggle is
* disabled. It's useless since inserting files is disabled. */ * disabled. It's useless since inserting files is disabled. */
/* Translators: try to keep this string under 22 characters long */
/* Translators: try to keep this string under 22 characters long. */
if (!ISSET(RESTRICTED)) if (!ISSET(RESTRICTED))
sc_init_one(&insertfile_list, NANO_NO_KEY, new_buffer_msg, sc_init_one(&insertfile_list, NANO_NO_KEY, new_buffer_msg,
IFHELP(nano_multibuffer_msg, TOGGLE_MULTIBUFFER_KEY), IFHELP(nano_multibuffer_msg, TOGGLE_MULTIBUFFER_KEY),
@ -936,24 +963,6 @@ void shortcut_init(bool unjustify)
#endif #endif
#endif #endif
#ifndef DISABLE_SPELLER
free_shortcutage(&spell_list);
sc_init_one(&spell_list, NANO_HELP_KEY, get_help_msg,
IFHELP(nano_help_msg, NANO_NO_KEY), NANO_HELP_FKEY,
NANO_NO_KEY, VIEW,
#ifndef DISABLE_HELP
do_help
#else
nano_disabled_msg
#endif
);
sc_init_one(&spell_list, NANO_CANCEL_KEY, cancel_msg,
IFHELP(nano_cancel_msg, NANO_NO_KEY), NANO_NO_KEY,
NANO_NO_KEY, VIEW, NULL);
#endif
#ifndef NANO_TINY #ifndef NANO_TINY
free_shortcutage(&extcmd_list); free_shortcutage(&extcmd_list);
@ -982,6 +991,52 @@ void shortcut_init(bool unjustify)
#endif #endif
#endif #endif
#ifndef DISABLE_HELP
free_shortcutage(&help_list);
sc_init_one(&help_list, NANO_REFRESH_KEY, refresh_msg,
IFHELP(nano_refresh_msg, NANO_NO_KEY), NANO_NO_KEY,
NANO_NO_KEY, VIEW, NULL);
sc_init_one(&help_list, NANO_EXIT_KEY, exit_msg,
IFHELP(nano_exit_msg, NANO_NO_KEY), NANO_EXIT_FKEY,
NANO_NO_KEY, VIEW, NULL);
sc_init_one(&help_list, NANO_PREVPAGE_KEY, prev_page_msg,
IFHELP(nano_prevpage_msg, NANO_NO_KEY), NANO_PREVPAGE_FKEY,
NANO_NO_KEY, VIEW, NULL);
sc_init_one(&help_list, NANO_NEXTPAGE_KEY, next_page_msg,
IFHELP(nano_nextpage_msg, NANO_NO_KEY), NANO_NEXTPAGE_FKEY,
NANO_NO_KEY, VIEW, NULL);
sc_init_one(&help_list, NANO_PREVLINE_KEY, N_("Prev Line"),
IFHELP(nano_prevline_msg, NANO_NO_KEY), NANO_NO_KEY,
NANO_NO_KEY, VIEW, NULL);
sc_init_one(&help_list, NANO_NEXTLINE_KEY, N_("Next Line"),
IFHELP(nano_nextline_msg, NANO_NO_KEY), NANO_NO_KEY,
NANO_NO_KEY, VIEW, NULL);
#endif
#ifndef DISABLE_SPELLER
free_shortcutage(&spell_list);
sc_init_one(&spell_list, NANO_HELP_KEY, get_help_msg,
IFHELP(nano_help_msg, NANO_NO_KEY), NANO_HELP_FKEY,
NANO_NO_KEY, VIEW,
#ifndef DISABLE_HELP
do_help
#else
nano_disabled_msg
#endif
);
sc_init_one(&spell_list, NANO_CANCEL_KEY, cancel_msg,
IFHELP(nano_cancel_msg, NANO_NO_KEY), NANO_NO_KEY,
NANO_NO_KEY, VIEW, NULL);
#endif
#ifndef DISABLE_BROWSER #ifndef DISABLE_BROWSER
free_shortcutage(&browser_list); free_shortcutage(&browser_list);
@ -1007,7 +1062,7 @@ void shortcut_init(bool unjustify)
IFHELP(nano_nextpage_msg, NANO_NO_KEY), NANO_NEXTPAGE_FKEY, IFHELP(nano_nextpage_msg, NANO_NO_KEY), NANO_NEXTPAGE_FKEY,
NANO_NO_KEY, VIEW, NULL); NANO_NO_KEY, VIEW, NULL);
/* Translators: try to keep this string under 22 characters long */ /* Translators: try to keep this string under 22 characters long. */
sc_init_one(&browser_list, NANO_GOTOLINE_KEY, N_("Go To Dir"), sc_init_one(&browser_list, NANO_GOTOLINE_KEY, N_("Go To Dir"),
IFHELP(nano_gotodir_msg, NANO_GOTOLINE_ALTKEY), IFHELP(nano_gotodir_msg, NANO_GOTOLINE_ALTKEY),
NANO_GOTOLINE_FKEY, NANO_NO_KEY, VIEW, NULL); NANO_GOTOLINE_FKEY, NANO_NO_KEY, VIEW, NULL);
@ -1071,6 +1126,7 @@ void toggle_init_one(int val, const char *desc, long flag)
u->next = NULL; u->next = NULL;
} }
/* Initialize the global toggle list. */
void toggle_init(void) void toggle_init(void)
{ {
/* There is no need to reinitialize the toggles. They can't /* There is no need to reinitialize the toggles. They can't
@ -1185,15 +1241,15 @@ void thanks_for_all_the_fish(void)
free_shortcutage(&gotoline_list); free_shortcutage(&gotoline_list);
free_shortcutage(&writefile_list); free_shortcutage(&writefile_list);
free_shortcutage(&insertfile_list); free_shortcutage(&insertfile_list);
#ifndef NANO_TINY
free_shortcutage(&extcmd_list);
#endif
#ifndef DISABLE_HELP #ifndef DISABLE_HELP
free_shortcutage(&help_list); free_shortcutage(&help_list);
#endif #endif
#ifndef DISABLE_SPELLER #ifndef DISABLE_SPELLER
free_shortcutage(&spell_list); free_shortcutage(&spell_list);
#endif #endif
#ifndef NANO_TINY
free_shortcutage(&extcmd_list);
#endif
#ifndef DISABLE_BROWSER #ifndef DISABLE_BROWSER
free_shortcutage(&browser_list); free_shortcutage(&browser_list);
free_shortcutage(&gotodir_list); free_shortcutage(&gotodir_list);

View File

@ -26,6 +26,7 @@
#include <string.h> #include <string.h>
#include <ctype.h> #include <ctype.h>
/* Move to the first line of the file. */
void do_first_line(void) void do_first_line(void)
{ {
const filestruct *current_save = openfile->current; const filestruct *current_save = openfile->current;
@ -40,6 +41,7 @@ void do_first_line(void)
edit_redraw(current_save, pww_save); edit_redraw(current_save, pww_save);
} }
/* Move to the last line of the file. */
void do_last_line(void) void do_last_line(void)
{ {
const filestruct *current_save = openfile->current; const filestruct *current_save = openfile->current;
@ -55,6 +57,7 @@ void do_last_line(void)
edit_redraw(current_save, pww_save); edit_redraw(current_save, pww_save);
} }
/* Move up one page. */
void do_page_up(void) void do_page_up(void)
{ {
int i; int i;
@ -95,6 +98,7 @@ void do_page_up(void)
edit_scroll(UP, editwinrows - 2); edit_scroll(UP, editwinrows - 2);
} }
/* Move down one page. */
void do_page_down(void) void do_page_down(void)
{ {
int i; int i;
@ -138,7 +142,8 @@ void do_page_down(void)
#ifndef DISABLE_JUSTIFY #ifndef DISABLE_JUSTIFY
/* Move up to the beginning of the last beginning-of-paragraph line /* Move up to the beginning of the last beginning-of-paragraph line
* before the current line. */ * before the current line. If allow_update is TRUE, update the screen
* afterwards. */
void do_para_begin(bool allow_update) void do_para_begin(bool allow_update)
{ {
const filestruct *current_save = openfile->current; const filestruct *current_save = openfile->current;
@ -160,6 +165,8 @@ void do_para_begin(bool allow_update)
edit_redraw(current_save, pww_save); edit_redraw(current_save, pww_save);
} }
/* Move up to the beginning of the last beginning-of-paragraph line
* before the current line, and update the screen afterwards. */
void do_para_begin_void(void) void do_para_begin_void(void)
{ {
do_para_begin(TRUE); do_para_begin(TRUE);
@ -167,9 +174,10 @@ void do_para_begin_void(void)
/* Move down to the beginning of the last line of the current paragraph. /* Move down to the beginning of the last line of the current paragraph.
* Then move down one line farther if there is such a line, or to the * Then move down one line farther if there is such a line, or to the
* end of the current line if not. A line is the last line of a * end of the current line if not. If allow_update is TRUE, update the
* paragraph if it is in a paragraph, and the next line either is a * screen afterwards. A line is the last line of a paragraph if it is
* beginning-of-paragraph line or isn't in a paragraph. */ * in a paragraph, and the next line either is the beginning line of a
* paragraph or isn't in a paragraph. */
void do_para_end(bool allow_update) void do_para_end(bool allow_update)
{ {
const filestruct *const current_save = openfile->current; const filestruct *const current_save = openfile->current;
@ -201,6 +209,9 @@ void do_para_end(bool allow_update)
edit_redraw(current_save, pww_save); edit_redraw(current_save, pww_save);
} }
/* Move down to the beginning of the last line of the current paragraph.
* Then move down one line farther if there is such a line, or to the
* end of the current line if not, and update the screen afterwards. */
void do_para_end_void(void) void do_para_end_void(void)
{ {
do_para_end(TRUE); do_para_end(TRUE);
@ -208,10 +219,10 @@ void do_para_end_void(void)
#endif /* !DISABLE_JUSTIFY */ #endif /* !DISABLE_JUSTIFY */
#ifndef NANO_TINY #ifndef NANO_TINY
/* Move to the next word in the current filestruct. If allow_punct is /* Move to the next word in the file. If allow_punct is TRUE, treat
* TRUE, treat punctuation as part of a word. If allow_update is TRUE, * punctuation as part of a word. If allow_update is TRUE, update the
* update the screen afterward. Return TRUE if we started on a word, * screen afterwards. Return TRUE if we started on a word, and FALSE
* and FALSE otherwise. */ * otherwise. */
bool do_next_word(bool allow_punct, bool allow_update) bool do_next_word(bool allow_punct, bool allow_update)
{ {
size_t pww_save = openfile->placewewant; size_t pww_save = openfile->placewewant;
@ -298,15 +309,18 @@ bool do_next_word(bool allow_punct, bool allow_update)
return started_on_word; return started_on_word;
} }
/* Move to the next word in the file, treating punctuation as part of a
* word if the WORD_BOUNDS flag is set, and update the screen
* afterwards. */
void do_next_word_void(void) void do_next_word_void(void)
{ {
do_next_word(ISSET(WORD_BOUNDS), TRUE); do_next_word(ISSET(WORD_BOUNDS), TRUE);
} }
/* Move to the previous word in the current filestruct. If allow_punct /* Move to the previous word in the file. If allow_punct is TRUE, treat
* is TRUE, treat punctuation as part of a word. If allow_update is * punctuation as part of a word. If allow_update is TRUE, update the
* TRUE, update the screen afterward. Return TRUE if we started on a * screen afterwards. Return TRUE if we started on a word, and FALSE
* word, and FALSE otherwise. */ * otherwise. */
bool do_prev_word(bool allow_punct, bool allow_update) bool do_prev_word(bool allow_punct, bool allow_update)
{ {
size_t pww_save = openfile->placewewant; size_t pww_save = openfile->placewewant;
@ -429,12 +443,19 @@ bool do_prev_word(bool allow_punct, bool allow_update)
return started_on_word; return started_on_word;
} }
/* Move to the previous word in the file, treating punctuation as part
* of a word if the WORD_BOUNDS flag is set, and update the screen
* afterwards. */
void do_prev_word_void(void) void do_prev_word_void(void)
{ {
do_prev_word(ISSET(WORD_BOUNDS), TRUE); do_prev_word(ISSET(WORD_BOUNDS), TRUE);
} }
#endif /* !NANO_TINY */ #endif /* !NANO_TINY */
/* Move to the beginning of the current line. If the SMART_HOME flag is
* set, move to the first non-whitespace character of the current line
* if we're not already there, or to the beginning of the current line
* if we are. */
void do_home(void) void do_home(void)
{ {
size_t pww_save = openfile->placewewant; size_t pww_save = openfile->placewewant;
@ -464,6 +485,7 @@ void do_home(void)
update_line(openfile->current, openfile->current_x); update_line(openfile->current, openfile->current_x);
} }
/* Move to the end of the current line. */
void do_end(void) void do_end(void)
{ {
size_t pww_save = openfile->placewewant; size_t pww_save = openfile->placewewant;
@ -477,6 +499,7 @@ void do_end(void)
update_line(openfile->current, openfile->current_x); update_line(openfile->current, openfile->current_x);
} }
/* Move up one line. */
void do_up(void) void do_up(void)
{ {
check_statusblank(); check_statusblank();
@ -516,6 +539,7 @@ void do_up(void)
} }
#ifndef NANO_TINY #ifndef NANO_TINY
/* Scroll up one line without scrolling the cursor. */
void do_scroll_up(void) void do_scroll_up(void)
{ {
check_statusblank(); check_statusblank();
@ -540,6 +564,7 @@ void do_scroll_up(void)
} }
#endif /* !NANO_TINY */ #endif /* !NANO_TINY */
/* Move down one line. */
void do_down(void) void do_down(void)
{ {
check_statusblank(); check_statusblank();
@ -579,6 +604,7 @@ void do_down(void)
} }
#ifndef NANO_TINY #ifndef NANO_TINY
/* Scroll down one line without scrolling the cursor. */
void do_scroll_down(void) void do_scroll_down(void)
{ {
check_statusblank(); check_statusblank();
@ -603,6 +629,7 @@ void do_scroll_down(void)
} }
#endif /* !NANO_TINY */ #endif /* !NANO_TINY */
/* Move left one character. */
void do_left(void) void do_left(void)
{ {
size_t pww_save = openfile->placewewant; size_t pww_save = openfile->placewewant;
@ -623,6 +650,7 @@ void do_left(void)
update_line(openfile->current, openfile->current_x); update_line(openfile->current, openfile->current_x);
} }
/* Move right one character. */
void do_right(void) void do_right(void)
{ {
size_t pww_save = openfile->placewewant; size_t pww_save = openfile->placewewant;

View File

@ -47,12 +47,14 @@
#include <setjmp.h> #include <setjmp.h>
#endif #endif
static struct termios oldterm; /* The user's original term settings. */ static struct termios oldterm;
static struct sigaction act; /* For all our fun signal handlers. */ /* The user's original terminal settings. */
static struct sigaction act;
/* For all our fun signal handlers. */
#ifndef NANO_TINY #ifndef NANO_TINY
static sigjmp_buf jmpbuf; /* Used to return to main() after a static sigjmp_buf jmpbuf;
* SIGWINCH. */ /* Used to return to main() after a SIGWINCH. */
#endif #endif
/* Create a new filestruct node. Note that we specifically do not set /* Create a new filestruct node. Note that we specifically do not set
@ -523,6 +525,7 @@ void free_openfilestruct(openfilestruct *src)
} }
#endif #endif
/* Display a warning about a key disabled in view mode. */
void print_view_warning(void) void print_view_warning(void)
{ {
statusbar(_("Key illegal in VIEW mode")); statusbar(_("Key illegal in VIEW mode"));
@ -597,6 +600,8 @@ void die(const char *msg, ...)
exit(1); exit(1);
} }
/* Save the current file under the name spacified in die_filename, which
* is modified to be unique if necessary. */
void die_save_file(const char *die_filename) void die_save_file(const char *die_filename)
{ {
char *retval; char *retval;
@ -630,6 +635,7 @@ void die_save_file(const char *die_filename)
free(retval); free(retval);
} }
/* Initialize the three window portions nano uses. */
void window_init(void) void window_init(void)
{ {
/* If the screen height is too small, get out. */ /* If the screen height is too small, get out. */
@ -668,6 +674,7 @@ void window_init(void)
} }
#ifndef DISABLE_MOUSE #ifndef DISABLE_MOUSE
/* Initialize mouse support. */
void mouse_init(void) void mouse_init(void)
{ {
if (ISSET(USE_MOUSE)) { if (ISSET(USE_MOUSE)) {
@ -710,6 +717,7 @@ void print1opt_full(const char *shortflag
printf("\n"); printf("\n");
} }
/* Explain how to properly use nano and its command line options. */
void usage(void) void usage(void)
{ {
#ifdef HAVE_GETOPT_LONG #ifdef HAVE_GETOPT_LONG
@ -818,6 +826,9 @@ void usage(void)
exit(0); exit(0);
} }
/* Display the current version of nano, the date and time it was
* compiled, contact information for it, and the configuration options
* it was compiled with. */
void version(void) void version(void)
{ {
printf(_(" GNU nano version %s (compiled %s, %s)\n"), VERSION, printf(_(" GNU nano version %s (compiled %s, %s)\n"), VERSION,
@ -883,16 +894,23 @@ void version(void)
printf("\n"); printf("\n");
} }
/* Return 1 if the MORE_SPACE flag is set, and 0 otherwise. This is
* used to calculate the relative screen position while taking this flag
* into account, since it adds one line to the edit window. */
int no_more_space(void) int no_more_space(void)
{ {
return ISSET(MORE_SPACE) ? 1 : 0; return ISSET(MORE_SPACE) ? 1 : 0;
} }
/* Return 2 if the NO_HELP flag is set, and 0 otherwise. This is used
* to calculate the relative screen position while taking this flag into
* account, since it removes two lines from the edit window. */
int no_help(void) int no_help(void)
{ {
return ISSET(NO_HELP) ? 2 : 0; return ISSET(NO_HELP) ? 2 : 0;
} }
/* Indicate a disabled function on the statusbar. */
void nano_disabled_msg(void) void nano_disabled_msg(void)
{ {
statusbar(_("Sorry, support for this function has been disabled")); statusbar(_("Sorry, support for this function has been disabled"));
@ -902,11 +920,14 @@ void do_exit(void)
{ {
int i; int i;
/* If the file hasn't been modified, pretend the user chose not to
* save. */
if (!openfile->modified) if (!openfile->modified)
/* Pretend the user chose not to save. */
i = 0; i = 0;
/* If the TEMP_FILE flag is set, pretend the user chose to save. */
else if (ISSET(TEMP_FILE)) else if (ISSET(TEMP_FILE))
i = 1; i = 1;
/* Otherwise, ask the user whether or not to save. */
else else
i = do_yesno_prompt(FALSE, i = do_yesno_prompt(FALSE,
_("Save modified buffer (ANSWERING \"No\" WILL DESTROY CHANGES) ? ")); _("Save modified buffer (ANSWERING \"No\" WILL DESTROY CHANGES) ? "));
@ -915,18 +936,22 @@ void do_exit(void)
dump_filestruct(openfile->fileage); dump_filestruct(openfile->fileage);
#endif #endif
/* If the user chose not to save, or if the user chose to save and
* the save succeeded, we're ready to exit. */
if (i == 0 || (i == 1 && do_writeout(TRUE) == 0)) { if (i == 0 || (i == 1 && do_writeout(TRUE) == 0)) {
#ifdef ENABLE_MULTIBUFFER #ifdef ENABLE_MULTIBUFFER
/* Exit only if there are no more open file buffers. */ /* Exit only if there are no more open file buffers. */
if (!close_buffer()) if (!close_buffer())
#endif #endif
finish(); finish();
/* If the user canceled, we go on. */
} else if (i != 1) } else if (i != 1)
statusbar(_("Cancelled")); statusbar(_("Cancelled"));
display_main_list(); display_main_list();
} }
/* Initialize the signal handlers. */
void signal_init(void) void signal_init(void)
{ {
/* Trap SIGINT and SIGQUIT because we want them to do useful /* Trap SIGINT and SIGQUIT because we want them to do useful
@ -1005,6 +1030,7 @@ RETSIGTYPE do_continue(int signal)
} }
#ifndef NANO_TINY #ifndef NANO_TINY
/* Handler for SIGWINCH (window size change). */
RETSIGTYPE handle_sigwinch(int signal) RETSIGTYPE handle_sigwinch(int signal)
{ {
const char *tty = ttyname(0); const char *tty = ttyname(0);
@ -1079,6 +1105,9 @@ RETSIGTYPE handle_sigwinch(int signal)
siglongjmp(jmpbuf, 1); siglongjmp(jmpbuf, 1);
} }
/* If allow is TRUE, block any SIGWINCH signals that we get, so that we
* can deal with them later. If allow is FALSE, unblock any SIGWINCH
* signals that we have, so that we can deal with them now. */
void allow_pending_sigwinch(bool allow) void allow_pending_sigwinch(bool allow)
{ {
sigset_t winch; sigset_t winch;
@ -1089,6 +1118,7 @@ void allow_pending_sigwinch(bool allow)
#endif /* !NANO_TINY */ #endif /* !NANO_TINY */
#ifndef NANO_TINY #ifndef NANO_TINY
/* Handle the global toggle specified in which. */
void do_toggle(const toggle *which) void do_toggle(const toggle *which)
{ {
bool enabled; bool enabled;
@ -1139,6 +1169,8 @@ void do_toggle(const toggle *which)
} }
#endif /* !NANO_TINY */ #endif /* !NANO_TINY */
/* Disable extended input and output processing in our terminal
* settings. */
void disable_extended_io(void) void disable_extended_io(void)
{ {
struct termios term; struct termios term;
@ -1149,6 +1181,8 @@ void disable_extended_io(void)
tcsetattr(0, TCSANOW, &term); tcsetattr(0, TCSANOW, &term);
} }
/* Disable interpretation of the special control keys in our terminal
* settings. */
void disable_signals(void) void disable_signals(void)
{ {
struct termios term; struct termios term;
@ -1159,6 +1193,8 @@ void disable_signals(void)
} }
#ifndef NANO_TINY #ifndef NANO_TINY
/* Enable interpretation of the special control keys in our terminal
* settings. */
void enable_signals(void) void enable_signals(void)
{ {
struct termios term; struct termios term;
@ -1169,6 +1205,8 @@ void enable_signals(void)
} }
#endif #endif
/* Disable interpretation of the flow control characters in our terminal
* settings. */
void disable_flow_control(void) void disable_flow_control(void)
{ {
struct termios term; struct termios term;
@ -1178,6 +1216,8 @@ void disable_flow_control(void)
tcsetattr(0, TCSANOW, &term); tcsetattr(0, TCSANOW, &term);
} }
/* Enable interpretation of the flow control characters in our terminal
* settings. */
void enable_flow_control(void) void enable_flow_control(void)
{ {
struct termios term; struct termios term;
@ -1206,6 +1246,15 @@ void terminal_init(void)
disable_flow_control(); disable_flow_control();
} }
/* Read in a character, interpret it as a shortcut or toggle if
* necessary, and return it. Set meta_key to TRUE if the character is a
* meta sequence, set func_key to TRUE if the character is a function
* key, set s_or_t to TRUE if the character is a shortcut or toggle
* key, set ran_func to TRUE if we ran a function associated with a
* shortcut key, and set finished to TRUE if we're done after running
* or trying to run a function associated with a shortcut key. If
* allow_funcs is FALSE, don't actually run any functions associated
* with shortcut keys. */
int do_input(bool *meta_key, bool *func_key, bool *s_or_t, bool int do_input(bool *meta_key, bool *func_key, bool *s_or_t, bool
*ran_func, bool *finished, bool allow_funcs) *ran_func, bool *finished, bool allow_funcs)
{ {
@ -1325,8 +1374,8 @@ int do_input(bool *meta_key, bool *func_key, bool *s_or_t, bool
/* Handle the normal edit window shortcuts, setting /* Handle the normal edit window shortcuts, setting
* ran_func to TRUE if we try to run their associated * ran_func to TRUE if we try to run their associated
* functions and setting finished to TRUE to indicate * functions and setting finished to TRUE to indicate
* that we're done after trying to run their associated * that we're done after running or trying to run their
* functions. */ * associated functions. */
default: default:
/* Blow away the text in the cutbuffer if we aren't /* Blow away the text in the cutbuffer if we aren't
* cutting text. */ * cutting text. */
@ -1364,6 +1413,7 @@ int do_input(bool *meta_key, bool *func_key, bool *s_or_t, bool
} }
#ifndef DISABLE_MOUSE #ifndef DISABLE_MOUSE
/* Handle a mouse click on the edit window or the shortcut list. */
bool do_mouse(void) bool do_mouse(void)
{ {
int mouse_x, mouse_y; int mouse_x, mouse_y;
@ -2095,5 +2145,6 @@ int main(int argc, char **argv)
TRUE); TRUE);
} }
/* We should never get here. */
assert(FALSE); assert(FALSE);
} }

View File

@ -64,15 +64,17 @@
#endif #endif
#ifdef USE_SLANG #ifdef USE_SLANG
/* Slang support enabled. */ /* Slang support. */
#include <slcurses.h> #include <slcurses.h>
/* Slang curses emulation brain damage, part 2: Slang doesn't define the /* Slang curses emulation brain damage, part 2: Slang doesn't define the
* curses equivalents of the Insert or Delete keys. */ * curses equivalents of the Insert or Delete keys. */
#define KEY_DC SL_KEY_DELETE #define KEY_DC SL_KEY_DELETE
#define KEY_IC SL_KEY_IC #define KEY_IC SL_KEY_IC
/* Ncurses support. */
#elif defined(HAVE_NCURSES_H) #elif defined(HAVE_NCURSES_H)
#include <ncurses.h> #include <ncurses.h>
#else /* Uh oh. */ #else
/* Curses support. */
#include <curses.h> #include <curses.h>
#endif /* CURSES_H */ #endif /* CURSES_H */
@ -172,120 +174,168 @@ typedef enum {
/* Structure types. */ /* Structure types. */
typedef struct filestruct { typedef struct filestruct {
char *data; char *data;
struct filestruct *next; /* Next node. */ /* The text of this line. */
struct filestruct *prev; /* Previous node. */ ssize_t lineno;
ssize_t lineno; /* The line number. */ /* The number of this line. */
struct filestruct *next;
/* Next node. */
struct filestruct *prev;
/* Previous node. */
} filestruct; } filestruct;
typedef struct partition { typedef struct partition {
filestruct *fileage; filestruct *fileage;
/* The top line of this portion of the file. */
filestruct *top_prev; filestruct *top_prev;
/* The line before the top line of this portion of the file. */
char *top_data; char *top_data;
/* The text before the beginning of the top line of this portion
* of the file. */
filestruct *filebot; filestruct *filebot;
/* The bottom line of this portion of the file. */
filestruct *bot_next; filestruct *bot_next;
/* The line after the bottom line of this portion of the
* file. */
char *bot_data; char *bot_data;
/* The text after the end of the bottom line of this portion of
* the file. */
} partition; } partition;
#ifdef ENABLE_COLOR #ifdef ENABLE_COLOR
typedef struct colortype { typedef struct colortype {
short fg; /* Foreground color. */ short fg;
short bg; /* Background color. */ /* This syntax's foreground color. */
bool bright; /* Is this color A_BOLD? */ short bg;
bool icase; /* Is this regex string case /* This syntax's background color. */
* insensitive? */ bool bright;
int pairnum; /* Color pair number used for this /* Is this color A_BOLD? */
* foreground/background. */ bool icase;
char *start_regex; /* Start (or all) of the regex /* Is this regex string case insensitive? */
* string. */ int pairnum;
regex_t *start; /* Compiled start (or all) of the regex /* The color pair number used for this foreground color and
* string. */ * background color. */
char *end_regex; /* End (if any) of the regex string. */ char *start_regex;
regex_t *end; /* Compiled end (if any) of the regex /* The start (or all) of the regex string. */
* string. */ regex_t *start;
/* The compiled start (or all) of the regex string. */
char *end_regex;
/* The end (if any) of the regex string. */
regex_t *end;
/* The compiled end (if any) of the regex string. */
struct colortype *next; struct colortype *next;
/* Next set of colors. */
} colortype; } colortype;
typedef struct exttype { typedef struct exttype {
char *ext_regex; /* Extensions that match this syntax. */ char *ext_regex;
regex_t *ext; /* Compiled extensions that match this /* The extensions that match this syntax. */
* syntax. */ regex_t *ext;
/* The compiled extensions that match this syntax. */
struct exttype *next; struct exttype *next;
/* Next set of extensions. */
} exttype; } exttype;
typedef struct syntaxtype { typedef struct syntaxtype {
char *desc; /* Name of this syntax type. */ char *desc;
exttype *extensions; /* List of extensions that this syntax /* The name of this syntax. */
* applies to. */ exttype *extensions;
colortype *color; /* Color struct for this syntax. */ /* The list of extensions that this syntax applies to. */
colortype *color;
/* The colors used in this syntax. */
struct syntaxtype *next; struct syntaxtype *next;
/* Next syntax. */
} syntaxtype; } syntaxtype;
#endif /* ENABLE_COLOR */ #endif /* ENABLE_COLOR */
typedef struct openfilestruct { typedef struct openfilestruct {
char *filename; /* Current file's name. */ char *filename;
filestruct *fileage; /* Current file's first line. */ /* The current file's name. */
filestruct *filebot; /* Current file's last line. */ filestruct *fileage;
filestruct *edittop; /* Current top of edit window. */ /* The current file's first line. */
filestruct *current; /* Current file's line. */ filestruct *filebot;
size_t totsize; /* Current file's total number of /* The current file's last line. */
* characters. */ filestruct *edittop;
size_t current_x; /* Current file's x-coordinate /* The current top of the edit window. */
* position. */ filestruct *current;
size_t placewewant; /* Current file's place we want. */ /* The current file's current line. */
ssize_t current_y; /* Current file's y-coordinate size_t totsize;
* position. */ /* The current file's total number of characters. */
bool modified; /* Current file's modification size_t current_x;
* status. */ /* The current file's x-coordinate position. */
size_t placewewant;
/* The current file's place we want. */
ssize_t current_y;
/* The current file's y-coordinate position. */
bool modified;
/* Whether the current file has been modified. */
#ifndef NANO_TINY #ifndef NANO_TINY
bool mark_set; /* Current file's marking status. */ bool mark_set;
filestruct *mark_begin; /* Current file's beginning marked /* Whether the mark is on in the current file. */
* line. */ filestruct *mark_begin;
size_t mark_begin_x; /* Current file's beginning marked /* The current file's beginning marked line, if any. */
* line's x-coordinate position. */ size_t mark_begin_x;
file_format fmt; /* Current file's format. */ /* The current file's beginning marked line's x-coordinate
struct stat *current_stat; /* Current file's stat. */ * position, if any. */
file_format fmt;
/* The current file's format. */
struct stat *current_stat;
/* The current file's stat. */
#endif #endif
#ifdef ENABLE_COLOR #ifdef ENABLE_COLOR
colortype *colorstrings; /* Current file's associated colors. */ colortype *colorstrings;
/* The current file's associated colors. */
#endif #endif
struct openfilestruct *next; struct openfilestruct *next;
/* Next node. */ /* Next node. */
struct openfilestruct *prev; struct openfilestruct *prev;
/* Previous node. */ /* Previous node. */
} openfilestruct; } openfilestruct;
typedef struct shortcut { typedef struct shortcut {
/* Key values that aren't used should be set to NANO_NO_KEY. */ /* Key values that aren't used should be set to NANO_NO_KEY. */
int ctrlval; /* Special sentinel key or control key we want int ctrlval;
* bound. */ /* The special sentinel key or control key we want bound, if
int metaval; /* Meta key we want bound. */ * any. */
int funcval; /* Function key we want bound. */ int metaval;
int miscval; /* Other Meta key we want bound. */ /* The meta key we want bound, if any. */
bool viewok; /* Is this function legal in view mode? */ int funcval;
void (*func)(void); /* Function to call when we catch this key. */ /* The function key we want bound, if any. */
const char *desc; /* Description, e.g. "Page Up". */ int miscval;
/* The other meta key we want bound, if any. */
bool viewok;
/* Is this function allowed when in view mode? */
void (*func)(void);
/* The function to call when we get this key. */
const char *desc;
/* The function's description, e.g. "Page Up". */
#ifndef DISABLE_HELP #ifndef DISABLE_HELP
const char *help; /* Help file entry text. */ const char *help;
/* The help file entry text for this function. */
#endif #endif
struct shortcut *next; struct shortcut *next;
/* Next shortcut. */
} shortcut; } shortcut;
#ifndef NANO_TINY #ifndef NANO_TINY
typedef struct toggle { typedef struct toggle {
int val; /* Sequence to toggle the key. Should only need int val;
* one. */ /* The sequence to toggle the key. We should only need one. */
const char *desc; /* Description for when toggle is, uh, toggled, const char *desc;
* e.g. "Cut to end"; we'll append Enabled or /* The description for when the toggle is, uh, toggled, e.g.
* Disabled. */ * "Cut to end"; we'll append Enabled or Disabled. */
long flag; /* What flag actually gets toggled. */ long flag;
/* Which flag actually gets toggled. */
struct toggle *next; struct toggle *next;
/* Next toggle. */
} toggle; } toggle;
#endif #endif
#ifdef ENABLE_NANORC #ifdef ENABLE_NANORC
typedef struct rcoption { typedef struct rcoption {
const char *name; const char *name;
/* The name of the rcfile option. */
long flag; long flag;
/* The flag associated with it, if any. */
} rcoption; } rcoption;
#endif #endif
@ -452,8 +502,8 @@ typedef struct rcoption {
#define NANO_REFRESH_KEY NANO_CONTROL_L #define NANO_REFRESH_KEY NANO_CONTROL_L
#define NANO_JUSTIFY_KEY NANO_CONTROL_J #define NANO_JUSTIFY_KEY NANO_CONTROL_J
#define NANO_JUSTIFY_FKEY KEY_F(4) #define NANO_JUSTIFY_FKEY KEY_F(4)
#define NANO_UNJUSTIFY_KEY NANO_UNCUT_KEY /* Same key as uncut. */ #define NANO_UNJUSTIFY_KEY NANO_UNCUT_KEY /* Same key as UnCut. */
#define NANO_UNJUSTIFY_FKEY NANO_UNCUT_FKEY /* Same key as uncut. */ #define NANO_UNJUSTIFY_FKEY NANO_UNCUT_FKEY /* Same key as UnCut. */
#define NANO_PREVLINE_KEY NANO_CONTROL_P #define NANO_PREVLINE_KEY NANO_CONTROL_P
#define NANO_NEXTLINE_KEY NANO_CONTROL_N #define NANO_NEXTLINE_KEY NANO_CONTROL_N
#define NANO_FORWARD_KEY NANO_CONTROL_F #define NANO_FORWARD_KEY NANO_CONTROL_F
@ -524,23 +574,23 @@ typedef struct rcoption {
#define VIEW TRUE #define VIEW TRUE
#define NOVIEW FALSE #define NOVIEW FALSE
/* Minimum editor window columns and rows required for nano to work /* The minimum editor window columns and rows required for nano to work
* correctly. */ * correctly. */
#define MIN_EDITOR_COLS 4 #define MIN_EDITOR_COLS 4
#define MIN_EDITOR_ROWS 1 #define MIN_EDITOR_ROWS 1
/* Default number of characters from end-of-line where text wrapping /* The default number of characters from the end of the line where
* occurs. */ * wrapping occurs. */
#define CHARS_FROM_EOL 8 #define CHARS_FROM_EOL 8
/* Default width of a tab. */ /* The default width of a tab in spaces. */
#define WIDTH_OF_TAB 8 #define WIDTH_OF_TAB 8
/* Maximum number of search/replace history strings saved, not counting /* The maximum number of search/replace history strings saved, not
* the blank lines at their ends. */ * counting the blank lines at their ends. */
#define MAX_SEARCH_HISTORY 100 #define MAX_SEARCH_HISTORY 100
/* Maximum number of bytes we read from a file at one time. */ /* The maximum number of bytes we read from a file at one time. */
#define MAX_BUF_SIZE 128 #define MAX_BUF_SIZE 128
#endif /* !NANO_H */ #endif /* !NANO_H */

View File

@ -38,6 +38,15 @@ static bool reset_statusbar_x = FALSE;
/* Should we reset the cursor position /* Should we reset the cursor position
* at the statusbar prompt? */ * at the statusbar prompt? */
/* Read in a character, interpret it as a shortcut or toggle if
* necessary, and return it. Set meta_key to TRUE if the character is a
* meta sequence, set func_key to TRUE if the character is a function
* key, set s_or_t to TRUE if the character is a shortcut or toggle
* key, set ran_func to TRUE if we ran a function associated with a
* shortcut key, and set finished to TRUE if we're done after running
* or trying to run a function associated with a shortcut key. If
* allow_funcs is FALSE, don't actually run any functions associated
* with shortcut keys. */
int do_statusbar_input(bool *meta_key, bool *func_key, bool *s_or_t, int do_statusbar_input(bool *meta_key, bool *func_key, bool *s_or_t,
bool *ran_func, bool *finished, bool allow_funcs) bool *ran_func, bool *finished, bool allow_funcs)
{ {
@ -75,7 +84,7 @@ int do_statusbar_input(bool *meta_key, bool *func_key, bool *s_or_t,
* statusbar prompt shortcut, set have_shortcut to TRUE. */ * statusbar prompt shortcut, set have_shortcut to TRUE. */
have_shortcut = (s != NULL || input == NANO_REFRESH_KEY || have_shortcut = (s != NULL || input == NANO_REFRESH_KEY ||
input == NANO_HOME_KEY || input == NANO_END_KEY || input == NANO_HOME_KEY || input == NANO_END_KEY ||
input == NANO_FORWARD_KEY || input == NANO_BACK_KEY || input == NANO_BACK_KEY || input == NANO_FORWARD_KEY ||
input == NANO_BACKSPACE_KEY || input == NANO_DELETE_KEY || input == NANO_BACKSPACE_KEY || input == NANO_DELETE_KEY ||
input == NANO_CUT_KEY || input == NANO_CUT_KEY ||
#ifndef NANO_TINY #ifndef NANO_TINY
@ -152,12 +161,12 @@ int do_statusbar_input(bool *meta_key, bool *func_key, bool *s_or_t,
case NANO_END_KEY: case NANO_END_KEY:
do_statusbar_end(); do_statusbar_end();
break; break;
case NANO_FORWARD_KEY:
do_statusbar_right();
break;
case NANO_BACK_KEY: case NANO_BACK_KEY:
do_statusbar_left(); do_statusbar_left();
break; break;
case NANO_FORWARD_KEY:
do_statusbar_right();
break;
case NANO_BACKSPACE_KEY: case NANO_BACKSPACE_KEY:
/* If we're using restricted mode, the filename /* If we're using restricted mode, the filename
* isn't blank, and we're at the "Write File" * isn't blank, and we're at the "Write File"
@ -223,8 +232,8 @@ int do_statusbar_input(bool *meta_key, bool *func_key, bool *s_or_t,
/* Handle the normal statusbar prompt shortcuts, setting /* Handle the normal statusbar prompt shortcuts, setting
* ran_func to TRUE if we try to run their associated * ran_func to TRUE if we try to run their associated
* functions and setting finished to TRUE to indicate * functions and setting finished to TRUE to indicate
* that we're done after trying to run their associated * that we're done after running or trying to run their
* functions. */ * associated functions. */
default: default:
if (s->func != NULL) { if (s->func != NULL) {
*ran_func = TRUE; *ran_func = TRUE;
@ -240,6 +249,7 @@ int do_statusbar_input(bool *meta_key, bool *func_key, bool *s_or_t,
} }
#ifndef DISABLE_MOUSE #ifndef DISABLE_MOUSE
/* Handle a mouse click on the statusbar prompt or the shortcut list. */
bool do_statusbar_mouse(void) bool do_statusbar_mouse(void)
{ {
int mouse_x, mouse_y; int mouse_x, mouse_y;
@ -342,6 +352,10 @@ void do_statusbar_output(char *output, size_t output_len, bool
update_statusbar_line(answer, statusbar_x); update_statusbar_line(answer, statusbar_x);
} }
/* Move to the beginning of the prompt text. If the SMART_HOME flag is
* set, move to the first non-whitespace character of the prompt text if
* we're not already there, or to the beginning of the prompt text if we
* are. */
void do_statusbar_home(void) void do_statusbar_home(void)
{ {
size_t pww_save = statusbar_pww; size_t pww_save = statusbar_pww;
@ -369,6 +383,7 @@ void do_statusbar_home(void)
update_statusbar_line(answer, statusbar_x); update_statusbar_line(answer, statusbar_x);
} }
/* Move to the end of the prompt text. */
void do_statusbar_end(void) void do_statusbar_end(void)
{ {
size_t pww_save = statusbar_pww; size_t pww_save = statusbar_pww;
@ -380,19 +395,7 @@ void do_statusbar_end(void)
update_statusbar_line(answer, statusbar_x); update_statusbar_line(answer, statusbar_x);
} }
void do_statusbar_right(void) /* Move left one character. */
{
if (statusbar_x < strlen(answer)) {
size_t pww_save = statusbar_pww;
statusbar_x = move_mbright(answer, statusbar_x);
statusbar_pww = statusbar_xplustabs();
if (need_statusbar_horizontal_update(pww_save))
update_statusbar_line(answer, statusbar_x);
}
}
void do_statusbar_left(void) void do_statusbar_left(void)
{ {
if (statusbar_x > 0) { if (statusbar_x > 0) {
@ -406,6 +409,21 @@ void do_statusbar_left(void)
} }
} }
/* Move right one character. */
void do_statusbar_right(void)
{
if (statusbar_x < strlen(answer)) {
size_t pww_save = statusbar_pww;
statusbar_x = move_mbright(answer, statusbar_x);
statusbar_pww = statusbar_xplustabs();
if (need_statusbar_horizontal_update(pww_save))
update_statusbar_line(answer, statusbar_x);
}
}
/* Backspace over one character. */
void do_statusbar_backspace(void) void do_statusbar_backspace(void)
{ {
if (statusbar_x > 0) { if (statusbar_x > 0) {
@ -414,6 +432,7 @@ void do_statusbar_backspace(void)
} }
} }
/* Delete one character. */
void do_statusbar_delete(void) void do_statusbar_delete(void)
{ {
statusbar_pww = statusbar_xplustabs(); statusbar_pww = statusbar_xplustabs();
@ -435,7 +454,7 @@ void do_statusbar_delete(void)
} }
} }
/* Move text from the statusbar prompt into oblivion. */ /* Move text from the prompt into oblivion. */
void do_statusbar_cut_text(void) void do_statusbar_cut_text(void)
{ {
assert(answer != NULL); assert(answer != NULL);
@ -456,9 +475,9 @@ void do_statusbar_cut_text(void)
} }
#ifndef NANO_TINY #ifndef NANO_TINY
/* Move to the next word at the statusbar prompt. If allow_punct is /* Move to the next word in the prompt text. If allow_punct is TRUE,
* TRUE, treat punctuation as part of a word. Return TRUE if we started * treat punctuation as part of a word. Return TRUE if we started on a
* on a word, and FALSE otherwise. */ * word, and FALSE otherwise. */
bool do_statusbar_next_word(bool allow_punct) bool do_statusbar_next_word(bool allow_punct)
{ {
size_t pww_save = statusbar_pww; size_t pww_save = statusbar_pww;
@ -521,7 +540,7 @@ bool do_statusbar_next_word(bool allow_punct)
return started_on_word; return started_on_word;
} }
/* Move to the previous word at the statusbar prompt. If allow_punct is /* Move to the previous word in the prompt text. If allow_punct is
* TRUE, treat punctuation as part of a word. Return TRUE if we started * TRUE, treat punctuation as part of a word. Return TRUE if we started
* on a word, and FALSE otherwise. */ * on a word, and FALSE otherwise. */
bool do_statusbar_prev_word(bool allow_punct) bool do_statusbar_prev_word(bool allow_punct)
@ -617,6 +636,8 @@ bool do_statusbar_prev_word(bool allow_punct)
} }
#endif /* !NANO_TINY */ #endif /* !NANO_TINY */
/* Get verbatim input. Set got_enter to TRUE if we got the Enter key as
* part of the verbatim input. */
void do_statusbar_verbatim_input(bool *got_enter) void do_statusbar_verbatim_input(bool *got_enter)
{ {
int *kbinput; int *kbinput;
@ -642,6 +663,10 @@ void do_statusbar_verbatim_input(bool *got_enter)
} }
#ifndef NANO_TINY #ifndef NANO_TINY
/* Search for a match to one of the two characters in bracket_set. If
* reverse is TRUE, search backwards for the leftmost bracket.
* Otherwise, search forwards for the rightmost bracket. Return TRUE if
* we found a match, and FALSE otherwise. */
bool find_statusbar_bracket_match(bool reverse, const char bool find_statusbar_bracket_match(bool reverse, const char
*bracket_set) *bracket_set)
{ {
@ -681,6 +706,8 @@ bool find_statusbar_bracket_match(bool reverse, const char
return TRUE; return TRUE;
} }
/* Search for a match to the bracket at the current cursor position, if
* there is one. */
void do_statusbar_find_bracket(void) void do_statusbar_find_bracket(void)
{ {
size_t statusbar_x_save, pww_save; size_t statusbar_x_save, pww_save;

View File

@ -24,17 +24,29 @@
#ifndef PROTO_H #ifndef PROTO_H
#define PROTO_H 1 #define PROTO_H 1
/* Public externs. */
#include "nano.h" #include "nano.h"
/* Public externs. See global.c for descriptions of them. */
#ifndef DISABLE_WRAPJUSTIFY #ifndef DISABLE_WRAPJUSTIFY
extern ssize_t fill; extern ssize_t fill;
extern ssize_t wrap_at; extern ssize_t wrap_at;
#endif #endif
extern int editwinrows;
extern char *last_search;
extern char *last_replace;
extern long flags; extern long flags;
extern ssize_t tabsize; extern WINDOW *topwin;
extern int currslen; extern WINDOW *edit;
extern WINDOW *bottomwin;
extern int editwinrows;
extern filestruct *cutbuffer;
#ifndef DISABLE_JUSTIFY
extern filestruct *jusbuffer;
#endif
extern partition *filepart;
extern openfilestruct *openfile;
#if !defined(NANO_TINY) && defined(ENABLE_NANORC) #if !defined(NANO_TINY) && defined(ENABLE_NANORC)
extern char *whitespace; extern char *whitespace;
@ -54,41 +66,29 @@ extern size_t quotelen;
#endif #endif
#endif #endif
extern char *answer;
extern ssize_t tabsize;
#ifndef NANO_TINY #ifndef NANO_TINY
extern char *backup_dir; extern char *backup_dir;
#endif #endif
extern WINDOW *topwin, *edit, *bottomwin;
extern char *answer;
extern char *last_search;
extern char *last_replace;
#ifndef DISABLE_OPERATINGDIR #ifndef DISABLE_OPERATINGDIR
extern char *operating_dir; extern char *operating_dir;
extern char *full_operating_dir; extern char *full_operating_dir;
#endif #endif
#ifndef DISABLE_SPELLER #ifndef DISABLE_SPELLER
extern char *alt_speller; extern char *alt_speller;
#endif #endif
extern struct stat fileinfo; extern shortcut *main_list;
extern filestruct *cutbuffer; extern shortcut *whereis_list;
#ifndef DISABLE_JUSTIFY extern shortcut *replace_list;
extern filestruct *jusbuffer;
#endif
extern partition *filepart;
extern openfilestruct *openfile;
#ifdef ENABLE_COLOR
extern syntaxtype *syntaxes;
extern char *syntaxstr;
#endif
extern shortcut *shortcut_list;
extern shortcut *main_list, *whereis_list;
extern shortcut *replace_list, *gotoline_list;
extern shortcut *writefile_list, *insertfile_list;
extern shortcut *replace_list_2; extern shortcut *replace_list_2;
extern shortcut *gotoline_list;
extern shortcut *writefile_list;
extern shortcut *insertfile_list;
#ifndef NANO_TINY #ifndef NANO_TINY
extern shortcut *extcmd_list; extern shortcut *extcmd_list;
#endif #endif
@ -99,20 +99,16 @@ extern shortcut *help_list;
extern shortcut *spell_list; extern shortcut *spell_list;
#endif #endif
#ifndef DISABLE_BROWSER #ifndef DISABLE_BROWSER
extern shortcut *browser_list, *gotodir_list; extern shortcut *browser_list;
extern shortcut *gotodir_list;
#endif
#ifdef ENABLE_COLOR
extern syntaxtype *syntaxes;
extern char *syntaxstr;
#endif #endif
extern const shortcut *currshortcut; extern const shortcut *currshortcut;
#ifdef HAVE_REGEX_H
extern regex_t search_regexp;
extern regmatch_t regmatches[10];
#ifdef ENABLE_COLOR
extern regex_t syntaxfile_regexp;
extern regmatch_t synfilematches[1];
#endif
#endif
#ifndef NANO_TINY #ifndef NANO_TINY
extern toggle *toggles; extern toggle *toggles;
#endif #endif
@ -126,12 +122,15 @@ extern filestruct *replaceage;
extern filestruct *replacebot; extern filestruct *replacebot;
#endif #endif
#ifdef HAVE_REGEX_H
extern regex_t search_regexp;
extern regmatch_t regmatches[10];
#endif
extern bool curses_ended; extern bool curses_ended;
extern char *homedir; extern char *homedir;
/* The functions we want available. */
/* Public functions in browser.c. */ /* Public functions in browser.c. */
#ifndef DISABLE_BROWSER #ifndef DISABLE_BROWSER
char *do_browser(char *path, DIR *dir); char *do_browser(char *path, DIR *dir);
@ -436,8 +435,8 @@ void do_statusbar_output(char *output, size_t output_len, bool
*got_enter, bool allow_cntrls); *got_enter, bool allow_cntrls);
void do_statusbar_home(void); void do_statusbar_home(void);
void do_statusbar_end(void); void do_statusbar_end(void);
void do_statusbar_right(void);
void do_statusbar_left(void); void do_statusbar_left(void);
void do_statusbar_right(void);
void do_statusbar_backspace(void); void do_statusbar_backspace(void);
void do_statusbar_delete(void); void do_statusbar_delete(void);
void do_statusbar_cut_text(void); void do_statusbar_cut_text(void);
@ -496,7 +495,7 @@ int regexp_init(const char *regexp);
void regexp_cleanup(void); void regexp_cleanup(void);
#endif #endif
void not_found_msg(const char *str); void not_found_msg(const char *str);
void search_abort(void); void search_replace_abort(void);
void search_init_globals(void); void search_init_globals(void);
int search_init(bool replacing, bool use_answer); int search_init(bool replacing, bool use_answer);
bool findnextstr( bool findnextstr(
@ -510,7 +509,6 @@ void do_search(void);
#ifndef NANO_TINY #ifndef NANO_TINY
void do_research(void); void do_research(void);
#endif #endif
void replace_abort(void);
#ifdef HAVE_REGEX_H #ifdef HAVE_REGEX_H
int replace_regexp(char *string, bool create); int replace_regexp(char *string, bool create);
#endif #endif
@ -526,7 +524,7 @@ void do_gotolinecolumn(ssize_t line, ssize_t column, bool use_answer,
bool interactive, bool save_pos, bool allow_update); bool interactive, bool save_pos, bool allow_update);
void do_gotolinecolumn_void(void); void do_gotolinecolumn_void(void);
#ifndef DISABLE_SPELLER #ifndef DISABLE_SPELLER
void do_gotopos(ssize_t line, size_t pos_x, ssize_t pos_y, size_t void do_gotopos(ssize_t pos_line, size_t pos_x, ssize_t pos_y, size_t
pos_pww); pos_pww);
#endif #endif
#ifndef NANO_TINY #ifndef NANO_TINY
@ -621,7 +619,7 @@ ssize_t ngetdelim(char **lineptr, size_t *n, int delim, FILE *stream);
int safe_regexec(const regex_t *preg, const char *string, size_t nmatch, int safe_regexec(const regex_t *preg, const char *string, size_t nmatch,
regmatch_t pmatch[], int eflags); regmatch_t pmatch[], int eflags);
#endif #endif
int regexp_bol_or_eol(const regex_t *preg, const char *string); bool regexp_bol_or_eol(const regex_t *preg, const char *string);
#endif #endif
#ifndef DISABLE_SPELLER #ifndef DISABLE_SPELLER
bool is_whole_word(size_t pos, const char *buf, const char *word); bool is_whole_word(size_t pos, const char *buf, const char *word);

View File

@ -93,8 +93,12 @@ const static rcoption rcopts[] = {
}; };
static bool errors = FALSE; static bool errors = FALSE;
/* Whether we got any errors while parsing an rcfile. */
static size_t lineno = 0; static size_t lineno = 0;
/* If we did, the line number where the current error
* occurred. */
static char *nanorc = NULL; static char *nanorc = NULL;
/* The path to the rcfile we're parsing. */
#ifdef ENABLE_COLOR #ifdef ENABLE_COLOR
static syntaxtype *endsyntax = NULL; static syntaxtype *endsyntax = NULL;
/* The end of the list of syntaxes. */ /* The end of the list of syntaxes. */
@ -180,6 +184,8 @@ char *parse_argument(char *ptr)
} }
#ifdef ENABLE_COLOR #ifdef ENABLE_COLOR
/* Return the short value corresponding to the color named in colorname,
* and set bright to TRUE if that color is bright. */
short color_to_short(const char *colorname, bool *bright) short color_to_short(const char *colorname, bool *bright)
{ {
short mcolor = -1; short mcolor = -1;
@ -217,6 +223,7 @@ short color_to_short(const char *colorname, bool *bright)
return mcolor; return mcolor;
} }
/* Parse the next regex string from the line at ptr, and return it. */
char *parse_next_regex(char *ptr) char *parse_next_regex(char *ptr)
{ {
assert(ptr != NULL); assert(ptr != NULL);
@ -265,6 +272,8 @@ bool nregcomp(const char *regex, int eflags)
return (rc == 0); return (rc == 0);
} }
/* Parse the next syntax string from the line at ptr, and add it to the
* global list of color syntaxes. */
void parse_syntax(char *ptr) void parse_syntax(char *ptr)
{ {
const char *fileregptr = NULL, *nameptr = NULL; const char *fileregptr = NULL, *nameptr = NULL;
@ -372,8 +381,9 @@ void parse_syntax(char *ptr)
} }
} }
/* Parse the color stuff into the colorstrings array. If icase is TRUE, /* Parse the color string in the line at ptr, and add it to the current
* treat the color stuff as case insensitive. */ * file's associated colors. If icase is TRUE, treat the color string
* as case insensitive. */
void parse_colors(char *ptr, bool icase) void parse_colors(char *ptr, bool icase)
{ {
short fg, bg; short fg, bg;
@ -529,7 +539,8 @@ void parse_colors(char *ptr, bool icase)
} }
#endif /* ENABLE_COLOR */ #endif /* ENABLE_COLOR */
/* Parse the rcfile, once it has been opened successfully. */ /* Parse the rcfile, once it has been opened successfully at
* rcstream. */
void parse_rcfile(FILE *rcstream) void parse_rcfile(FILE *rcstream)
{ {
char *buf = NULL; char *buf = NULL;

View File

@ -68,6 +68,8 @@ int regexp_init(const char *regexp)
return 1; return 1;
} }
/* Decompile the compiled regular expression we used in the last
* search, if any. */
void regexp_cleanup(void) void regexp_cleanup(void)
{ {
if (regexp_compiled) { if (regexp_compiled) {
@ -77,6 +79,8 @@ void regexp_cleanup(void)
} }
#endif #endif
/* Indicate on the statusbar that the string at str was not found by the
* last search. */
void not_found_msg(const char *str) void not_found_msg(const char *str)
{ {
char *disp; char *disp;
@ -93,7 +97,11 @@ void not_found_msg(const char *str)
free(disp); free(disp);
} }
void search_abort(void) /* Abort the current search or replace. Clean up by displaying the main
* shortcut list, updating the screen if the mark was on before, and
* decompiling the compiled regular expression we used in the last
* search, if any. */
void search_replace_abort(void)
{ {
display_main_list(); display_main_list();
#ifndef NANO_TINY #ifndef NANO_TINY
@ -105,6 +113,7 @@ void search_abort(void)
#endif #endif
} }
/* Initialize the global search and replace strings. */
void search_init_globals(void) void search_init_globals(void)
{ {
if (last_search == NULL) if (last_search == NULL)
@ -403,6 +412,8 @@ bool findnextstr(
return TRUE; return TRUE;
} }
/* Clear the flag indicating that a search reached the last line of the
* file. We need to do this just before a new search. */
void findnextstr_wrap_reset(void) void findnextstr_wrap_reset(void)
{ {
search_last_line = FALSE; search_last_line = FALSE;
@ -424,7 +435,7 @@ void do_search(void)
i = search_init(FALSE, FALSE); i = search_init(FALSE, FALSE);
if (i == -1) /* Cancel, Go to Line, blank search string, or if (i == -1) /* Cancel, Go to Line, blank search string, or
* regcomp() failed. */ * regcomp() failed. */
search_abort(); search_replace_abort();
else if (i == -2) /* Replace. */ else if (i == -2) /* Replace. */
do_replace(); do_replace();
#if !defined(NANO_TINY) || defined(HAVE_REGEX_H) #if !defined(NANO_TINY) || defined(HAVE_REGEX_H)
@ -487,11 +498,11 @@ void do_search(void)
openfile->placewewant = xplustabs(); openfile->placewewant = xplustabs();
edit_redraw(fileptr, old_pww); edit_redraw(fileptr, old_pww);
search_abort(); search_replace_abort();
} }
#ifndef NANO_TINY #ifndef NANO_TINY
/* Search for the next string without prompting. */ /* Search for the last string without prompting. */
void do_research(void) void do_research(void)
{ {
filestruct *fileptr = openfile->current; filestruct *fileptr = openfile->current;
@ -553,16 +564,10 @@ void do_research(void)
openfile->placewewant = xplustabs(); openfile->placewewant = xplustabs();
edit_redraw(fileptr, old_pww); edit_redraw(fileptr, old_pww);
search_abort(); search_replace_abort();
} }
#endif #endif
void replace_abort(void)
{
/* For now, we do the same thing as search_abort(). */
search_abort();
}
#ifdef HAVE_REGEX_H #ifdef HAVE_REGEX_H
int replace_regexp(char *string, bool create) int replace_regexp(char *string, bool create)
{ {
@ -881,14 +886,14 @@ void do_replace(void)
if (ISSET(VIEW_MODE)) { if (ISSET(VIEW_MODE)) {
print_view_warning(); print_view_warning();
replace_abort(); search_replace_abort();
return; return;
} }
i = search_init(TRUE, FALSE); i = search_init(TRUE, FALSE);
if (i == -1) { /* Cancel, Go to Line, blank search if (i == -1) { /* Cancel, Go to Line, blank search
* string, or regcomp() failed. */ * string, or regcomp() failed. */
replace_abort(); search_replace_abort();
return; return;
} else if (i == -2) { /* No Replace. */ } else if (i == -2) { /* No Replace. */
do_search(); do_search();
@ -930,7 +935,7 @@ void do_replace(void)
answer = mallocstrcpy(answer, last_replace); answer = mallocstrcpy(answer, last_replace);
statusbar(_("Cancelled")); statusbar(_("Cancelled"));
} }
replace_abort(); search_replace_abort();
return; return;
} }
@ -961,7 +966,7 @@ void do_replace(void)
"Replaced %lu occurrences", (unsigned long)numreplaced), "Replaced %lu occurrences", (unsigned long)numreplaced),
(unsigned long)numreplaced); (unsigned long)numreplaced);
replace_abort(); search_replace_abort();
} }
/* Go to the specified line and column, or ask for them if interactive /* Go to the specified line and column, or ask for them if interactive
@ -1035,6 +1040,7 @@ void do_gotolinecolumn(ssize_t line, ssize_t column, bool use_answer,
display_main_list(); display_main_list();
} }
/* Go to the specified line and column, asking for them beforehand. */
void do_gotolinecolumn_void(void) void do_gotolinecolumn_void(void)
{ {
do_gotolinecolumn(openfile->current->lineno, do_gotolinecolumn(openfile->current->lineno,
@ -1042,13 +1048,16 @@ void do_gotolinecolumn_void(void)
} }
#ifndef DISABLE_SPELLER #ifndef DISABLE_SPELLER
void do_gotopos(ssize_t line, size_t pos_x, ssize_t pos_y, size_t /* Go to the line with the number specified in pos_line, the
* x-coordinate specified in pos_x, the y-coordinate specified in pos_y,
* and the place we want specified in pos_pww. */
void do_gotopos(ssize_t pos_line, size_t pos_x, ssize_t pos_y, size_t
pos_pww) pos_pww)
{ {
/* Since do_gotolinecolumn() resets the x-coordinate but not the /* Since do_gotolinecolumn() resets the x-coordinate but not the
* y-coordinate, set the coordinates up this way. */ * y-coordinate, set the coordinates up this way. */
openfile->current_y = pos_y; openfile->current_y = pos_y;
do_gotolinecolumn(line, pos_x + 1, FALSE, FALSE, TRUE, TRUE); do_gotolinecolumn(pos_line, pos_x + 1, FALSE, FALSE, TRUE, TRUE);
/* Set the rest of the coordinates up. */ /* Set the rest of the coordinates up. */
openfile->placewewant = pos_pww; openfile->placewewant = pos_pww;
@ -1058,8 +1067,9 @@ void do_gotopos(ssize_t line, size_t pos_x, ssize_t pos_y, size_t
#ifndef NANO_TINY #ifndef NANO_TINY
/* Search for a match to one of the two characters in bracket_set. If /* Search for a match to one of the two characters in bracket_set. If
* reverse is TRUE, search backwards. Otherwise, search forwards. * reverse is TRUE, search backwards for the leftmost bracket.
* Return TRUE if we found a match, or FALSE otherwise. */ * Otherwise, search forwards for the rightmost bracket. Return TRUE if
* we found a match, and FALSE otherwise. */
bool find_bracket_match(bool reverse, const char *bracket_set) bool find_bracket_match(bool reverse, const char *bracket_set)
{ {
filestruct *fileptr = openfile->current; filestruct *fileptr = openfile->current;

View File

@ -33,8 +33,8 @@
#ifndef NANO_TINY #ifndef NANO_TINY
static pid_t pid = -1; static pid_t pid = -1;
/* The PID of the newly forked process in execute_command(), for /* The PID of the forked process in execute_command(), for use
* use with the cancel_command() signal handler. */ * with the cancel_command() signal handler. */
#endif #endif
#ifndef DISABLE_WRAPPING #ifndef DISABLE_WRAPPING
static bool prepend_wrap = FALSE; static bool prepend_wrap = FALSE;
@ -46,6 +46,7 @@ static filestruct *jusbottom = NULL;
#endif #endif
#ifndef NANO_TINY #ifndef NANO_TINY
/* Toggle the mark. */
void do_mark(void) void do_mark(void)
{ {
openfile->mark_set = !openfile->mark_set; openfile->mark_set = !openfile->mark_set;
@ -62,6 +63,7 @@ void do_mark(void)
} }
#endif /* !NANO_TINY */ #endif /* !NANO_TINY */
/* Delete one character. */
void do_delete(void) void do_delete(void)
{ {
bool do_refresh = FALSE; bool do_refresh = FALSE;
@ -150,6 +152,7 @@ void do_delete(void)
update_line(openfile->current, openfile->current_x); update_line(openfile->current, openfile->current_x);
} }
/* Backspace over one character. */
void do_backspace(void) void do_backspace(void)
{ {
if (openfile->current != openfile->fileage || if (openfile->current != openfile->fileage ||
@ -159,6 +162,8 @@ void do_backspace(void)
} }
} }
/* Insert a tab. If the TABS_TO_SPACES flag is set, insert the number
* of spaces that a tab would normally take up. */
void do_tab(void) void do_tab(void)
{ {
#ifndef NANO_TINY #ifndef NANO_TINY
@ -187,7 +192,7 @@ void do_tab(void)
#endif #endif
} }
/* Someone hits Enter *gasp!* */ /* Someone hits Enter/Return *gasp!* */
void do_enter(void) void do_enter(void)
{ {
filestruct *newnode = make_new_node(openfile->current); filestruct *newnode = make_new_node(openfile->current);
@ -244,6 +249,8 @@ void do_enter(void)
} }
#ifndef NANO_TINY #ifndef NANO_TINY
/* Send a SIGKILL (unconditional kill) to the forked process in
* execute_command(). */
RETSIGTYPE cancel_command(int signal) RETSIGTYPE cancel_command(int signal)
{ {
if (kill(pid, SIGKILL) == -1) if (kill(pid, SIGKILL) == -1)
@ -341,6 +348,8 @@ bool execute_command(const char *command)
#endif /* !NANO_TINY */ #endif /* !NANO_TINY */
#ifndef DISABLE_WRAPPING #ifndef DISABLE_WRAPPING
/* Clear the prepend_wrap flag. We need to do this as soon as we do
* something other than type text. */
void wrap_reset(void) void wrap_reset(void)
{ {
prepend_wrap = FALSE; prepend_wrap = FALSE;
@ -1555,11 +1564,13 @@ void do_justify(bool full_justify)
display_main_list(); display_main_list();
} }
/* Justify the current paragraph. */
void do_justify_void(void) void do_justify_void(void)
{ {
do_justify(FALSE); do_justify(FALSE);
} }
/* Justify the entire file. */
void do_full_justify(void) void do_full_justify(void)
{ {
do_justify(TRUE); do_justify(TRUE);
@ -1732,9 +1743,9 @@ bool do_int_spell_fix(const char *word)
return !canceled; return !canceled;
} }
/* Integrated spell checking using the spell program, filtered through /* Internal (integrated) spell checking using the spell program,
* the sort and uniq programs. Return NULL for normal termination, * filtered through the sort and uniq programs. Return NULL for normal
* and the error string otherwise. */ * termination, and the error string otherwise. */
const char *do_int_speller(const char *tempfile_name) const char *do_int_speller(const char *tempfile_name)
{ {
char *read_buff, *read_buff_ptr, *read_buff_word; char *read_buff, *read_buff_ptr, *read_buff_word;
@ -1882,7 +1893,7 @@ const char *do_int_speller(const char *tempfile_name)
do_int_spell_fix(read_buff_word); do_int_spell_fix(read_buff_word);
free(read_buff); free(read_buff);
replace_abort(); search_replace_abort();
edit_refresh(); edit_refresh();
/* Process the end of the spell process. */ /* Process the end of the spell process. */
@ -1914,8 +1925,8 @@ const char *do_int_speller(const char *tempfile_name)
exit(1); exit(1);
} }
/* External spell checking. Return value: NULL for normal termination, /* External (alternate) spell checking. Return NULL for normal
* otherwise the error string. */ * termination, and the error string otherwise. */
const char *do_alt_speller(char *tempfile_name) const char *do_alt_speller(char *tempfile_name)
{ {
int alt_spell_status; int alt_spell_status;
@ -2107,6 +2118,8 @@ const char *do_alt_speller(char *tempfile_name)
return NULL; return NULL;
} }
/* Spell check the current file. If an alternate spell checker is
* specified, use it. Otherwise, use the internal spell checker. */
void do_spell(void) void do_spell(void)
{ {
int i; int i;
@ -2220,6 +2233,7 @@ void do_wordlinechar_count(void)
} }
#endif /* !NANO_TINY */ #endif /* !NANO_TINY */
/* Get verbatim input. */
void do_verbatim_input(void) void do_verbatim_input(void)
{ {
int *kbinput; int *kbinput;

View File

@ -30,6 +30,7 @@
#include <ctype.h> #include <ctype.h>
#include <errno.h> #include <errno.h>
/* Return the number of decimal digits in n. */
int digits(size_t n) int digits(size_t n)
{ {
int i = 1; int i = 1;
@ -249,7 +250,9 @@ int safe_regexec(const regex_t *preg, const char *string, size_t nmatch,
} }
#endif #endif
int regexp_bol_or_eol(const regex_t *preg, const char *string) /* Do the compiled regex in preg and the regex in string match the
* beginning or end of a line? */
bool regexp_bol_or_eol(const regex_t *preg, const char *string)
{ {
return (regexec(preg, string, 0, NULL, 0) == 0 && return (regexec(preg, string, 0, NULL, 0) == 0 &&
regexec(preg, string, 0, NULL, REG_NOTBOL | REG_NOTEOL) == regexec(preg, string, 0, NULL, REG_NOTBOL | REG_NOTEOL) ==
@ -361,7 +364,9 @@ void nperror(const char *s)
} }
} }
/* Thanks, BG, many people have been asking for this... */ /* This is a wrapper for the malloc() function that properly handles
* things when we run out of memory. Thanks, BG, many people have been
* asking for this... */
void *nmalloc(size_t howmuch) void *nmalloc(size_t howmuch)
{ {
void *r = malloc(howmuch); void *r = malloc(howmuch);
@ -372,6 +377,8 @@ void *nmalloc(size_t howmuch)
return r; return r;
} }
/* This is a wrapper for the realloc() function that properly handles
* things when we run out of memory. */
void *nrealloc(void *ptr, size_t howmuch) void *nrealloc(void *ptr, size_t howmuch)
{ {
void *r = realloc(ptr, howmuch); void *r = realloc(ptr, howmuch);
@ -511,11 +518,14 @@ void new_magicline(void)
#ifndef NANO_TINY #ifndef NANO_TINY
/* Remove the magicline from filebot, if there is one and it isn't the /* Remove the magicline from filebot, if there is one and it isn't the
* only line in the file. */ * only line in the file. Assume that edittop and current are not at
* filebot. */
void remove_magicline(void) void remove_magicline(void)
{ {
if (openfile->filebot->data[0] == '\0' && if (openfile->filebot->data[0] == '\0' &&
openfile->filebot != openfile->fileage) { openfile->filebot != openfile->fileage) {
assert(openfile->filebot != openfile->edittop && openfile->filebot != openfile->current);
openfile->filebot = openfile->filebot->prev; openfile->filebot = openfile->filebot->prev;
free_filestruct(openfile->filebot->next); free_filestruct(openfile->filebot->next);
openfile->filebot->next = NULL; openfile->filebot->next = NULL;

View File

@ -1586,6 +1586,14 @@ bool get_mouseinput(int *mouse_x, int *mouse_y, bool allow_shortcuts)
} }
#endif /* !DISABLE_MOUSE */ #endif /* !DISABLE_MOUSE */
/* Return the shortcut corresponding to the values of kbinput (the key
* itself), meta_key (whether the key is a meta sequence), and func_key
* (whether the key is a function key), if any. The shortcut will be
* the first one in the list (control key, meta key sequence, function
* key, other meta key sequence) for the corresponding function. For
* example, passing in a meta key sequence that corresponds to a
* function with a control key, a function key, and a meta key sequence
* will return the control key corresponding to that function. */
const shortcut *get_shortcut(const shortcut *s_list, int *kbinput, bool const shortcut *get_shortcut(const shortcut *s_list, int *kbinput, bool
*meta_key, bool *func_key) *meta_key, bool *func_key)
{ {
@ -1638,6 +1646,9 @@ const shortcut *get_shortcut(const shortcut *s_list, int *kbinput, bool
} }
#ifndef NANO_TINY #ifndef NANO_TINY
/* Return the global toggle corresponding to the values of kbinput (the
* key itself) and meta_key (whether the key is a meta sequence), if
* any. */
const toggle *get_toggle(int kbinput, bool meta_key) const toggle *get_toggle(int kbinput, bool meta_key)
{ {
const toggle *t = toggles; const toggle *t = toggles;
@ -1667,17 +1678,22 @@ void blank_line(WINDOW *win, int y, int x, int n)
waddch(win, ' '); waddch(win, ' ');
} }
/* Blank the first line of the top portion of the window. */
void blank_titlebar(void) void blank_titlebar(void)
{ {
blank_line(topwin, 0, 0, COLS); blank_line(topwin, 0, 0, COLS);
} }
/* If the MORE_SPACE flag isn't set, blank the second line of the top
* portion of the window. */
void blank_topbar(void) void blank_topbar(void)
{ {
if (!ISSET(MORE_SPACE)) if (!ISSET(MORE_SPACE))
blank_line(topwin, 1, 0, COLS); blank_line(topwin, 1, 0, COLS);
} }
/* Blank all the lines of the middle portion of the window, i.e, the
* edit window. */
void blank_edit(void) void blank_edit(void)
{ {
int i; int i;
@ -1685,11 +1701,14 @@ void blank_edit(void)
blank_line(edit, i, 0, COLS); blank_line(edit, i, 0, COLS);
} }
/* Blank the first line of the bottom portion of the window. */
void blank_statusbar(void) void blank_statusbar(void)
{ {
blank_line(bottomwin, 0, 0, COLS); blank_line(bottomwin, 0, 0, COLS);
} }
/* If the NO_HELP flag isn't set, blank the last two lines of the bottom
* portion of the window. */
void blank_bottombars(void) void blank_bottombars(void)
{ {
if (!ISSET(NO_HELP)) { if (!ISSET(NO_HELP)) {
@ -1698,6 +1717,9 @@ void blank_bottombars(void)
} }
} }
/* Check if the number of keystrokes needed to blank the statusbar has
* been pressed. If so, blank the statusbar, unless constant cursor
* position display is on. */
void check_statusblank(void) void check_statusblank(void)
{ {
if (statusblank > 0) if (statusblank > 0)
@ -1872,6 +1894,12 @@ char *display_string(const char *buf, size_t start_col, size_t len, bool
return converted; return converted;
} }
/* Display the path specified in path on the titlebar, along with the
* current version of nano and whether the current file has been
* modified. If path is NULL, assume we're in normal editing mode and
* display the current filename instead. Otherwise, assume we're in the
* file browser, and don't display whether the current file has been
* modified. */
void titlebar(const char *path) void titlebar(const char *path)
{ {
int space = COLS; int space = COLS;
@ -2029,8 +2057,8 @@ void titlebar(const char *path)
wnoutrefresh(edit); wnoutrefresh(edit);
} }
/* Set the modified flag if it isn't already set, and then update the /* Mark the current file as modified if it isn't already, and then
* titlebar. */ * update the titlebar to display the file's new status. */
void set_modified(void) void set_modified(void)
{ {
if (!openfile->modified) { if (!openfile->modified) {
@ -2106,6 +2134,8 @@ void statusbar(const char *msg, ...)
25; 25;
} }
/* Display the shortcut list in s on the last two rows of the bottom
* portion of the window. */
void bottombars(const shortcut *s) void bottombars(const shortcut *s)
{ {
size_t i, colwidth, slen; size_t i, colwidth, slen;
@ -2846,6 +2876,7 @@ void edit_update(update_type location)
openfile->edittop = foo; openfile->edittop = foo;
} }
/* Unconditionally redraw the entire screen. */
void total_redraw(void) void total_redraw(void)
{ {
#ifdef USE_SLANG #ifdef USE_SLANG
@ -2858,6 +2889,8 @@ void total_redraw(void)
#endif #endif
} }
/* Unconditionally redraw the entire screen, and then refresh it using
* the current file. */
void total_refresh(void) void total_refresh(void)
{ {
total_redraw(); total_redraw();
@ -2866,6 +2899,8 @@ void total_refresh(void)
bottombars(currshortcut); bottombars(currshortcut);
} }
/* Display the main shortcut list on the last two rows of the bottom
* portion of the window. */
void display_main_list(void) void display_main_list(void)
{ {
bottombars(main_list); bottombars(main_list);
@ -2921,6 +2956,7 @@ void do_cursorpos(bool constant)
disable_cursorpos = FALSE; disable_cursorpos = FALSE;
} }
/* Unconditionally display the current cursor position. */
void do_cursorpos_void(void) void do_cursorpos_void(void)
{ {
do_cursorpos(FALSE); do_cursorpos(FALSE);