[gtk+/wip/combo: 3/11] Document GtkCombo



commit f5a8fc58d12987096d800ad66399c9b18aed4152
Author: Matthias Clasen <mclasen redhat com>
Date:   Thu Dec 25 16:31:07 2014 -0500

    Document GtkCombo
    
    Add documentation for GtkCombo.

 docs/reference/gtk/gtk-docs.sgml     |    1 +
 docs/reference/gtk/gtk3-sections.txt |   27 +++++
 docs/reference/gtk/gtk3.types.in     |    1 +
 gtk/gtkcombo.c                       |  176 ++++++++++++++++++++++++++++++++-
 4 files changed, 199 insertions(+), 6 deletions(-)
---
diff --git a/docs/reference/gtk/gtk-docs.sgml b/docs/reference/gtk/gtk-docs.sgml
index e6712a3..868ab6b 100644
--- a/docs/reference/gtk/gtk-docs.sgml
+++ b/docs/reference/gtk/gtk-docs.sgml
@@ -193,6 +193,7 @@
       <xi:include href="xml/gtkradiotoolbutton.xml" />
       <xi:include href="xml/gtkpopover.xml" />
       <xi:include href="xml/gtkpopovermenu.xml" />
+      <xi:include href="xml/gtkcombo.xml" />
     </chapter>
 
     <chapter id="SelectorWidgets">
diff --git a/docs/reference/gtk/gtk3-sections.txt b/docs/reference/gtk/gtk3-sections.txt
index 8c0270b..7c68edc 100644
--- a/docs/reference/gtk/gtk3-sections.txt
+++ b/docs/reference/gtk/gtk3-sections.txt
@@ -978,6 +978,33 @@ gtk_combo_box_text_get_type
 </SECTION>
 
 <SECTION>
+<FILE>gtkcombo</FILE>
+<TITLE>GtkCombo</TITLE>
+GtkCombo
+gtk_combo_new
+gtk_combo_get_active
+gtk_combo_set_active
+gtk_combo_add
+gtk_combo_remove
+gtk_combo_get_placeholder
+gtk_combo_set_placeholder
+gtk_combo_get_allow_custom
+gtk_combo_set_allow_custom
+
+<SUBSECTION Standard>
+GTK_TYPE_COMBO
+GTK_COMBO
+GTK_IS_COMBO
+GTK_COMBO_CLASS
+GTK_IS_COMBO_CLASS
+GTK_COMBO_GET_CLASS
+
+<SUBSECTION Private>
+gtk_combo_get_type
+</SECTION>
+
+
+<SECTION>
 <FILE>gtkcontainer</FILE>
 <TITLE>GtkContainer</TITLE>
 GtkContainer
diff --git a/docs/reference/gtk/gtk3.types.in b/docs/reference/gtk/gtk3.types.in
index 0bc2c6a..b3e486b 100644
--- a/docs/reference/gtk/gtk3.types.in
+++ b/docs/reference/gtk/gtk3.types.in
@@ -55,6 +55,7 @@ gtk_color_selection_dialog_get_type
 gtk_color_selection_get_type
 gtk_combo_box_get_type
 gtk_combo_box_text_get_type
+gtk_combo_get_type
 gtk_container_get_type
 gtk_css_provider_get_type
 gtk_dialog_get_type
diff --git a/gtk/gtkcombo.c b/gtk/gtkcombo.c
index 37ecc90..cdae5f2 100644
--- a/gtk/gtkcombo.c
+++ b/gtk/gtkcombo.c
@@ -39,9 +39,45 @@
 #include "gtkprivate.h"
 
 
