Allow to list keys in all schemas
authorMatthias Clasen <mclasen@redhat.com>
Wed, 23 Feb 2011 05:13:39 +0000 (00:13 -0500)
committerMatthias Clasen <mclasen@redhat.com>
Wed, 23 Feb 2011 05:18:37 +0000 (00:18 -0500)
Make the schema argument to gsettings list-recursively optional.
This allows to search for not exactly known keys by going

gsettings list-recursively | grep 'font'

docs/reference/gio/gsettings.xml
gio/gsettings-tool.c

index 5a3bd21764a3936692fd40df6dafa3dc97e516c6..1d8e3818700435cd9c0c5c545b598cd499670ea8 100644 (file)
@@ -22,7 +22,7 @@
     <command>gsettings</command>
     <arg choice="plain">monitor</arg>
     <arg choice="plain"><replaceable>SCHEMA</replaceable><arg choice="opt">:<replaceable>PATH</replaceable></arg></arg>
-    <arg choice="plain"><replaceable>KEY</replaceable></arg>
+    <arg choice="opt"><replaceable>KEY</replaceable></arg>
   </cmdsynopsis>
   <cmdsynopsis>
     <command>gsettings</command>
@@ -70,7 +70,7 @@
   <cmdsynopsis>
     <command>gsettings</command>
     <arg choice="plain">list-recursively</arg>
-    <arg choice="plain"><replaceable>SCHEMA</replaceable><arg choice="opt">:<replaceable>PATH</replaceable></arg></arg>
+    <arg choice="opt"><replaceable>SCHEMA</replaceable><arg choice="opt">:<replaceable>PATH</replaceable></arg></arg>
   </cmdsynopsis>
   <cmdsynopsis>
     <command>gsettings</command>
@@ -116,7 +116,8 @@ The value is printed out as a serialised
 <term><option>monitor</option></term>
 <listitem><para>
 Monitors <replaceable>KEY</replaceable> for changes and prints the changed
-values. Monitoring will continue until the process is terminated.
+values. If no <replaceable>KEY</replaceable> is specified, all keys in the
+schema are monitored. Monitoring will continue until the process is terminated.
 </para></listitem>
 </varlistentry>
 
@@ -185,7 +186,8 @@ Lists the children of <replaceable>SCHEMA</replaceable>.
 <varlistentry>
 <term><option>list-recursively</option></term>
 <listitem><para>
-Lists keys and values, recursively.
+Lists keys and values, recursively. If no <replaceable>SCHEMA</replaceable>
+is given, list keys in all schemas.
 </para></listitem>
 </varlistentry>
 
index ce624b91d20a7eddeef4d308adaffaaf1893eb19..14bd99f2233955f396f120359a5f94707909dcc0 100644 (file)
@@ -240,29 +240,44 @@ gsettings_list_recursively (GSettings   *settings,
                             const gchar *key,
                             const gchar *value)
 {
-  gchar **children;
-  gint i;
-
-  enumerate (settings);
+  if (settings)
+    {
+      gchar **children;
+      gint i;
 
-  children = g_settings_list_children (settings);
+      enumerate (settings);
+      children = g_settings_list_children (settings);
+      for (i = 0; children[i]; i++)
+        {
+          GSettings *child;
+          gchar *schema;
 
-  for (i = 0; children[i]; i++)
-    {
-      GSettings *child;
-      gchar *schema;
+          child = g_settings_get_child (settings, children[i]);
+          g_object_get (child, "schema", &schema, NULL);
 
-      child = g_settings_get_child (settings, children[i]);
-      g_object_get (child, "schema", &schema, NULL);
+          if (is_schema (schema))
+            enumerate (child);
 
-      if (is_schema (schema))
-        enumerate (child);
+          g_object_unref (child);
+          g_free (schema);
+        }
 
-      g_object_unref (child);
-      g_free (schema);
+      g_strfreev (children);
     }
+  else
+    {
+      const gchar * const *schemas;
+      gint i;
 
-  g_strfreev (children);
+      schemas = g_settings_list_schemas ();
+
+      for (i = 0; schemas[i]; i++)
+        {
+          settings = g_settings_new (schemas[i]);
+          enumerate (settings);
+          g_object_unref (settings);
+        }
+    }
 }
 
 static void
@@ -485,8 +500,9 @@ gsettings_help (gboolean     requested,
 
   else if (strcmp (command, "list-recursively") == 0)
     {
-      description = _("List keys and values, recursively");
-      synopsis = N_("SCHEMA[:PATH]");
+      description = _("List keys and values, recursively\n"
+                      "If no SCHEMA is given, list all keys\n");
+      synopsis = N_("[SCHEMA[:PATH]]");
     }
 
   else if (strcmp (command, "get") == 0)
@@ -640,7 +656,7 @@ main (int argc, char **argv)
   else if (argc == 3 && strcmp (argv[1], "list-children") == 0)
     function = gsettings_list_children;
 
-  else if (argc == 3 && strcmp (argv[1], "list-recursively") == 0)
+  else if ((argc == 2 || argc == 3) && strcmp (argv[1], "list-recursively") == 0)
     function = gsettings_list_recursively;
 
   else if (argc == 4 && strcmp (argv[1], "range") == 0)