Not trying to position the cursor when opening a buffer failed.
This fixes Savannah bug #46778. git-svn-id: svn://svn.savannah.gnu.org/nano/trunk/nano@5514 35c25a1d-7b9e-4130-9fde-d3aeb78583b8master
parent
ae598e79a6
commit
37d8ad8687
|
@ -1,3 +1,8 @@
|
||||||
|
2015-12-30 Benno Schulenberg <bensberg@justemail.net>
|
||||||
|
* src/nano.c (main), src/files.c (open_buffer): Don't try to position
|
||||||
|
the cursor when opening a buffer failed (because the user specified a
|
||||||
|
directory, for example). This fixes Savannah bug #46778.
|
||||||
|
|
||||||
2015-12-29 Benno Schulenberg <bensberg@justemail.net>
|
2015-12-29 Benno Schulenberg <bensberg@justemail.net>
|
||||||
* doc/syntax/{c,objc,asm}.nanorc: Disable the regex for multiline
|
* doc/syntax/{c,objc,asm}.nanorc: Disable the regex for multiline
|
||||||
strings as it colours some things wrong and is a glutton on time.
|
strings as it colours some things wrong and is a glutton on time.
|
||||||
|
|
|
@ -323,7 +323,7 @@ int do_lockfile(const char *filename)
|
||||||
|
|
||||||
/* If it's not "", filename is a file to open. We make a new buffer, if
|
/* If it's not "", filename is a file to open. We make a new buffer, if
|
||||||
* necessary, and then open and read the file, if applicable. */
|
* necessary, and then open and read the file, if applicable. */
|
||||||
void open_buffer(const char *filename, bool undoable)
|
bool open_buffer(const char *filename, bool undoable)
|
||||||
{
|
{
|
||||||
bool quiet = FALSE;
|
bool quiet = FALSE;
|
||||||
bool new_buffer = (openfile == NULL
|
bool new_buffer = (openfile == NULL
|
||||||
|
@ -343,7 +343,7 @@ void open_buffer(const char *filename, bool undoable)
|
||||||
if (check_operating_dir(filename, FALSE)) {
|
if (check_operating_dir(filename, FALSE)) {
|
||||||
statusbar(_("Can't insert file from outside of %s"),
|
statusbar(_("Can't insert file from outside of %s"),
|
||||||
operating_dir);
|
operating_dir);
|
||||||
return;
|
return FALSE;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -358,7 +358,7 @@ void open_buffer(const char *filename, bool undoable)
|
||||||
else
|
else
|
||||||
statusbar(_("\"%s\" is not a normal file"), filename);
|
statusbar(_("\"%s\" is not a normal file"), filename);
|
||||||
beep();
|
beep();
|
||||||
return;
|
return FALSE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -374,7 +374,7 @@ void open_buffer(const char *filename, bool undoable)
|
||||||
#ifndef DISABLE_MULTIBUFFER
|
#ifndef DISABLE_MULTIBUFFER
|
||||||
if (openfile->next) {
|
if (openfile->next) {
|
||||||
close_buffer(TRUE);
|
close_buffer(TRUE);
|
||||||
return;
|
return FALSE;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
} else if (lockstatus == 0) {
|
} else if (lockstatus == 0) {
|
||||||
|
@ -421,6 +421,7 @@ void open_buffer(const char *filename, bool undoable)
|
||||||
if (new_buffer)
|
if (new_buffer)
|
||||||
color_update();
|
color_update();
|
||||||
#endif
|
#endif
|
||||||
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef DISABLE_SPELLER
|
#ifndef DISABLE_SPELLER
|
||||||
|
|
|
@ -2622,7 +2622,9 @@ int main(int argc, char **argv)
|
||||||
if (i < argc - 1 && argv[i][0] == '+')
|
if (i < argc - 1 && argv[i][0] == '+')
|
||||||
parse_line_column(&argv[i][1], &iline, &icol);
|
parse_line_column(&argv[i][1], &iline, &icol);
|
||||||
else {
|
else {
|
||||||
open_buffer(argv[i], FALSE);
|
/* If opening fails, don't try to position the cursor. */
|
||||||
|
if (!open_buffer(argv[i], FALSE))
|
||||||
|
continue;
|
||||||
|
|
||||||
/* If a position was given on the command line, go there. */
|
/* If a position was given on the command line, go there. */
|
||||||
if (iline > 0 || icol > 0) {
|
if (iline > 0 || icol > 0) {
|
||||||
|
|
|
@ -283,7 +283,7 @@ void do_uncut_text(void);
|
||||||
/* All functions in files.c. */
|
/* All functions in files.c. */
|
||||||
void make_new_buffer(void);
|
void make_new_buffer(void);
|
||||||
void initialize_buffer_text(void);
|
void initialize_buffer_text(void);
|
||||||
void open_buffer(const char *filename, bool undoable);
|
bool open_buffer(const char *filename, bool undoable);
|
||||||
#ifndef DISABLE_SPELLER
|
#ifndef DISABLE_SPELLER
|
||||||
void replace_buffer(const char *filename);
|
void replace_buffer(const char *filename);
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue