mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2024-12-28 00:16:15 +01:00
Do not show empty groups in --help output. Initial patch from Yevgen
Muntyan. (#504142) * glib/goption.c: Do not show empty groups in --help output. * glib/tests/Makefile.am: Add option-context.c * glib/tests/option-context.c: Test skipping of empty groups. svn path=/trunk/; revision=6198
This commit is contained in:
parent
fcf262e393
commit
005a22ab10
@ -1,3 +1,12 @@
|
|||||||
|
2007-12-18 Mathias Hasselmann <mathias@openismus.com>
|
||||||
|
|
||||||
|
Do not show empty groups in --help output. Initial patch from Yevgen
|
||||||
|
Muntyan. (#504142)
|
||||||
|
|
||||||
|
* glib/goption.c: Do not show empty groups in --help output.
|
||||||
|
* glib/tests/Makefile.am: Add option-context.c
|
||||||
|
* glib/tests/option-context.c: Test skipping of empty groups.
|
||||||
|
|
||||||
2007-12-22 Matthias Clasen <mclasen@redhat.com>
|
2007-12-22 Matthias Clasen <mclasen@redhat.com>
|
||||||
|
|
||||||
* glib/gkeyfile.c: Remove wrong documentation about start group
|
* glib/gkeyfile.c: Remove wrong documentation about start group
|
||||||
|
@ -520,6 +520,45 @@ print_entry (GOptionGroup *group,
|
|||||||
g_string_free (str, TRUE);
|
g_string_free (str, TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
group_has_visible_entries (GOptionGroup *group,
|
||||||
|
gboolean main_entries)
|
||||||
|
{
|
||||||
|
GOptionFlags reject_filter = G_OPTION_FLAG_HIDDEN;
|
||||||
|
GOptionEntry *entry;
|
||||||
|
gint i, l;
|
||||||
|
|
||||||
|
if (!main_entries)
|
||||||
|
reject_filter |= G_OPTION_FLAG_IN_MAIN;
|
||||||
|
|
||||||
|
for (i = 0, l = (group ? group->n_entries : 0); i < l; i++)
|
||||||
|
{
|
||||||
|
entry = &group->entries[i];
|
||||||
|
|
||||||
|
if (main_entries && !(entry->flags & G_OPTION_FLAG_IN_MAIN))
|
||||||
|
continue;
|
||||||
|
if (!(entry->flags & reject_filter))
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
group_list_has_visible_entires (GList *group_list,
|
||||||
|
gboolean main_entries)
|
||||||
|
{
|
||||||
|
while (group_list)
|
||||||
|
{
|
||||||
|
if (group_has_visible_entries (group_list->data, main_entries))
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
group_list = group_list->next;
|
||||||
|
}
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* g_option_context_get_help:
|
* g_option_context_get_help:
|
||||||
* @context: a #GOptionContext
|
* @context: a #GOptionContext
|
||||||
@ -687,6 +726,7 @@ g_option_context_get_help (GOptionContext *context,
|
|||||||
{
|
{
|
||||||
GOptionGroup *group = list->data;
|
GOptionGroup *group = list->data;
|
||||||
|
|
||||||
|
if (group_has_visible_entries (group, FALSE))
|
||||||
g_string_append_printf (string, " --help-%-*s %s\n",
|
g_string_append_printf (string, " --help-%-*s %s\n",
|
||||||
max_length - 5, group->name,
|
max_length - 5, group->name,
|
||||||
TRANSLATE (group, group->help_description));
|
TRANSLATE (group, group->help_description));
|
||||||
@ -701,12 +741,15 @@ g_option_context_get_help (GOptionContext *context,
|
|||||||
{
|
{
|
||||||
/* Print a certain group */
|
/* Print a certain group */
|
||||||
|
|
||||||
|
if (group_has_visible_entries (group, FALSE))
|
||||||
|
{
|
||||||
g_string_append (string, TRANSLATE (group, group->description));
|
g_string_append (string, TRANSLATE (group, group->description));
|
||||||
g_string_append (string, "\n");
|
g_string_append (string, "\n");
|
||||||
for (i = 0; i < group->n_entries; i++)
|
for (i = 0; i < group->n_entries; i++)
|
||||||
print_entry (group, max_length, &group->entries[i], string);
|
print_entry (group, max_length, &group->entries[i], string);
|
||||||
g_string_append (string, "\n");
|
g_string_append (string, "\n");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
else if (!main_help)
|
else if (!main_help)
|
||||||
{
|
{
|
||||||
/* Print all groups */
|
/* Print all groups */
|
||||||
@ -717,6 +760,8 @@ g_option_context_get_help (GOptionContext *context,
|
|||||||
{
|
{
|
||||||
GOptionGroup *group = list->data;
|
GOptionGroup *group = list->data;
|
||||||
|
|
||||||
|
if (group_has_visible_entries (group, FALSE))
|
||||||
|
{
|
||||||
g_string_append (string, group->description);
|
g_string_append (string, group->description);
|
||||||
g_string_append (string, "\n");
|
g_string_append (string, "\n");
|
||||||
for (i = 0; i < group->n_entries; i++)
|
for (i = 0; i < group->n_entries; i++)
|
||||||
@ -724,12 +769,16 @@ g_option_context_get_help (GOptionContext *context,
|
|||||||
print_entry (group, max_length, &group->entries[i], string);
|
print_entry (group, max_length, &group->entries[i], string);
|
||||||
|
|
||||||
g_string_append (string, "\n");
|
g_string_append (string, "\n");
|
||||||
|
}
|
||||||
|
|
||||||
list = list->next;
|
list = list->next;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Print application options if --help or --help-all has been specified */
|
/* Print application options if --help or --help-all has been specified */
|
||||||
if (main_help || !group)
|
if ((main_help || !group) &&
|
||||||
|
(group_has_visible_entries (context->main_group, TRUE) ||
|
||||||
|
group_list_has_visible_entires (context->groups, TRUE)))
|
||||||
{
|
{
|
||||||
list = context->groups;
|
list = context->groups;
|
||||||
|
|
||||||
|
@ -10,6 +10,10 @@ TEST_PROGS += testing
|
|||||||
testing_SOURCES = testing.c
|
testing_SOURCES = testing.c
|
||||||
testing_LDADD = $(progs_ldadd)
|
testing_LDADD = $(progs_ldadd)
|
||||||
|
|
||||||
|
TEST_PROGS += option-context
|
||||||
|
option_context_SOURCES = option-context.c
|
||||||
|
option_context_LDADD = $(progs_ldadd)
|
||||||
|
|
||||||
# some testing of gtester funcitonality
|
# some testing of gtester funcitonality
|
||||||
XMLLINT=xmllint
|
XMLLINT=xmllint
|
||||||
gtester-xmllint-check: # check testreport xml with xmllint if present
|
gtester-xmllint-check: # check testreport xml with xmllint if present
|
||||||
|
162
glib/tests/option-context.c
Normal file
162
glib/tests/option-context.c
Normal file
@ -0,0 +1,162 @@
|
|||||||
|
/* Unit tests for GOptionContext
|
||||||
|
* Copyright (C) 2007 Openismus GmbH
|
||||||
|
* Authors: Mathias Hasselmann
|
||||||
|
*
|
||||||
|
* This work is provided "as is"; redistribution and modification
|
||||||
|
* in whole or in part, in any medium, physical or electronic is
|
||||||
|
* permitted without restriction.
|
||||||
|
*
|
||||||
|
* This work is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||||
|
*
|
||||||
|
* In no event shall the authors or contributors be liable for any
|
||||||
|
* direct, indirect, incidental, special, exemplary, or consequential
|
||||||
|
* damages (including, but not limited to, procurement of substitute
|
||||||
|
* goods or services; loss of use, data, or profits; or business
|
||||||
|
* interruption) however caused and on any theory of liability, whether
|
||||||
|
* in contract, strict liability, or tort (including negligence or
|
||||||
|
* otherwise) arising in any way out of the use of this software, even
|
||||||
|
* if advised of the possibility of such damage.
|
||||||
|
*/
|
||||||
|
#include <glib/gtestutils.h>
|
||||||
|
|
||||||
|
static void
|
||||||
|
group_captions (void)
|
||||||
|
{
|
||||||
|
gchar *help_variants[] = { "--help", "--help-all", "--help-test" };
|
||||||
|
|
||||||
|
GOptionEntry main_entries[] = {
|
||||||
|
{ "main-switch", 0,
|
||||||
|
G_OPTION_FLAG_NO_ARG | G_OPTION_FLAG_IN_MAIN,
|
||||||
|
G_OPTION_ARG_NONE, NULL,
|
||||||
|
"A switch that is in the main group", NULL },
|
||||||
|
{ NULL }
|
||||||
|
};
|
||||||
|
|
||||||
|
GOptionEntry group_entries[] = {
|
||||||
|
{ "test-switch", 0,
|
||||||
|
G_OPTION_FLAG_NO_ARG,
|
||||||
|
G_OPTION_ARG_NONE, NULL,
|
||||||
|
"A switch that is in the test group", NULL },
|
||||||
|
{ NULL }
|
||||||
|
};
|
||||||
|
|
||||||
|
gint i, j;
|
||||||
|
|
||||||
|
g_test_bug ("504142");
|
||||||
|
|
||||||
|
for (i = 0; i < 4; ++i)
|
||||||
|
{
|
||||||
|
gboolean have_main_entries = (0 != (i & 1));
|
||||||
|
gboolean have_test_entries = (0 != (i & 2));
|
||||||
|
|
||||||
|
GOptionContext *options;
|
||||||
|
GOptionGroup *group;
|
||||||
|
|
||||||
|
options = g_option_context_new (NULL);
|
||||||
|
group = g_option_group_new ("test", "Test Options",
|
||||||
|
"Show all test options",
|
||||||
|
NULL, NULL);
|
||||||
|
|
||||||
|
if (have_main_entries)
|
||||||
|
g_option_context_add_main_entries (options, main_entries, NULL);
|
||||||
|
if (have_test_entries)
|
||||||
|
g_option_group_add_entries (group, group_entries);
|
||||||
|
|
||||||
|
g_option_context_add_group (options, group);
|
||||||
|
|
||||||
|
for (j = 0; j < G_N_ELEMENTS (help_variants); ++j)
|
||||||
|
{
|
||||||
|
gchar *args[] = { __FILE__, help_variants[j], NULL };
|
||||||
|
|
||||||
|
g_test_message ("test setup: args='%s', main-entries=%d, test-entries=%d",
|
||||||
|
args[1], have_main_entries, have_test_entries);
|
||||||
|
|
||||||
|
if (g_test_trap_fork (0, G_TEST_TRAP_SILENCE_STDOUT |
|
||||||
|
G_TEST_TRAP_SILENCE_STDERR))
|
||||||
|
{
|
||||||
|
gchar **argv = args;
|
||||||
|
gint argc = 2;
|
||||||
|
|
||||||
|
g_option_context_parse (options, &argc, &argv, NULL);
|
||||||
|
g_assert_not_reached ();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
gboolean expect_main_description = FALSE;
|
||||||
|
gboolean expect_main_switch = FALSE;
|
||||||
|
|
||||||
|
gboolean expect_test_description = FALSE;
|
||||||
|
gboolean expect_test_switch = FALSE;
|
||||||
|
gboolean expect_test_group = FALSE;
|
||||||
|
|
||||||
|
g_test_trap_assert_passed ();
|
||||||
|
g_test_trap_assert_stderr ("");
|
||||||
|
|
||||||
|
switch (j)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
g_assert_cmpstr ("--help", ==, args[1]);
|
||||||
|
expect_main_switch = have_main_entries;
|
||||||
|
expect_test_group = have_test_entries;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 1:
|
||||||
|
g_assert_cmpstr ("--help-all", ==, args[1]);
|
||||||
|
expect_main_switch = have_main_entries;
|
||||||
|
expect_test_switch = have_test_entries;
|
||||||
|
expect_test_group = have_test_entries;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 2:
|
||||||
|
g_assert_cmpstr ("--help-test", ==, args[1]);
|
||||||
|
expect_test_switch = have_test_entries;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
g_assert_not_reached ();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
expect_main_description |= expect_main_switch;
|
||||||
|
expect_test_description |= expect_test_switch;
|
||||||
|
|
||||||
|
if (expect_main_description)
|
||||||
|
g_test_trap_assert_stdout ("*Application Options*");
|
||||||
|
else
|
||||||
|
g_test_trap_assert_stdout_unmatched ("*Application Options*");
|
||||||
|
if (expect_main_switch)
|
||||||
|
g_test_trap_assert_stdout ("*--main-switch*");
|
||||||
|
else
|
||||||
|
g_test_trap_assert_stdout_unmatched ("*--main-switch*");
|
||||||
|
|
||||||
|
if (expect_test_description)
|
||||||
|
g_test_trap_assert_stdout ("*Test Options*");
|
||||||
|
else
|
||||||
|
g_test_trap_assert_stdout_unmatched ("*Test Options*");
|
||||||
|
if (expect_test_switch)
|
||||||
|
g_test_trap_assert_stdout ("*--test-switch*");
|
||||||
|
else
|
||||||
|
g_test_trap_assert_stdout_unmatched ("*--test-switch*");
|
||||||
|
|
||||||
|
if (expect_test_group)
|
||||||
|
g_test_trap_assert_stdout ("*--help-test*");
|
||||||
|
else
|
||||||
|
g_test_trap_assert_stdout_unmatched ("*--help-test*");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
main (int argc,
|
||||||
|
char *argv[])
|
||||||
|
{
|
||||||
|
g_test_init (&argc, &argv, NULL);
|
||||||
|
|
||||||
|
g_test_bug_base ("http://bugzilla.gnome.org/");
|
||||||
|
g_test_add_func ("/group/captions", group_captions);
|
||||||
|
|
||||||
|
return g_test_run();
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user