mirror of
git://git.sv.gnu.org/nano.git
synced 2025-01-27 03:32:05 +03:00
browser: don't seem to enter a directory when it is inaccessible
This fixes https://savannah.gnu.org/bugs/?48286. Reviewed-by: Benno Schulenberg <bensberg@justemail.net> Signed-off-by: Rishabh Dave <rishabhddave@gmail.com>
This commit is contained in:
parent
ddd9c7a022
commit
559858a3dd
@ -115,6 +115,7 @@ char *do_browser(char *path)
|
|||||||
|
|
||||||
old_selected = (size_t)-1;
|
old_selected = (size_t)-1;
|
||||||
|
|
||||||
|
free(newpath);
|
||||||
newpath = NULL;
|
newpath = NULL;
|
||||||
present_path = mallocstrcpy(present_path, path);
|
present_path = mallocstrcpy(present_path, path);
|
||||||
|
|
||||||
@ -123,9 +124,6 @@ char *do_browser(char *path)
|
|||||||
while (TRUE) {
|
while (TRUE) {
|
||||||
struct stat st;
|
struct stat st;
|
||||||
int i;
|
int i;
|
||||||
char *new_path;
|
|
||||||
/* The path we switch to at the "Go to Directory"
|
|
||||||
* prompt. */
|
|
||||||
|
|
||||||
/* Make sure that the cursor is off. */
|
/* Make sure that the cursor is off. */
|
||||||
curs_set(0);
|
curs_set(0);
|
||||||
@ -258,37 +256,32 @@ char *do_browser(char *path)
|
|||||||
sunder(answer);
|
sunder(answer);
|
||||||
align(&answer);
|
align(&answer);
|
||||||
|
|
||||||
new_path = real_dir_from_tilde(answer);
|
newpath = real_dir_from_tilde(answer);
|
||||||
|
|
||||||
if (new_path[0] != '/') {
|
if (newpath[0] != '/') {
|
||||||
new_path = charealloc(new_path, strlen(path) +
|
newpath = charealloc(newpath, strlen(path) +
|
||||||
strlen(answer) + 1);
|
strlen(answer) + 1);
|
||||||
sprintf(new_path, "%s%s", path, answer);
|
sprintf(newpath, "%s%s", path, answer);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef DISABLE_OPERATINGDIR
|
#ifndef DISABLE_OPERATINGDIR
|
||||||
if (check_operating_dir(new_path, FALSE)) {
|
if (check_operating_dir(newpath, FALSE)) {
|
||||||
/* TRANSLATORS: This refers to the confining effect of the
|
/* TRANSLATORS: This refers to the confining effect of the
|
||||||
* option --operatingdir, not of --restricted. */
|
* option --operatingdir, not of --restricted. */
|
||||||
statusline(ALERT, _("Can't go outside of %s"),
|
statusline(ALERT, _("Can't go outside of %s"),
|
||||||
full_operating_dir);
|
full_operating_dir);
|
||||||
free(new_path);
|
free(newpath);
|
||||||
|
newpath = NULL;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
/* In case the specified directory cannot be entered, select it
|
||||||
|
* (if it is in the current list) so it will be highlighted. */
|
||||||
|
for (i = 0; i < filelist_len; i++)
|
||||||
|
if (strcmp(filelist[i], newpath) == 0)
|
||||||
|
selected = i;
|
||||||
|
|
||||||
dir = opendir(new_path);
|
/* Try opening and reading the specified directory. */
|
||||||
if (dir == NULL) {
|
|
||||||
/* We can't open this directory for some reason. */
|
|
||||||
statusline(ALERT, _("Error reading %s: %s"), answer,
|
|
||||||
strerror(errno));
|
|
||||||
free(new_path);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Start over again with the new path value. */
|
|
||||||
free(path);
|
|
||||||
path = new_path;
|
|
||||||
goto read_directory_contents;
|
goto read_directory_contents;
|
||||||
} else if (func == do_up_void) {
|
} else if (func == do_up_void) {
|
||||||
if (selected >= width)
|
if (selected >= width)
|
||||||
@ -347,7 +340,7 @@ char *do_browser(char *path)
|
|||||||
present_name = striponedir(filelist[selected]);
|
present_name = striponedir(filelist[selected]);
|
||||||
|
|
||||||
/* Try opening and reading the selected directory. */
|
/* Try opening and reading the selected directory. */
|
||||||
newpath = filelist[selected];
|
newpath = strdup(filelist[selected]);
|
||||||
goto read_directory_contents;
|
goto read_directory_contents;
|
||||||
} else if (func == do_exit) {
|
} else if (func == do_exit) {
|
||||||
/* Exit from the file browser. */
|
/* Exit from the file browser. */
|
||||||
|
Loading…
Reference in New Issue
Block a user