Blame atk/atkselection.c

Packit Service ef73c4
/* ATK -  Accessibility Toolkit
Packit Service ef73c4
 * Copyright 2001 Sun Microsystems Inc.
Packit Service ef73c4
 *
Packit Service ef73c4
 * This library is free software; you can redistribute it and/or
Packit Service ef73c4
 * modify it under the terms of the GNU Lesser General Public
Packit Service ef73c4
 * License as published by the Free Software Foundation; either
Packit Service ef73c4
 * version 2 of the License, or (at your option) any later version.
Packit Service ef73c4
 *
Packit Service ef73c4
 * This library is distributed in the hope that it will be useful,
Packit Service ef73c4
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service ef73c4
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service ef73c4
 * Lesser General Public License for more details.
Packit Service ef73c4
 *
Packit Service ef73c4
 * You should have received a copy of the GNU Lesser General Public
Packit Service ef73c4
 * License along with this library; if not, write to the
Packit Service ef73c4
 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Packit Service ef73c4
 * Boston, MA 02111-1307, USA.
Packit Service ef73c4
 */
Packit Service ef73c4
Packit Service ef73c4
#include "config.h"
Packit Service ef73c4
Packit Service ef73c4
#include "atkselection.h"
Packit Service ef73c4
Packit Service ef73c4
/**
Packit Service ef73c4
 * SECTION:atkselection
Packit Service ef73c4
 * @Short_description: The ATK interface implemented by container
Packit Service ef73c4
 *  objects whose #AtkObject children can be selected.
Packit Service ef73c4
 * @Title:AtkSelection
Packit Service ef73c4
 *
Packit Service ef73c4
 * #AtkSelection should be implemented by UI components with children
Packit Service ef73c4
 * which are exposed by #atk_object_ref_child and
Packit Service ef73c4
 * #atk_object_get_n_children, if the use of the parent UI component
Packit Service ef73c4
 * ordinarily involves selection of one or more of the objects
Packit Service ef73c4
 * corresponding to those #AtkObject children - for example,
Packit Service ef73c4
 * selectable lists.
Packit Service ef73c4
 *
Packit Service ef73c4
 * Note that other types of "selection" (for instance text selection)
Packit Service ef73c4
 * are accomplished a other ATK interfaces - #AtkSelection is limited
Packit Service ef73c4
 * to the selection/deselection of children.
Packit Service ef73c4
 */
