1 /* nproc - print the number of processors.
2 Copyright (C) 2009-2024 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 <https://www.gnu.org/licenses/>. */
17 /* Written by Giuseppe Scrivano. */
22 #include <sys/types.h>
27 #include "xdectoint.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")
36 ALL_OPTION
= CHAR_MAX
+ 1,
40 static struct option
const longopts
[] =
42 {"all", no_argument
, nullptr, ALL_OPTION
},
43 {"ignore", required_argument
, nullptr, IGNORE_OPTION
},
44 {GETOPT_HELP_OPTION_DECL
},
45 {GETOPT_VERSION_OPTION_DECL
},
46 {nullptr, 0, nullptr, 0}
52 if (status
!= EXIT_SUCCESS
)
56 printf (_("Usage: %s [OPTION]...\n"), program_name
);
58 Print the number of processing units available to the current process,\n\
59 which may be less than the number of online processors\n\
63 --all print the number of installed processors\n\
64 --ignore=N if possible, exclude N processing units\n\
67 fputs (HELP_OPTION_DESCRIPTION
, stdout
);
68 fputs (VERSION_OPTION_DESCRIPTION
, stdout
);
69 emit_ancillary_info (PROGRAM_NAME
);
75 main (int argc
, char **argv
)
77 unsigned long nproc
, ignore
= 0;
78 initialize_main (&argc
, &argv
);
79 set_program_name (argv
[0]);
80 setlocale (LC_ALL
, "");
81 bindtextdomain (PACKAGE
, LOCALEDIR
);
84 atexit (close_stdout
);
86 enum nproc_query mode
= NPROC_CURRENT_OVERRIDABLE
;
90 int c
= getopt_long (argc
, argv
, "", longopts
, nullptr);
95 case_GETOPT_HELP_CHAR
;
97 case_GETOPT_VERSION_CHAR (PROGRAM_NAME
, AUTHORS
);
104 ignore
= xnumtoumax (optarg
, 10, 0, ULONG_MAX
, "",
105 _("invalid number"), 0, XTOINT_MAX_QUIET
);
109 usage (EXIT_FAILURE
);
115 error (0, 0, _("extra operand %s"), quote (argv
[optind
]));
116 usage (EXIT_FAILURE
);
119 nproc
= num_processors (mode
);
126 printf ("%lu\n", nproc
);