-/* TODO
- * - docs
- * - grouping
+/**
+ * SECTION:gtkcombo
+ * @Short_description: A simple text-only combo box using a popover
+ * @Title: GtkCombo
+ * @See_also: #GtkComboBoxText
+ *
+ * A GtkCombo is a simple variant of a combo box that hides the
+ * model-view complexity of #GtkcomboBox and uses popovers.
+ *
+ * To create a GtkCombo, use gtk_combo_new().
+ *
+ * You can add items to a Gtkcombo using gtk_combo_add() and remove them
+ * with gtk_combo_remove(). Each item has an id that is returned as the
+ * value of the #GtkCombo:active property when the item is currently
+ * selected, an optional text that is used to display the item, and an
+ * optional sort key that is used to sort the items.
+ *
+ * If you want to allow the user to enter custom values, use
+ * gtk_combo_set_allow_custom().
+ *
+ * # GtkCombo as GtkBuildable
+ *
+ * The GtkCombo implementation of the GtkBuildable interface supports
+ * adding items directly using the <items> element and specifying <item>
+ * elements for each item. Each <item> element can specify the “id”
+ * and "sort" corresponding to the appended text and also supports
+ * the regular translation attributes “translatable”, “context” and
+ * “comments”.
+ *
+ * Here is a UI definition fragment specifying some GtkCombo items:
+ * |[
+ * <object class="GtkCombo">
+ *   <items>
+ *     <item translatable="yes" id="factory" sort="aaa">Factory</item>
+ *     <item translatable="yes" id="home" sort="ccc">Home</item>
+ *     <item translatable="yes" id="subway" sort="bbb">Subway</item>
+ *   </items>
+ * </object>
+ * ]|
  */
 
 
@@ -400,19 +436,44 @@ gtk_combo_class_init (GtkComboClass *class)
   object_class->set_property = gtk_combo_set_property;
   object_class->get_property = gtk_combo_get_property;
 