Packit Service ef73c4
Packit Service ef73c4
Packit Service ef73c4
enum {
Packit Service ef73c4
  SELECTION_CHANGED,
Packit Service ef73c4
  LAST_SIGNAL
Packit Service ef73c4
};
Packit Service ef73c4
Packit Service ef73c4
static void atk_selection_base_init (gpointer *g_class);
Packit Service ef73c4
Packit Service ef73c4
static guint atk_selection_signals[LAST_SIGNAL] = { 0 };
Packit Service ef73c4
Packit Service ef73c4
GType
Packit Service ef73c4
atk_selection_get_type (void)
Packit Service ef73c4
{
Packit Service ef73c4
  static GType type = 0;
Packit Service ef73c4
Packit Service ef73c4
  if (!type) {
Packit Service ef73c4
    GTypeInfo tinfo =
Packit Service ef73c4
    {
Packit Service ef73c4
      sizeof (AtkSelectionIface),
Packit Service ef73c4
      (GBaseInitFunc)atk_selection_base_init,
Packit Service ef73c4
      (GBaseFinalizeFunc) NULL,
Packit Service ef73c4
Packit Service ef73c4
    };
Packit Service ef73c4
Packit Service ef73c4
    type = g_type_register_static (G_TYPE_INTERFACE, "AtkSelection", &tinfo, 0);
Packit Service ef73c4
  }
Packit Service ef73c4
Packit Service ef73c4
  return type;
Packit Service ef73c4
}
Packit Service ef73c4
Packit Service ef73c4
static void
Packit Service ef73c4
atk_selection_base_init (gpointer *g_class)
Packit Service ef73c4
{
Packit Service ef73c4
  static gboolean initialized = FALSE;
Packit Service ef73c4
Packit Service ef73c4
  if (! initialized)
Packit Service ef73c4
    {
Packit Service ef73c4
      /**
Packit Service ef73c4
       * AtkSelection::selection-changed:
Packit Service ef73c4
       * @atkselection: the object which received the signal.
Packit Service ef73c4
       *
Packit Service ef73c4
       * The "selection-changed" signal is emitted by an object which
Packit Service ef73c4
       * implements AtkSelection interface when the selection changes.
Packit Service ef73c4
       */
Packit Service ef73c4
      atk_selection_signals[SELECTION_CHANGED] =
Packit Service ef73c4
        g_signal_new ("selection_changed",
Packit Service ef73c4
                      ATK_TYPE_SELECTION,
Packit Service ef73c4
                      G_SIGNAL_RUN_LAST,
Packit Service ef73c4
                      G_STRUCT_OFFSET (AtkSelectionIface, selection_changed),
Packit Service ef73c4
                      (GSignalAccumulator) NULL, NULL,
Packit Service ef73c4
                      g_cclosure_marshal_VOID__VOID,
Packit Service ef73c4
                      G_TYPE_NONE, 0);
Packit Service ef73c4
Packit Service ef73c4
Packit Service ef73c4
      initialized = TRUE;
Packit Service ef73c4
    }
Packit Service ef73c4
}
Packit Service ef73c4
Packit Service ef73c4
/**
Packit Service ef73c4
 * atk_selection_add_selection:
Packit Service ef73c4
 * @selection: a #GObject instance that implements AtkSelectionIface
Packit Service ef73c4
 * @i: a #gint specifying the child index.
Packit Service ef73c4
 *
Packit Service ef73c4
 * Adds the specified accessible child of the object to the
Packit Service ef73c4
 * object's selection.
Packit Service ef73c4
 *
Packit Service ef73c4
 * Returns: TRUE if success, FALSE otherwise.
Packit Service ef73c4
 **/
Packit Service ef73c4
gboolean
Packit Service ef73c4
atk_selection_add_selection (AtkSelection *obj,
Packit Service ef73c4
                             gint         i)
Packit Service ef73c4
{
Packit Service ef73c4
  AtkSelectionIface *iface;
Packit Service ef73c4
Packit Service ef73c4
  g_return_val_if_fail (ATK_IS_SELECTION (obj), FALSE);
Packit Service ef73c4
Packit Service ef73c4
  iface = ATK_SELECTION_GET_IFACE (obj);
Packit Service ef73c4
Packit Service ef73c4
  if (iface->add_selection)
Packit Service ef73c4
    return (iface->add_selection) (obj, i);
Packit Service ef73c4
  else
Packit Service ef73c4
    return FALSE;
Packit Service ef73c4
}
Packit Service ef73c4
Packit Service ef73c4
/**
Packit Service ef73c4
 * atk_selection_clear_selection:
Packit Service ef73c4
 * @selection: a #GObject instance that implements AtkSelectionIface
Packit Service ef73c4
 *
Packit Service ef73c4
 * Clears the selection in the object so that no children in the object
Packit Service ef73c4
 * are selected.
Packit Service ef73c4
 *
Packit Service ef73c4
 * Returns: TRUE if success, FALSE otherwise.
Packit Service ef73c4
 **/
