From: Eric Andersen Date: Mon, 7 May 2001 23:01:32 +0000 (-0000) Subject: A patch from Vladimir to simplify concat_path_file() and X-Git-Tag: 0_52~219 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=4ad13e5d957ae85b3a6a61fce7b58a661adb2b1c;p=platform%2Fupstream%2Fbusybox.git A patch from Vladimir to simplify concat_path_file() and make it less likely to break. --- diff --git a/libbb/concat_path_file.c b/libbb/concat_path_file.c index ce92310..6b7abf2 100644 --- a/libbb/concat_path_file.c +++ b/libbb/concat_path_file.c @@ -11,16 +11,12 @@ extern char *concat_path_file(const char *path, const char *filename) { char *outbuf; - int l; - int flg_slash = 1; - - l = strlen(path); - if (l>0 && path[l-1] == '/') - flg_slash--; - l += strlen(filename); - if (l>0 && filename[0] == '/') - flg_slash--; - outbuf = xmalloc(l+1+flg_slash); - sprintf(outbuf, (flg_slash ? "%s/%s" : "%s%s"), path, filename); + const char *lc; + + lc = last_char_is((char*)path, '/'); + if (filename[0] == '/') + filename++; + outbuf = xmalloc(strlen(path)+strlen(filename)+1+(lc==NULL)); + sprintf(outbuf, (lc==NULL ? "%s/%s" : "%s%s"), path, filename); return outbuf; }