X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;ds=sidebyside;f=swaponoff.c;h=ce0e2c6ccdb2e403c92a508ed116d8e66b414ac0;hb=6fc92a506ab3c490a4dc028334c908f19c0d0806;hp=0f8c4f5f349b010aefb2722083d2f8f30deb1d11;hpb=7ab9c7ee52db8759d457819f5480378fa3aa97cc;p=oweals%2Fbusybox.git diff --git a/swaponoff.c b/swaponoff.c index 0f8c4f5f3..ce0e2c6cc 100644 --- a/swaponoff.c +++ b/swaponoff.c @@ -3,7 +3,7 @@ * Mini swapon/swapoff implementation for busybox * * - * Copyright (C) 1999,2000 by Lineo, inc. + * Copyright (C) 1999,2000,2001 by Lineo, inc. * Written by Erik Andersen , * * This program is free software; you can redistribute it and/or modify @@ -22,40 +22,28 @@ * */ -#include "internal.h" #include -#include -#include #include #include -#include #include +#include +#include +#include - -static int whichApp; -static const char *appName; - -static const char swapoff_usage[] = - "swapoff [OPTION] [device]\n" -#ifndef BB_FEATURE_TRIVIAL_HELP - "\nStop swapping virtual memory pages on the given device.\n\n" - "Options:\n" - "\t-a\tStop swapping on all swap devices\n" -#endif - ; - -static const char swapon_usage[] = - "swapon [OPTION] [device]\n" -#ifndef BB_FEATURE_TRIVIAL_HELP - "\nStart swapping virtual memory pages on the given device.\n\n" - "Options:\n" - "\t-a\tStart swapping on all swap devices\n" +#if __GNU_LIBRARY__ < 5 +/* libc5 doesn't have sys/swap.h, define these here. */ +extern int swapon (__const char *__path, int __flags); +extern int swapoff (__const char *__path); +#else +#include #endif - ; +#include "busybox.h" + +static int whichApp; -#define SWAPON_APP 1 -#define SWAPOFF_APP 2 +static const int SWAPON_APP = 1; +static const int SWAPOFF_APP = 2; static void swap_enable_disable(char *device) @@ -67,10 +55,8 @@ static void swap_enable_disable(char *device) else status = swapoff(device); - if (status != 0) { - perror(appName); - exit(FALSE); - } + if (status != 0) + perror_msg_and_die(applet_name); } static void do_em_all() @@ -78,28 +64,23 @@ static void do_em_all() struct mntent *m; FILE *f = setmntent("/etc/fstab", "r"); - if (f == NULL) { - perror("/etc/fstab"); - exit(FALSE); - } + if (f == NULL) + perror_msg_and_die("/etc/fstab"); while ((m = getmntent(f)) != NULL) { - if (!strstr(m->mnt_type, MNTTYPE_SWAP)) { + if (strcmp(m->mnt_type, MNTTYPE_SWAP)==0) { swap_enable_disable(m->mnt_fsname); } } endmntent(f); - exit(TRUE); + exit(EXIT_SUCCESS); } extern int swap_on_off_main(int argc, char **argv) { - if (strcmp(*argv, "swapon") == 0) { - appName = *argv; + if (strcmp(applet_name, "swapon") == 0) { whichApp = SWAPON_APP; - } else { - appName = *argv; whichApp = SWAPOFF_APP; } @@ -118,7 +99,7 @@ extern int swap_on_off_main(int argc, char **argv) struct stat statBuf; if (stat("/etc/fstab", &statBuf) < 0) - fatalError("/etc/fstab file missing\n"); + error_msg_and_die("/etc/fstab file missing"); } do_em_all(); break; @@ -127,9 +108,8 @@ extern int swap_on_off_main(int argc, char **argv) } } swap_enable_disable(*argv); - exit(TRUE); + return EXIT_SUCCESS; usage_and_exit: - usage((whichApp == SWAPON_APP) ? swapon_usage : swapoff_usage); - exit(FALSE); + show_usage(); }