Packit Service ef73c4
gboolean
Packit Service ef73c4
atk_selection_clear_selection (AtkSelection *obj)
Packit Service ef73c4
{
Packit Service ef73c4
  AtkSelectionIface *iface;
Packit Service ef73c4
Packit Service ef73c4
  g_return_val_if_fail (ATK_IS_SELECTION (obj), FALSE);
Packit Service ef73c4
Packit Service ef73c4
  iface = ATK_SELECTION_GET_IFACE (obj);
Packit Service ef73c4
Packit Service ef73c4
  if (iface->clear_selection)
Packit Service ef73c4
    return (iface->clear_selection) (obj);
Packit Service ef73c4
  else
Packit Service ef73c4
    return FALSE;
Packit Service ef73c4
}
Packit Service ef73c4
Packit Service ef73c4
/**
Packit Service ef73c4
 * atk_selection_ref_selection:
Packit Service ef73c4
 * @selection: a #GObject instance that implements AtkSelectionIface
Packit Service ef73c4
 * @i: a #gint specifying the index in the selection set.  (e.g. the
Packit Service ef73c4
 * ith selection as opposed to the ith child).
Packit Service ef73c4
 *
Packit Service ef73c4
 * Gets a reference to the accessible object representing the specified 
Packit Service ef73c4
 * selected child of the object.
Packit Service ef73c4
 * Note: callers should not rely on %NULL or on a zero value for
Packit Service ef73c4
 * indication of whether AtkSelectionIface is implemented, they should
Packit Service ef73c4
 * use type checking/interface checking macros or the
Packit Service ef73c4
 * atk_get_accessible_value() convenience method.
Packit Service ef73c4
 *
Packit Service ef73c4
 * Returns: (nullable) (transfer full): an #AtkObject representing the
Packit Service ef73c4
 * selected accessible, or %NULL if @selection does not implement this
Packit Service ef73c4
 * interface.
Packit Service ef73c4
 **/
Packit Service ef73c4
AtkObject*
Packit Service ef73c4
atk_selection_ref_selection (AtkSelection *obj,
Packit Service ef73c4
                             gint         i)
Packit Service ef73c4
{
Packit Service ef73c4
  AtkSelectionIface *iface;
Packit Service ef73c4
Packit Service ef73c4
  g_return_val_if_fail (ATK_IS_SELECTION (obj), NULL);
Packit Service ef73c4
Packit Service ef73c4
  iface = ATK_SELECTION_GET_IFACE (obj);
Packit Service ef73c4
Packit Service ef73c4
  if (iface->ref_selection)
Packit Service ef73c4
    return (iface->ref_selection) (obj, i);
Packit Service ef73c4
  else
Packit Service ef73c4
    return NULL;
Packit Service ef73c4
}
Packit Service ef73c4
Packit Service ef73c4
/**
Packit Service ef73c4
 * atk_selection_get_selection_count:
Packit Service ef73c4
 * @selection: a #GObject instance that implements AtkSelectionIface
Packit Service ef73c4
 *
Packit Service ef73c4
 * Gets the number of accessible children currently selected.
Packit Service ef73c4
 * Note: callers should not rely on %NULL or on a zero value for
Packit Service ef73c4
 * indication of whether AtkSelectionIface is implemented, they should
Packit Service ef73c4
 * use type checking/interface checking macros or the
Packit Service ef73c4
 * atk_get_accessible_value() convenience method.
Packit Service ef73c4
 *
Packit Service ef73c4
 * Returns: a gint representing the number of items selected, or 0
Packit Service ef73c4
 * if @selection does not implement this interface.
Packit Service ef73c4
 **/
Packit Service ef73c4
gint
Packit Service ef73c4
atk_selection_get_selection_count (AtkSelection *obj)
Packit Service ef73c4
{
Packit Service ef73c4
  AtkSelectionIface *iface;
Packit Service ef73c4
Packit Service ef73c4
  g_return_val_if_fail (ATK_IS_SELECTION (obj), 0);
Packit Service ef73c4
Packit Service ef73c4
  iface = ATK_SELECTION_GET_IFACE (obj);
Packit Service ef73c4
Packit Service ef73c4
  if (iface->get_selection_count)
Packit Service ef73c4
    return (iface->get_selection_count) (obj);
Packit Service ef73c4
  else
Packit Service ef73c4
    return 0;
Packit Service ef73c4
}
Packit Service ef73c4
Packit Service ef73c4
/**
Packit Service ef73c4
 * atk_selection_is_child_selected:
Packit Service ef73c4
 * @selection: a #GObject instance that implements AtkSelectionIface
Packit Service ef73c4
 * @i: a #gint specifying the child index.
Packit Service ef73c4
 *
Packit Service ef73c4
 * Determines if the current child of this object is selected
Packit Service ef73c4
 * Note: callers should not rely on %NULL or on a zero value for
Packit Service ef73c4
 * indication of whether AtkSelectionIface is implemented, they should
Packit Service ef73c4
 * use type checking/interface checking macros or the
Packit Service ef73c4
 * atk_get_accessible_value() convenience method.
Packit Service ef73c4
 *
Packit Service ef73c4
 * Returns: a gboolean representing the specified child is selected, or 0
Packit Service ef73c4
 * if @selection does not implement this interface.
Packit Service ef73c4
 **/
