Bump to version 1.22.1
[platform/upstream/busybox.git] / coreutils / nice.c
index b66f9d8..ce75991 100644 (file)
@@ -4,83 +4,54 @@
  *
  * Copyright (C) 2005  Manuel Novoa III  <mjn3@codepoet.org>
  *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
- *
+ * Licensed under GPLv2 or later, see file LICENSE in this source tree.
  */
 
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-#include <limits.h>
-#include <errno.h>
-#include <unistd.h>
-#include <sys/time.h>
-#include <sys/resource.h>
-#include "busybox.h"
+//usage:#define nice_trivial_usage
+//usage:       "[-n ADJUST] [PROG ARGS]"
+//usage:#define nice_full_usage "\n\n"
+//usage:       "Change scheduling priority, run PROG\n"
+//usage:     "\n       -n ADJUST       Adjust priority by ADJUST"
 
-static inline int int_add_no_wrap(int a, int b)
-{
-       int s = a + b;
-
-       if (b < 0) {
-               if (s > a) s = INT_MIN;
-       } else {
-               if (s < a) s = INT_MAX;
-       }
-
-       return s;
-}
+#include <sys/resource.h>
+#include "libbb.h"
 
+int nice_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
 int nice_main(int argc, char **argv)
 {
-       static const char Xetpriority_msg[] = "cannot %cet priority";
-
        int old_priority, adjustment;
 
-       errno = 0;                       /* Needed for getpriority error detection. */
        old_priority = getpriority(PRIO_PROCESS, 0);
-       if (errno) {
-               bb_perror_msg_and_die(Xetpriority_msg, 'g');
-       }
 
-       if (!*++argv) { /* No args, so (GNU) output current nice value. */
-               bb_printf("%d\n", old_priority);
-               bb_fflush_stdout_and_exit(EXIT_SUCCESS);
+       if (!*++argv) { /* No args, so (GNU) output current nice value. */
+               printf("%d\n", old_priority);
+               fflush_stdout_and_exit(EXIT_SUCCESS);
        }
 
-       adjustment = 10;                        /* Set default adjustment. */
+       adjustment = 10;  /* Set default adjustment. */
 
-       if ((argv[0][0] == '-') && (argv[0][1] == 'n') && !argv[0][2]) { /* "-n" */
-               if (argc < 4) {                 /* Missing priority and/or utility! */
+       if (argv[0][0] == '-') {
+               if (argv[0][1] == 'n') { /* -n */
+                       if (argv[0][2]) { /* -nNNNN (w/o space) */
+                               argv[0] += 2; argv--; argc++;
+                       }
+               } else { /* -NNN (NNN may be negative) == -n NNN */
+                       argv[0] += 1; argv--; argc++;
+               }
+               if (argc < 4) {  /* Missing priority and/or utility! */
                        bb_show_usage();
                }
-               adjustment = bb_xgetlarg(argv[1], 10, INT_MIN, INT_MAX);
+               adjustment = xatoi_range(argv[1], INT_MIN/2, INT_MAX/2);
                argv += 2;
        }
 
-       {  /* Set our priority.  Handle integer wrapping for old + adjust. */
-               int new_priority = int_add_no_wrap(old_priority, adjustment);
+       {  /* Set our priority. */
+               int prio = old_priority + adjustment;
 
-               if (setpriority(PRIO_PROCESS, 0, new_priority) < 0) {
-                       bb_perror_msg_and_die(Xetpriority_msg, 's');
+               if (setpriority(PRIO_PROCESS, 0, prio) < 0) {
+                       bb_perror_msg_and_die("setpriority(%d)", prio);
                }
        }
-       
-       execvp(*argv, argv);            /* Now exec the desired program. */
 
-       /* The exec failed... */
-       bb_default_error_retval = (errno == ENOENT) ? 127 : 126; /* SUSv3 */
-       bb_perror_msg_and_die("%s", *argv);
+       BB_EXECVP_or_die(argv);
 }