2016-01-20 Benno Schulenberg <bensberg@justemail.net>
* src/files.c (open_buffer): Readjust the indentation and a comment.
+ * src/files.c (has_valid_path): Get rid of a global variable.
2016-01-20 Rishabh Dave <rishabhddave@gmail.com>
* src/files.c (verify_path, open_buffer): When opening a new buffer,
#include <pwd.h>
#include <libgen.h>
-/* Determine whether the containing directory of the given filename exists.
- * Pass the result back in the global variable valid_path. */
-void verify_path(const char *filename)
+/* Verify that the containing directory of the given filename exists. */
+bool has_valid_path(const char *filename)
{
char *parentdir;
struct stat parentinfo;
+ bool validity = TRUE;
if (strrchr(filename, '/') == NULL)
parentdir = mallocstrcpy(NULL, ".");
else
parentdir = dirname(mallocstrcpy(NULL, filename));
- if (stat(parentdir, &parentinfo) != -1 && S_ISDIR(parentinfo.st_mode))
- valid_path = TRUE;
- else {
+ if (stat(parentdir, &parentinfo) == -1 || !S_ISDIR(parentinfo.st_mode)) {
statusbar(_("Directory '%s' does not exist"), parentdir);
- valid_path = FALSE;
+ validity = FALSE;
beep();
}
free(parentdir);
+ return validity;
}
/* Add an entry to the openfile openfilestruct. This should only be
titlebar(NULL);
#ifndef NANO_TINY
- if (!ISSET(LOCKING) || openfile->filename[0] == '\0' || !valid_path)
+ if (!ISSET(LOCKING) || openfile->filename[0] == '\0')
return;
if (openfile->lock_filename == NULL) {
if (new_buffer) {
make_new_buffer();
- verify_path(filename);
-
+ if (!has_valid_path(filename))
+ quiet = TRUE;
#ifndef NANO_TINY
- if (valid_path) {
+ else {
if (ISSET(LOCKING) && filename[0] != '\0') {
int lockstatus = do_lockfile(filename);
if (lockstatus < 0) {
}
if (newfie) {
- if (!quiet && valid_path)
+ if (!quiet)
statusbar(_("New File"));
return -2;
}
/* Whether the current keystroke is an extended keypad value. */
bool focusing = FALSE;
/* Whether an update of the edit window should center the cursor. */
-bool valid_path;
- /* Whether the containing directory of a specified file exists. */
#ifndef NANO_TINY
int controlleft = CONTROL_LEFT;