maint: update all copyright year number ranges
[platform/upstream/coreutils.git] / src / nproc.c
1 /* nproc - print the number of processors.
2    Copyright (C) 2009-2013 Free Software Foundation, Inc.
3
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.
8
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.
13
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/>.  */
16
17 /* Written by Giuseppe Scrivano.  */
18
19 #include <config.h>
20 #include <getopt.h>
21 #include <stdio.h>
22 #include <sys/types.h>
23
24 #include "system.h"
25 #include "error.h"
26 #include "nproc.h"
27 #include "quote.h"
28 #include "xstrtol.h"
29
30 /* The official name of this program (e.g., no 'g' prefix).  */
31 #define PROGRAM_NAME "nproc"
32
33 #define AUTHORS proper_name ("Giuseppe Scrivano")
34
35 enum
36 {
37   ALL_OPTION = CHAR_MAX + 1,
38   IGNORE_OPTION
39 };
40
41 static struct option const longopts[] =
42 {
43   {"all", no_argument, NULL, ALL_OPTION},
44   {"ignore", required_argument, NULL, IGNORE_OPTION},
45   {GETOPT_HELP_OPTION_DECL},
46   {GETOPT_VERSION_OPTION_DECL},
47   {NULL, 0, NULL, 0}
48 };
49
50 void
51 usage (int status)
52 {
53   if (status != EXIT_SUCCESS)
54     emit_try_help ();
55   else
56     {
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);
67
68       fputs (HELP_OPTION_DESCRIPTION, stdout);
69       fputs (VERSION_OPTION_DESCRIPTION, stdout);
70       emit_ancillary_info ();
71     }
72   exit (status);
73 }
74
75 int
76 main (int argc, char **argv)
77 {
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);
84
85   atexit (close_stdout);
86
87   enum nproc_query mode = NPROC_CURRENT_OVERRIDABLE;
88
89   while (1)
90     {
91       int c = getopt_long (argc, argv, "", longopts, NULL);
92       if (c == -1)
93         break;
94       switch (c)
95         {
96         case_GETOPT_HELP_CHAR;
97
98         case_GETOPT_VERSION_CHAR (PROGRAM_NAME, AUTHORS);
99
100         case ALL_OPTION:
101           mode = NPROC_ALL;
102           break;
103
104         case IGNORE_OPTION:
105           if (xstrtoul (optarg, NULL, 10, &ignore, "") != LONGINT_OK)
106             {
107               error (0, 0, _("%s: invalid number to ignore"), optarg);
108               usage (EXIT_FAILURE);
109             }
110           break;
111
112         default:
113           usage (EXIT_FAILURE);
114         }
115     }
116
117   if (argc != optind)
118     {
119       error (0, 0, _("extra operand %s"), quote (argv[optind]));
120       usage (EXIT_FAILURE);
121     }
122
123   nproc = num_processors (mode);
124
125   if (ignore < nproc)
126     nproc -= ignore;
127   else
128     nproc = 1;
129
130   printf ("%lu\n", nproc);
131
132   exit (EXIT_SUCCESS);
133 }