aboutsummaryrefslogtreecommitdiff
path: root/coreutils/mkdir.c
diff options
context:
space:
mode:
authorDenys Vlasenko <vda.linux@googlemail.com>2014-05-19 16:23:50 +0200
committerDenys Vlasenko <vda.linux@googlemail.com>2014-05-19 16:23:50 +0200
commit17f8418ea75410c3fbf9c9558f50f22cb8808e3e (patch)
tree9b9a7d6296ffb77c8b855eb34b8cbf03b960e005 /coreutils/mkdir.c
parent539e2802ebd2680602de0a2c76069b7f555392d9 (diff)
downloadbusybox-w32-17f8418ea75410c3fbf9c9558f50f22cb8808e3e.tar.gz
busybox-w32-17f8418ea75410c3fbf9c9558f50f22cb8808e3e.tar.bz2
busybox-w32-17f8418ea75410c3fbf9c9558f50f22cb8808e3e.zip
Add conditional support for -v / --verbose
With FEATURE_VERBOSE off, practically no size change. With it on: function old new delta remove_file 493 556 +63 install_main 719 765 +46 bb_make_directory 383 419 +36 rmdir_main 162 191 +29 copy_file 1516 1544 +28 mv_main 502 525 +23 cmp_main 677 693 +16 bbconfig_config_bz2 5264 5279 +15 mkdir_main 158 168 +10 install_longopts 66 76 +10 rm_main 167 175 +8 nexpr 840 846 +6 scan_tree 275 280 +5 fsck_main 1807 1811 +4 ed_main 2541 2545 +4 expand_one_var 1574 1575 +1 swap_on_off_main 420 418 -2 parse_command 1443 1440 -3 redirect 1279 1274 -5 do_load 946 918 -28 ------------------------------------------------------------------------------ (add/remove: 0/0 grow/shrink: 16/4 up/down: 304/-38) Total: 266 bytes Based on the patch by Igor Živković. Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'coreutils/mkdir.c')
-rw-r--r--coreutils/mkdir.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/coreutils/mkdir.c b/coreutils/mkdir.c
index 4a8e43e43..864edfb0a 100644
--- a/coreutils/mkdir.c
+++ b/coreutils/mkdir.c
@@ -48,7 +48,9 @@ static const char mkdir_longopts[] ALIGN1 =
48#if ENABLE_SELINUX 48#if ENABLE_SELINUX
49 "context\0" Required_argument "Z" 49 "context\0" Required_argument "Z"
50#endif 50#endif
51#if ENABLE_FEATURE_VERBOSE
51 "verbose\0" No_argument "v" 52 "verbose\0" No_argument "v"
53#endif
52 ; 54 ;
53#endif 55#endif
54 56
@@ -67,7 +69,7 @@ int mkdir_main(int argc UNUSED_PARAM, char **argv)
67#if ENABLE_FEATURE_MKDIR_LONG_OPTIONS 69#if ENABLE_FEATURE_MKDIR_LONG_OPTIONS
68 applet_long_options = mkdir_longopts; 70 applet_long_options = mkdir_longopts;
69#endif 71#endif
70 opt = getopt32(argv, "m:p" IF_SELINUX("Z:") "v", &smode IF_SELINUX(,&scontext)); 72 opt = getopt32(argv, "m:pv" IF_SELINUX("Z:"), &smode IF_SELINUX(,&scontext));
71 if (opt & 1) { 73 if (opt & 1) {
72 mode_t mmode = 0777; 74 mode_t mmode = 0777;
73 if (!bb_parse_mode(smode, &mmode)) { 75 if (!bb_parse_mode(smode, &mmode)) {
@@ -77,8 +79,10 @@ int mkdir_main(int argc UNUSED_PARAM, char **argv)
77 } 79 }
78 if (opt & 2) 80 if (opt & 2)
79 flags |= FILEUTILS_RECUR; 81 flags |= FILEUTILS_RECUR;
82 if ((opt & 4) && FILEUTILS_VERBOSE)
83 flags |= FILEUTILS_VERBOSE;
80#if ENABLE_SELINUX 84#if ENABLE_SELINUX
81 if (opt & 4) { 85 if (opt & 8) {
82 selinux_or_die(); 86 selinux_or_die();
83 setfscreatecon_or_die(scontext); 87 setfscreatecon_or_die(scontext);
84 } 88 }