tests: cut: exercise distro-added multibyte code paths
[coreutils/ericb.git] / src / nproc.c
blobb0d16364b018080057e946508cbe3c04008ae9a0
1 /* nproc - print the number of processors.
2 Copyright (C) 2009-2011 Free Software Foundation, Inc.
4 This program is free software: you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation, either version 3 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program. If not, see <http://www.gnu.org/licenses/>. */
17 /* Written by Giuseppe Scrivano. */
19 #include <config.h>
20 #include <getopt.h>
21 #include <stdio.h>
22 #include <sys/types.h>
24 #include "system.h"
25 #include "error.h"
26 #include "nproc.h"
27 #include "xstrtol.h"
29 /* The official name of this program (e.g., no `g' prefix). */
30 #define PROGRAM_NAME "nproc"
32 #define AUTHORS proper_name ("Giuseppe Scrivano")
34 enum
36 ALL_OPTION = CHAR_MAX + 1,
37 IGNORE_OPTION
40 static struct option const longopts[] =
42 {"all", no_argument, NULL, ALL_OPTION},
43 {"ignore", required_argument, NULL, IGNORE_OPTION},
44 {GETOPT_HELP_OPTION_DECL},
45 {GETOPT_VERSION_OPTION_DECL},
46 {NULL, 0, NULL, 0}
49 void
50 usage (int status)
52 if (status != EXIT_SUCCESS)
53 fprintf (stderr, _("Try `%s --help' for more information.\n"),
54 program_name);
55 else
57 printf (_("Usage: %s [OPTION]...\n"), program_name);
58 fputs (_("\
59 Print the number of processing units available to the current process,\n\
60 which may be less than the number of online processors\n\
61 \n\
62 "), stdout);
63 fputs (_("\
64 --all print the number of installed processors\n\
65 --ignore=N if possible, exclude N processing units\n\
66 "), stdout);
68 fputs (HELP_OPTION_DESCRIPTION, stdout);
69 fputs (VERSION_OPTION_DESCRIPTION, stdout);
70 emit_ancillary_info ();
72 exit (status);
75 int
76 main (int argc, char **argv)
78 unsigned long nproc, ignore = 0;
79 initialize_main (&argc, &argv);
80 set_program_name (argv[0]);
81 setlocale (LC_ALL, "");
82 bindtextdomain (PACKAGE, LOCALEDIR);
83 textdomain (PACKAGE);
85 atexit (close_stdout);
87 enum nproc_query mode = NPROC_CURRENT_OVERRIDABLE;
89 while (1)
91 int c = getopt_long (argc, argv, "", longopts, NULL);
92 if (c == -1)
93 break;
94 switch (c)
96 case_GETOPT_HELP_CHAR;
98 case_GETOPT_VERSION_CHAR (PROGRAM_NAME, AUTHORS);
100 case ALL_OPTION:
101 mode = NPROC_ALL;
102 break;
104 case IGNORE_OPTION:
105 if (xstrtoul (optarg, NULL, 10, &ignore, "") != LONGINT_OK)
107 error (0, 0, _("%s: invalid number to ignore"), optarg);
108 usage (EXIT_FAILURE);
110 break;
112 default:
113 usage (EXIT_FAILURE);
117 nproc = num_processors (mode);
119 if (ignore < nproc)
120 nproc -= ignore;
121 else
122 nproc = 1;
124 printf ("%lu\n", nproc);
126 exit (EXIT_SUCCESS);