summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJun-ichi Takimoto <takimoto-j@kba.biglobe.ne.jp>2018-08-01 21:36:44 +0900
committerJun-ichi Takimoto <takimoto-j@kba.biglobe.ne.jp>2018-08-01 21:36:44 +0900
commitad9f07e66fded8a44adba15d576960cef587f9d4 (patch)
tree365b51648af05a76a01e9539b6604294f5f38981
parent96ea5e32b442ff2406f1d7268cccdd73baf313ea (diff)
downloadzsh-ad9f07e66fded8a44adba15d576960cef587f9d4.tar.gz
zsh-ad9f07e66fded8a44adba15d576960cef587f9d4.zip
43227: fix memory leaks in term{cap,info}.c
-rw-r--r--ChangeLog5
-rw-r--r--Src/Modules/termcap.c14
-rw-r--r--Src/Modules/terminfo.c14
-rw-r--r--Src/utils.c37
4 files changed, 50 insertions, 20 deletions
diff --git a/ChangeLog b/ChangeLog
index cf35c734f..462e21781 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2018-08-01 Jun-ichi Takimoto <takimoto-j@kba.biglobe.ne.jp>
+
+ * 43227: Src/Modules/termcap.c, Src/Modules/terminfo.c,
+ Src/utils.c: fix memory leaks not fixed in 43219
+
2018-07-31 dana <dana@dana.is>
* 43207 (tweaked): Completion/Unix/Type/_bind_addresses,
diff --git a/Src/Modules/termcap.c b/Src/Modules/termcap.c
index 60a6e138a..af4009a3a 100644
--- a/Src/Modules/termcap.c
+++ b/Src/Modules/termcap.c
@@ -345,16 +345,7 @@ int
boot_(UNUSED(Module m))
{
#ifdef HAVE_TGETENT
-# ifdef HAVE_SETUPTERM
- int errret;
-
- /*
- * Just because we can't set up the terminal doesn't
- * mean the modules hasn't booted---TERM may change,
- * and it should be handled dynamically---so ignore errors here.
- */
- (void)setupterm((char *)0, 1, &errret);
-# endif
+ zsetupterm();
#endif
return 0;
}
@@ -363,6 +354,9 @@ boot_(UNUSED(Module m))
int
cleanup_(Module m)
{
+#ifdef HAVE_TGETENT
+ zdeleteterm();
+#endif
return setfeatureenables(m, &module_features, NULL);
}
diff --git a/Src/Modules/terminfo.c b/Src/Modules/terminfo.c
index bbd325899..4596b41d2 100644
--- a/Src/Modules/terminfo.c
+++ b/Src/Modules/terminfo.c
@@ -338,16 +338,7 @@ int
boot_(UNUSED(Module m))
{
#ifdef USE_TERMINFO_MODULE
-# ifdef HAVE_SETUPTERM
- int errret;
-
- /*
- * Just because we can't set up the terminal doesn't
- * mean the modules hasn't booted---TERM may change,
- * and it should be handled dynamically---so ignore errors here.
- */
- (void)setupterm((char *)0, 1, &errret);
-# endif
+ zsetupterm();
#endif
return 0;
@@ -357,6 +348,9 @@ boot_(UNUSED(Module m))
int
cleanup_(Module m)
{
+#ifdef USE_TERMINFO_MODULE
+ zdeleteterm();
+#endif
return setfeatureenables(m, &module_features, NULL);
}
diff --git a/Src/utils.c b/Src/utils.c
index ee2ad207f..075d27241 100644
--- a/Src/utils.c
+++ b/Src/utils.c
@@ -375,6 +375,43 @@ zerrmsg(FILE *file, const char *fmt, va_list ap)
fflush(file);
}
+/*
+ * Wrapper for setupterm() and del_curterm().
+ * These are called from terminfo.c and termcap.c.
+ */
+static int term_count; /* reference count of cur_term */
+
+/**/
+mod_export void
+zsetupterm(void)
+{
+#ifdef HAVE_SETUPTERM
+ int errret;
+
+ DPUTS(term_count < 0 || (term_count > 0 && !cur_term),
+ "inconsistent term_count and/or cur_term");
+ /*
+ * Just because we can't set up the terminal doesn't
+ * mean the modules hasn't booted---TERM may change,
+ * and it should be handled dynamically---so ignore errors here.
+ */
+ if (term_count++ == 0)
+ (void)setupterm((char *)0, 1, &errret);
+#endif
+}
+
+/**/
+mod_export void
+zdeleteterm(void)
+{
+#ifdef HAVE_SETUPTERM
+ DPUTS(term_count < 1 || !cur_term,
+ "inconsistent term_count and/or cur_term");
+ if (--term_count == 0)
+ del_curterm(cur_term);
+#endif
+}
+
/* Output a single character, for the termcap routines. *
* This is used instead of putchar since it can be a macro. */