Packit Service ef73c4
gboolean
Packit Service ef73c4
atk_selection_is_child_selected (AtkSelection *obj,
Packit Service ef73c4
                                 gint         i)
Packit Service ef73c4
{
Packit Service ef73c4
  AtkSelectionIface *iface;
Packit Service ef73c4
Packit Service ef73c4
  g_return_val_if_fail (ATK_IS_SELECTION (obj), FALSE);
Packit Service ef73c4
Packit Service ef73c4
  iface = ATK_SELECTION_GET_IFACE (obj);
Packit Service ef73c4
Packit Service ef73c4
  if (iface->is_child_selected)
Packit Service ef73c4
    return (iface->is_child_selected) (obj, i);
Packit Service ef73c4
  else
Packit Service ef73c4
    return FALSE;
Packit Service ef73c4
}
Packit Service ef73c4
Packit Service ef73c4
/**
Packit Service ef73c4
 * atk_selection_remove_selection:
Packit Service ef73c4
 * @selection: a #GObject instance that implements AtkSelectionIface
Packit Service ef73c4
 * @i: a #gint specifying the index in the selection set.  (e.g. the
Packit Service ef73c4
 * ith selection as opposed to the ith child).
Packit Service ef73c4
 *
Packit Service ef73c4
 * Removes the specified child of the object from the object's selection.
Packit Service ef73c4
 *
Packit Service ef73c4
 * Returns: TRUE if success, FALSE otherwise.
Packit Service ef73c4
 **/
Packit Service ef73c4
gboolean
Packit Service ef73c4
atk_selection_remove_selection (AtkSelection *obj,
Packit Service ef73c4
                                gint         i)
Packit Service ef73c4
{
Packit Service ef73c4
  AtkSelectionIface *iface;
Packit Service ef73c4
Packit Service ef73c4
  g_return_val_if_fail (ATK_IS_SELECTION (obj), FALSE);
Packit Service ef73c4
Packit Service ef73c4
  iface = ATK_SELECTION_GET_IFACE (obj);
Packit Service ef73c4
Packit Service ef73c4
  if (iface->remove_selection)
Packit Service ef73c4
    return (iface->remove_selection) (obj, i);
Packit Service ef73c4
  else
Packit Service ef73c4
    return FALSE;
Packit Service ef73c4
}
Packit Service ef73c4
Packit Service ef73c4
/**
Packit Service ef73c4
 * atk_selection_select_all_selection:
Packit Service ef73c4
 * @selection: a #GObject instance that implements AtkSelectionIface
Packit Service ef73c4
 *
Packit Service ef73c4
 * Causes every child of the object to be selected if the object
Packit Service ef73c4
 * supports multiple selections.
Packit Service ef73c4
 *
Packit Service ef73c4
 * Returns: TRUE if success, FALSE otherwise.
Packit Service ef73c4
 **/
Packit Service ef73c4
gboolean
Packit Service ef73c4
atk_selection_select_all_selection (AtkSelection *obj)
Packit Service ef73c4
{
Packit Service ef73c4
  AtkSelectionIface *iface;
Packit Service ef73c4
Packit Service ef73c4
  g_return_val_if_fail (ATK_IS_SELECTION (obj), FALSE);
Packit Service ef73c4
Packit Service ef73c4
  iface = ATK_SELECTION_GET_IFACE (obj);
Packit Service ef73c4
Packit Service ef73c4
  if (iface->select_all_selection)
Packit Service ef73c4
    return (iface->select_all_selection) (obj);
Packit Service ef73c4
  else
Packit Service ef73c4
    return FALSE;
Packit Service ef73c4
}