+  /**
+   * GtkCombo:active:
+   *
+   * The ID of the currently selected item, or %NULL
+   * if no item is currently selected.
+   */
   g_object_class_install_property (object_class,
                                    PROP_ACTIVE,
-                                   g_param_spec_string ("active", P_("Active"), P_("Active"),
+                                   g_param_spec_string ("active",
+                                                        P_("Active"),
+                                                        P_("Active ID"),
                                                         NULL,
                                                         GTK_PARAM_READWRITE));
+
+  /**
+   * GtkCombo:placeholder:
+   *
+   * The text that is displayed if not item is selected.
+   */
   g_object_class_install_property (object_class,
                                    PROP_PLACEHOLDER,
-                                   g_param_spec_string ("placeholder", P_("Placeholder"), P_("Placeholder"),
+                                   g_param_spec_string ("placeholder",
+                                                        P_("Placeholder"),
+                                                        P_("Placeholder text"),
                                                         NULL,
                                                         GTK_PARAM_READWRITE));
+
+  /**
+   * GtkCombo:allow-custom:
+   *
+   * Whether the combo should allow the user to enter
+   * custom values.
+   */
   g_object_class_install_property (object_class,
                                    PROP_ALLOW_CUSTOM,
-                                   g_param_spec_boolean ("allow-custom", P_("Allow custom"), P_("Allow 
custom"),
+                                   g_param_spec_boolean ("allow-custom",
+                                                         P_("Allow custom"),
+                                                         P_("Allow custom items"),
                                                          FALSE,
                                                          GTK_PARAM_READWRITE));
 
@@ -1098,12 +1159,33 @@ button_key_press (GtkWidget *widget,
 
 /***/
 
+
+/**
+ * gtk_combo_new:
+ *
+ * Creates a new #GtkCombo.
+ *
+ * Returns: A new #GtkCombo
+ *
+ * Since: 3.16
+ */
 GtkWidget *
 gtk_combo_new (void)
 {
   return g_object_new (GTK_TYPE_COMBO, NULL);
 }
 
+/**
+ * gtk_combo_get_active:
+ * @combo: a #GtkCombo
+ *
+ * Gets the ID of the currently selected item.
+ *
+ * Returns: (transfer none): the active ID, or %NULL if no
+ *   item is selected
+ *
+ * Since: 3.16
+ */
 const gchar *
 gtk_combo_get_active (GtkCombo *combo)
 {
@@ -1112,6 +1194,17 @@ gtk_combo_get_active (GtkCombo *combo)
   return combo->active;
 }
 
+/**
+ * gtk_combo_set_active:
+ * @combo: a #GtkCombo
+ * @id: the ID to select
+ *
+ * Sets the active ID to @id. If @id is not the ID
+ * of an item of combo, no item will be selected
+ * after this call.
+ *
+ * Since: 3.16
+ */
 void
 gtk_combo_set_active (GtkCombo    *combo,
                       const gchar *id)
@@ -1121,6 +1214,23 @@ gtk_combo_set_active (GtkCombo    *combo,
   set_active (combo, id);
 }
 
+/**
+ * gtk_combo_add:
+ * @combo: a #GtkCombo
+ * @id: the ID for the item to add
+ * @sort: (allow-none): a sort key for the item
+ * @text: (allow-none): the text to display for the item
+ *
+ * Adds an item to the combo.
+ *
+ * If an item with this ID already exists, its sort key
+ * and display text will be updated with the new values.
+ *
+ * If @sort is %NULL, the item will be sorted according to @text.
+ * If @text is %NULL, the @id will be used to display the item.
+ *
+ * Since: 3.16
+ */
 void
 gtk_combo_add (GtkCombo    *combo,
                const gchar *id,
@@ -1133,6 +1243,18 @@ gtk_combo_add (GtkCombo    *combo,
   collapse_list (combo);
 }
 
+/**
+ * gtk_combo_remove:
+ * @combo: a #GtkCombo
+ * @id: the ID of the item to remove
+ *
+ * Removes an item from the combo.
+ *
+ * If the item with the this ID is currently selected,
+ * no item will be selected after this call.
+ *
+ * Since: 3.16
+ */
 void
 gtk_combo_remove (GtkCombo    *combo,
                   const gchar *id)
@@ -1148,6 +1270,16 @@ gtk_combo_remove (GtkCombo    *combo,
   collapse_list (combo);
 }
 
+/**
+ * gtk_combo_set_placeholder:
+ * @combo: a #GtkCombo
+ * @text: (allow-none): the placeholder text to use, or %NULL
+ *
+ * Sets the placeholder text that is displayed in the combo
+ * if no item is currently selected.
+ *
+ * Since: 3.16
+ */
 void
 gtk_combo_set_placeholder (GtkCombo    *combo,
                            const gchar *text)
@@ -1163,6 +1295,17 @@ gtk_combo_set_placeholder (GtkCombo    *combo,
   g_object_notify (G_OBJECT (combo), "placeholder");
 }
 
+/**
+ * gtk_combo_get_placeholder:
+ * @combo: a #GtkCombo
+ *
+ * Gets the placholder text that is displayed in the combo
+ * if no item is currently selected.
+ *
+ * Returns: (transfer none): the placeholder text
+ *
+ * Since: 3.16
+ */
 const gchar *
 gtk_combo_get_placeholder (GtkCombo *combo)
 {
@@ -1171,6 +1314,16 @@ gtk_combo_get_placeholder (GtkCombo *combo)
   return combo->placeholder;
 }
 
+/**
+ * gtk_combo_set_allow_custom:
+ * @combo: a #GtkCombo
+ * @allow: whether to allow custom items
+ *
+ * Sets whether the combo should allow the user
+ * to enter custom values.
+ *
+ * Since: 3.16
+ */
 void
 gtk_combo_set_allow_custom (GtkCombo *combo,
                             gboolean  allow)
@@ -1187,6 +1340,17 @@ gtk_combo_set_allow_custom (GtkCombo *combo,
   g_object_notify (G_OBJECT (combo), "allow-custom");
 }
 
+/**
+ * gtk_combo_get_allow_custom:
+ * #combo: a #GtkCombo
+ *
+ * Gets whether the combo should allow the user
+ * to enter custom values.
+ *
+ * Returns: %TRUE if custom values are allowed
+ *
+ * Since: 3.16
+ */
 gboolean
 gtk_combo_get_allow_custom (GtkCombo *combo)
 {


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]