nano

nano with my custom patches
git clone git://bsandro.tech/nano
Log | Files | Refs | README | LICENSE

commit a7bdd2e9c683c07507fcef336ca05e63243aa837
parent 4953e49d92fadd0de23d6e7a49ae122bff3cd0d1
Author: David Lawrence Ramsey <pooka109@gmail.com>
Date:   Wed,  5 Jul 2006 03:38:49 +0000

in do_browse_from(), during the operating directory check, if path isn't
NULL, don't bother freeing it before mallocstrcpy()ing operating_dir
into it, as the latter operation will free it


git-svn-id: svn://svn.savannah.gnu.org/nano/trunk/nano@3746 35c25a1d-7b9e-4130-9fde-d3aeb78583b8

Diffstat:
MChangeLog | 4++++
Msrc/browser.c | 7++-----
2 files changed, 6 insertions(+), 5 deletions(-)

diff --git a/ChangeLog b/ChangeLog @@ -17,6 +17,10 @@ CVS code - - After entering "..", select the directory we were in before instead of the first filename in the list, as Pico does. (DLR) - Simplify screen update handling and exiting. (DLR) + do_browse_from() + - During the operating directory check, if path isn't NULL, + don't bother freeing it before mallocstrcpy()ing operating_dir + into it, as the latter operation will free it. (DLR) browser_init() - Fix off-by-one error when calculating longest that kept the rightmost column of the screen from being used. (DLR) diff --git a/src/browser.c b/src/browser.c @@ -415,11 +415,8 @@ char *do_browse_from(const char *inpath) #ifndef DISABLE_OPERATINGDIR /* If the resulting path isn't in the operating directory, use * the operating directory instead. */ - if (check_operating_dir(path, FALSE)) { - if (path != NULL) - free(path); - path = mallocstrcpy(NULL, operating_dir); - } + if (check_operating_dir(path, FALSE)) + path = mallocstrcpy(path, operating_dir); #endif if (path != NULL)