From mboxrd@z Thu Jan 1 00:00:00 1970 From: Thomas Wood Subject: [PATCH i-g-t 4/8] lib: add igt_simple_init_parse_opts Date: Wed, 23 Jul 2014 11:57:51 +0100 Message-ID: <1406113075-30860-5-git-send-email-thomas.wood@intel.com> References: <1406113075-30860-1-git-send-email-thomas.wood@intel.com> Mime-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Return-path: Received: from mail-wg0-f45.google.com (mail-wg0-f45.google.com [74.125.82.45]) by gabe.freedesktop.org (Postfix) with ESMTP id 6ABCA6E625 for ; Wed, 23 Jul 2014 03:58:05 -0700 (PDT) Received: by mail-wg0-f45.google.com with SMTP id x12so970367wgg.28 for ; Wed, 23 Jul 2014 03:58:04 -0700 (PDT) In-Reply-To: <1406113075-30860-1-git-send-email-thomas.wood@intel.com> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: intel-gfx-bounces@lists.freedesktop.org Sender: "Intel-gfx" To: intel-gfx@lists.freedesktop.org Cc: daniel.vetter@ffwll.ch List-Id: intel-gfx@lists.freedesktop.org This function allows simple tests to register additional command line options. Signed-off-by: Thomas Wood --- lib/igt_core.c | 22 ++++++++++++++++++++++ lib/igt_core.h | 5 +++++ 2 files changed, 27 insertions(+) diff --git a/lib/igt_core.c b/lib/igt_core.c index ee6f90c..72c77e6 100644 --- a/lib/igt_core.c +++ b/lib/igt_core.c @@ -500,6 +500,28 @@ void igt_simple_init(int argc, char **argv) optind = 1; } +/** + * igt_simple_init_parse_opts: + * @argc: argc from the test's main() + * @argv: argv from the test's main() + * @extra_short_opts: getopt_long() compliant list with additional short options + * @extra_long_opts: getopt_long() compliant list with additional long options + * @help_str: help string for the additional options + * @extra_opt_handler: handler for the additional options + * + * This initializes a simple test without any support for subtests and allows + * an arbitrary set of additional options. + */ +void igt_simple_init_parse_opts(int argc, char **argv, + const char *extra_short_opts, + struct option *extra_long_opts, + const char *help_str, + igt_opt_handler_t extra_opt_handler) +{ + common_init(argc, argv, extra_short_opts, extra_long_opts, help_str, + extra_opt_handler); +} + /* * Note: Testcases which use these helpers MUST NOT output anything to stdout * outside of places protected by igt_run_subtest checks - the piglit diff --git a/lib/igt_core.h b/lib/igt_core.h index 6138487..408cf3a 100644 --- a/lib/igt_core.h +++ b/lib/igt_core.h @@ -162,6 +162,11 @@ bool igt_only_list_subtests(void); static void igt_tokencat(__real_main, __LINE__)(void) \ void igt_simple_init(int argc, char **argv); +void igt_simple_init_parse_opts(int argc, char **argv, + const char *extra_short_opts, + struct option *extra_long_opts, + const char *help_str, + igt_opt_handler_t extra_opt_handler); /** * igt_simple_main: -- 1.9.3