2 * Copyright (c) 1983, 1989, 1993
3 * The Regents of the University of California. All rights reserved.
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution.
13 * 3. All advertising materials mentioning features or use of this software
14 * must display the following acknowledgement:
15 * This product includes software developed by the University of
16 * California, Berkeley and its contributors.
17 * 4. Neither the name of the University nor the names of its contributors
18 * may be used to endorse or promote products derived from this software
19 * without specific prior written permission.
21 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
22 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
25 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
34 /* 1999-02-22 Arkadiusz MiĆkiewicz <misiek@pld.ORG.PL>
35 * - added Native Language Support
38 #include <sys/types.h>
40 #include <sys/resource.h>
49 #include "closestream.h"
51 static const char *idtype
[] = {
52 [PRIO_PROCESS
] = N_("process ID"),
53 [PRIO_PGRP
] = N_("process group ID"),
54 [PRIO_USER
] = N_("user ID"),
57 static void __attribute__((__noreturn__
)) usage(void)
60 fputs(USAGE_HEADER
, out
);
62 _(" %1$s [-n] <priority> [-p|--pid] <pid>...\n"
63 " %1$s [-n] <priority> -g|--pgrp <pgid>...\n"
64 " %1$s [-n] <priority> -u|--user <user>...\n"),
65 program_invocation_short_name
);
67 fputs(USAGE_SEPARATOR
, out
);
68 fputs(_("Alter the priority of running processes.\n"), out
);
70 fputs(USAGE_OPTIONS
, out
);
71 fputs(_(" -n, --priority <num> specify the nice increment value\n"), out
);
72 fputs(_(" -p, --pid <id> interpret argument as process ID (default)\n"), out
);
73 fputs(_(" -g, --pgrp <id> interpret argument as process group ID\n"), out
);
74 fputs(_(" -u, --user <name>|<id> interpret argument as username or user ID\n"), out
);
75 fputs(USAGE_SEPARATOR
, out
);
76 printf(USAGE_HELP_OPTIONS(24));
77 printf(USAGE_MAN_TAIL("renice(1)"));
81 static int getprio(const int which
, const int who
, int *prio
)
84 *prio
= getpriority(which
, who
);
85 if (*prio
== -1 && errno
) {
86 warn(_("failed to get priority for %d (%s)"), who
, idtype
[which
]);
92 static int donice(const int which
, const int who
, const int prio
)
96 if (getprio(which
, who
, &oldprio
) != 0)
98 if (setpriority(which
, who
, prio
) < 0) {
99 warn(_("failed to set priority for %d (%s)"), who
, idtype
[which
]);
102 if (getprio(which
, who
, &newprio
) != 0)
104 printf(_("%d (%s) old priority %d, new priority %d\n"),
105 who
, idtype
[which
], oldprio
, newprio
);
110 * Change the priority (the nice value) of processes
111 * or groups of processes which are already running.
113 int main(int argc
, char **argv
)
115 int which
= PRIO_PROCESS
;
116 int who
= 0, prio
, errs
= 0;
119 setlocale(LC_ALL
, "");
120 bindtextdomain(PACKAGE
, LOCALEDIR
);
122 close_stdout_atexit();
128 if (strcmp(*argv
, "-h") == 0 ||
129 strcmp(*argv
, "--help") == 0)
132 if (strcmp(*argv
, "-v") == 0 ||
133 strcmp(*argv
, "-V") == 0 ||
134 strcmp(*argv
, "--version") == 0)
135 print_version(EXIT_SUCCESS
);
138 if (*argv
&& (strcmp(*argv
, "-n") == 0 || strcmp(*argv
, "--priority") == 0)) {
143 if (argc
< 2 || !*argv
) {
144 warnx(_("not enough arguments"));
145 errtryhelp(EXIT_FAILURE
);
148 prio
= strtol(*argv
, &endptr
, 10);
150 warnx(_("invalid priority '%s'"), *argv
);
151 errtryhelp(EXIT_FAILURE
);
156 for (; argc
> 0; argc
--, argv
++) {
157 if (strcmp(*argv
, "-g") == 0 || strcmp(*argv
, "--pgrp") == 0) {
161 if (strcmp(*argv
, "-u") == 0 || strcmp(*argv
, "--user") == 0) {
165 if (strcmp(*argv
, "-p") == 0 || strcmp(*argv
, "--pid") == 0) {
166 which
= PRIO_PROCESS
;
169 if (which
== PRIO_USER
) {
170 struct passwd
*pwd
= getpwnam(*argv
);
175 who
= strtol(*argv
, &endptr
, 10);
176 if (who
< 0 || *endptr
) {
177 warnx(_("unknown user %s"), *argv
);
182 who
= strtol(*argv
, &endptr
, 10);
183 if (who
< 0 || *endptr
) {
184 /* TRANSLATORS: The first %s is one of the above
185 * three ID names. Read: "bad value for %s: %s" */
186 warnx(_("bad %s value: %s"), idtype
[which
], *argv
);
191 errs
|= donice(which
, who
, prio
);
193 return errs
!= 0 ? EXIT_FAILURE
: EXIT_SUCCESS
;