mirror of
git://nv-tegra.nvidia.com/tegra/gfx-src/nv-xconfig.git
synced 2025-12-22 09:22:53 +03:00
069ad68dd61a879f00fb30d35a10180d5951ddb0 - nvidia-xconfig-580.00/Makefile 4cc77b90af91e615a64ae04893fdffa7939db84c - nvidia-xconfig-580.00/COPYING e67b6dba2eb0dfcee7213598cd0c45b46c12fa88 - nvidia-xconfig-580.00/option_table.h 647e7896275a1113ec99352d573823a05001f57e - nvidia-xconfig-580.00/lscf.c 1e39095238886dfc6a69f7ec750e10c05a93e7d1 - nvidia-xconfig-580.00/nvidia-xconfig.1.m4 a5ad539267b73169480e7898b284823639c4db3a - nvidia-xconfig-580.00/tree.c 89c18e4a9734816026726377e96eb9ccd4fff018 - nvidia-xconfig-580.00/nvidia-xconfig.c 8ce5587db4b7482d207f347415f10c3562e3bb6d - nvidia-xconfig-580.00/options.c 0f390dff6644fa2454a96d5aa9ff5478e88b20ed - nvidia-xconfig-580.00/nvidia-cfg.h 071d03a0ec013e39290d8bf08f1a57565f8580e4 - nvidia-xconfig-580.00/nvidia-xconfig.h bfa37f78ba458f14a1865bbf3f67eb84987a7e1c - nvidia-xconfig-580.00/extract_edids.c d37da5a118e0418b267a48d05fd144611316b42c - nvidia-xconfig-580.00/gen-manpage-opts.c 41bcac41393c9a465c30c07cf1ab386647a16687 - nvidia-xconfig-580.00/util.c 9b0c02164398be2795fea7cb13c9e1b062d24bfb - nvidia-xconfig-580.00/query_gpu_info.c c946eefad99cec9366d8abbd4e45c5d138d3b7be - nvidia-xconfig-580.00/make_usable.c a45c13d9f89e79eb41b014104b01fa8b1d5029ae - nvidia-xconfig-580.00/multiple_screens.c c7b8d8ca0f7c9dcc2cdca4f8e77d1122c71892ef - nvidia-xconfig-580.00/XF86Config-parser/Read.c a9bc06f33bf525c2b08be2dc3cd64a59c4c7946d - nvidia-xconfig-580.00/XF86Config-parser/Configint.h 2022a4a3c2a1b23a67ae74f50a3849f5f3a45e4b - nvidia-xconfig-580.00/XF86Config-parser/Keyboard.c 83b0a8efd6a508db54995688ab353591bdb242a2 - nvidia-xconfig-580.00/XF86Config-parser/Flags.c e67d630ef396ab7d34524c333f3a77fc42ba8fc6 - nvidia-xconfig-580.00/XF86Config-parser/configProcs.h f3d611bdbddfa64675a0810ef81dada57e224bcd - nvidia-xconfig-580.00/XF86Config-parser/Extensions.c 5ffb2caa5077a2e6ec1c5ece807e71503fb2fbce - nvidia-xconfig-580.00/XF86Config-parser/Module.c 7344be997921dec57959691e986763ee686888d5 - nvidia-xconfig-580.00/XF86Config-parser/Device.c 33211ca0a10f50e2c87b9e8feef6c1ab381b57a1 - nvidia-xconfig-580.00/XF86Config-parser/DRI.c 953b945f3b117d6fb44f1f738af17b6380a9ec72 - nvidia-xconfig-580.00/XF86Config-parser/Monitor.c 6c210ad0eaee1db3fec48ff01746cb054b4f9aaa - nvidia-xconfig-580.00/XF86Config-parser/Video.c 4407207cf890539dc604cff5b834c994b307729a - nvidia-xconfig-580.00/XF86Config-parser/Write.c de1c758e29f217e1a99e4c076d54ac84bce98b18 - nvidia-xconfig-580.00/XF86Config-parser/Screen.c c66a0a141e25e31b568fb9df41f17d7fb9e6d3b9 - nvidia-xconfig-580.00/XF86Config-parser/xf86Parser.h 9cbc29da282aa957f28b7fc83caf1e3b19ee2a52 - nvidia-xconfig-580.00/XF86Config-parser/Vendor.c 18711ff932af2202869a30f3b32d6d7fe7811c84 - nvidia-xconfig-580.00/XF86Config-parser/Layout.c cda3a4ab05bf48ba28af35b5c4c632e968afc7fa - nvidia-xconfig-580.00/XF86Config-parser/Util.c ec19d673a6a7d1d8f855f2d32d3e8f63046c3625 - nvidia-xconfig-580.00/XF86Config-parser/Files.c ac878b26ded86a3c502a6a81fc4c4a96162afefb - nvidia-xconfig-580.00/XF86Config-parser/Merge.c 0a274c4bc54b6ae0f6d009e443bda0cb033d66b5 - nvidia-xconfig-580.00/XF86Config-parser/Pointer.c 3f2238c88d737bd329a9bca1ac4b0bcf77bb9ac2 - nvidia-xconfig-580.00/XF86Config-parser/xf86tokens.h 45ceb0129668346ae3e52d81bb6e2f97efadf9d0 - nvidia-xconfig-580.00/XF86Config-parser/Input.c 4d9b03ea3badceb6bdfdf6589e6731140ec44079 - nvidia-xconfig-580.00/XF86Config-parser/Generate.c 04efe162cf6d97882f2bb87f3712d9a65c2320f3 - nvidia-xconfig-580.00/XF86Config-parser/Scan.c 5d55b94375c2055cfa1578e4c7f34c90e63a33f7 - nvidia-xconfig-580.00/common-utils/gen-manpage-opts-helper.c 384e36102dcd08ed4c5de05b5e3b8a7cdb2e257d - nvidia-xconfig-580.00/common-utils/nvgetopt.c 6bc8be0bf82d813c3274145e689f5b10d534910c - nvidia-xconfig-580.00/common-utils/common-utils.h 8db48a58d1654ed69920366bef10f38b789a1a84 - nvidia-xconfig-580.00/common-utils/msg.c e572cac43202f6c2af1c80b9e3901215126093ed - nvidia-xconfig-580.00/common-utils/nvgetopt.h 205071eacd9a24d07fea6a512fed1e1ce97ebc3a - nvidia-xconfig-580.00/common-utils/common-utils.c 1654638c567bc7f2bd70b54d807b498ab14c1061 - nvidia-xconfig-580.00/common-utils/nvpci-utils.h 8259a24058c714629f9819cc8c830ea9b202bb27 - nvidia-xconfig-580.00/common-utils/gen-manpage-opts-helper.h 524990f5497f9bbeb3d148b5e7dc8d2267c3163d - nvidia-xconfig-580.00/common-utils/nvpci-utils.c abb5c1b445d9353f2d2840bda848cd16109710a4 - nvidia-xconfig-580.00/common-utils/msg.h Change-Id: Idf6d53d8705edc61d08ff027847197c576f4a297
206 lines
6.8 KiB
C
206 lines
6.8 KiB
C
/*
|
|
* Copyright (C) 2004-2010 NVIDIA Corporation
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
* copy of this software and associated documentation files (the "Software"),
|
|
* to deal in the Software without restriction, including without limitation
|
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
* and/or sell copies of the Software, and to permit persons to whom the
|
|
* Software is furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in
|
|
* all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
* DEALINGS IN THE SOFTWARE.
|
|
*/
|
|
|
|
#ifndef __NVGETOPT_H__
|
|
#define __NVGETOPT_H__
|
|
|
|
#define NVGETOPT_FALSE 0
|
|
#define NVGETOPT_TRUE 1
|
|
|
|
|
|
/*
|
|
* mask of bits not used by nvgetopt in NVGetoptOption::flags;
|
|
* these bits are available for use within specific users of
|
|
* nvgetopt
|
|
*/
|
|
|
|
#define NVGETOPT_UNUSED_FLAG_RANGE 0xffff0000
|
|
|
|
/*
|
|
* indicates that the option is a boolean value; the presence of the
|
|
* option will be interpreted as a TRUE value; if the option is
|
|
* prepended with '--no-', the option will be interpreted as a FALSE
|
|
* value. On success, nvgetopt will return the parsed boolean value
|
|
* through 'boolval'.
|
|
*/
|
|
|
|
#define NVGETOPT_IS_BOOLEAN 0x0001
|
|
|
|
|
|
/*
|
|
* indicates that the option takes an argument to be interpreted as a
|
|
* string; on success, nvgetopt will return the parsed string argument
|
|
* through 'strval'.
|
|
*/
|
|
|
|
#define NVGETOPT_STRING_ARGUMENT 0x0002
|
|
|
|
|
|
/*
|
|
* indicates that the option takes an argument to be interpreted as an
|
|
* integer; on success, nvgetopt will return the parsed integer
|
|
* argument through 'intval'.
|
|
*/
|
|
|
|
#define NVGETOPT_INTEGER_ARGUMENT 0x0004
|
|
|
|
|
|
/*
|
|
* indicates that the option takes an argument to be interpreted as
|
|
* an double; on success, nvgetopt will return the parsed double
|
|
* argument through 'doubleval'.
|
|
*/
|
|
|
|
#define NVGETOPT_DOUBLE_ARGUMENT 0x0008
|
|
|
|
|
|
/* helper macro */
|
|
|
|
#define NVGETOPT_HAS_ARGUMENT (NVGETOPT_STRING_ARGUMENT | \
|
|
NVGETOPT_INTEGER_ARGUMENT | \
|
|
NVGETOPT_DOUBLE_ARGUMENT)
|
|
|
|
/*
|
|
* indicates that the option, which normally takes an argument, can be
|
|
* disabled if the option is prepended with '--no-', in which case,
|
|
* the option does not take an argument. If the option is disabled,
|
|
* nvgetopt will return TRUE through 'disable_val'.
|
|
*
|
|
* Note that NVGETOPT_ALLOW_DISABLE can only be used with options that
|
|
* take arguments.
|
|
*/
|
|
|
|
#define NVGETOPT_ALLOW_DISABLE 0x0010
|
|
|
|
|
|
/*
|
|
* indicates that the argument for this option is optional; if no
|
|
* argument is present (either the option is already at the end of the
|
|
* argv array, or the next option in argv starts with '-'), then the
|
|
* option is returned without an argument.
|
|
*/
|
|
|
|
#define NVGETOPT_ARGUMENT_IS_OPTIONAL 0x0020
|
|
|
|
|
|
/*
|
|
* The NVGETOPT_HELP_ALWAYS flag is not used by nvgetopt() itself, but
|
|
* is often used by other users of NVGetoptOption tables, who print
|
|
* out basic and advanced help. In such cases, OPTION_HELP_ALWAYS is
|
|
* used to indicate that the help for the option should always be
|
|
* printed.
|
|
*/
|
|
|
|
#define NVGETOPT_HELP_ALWAYS 0x0040
|
|
|
|
|
|
/*
|
|
* Indicates that an option is deprecated. The description field of the
|
|
* NVGetoptOption, if set, may be used to store text explaining why the
|
|
* option is no longer used.
|
|
*/
|
|
|
|
#define NVGETOPT_IS_DEPRECATED 0x0080
|
|
|
|
/*
|
|
* These flags indicate that a particular boolean or disableable value is no
|
|
* longer supported. They can be used together with NVGETOPT_DEPRECATED in
|
|
* order to differentiate between deprecated boolean values or enable/disable
|
|
* states that will be ignored, and unsupported boolean values or enable/disable
|
|
* states that are invalid.
|
|
*/
|
|
|
|
#define NVGETOPT_DISABLE_IS_INVALID 0x0100
|
|
#define NVGETOPT_ENABLE_IS_INVALID 0x0200
|
|
|
|
typedef struct {
|
|
const char *name;
|
|
int val;
|
|
unsigned int flags;
|
|
const char *arg_name; /* not used by nvgetopt() */
|
|
const char *description; /* not used by nvgetopt() */
|
|
} NVGetoptOption;
|
|
|
|
|
|
/*
|
|
* nvgetopt() - see the glibc getopt_long(3) manpage for usage
|
|
* description. Options can be prepended with "--", "-", or "--no-".
|
|
*
|
|
* A global variable stores the current index into the argv array, so
|
|
* subsequent calls to nvgetopt() will advance through argv[].
|
|
*
|
|
* On success, the matching NVGetoptOption.val is returned.
|
|
*
|
|
* If the NVGETOPT_IS_BOOLEAN flag is set, boolval will be set to TRUE
|
|
* (or FALSE, if the option string was prepended with "--no-").
|
|
*
|
|
* disable_val will be assigned TRUE if the option string was
|
|
* prepended with "--no-", otherwise it will be assigned FALSE.
|
|
*
|
|
* If an argument is successfully parsed, one of strval, intval, or
|
|
* doubleval will be assigned, based on which of
|
|
* NVGETOPT_STRING_ARGUMENT, NVGETOPT_INTEGER_ARGUMENT, or
|
|
* NVGETOPT_DOUBLE_ARGUMENT is set in the option's flags. If strval
|
|
* is assigned to a non-NULL value by nvgetopt, then it is the
|
|
* caller's responsibility to free the string when done with it.
|
|
*
|
|
* On failure, an error is printed to stderr, and 0 is returned.
|
|
*
|
|
* When there are no more options to parse, -1 is returned.
|
|
*/
|
|
|
|
int nvgetopt(int argc,
|
|
char *argv[],
|
|
const NVGetoptOption *options,
|
|
char **strval,
|
|
int *boolval,
|
|
int *intval,
|
|
double *doubleval,
|
|
int *disable_val);
|
|
|
|
/*
|
|
* nvgetopt_print_help() - print a help message for each option in the
|
|
* provided NVGetoptOption array. This is useful for a utility's
|
|
* "--help" output.
|
|
*
|
|
* Options will only be printed if they have every bit set that
|
|
* include_mask includes.
|
|
*
|
|
* For each option, the provided callback function will be called with
|
|
* two strings: a name string that lists the option's name, and a
|
|
* description string for the option. The callback function is
|
|
* responsible for actually printing these strings. Examples:
|
|
*
|
|
* name = "-v, --version";
|
|
* description = "Print usage information for the common commandline "
|
|
* "options and exit.";
|
|
*/
|
|
|
|
typedef void nvgetopt_print_help_callback_ptr(const char *name,
|
|
const char *description);
|
|
|
|
void nvgetopt_print_help(const NVGetoptOption *options,
|
|
unsigned int include_mask,
|
|
nvgetopt_print_help_callback_ptr callback);
|
|
|
|
#endif /* __NVGETOPT_H__ */
|