From c96606cc0617b85d3bf0784d0bf1ecd71e44cbd7 Mon Sep 17 00:00:00 2001 From: Peter Stephenson Date: Mon, 23 Feb 2015 17:38:16 +0000 Subject: 34623: free history more often if "remetafying" --- ChangeLog | 4 ++++ Src/hist.c | 8 ++++++-- 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/ChangeLog b/ChangeLog index 9e98f5550..1d5b9ce04 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +2015-02-23 Peter Stephenson + + * 34623: Src/hist.c: free history more often in previous case. + 2015-02-23 Mikael Magnusson * 34615 + 34619: Src/hist.c: Remeta one frame earlier diff --git a/Src/hist.c b/Src/hist.c index c530e7283..aa07ce875 100644 --- a/Src/hist.c +++ b/Src/hist.c @@ -2593,8 +2593,6 @@ readhistfile(char *fn, int err, int readflags) start = pt; uselex = isset(HISTLEXWORDS) && !(readflags & HFILE_FAST); histsplitwords(pt, &words, &nwords, &nwordpos, uselex); - if (uselex) - freeheap(); he->nwords = nwordpos/2; if (he->nwords) { @@ -2607,6 +2605,12 @@ readhistfile(char *fn, int err, int readflags) freehistnode(&he->node); curhist--; } + /* + * Do this last out of paranoia in case use of + * heap is disguised... + */ + if (uselex || remeta) + freeheap(); } if (start && readflags & HFILE_USE_OPTIONS) { zsfree(lasthist.text); -- cgit 1.4.1