diff options
| author | Ron Yorston <rmy@pobox.com> | 2019-01-05 14:16:50 +0000 |
|---|---|---|
| committer | Ron Yorston <rmy@pobox.com> | 2019-01-05 14:16:50 +0000 |
| commit | fa96aa8d70eb1dfd7b3550fab417a43b3a507a6d (patch) | |
| tree | 2b7d4c0a4a56175018f28e7e116a3dcdfb78e06a /libbb | |
| parent | da7d205446459dfa1ba7bb46206955383dc6a420 (diff) | |
| download | busybox-w32-fa96aa8d70eb1dfd7b3550fab417a43b3a507a6d.tar.gz busybox-w32-fa96aa8d70eb1dfd7b3550fab417a43b3a507a6d.tar.bz2 busybox-w32-fa96aa8d70eb1dfd7b3550fab417a43b3a507a6d.zip | |
busybox: add --uninstall option
Add an option to allow hard links to be removed.
busybox --uninstall file
removes all hard links to the given file (including the file itself.)
Since Microsoft Windows refuses to delete a running executable a
BusyBox binary is unable to remove links to itself.
busybox --uninstall -n file
displays the names of all hard links to the given file.
Although this feature is couched in terms of uninstalling BusyBox
it's actually quite general: it can be used to delete or display
hard links to any file.
Diffstat (limited to 'libbb')
| -rw-r--r-- | libbb/appletlib.c | 34 |
1 files changed, 32 insertions, 2 deletions
diff --git a/libbb/appletlib.c b/libbb/appletlib.c index 11136de11..8a66b3303 100644 --- a/libbb/appletlib.c +++ b/libbb/appletlib.c | |||
| @@ -776,7 +776,8 @@ static void install_links(const char *busybox, | |||
| 776 | while (*appname) { | 776 | while (*appname) { |
| 777 | fpc = xasprintf("%s/%s.exe", custom_install_dir, appname); | 777 | fpc = xasprintf("%s/%s.exe", custom_install_dir, appname); |
| 778 | rc = link(busybox, fpc); | 778 | rc = link(busybox, fpc); |
| 779 | if (rc != 0 && errno != EEXIST) { | 779 | if (rc != 0 && (errno != EEXIST || |
| 780 | strcmp("busybox.exe", bb_basename(fpc)) != 0)) { | ||
| 780 | bb_simple_perror_msg(fpc); | 781 | bb_simple_perror_msg(fpc); |
| 781 | } | 782 | } |
| 782 | free(fpc); | 783 | free(fpc); |
| @@ -885,7 +886,13 @@ int busybox_main(int argc UNUSED_PARAM, char **argv) | |||
| 885 | " or: busybox --show SCRIPT\n" | 886 | " or: busybox --show SCRIPT\n" |
| 886 | # endif | 887 | # endif |
| 887 | IF_FEATURE_INSTALLER( | 888 | IF_FEATURE_INSTALLER( |
| 888 | " or: busybox --install "IF_NOT_PLATFORM_MINGW32("[-s] ")"[DIR]\n" | 889 | IF_NOT_PLATFORM_MINGW32( |
| 890 | " or: busybox --install [-s] [DIR]\n" | ||
| 891 | ) | ||
| 892 | IF_PLATFORM_MINGW32( | ||
| 893 | " or: busybox --install [DIR]\n" | ||
| 894 | " or: busybox --uninstall [-n] file\n" | ||
| 895 | ) | ||
| 889 | ) | 896 | ) |
| 890 | " or: function [arguments]...\n" | 897 | " or: function [arguments]...\n" |
| 891 | "\n" | 898 | "\n" |
| @@ -1016,6 +1023,29 @@ int busybox_main(int argc UNUSED_PARAM, char **argv) | |||
| 1016 | return 0; | 1023 | return 0; |
| 1017 | } | 1024 | } |
| 1018 | 1025 | ||
| 1026 | #if ENABLE_PLATFORM_MINGW32 && ENABLE_FEATURE_INSTALLER | ||
| 1027 | if (strcmp(argv[1], "--uninstall") == 0) { | ||
| 1028 | char name[PATH_MAX]; | ||
| 1029 | int dry_run = (argv[2] && strcmp(argv[2], "-n") == 0 && ++argv); | ||
| 1030 | const char *file = argv[2]; | ||
| 1031 | |||
| 1032 | if (!argv[2]) | ||
| 1033 | bb_error_msg_and_die(bb_msg_requires_arg, "--uninstall"); | ||
| 1034 | |||
| 1035 | while (enumerate_links(file, name)) { | ||
| 1036 | if (dry_run) { | ||
| 1037 | full_write1_str(name); | ||
| 1038 | full_write1_str("\n"); | ||
| 1039 | } | ||
| 1040 | else if (unlink(name) != 0) { | ||
| 1041 | bb_simple_perror_msg(name); | ||
| 1042 | } | ||
| 1043 | file = NULL; | ||
| 1044 | } | ||
| 1045 | return 0; | ||
| 1046 | } | ||
| 1047 | #endif | ||
| 1048 | |||
| 1019 | if (strcmp(argv[1], "--help") == 0) { | 1049 | if (strcmp(argv[1], "--help") == 0) { |
| 1020 | /* "busybox --help [<applet>]" */ | 1050 | /* "busybox --help [<applet>]" */ |
| 1021 | if (!argv[2]) | 1051 | if (!argv[2]) |
