2011-03-03 11:05:56 +00:00
|
|
|
From fc87b0a32c130a2b3ab37e614d4a1c6c8e5d70e7 Mon Sep 17 00:00:00 2001
|
2010-11-22 22:15:06 +00:00
|
|
|
From: Kamil Dudka <kdudka@redhat.com>
|
|
|
|
Date: Thu, 19 Aug 2010 13:58:12 +0200
|
2014-05-29 07:23:07 +00:00
|
|
|
Subject: [PATCH 2/3] check stat's result and avoid calling stat on a NULL pointer
|
2010-11-22 22:15:06 +00:00
|
|
|
|
|
|
|
---
|
2014-05-29 07:23:07 +00:00
|
|
|
src/files.c | 36 +++++++++++++++++++++++++-----------
|
|
|
|
1 file changed, 25 insertions(+), 11 deletions(-)
|
2010-11-22 22:15:06 +00:00
|
|
|
|
|
|
|
diff --git a/src/files.c b/src/files.c
|
2011-03-03 11:05:56 +00:00
|
|
|
index f6efbf1..99cc1b8 100644
|
2010-11-22 22:15:06 +00:00
|
|
|
--- a/src/files.c
|
|
|
|
+++ b/src/files.c
|
2015-12-06 14:46:58 +00:00
|
|
|
@@ -321,6 +321,24 @@ int do_lockfile(const char *filename)
|
2014-05-29 07:23:07 +00:00
|
|
|
}
|
|
|
|
#endif /* !NANO_TINY */
|
2010-11-22 22:15:06 +00:00
|
|
|
|
|
|
|
+#ifndef NANO_TINY
|
|
|
|
+/* If *pstat is NULL, perform a stat call with the given file name. On success,
|
|
|
|
+ * *pstat points to a newly allocated buffer that contains the stat's result.
|
|
|
|
+ * On stat's failure, the NULL pointer in *pstat is left intact. */
|
|
|
|
+void stat_if_needed(const char *filename, struct stat **pstat)
|
|
|
|
+{
|
|
|
|
+ struct stat *tmp;
|
|
|
|
+ if (*pstat)
|
|
|
|
+ return;
|
|
|
|
+
|
|
|
|
+ tmp = (struct stat *)nmalloc(sizeof(struct stat));
|
|
|
|
+ if (0 == stat(filename, tmp))
|
|
|
|
+ *pstat = tmp;
|
|
|
|
+ else
|
|
|
|
+ free(tmp);
|
|
|
|
+}
|
|
|
|
+#endif
|
|
|
|
+
|
|
|
|
/* 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. */
|
2016-01-11 08:08:24 +00:00
|
|
|
bool open_buffer(const char *filename, bool undoable)
|
|
|
|
@@ -399,11 +417,7 @@ bool open_buffer(const char *filename, bool undoable)
|
2010-11-22 22:15:06 +00:00
|
|
|
if (rc > 0) {
|
|
|
|
read_file(f, rc, filename, undoable, new_buffer);
|
|
|
|
#ifndef NANO_TINY
|
|
|
|
- if (openfile->current_stat == NULL) {
|
|
|
|
- openfile->current_stat =
|
|
|
|
- (struct stat *)nmalloc(sizeof(struct stat));
|
|
|
|
- stat(filename, openfile->current_stat);
|
|
|
|
- }
|
|
|
|
+ stat_if_needed(filename, &openfile->current_stat);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2016-01-11 08:08:24 +00:00
|
|
|
@@ -1744,10 +1758,8 @@ bool write_file(const char *name, FILE *f_open, bool tmp, append_type
|
2014-05-29 07:23:07 +00:00
|
|
|
* specified it interactively), stat and save the value now,
|
|
|
|
* or else we will chase null pointers when we do modtime checks,
|
|
|
|
* preserve file times, and so on, during backup. */
|
|
|
|
- if (openfile->current_stat == NULL && !tmp && realexists) {
|
|
|
|
- openfile->current_stat = (struct stat *)nmalloc(sizeof(struct stat));
|
2010-11-22 22:15:06 +00:00
|
|
|
- stat(realname, openfile->current_stat);
|
2014-05-29 07:23:07 +00:00
|
|
|
- }
|
2010-11-22 22:15:06 +00:00
|
|
|
+ if (!tmp && realexists)
|
|
|
|
+ stat_if_needed(realname, &openfile->current_stat);
|
|
|
|
|
|
|
|
/* We backup only if the backup toggle is set, the file isn't
|
|
|
|
* temporary, and the file already exists. Furthermore, if we
|
2016-01-11 08:08:24 +00:00
|
|
|
@@ -2137,8 +2149,10 @@ bool write_file(const char *name, FILE *f_open, bool tmp, append_type
|
2010-11-28 20:01:32 +00:00
|
|
|
if (openfile->current_stat == NULL)
|
|
|
|
openfile->current_stat =
|
|
|
|
(struct stat *)nmalloc(sizeof(struct stat));
|
2014-05-29 07:23:07 +00:00
|
|
|
- if (!openfile->mark_set)
|
|
|
|
- stat(realname, openfile->current_stat);
|
|
|
|
+ if (!openfile->mark_set && 0 != stat(realname, openfile->current_stat)) {
|
2010-11-28 20:01:32 +00:00
|
|
|
+ free(openfile->current_stat);
|
|
|
|
+ openfile->current_stat = NULL;
|
|
|
|
+ }
|
2010-11-22 22:15:06 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
statusbar(P_("Wrote %lu line", "Wrote %lu lines",
|
|
|
|
--
|
2011-03-03 11:05:56 +00:00
|
|
|
1.7.4
|
2010-11-22 22:15:06 +00:00
|
|
|
|