aboutsummaryrefslogtreecommitdiff
path: root/libbb
diff options
context:
space:
mode:
authorDenys Vlasenko <vda.linux@googlemail.com>2015-02-07 21:21:02 +0100
committerDenys Vlasenko <vda.linux@googlemail.com>2015-02-07 21:21:02 +0100
commit23cfaab47de7392c1ba7d601a05fb36da3629b28 (patch)
tree228cbefac14b7e60edda2e9314a30bfd43a7e5c5 /libbb
parent68c048fb23bd8b0831bbd02ec66900b12390cf19 (diff)
downloadbusybox-w32-23cfaab47de7392c1ba7d601a05fb36da3629b28.tar.gz
busybox-w32-23cfaab47de7392c1ba7d601a05fb36da3629b28.tar.bz2
busybox-w32-23cfaab47de7392c1ba7d601a05fb36da3629b28.zip
libpwdgrp: use getpwent() instead of getpwent_r()
function old new delta massage_data_for_non_r_func - 90 +90 bb_internal_getpwent - 69 +69 getXXnam_r 94 162 +68 fill_bounds 131 128 -3 deluser_main 355 310 -45 complete_username 123 78 -45 getXXnam 163 90 -73 massage_data_for_r_func 103 - -103 bb_internal_getpwent_r 121 - -121 ------------------------------------------------------------------------------ (add/remove: 2/2 grow/shrink: 1/5 up/down: 227/-407) Total: -163 bytes Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'libbb')
-rw-r--r--libbb/lineedit.c13
1 files changed, 5 insertions, 8 deletions
diff --git a/libbb/lineedit.c b/libbb/lineedit.c
index 720a4951e..249b401b4 100644
--- a/libbb/lineedit.c
+++ b/libbb/lineedit.c
@@ -672,23 +672,20 @@ static char *username_path_completion(char *ud)
672 */ 672 */
673static NOINLINE unsigned complete_username(const char *ud) 673static NOINLINE unsigned complete_username(const char *ud)
674{ 674{
675 /* Using _r function to avoid pulling in static buffers */ 675 struct passwd *pw;
676 char line_buff[256];
677 struct passwd pwd;
678 struct passwd *result;
679 unsigned userlen; 676 unsigned userlen;
680 677
681 ud++; /* skip ~ */ 678 ud++; /* skip ~ */
682 userlen = strlen(ud); 679 userlen = strlen(ud);
683 680
684 setpwent(); 681 setpwent();
685 while (!getpwent_r(&pwd, line_buff, sizeof(line_buff), &result)) { 682 while ((pw = getpwent()) != NULL) {
686 /* Null usernames should result in all users as possible completions. */ 683 /* Null usernames should result in all users as possible completions. */
687 if (/*!userlen || */ strncmp(ud, pwd.pw_name, userlen) == 0) { 684 if (/*!userlen || */ strncmp(ud, pw->pw_name, userlen) == 0) {
688 add_match(xasprintf("~%s/", pwd.pw_name)); 685 add_match(xasprintf("~%s/", pw->pw_name));
689 } 686 }
690 } 687 }
691 endpwent(); 688 endpwent(); /* don't keep password file open */
692 689
693 return 1 + userlen; 690 return 1 + userlen;
694} 691}