2019-08-13 19:59:33 +08:00
|
|
|
/* LIBGIMP - The GIMP Library
|
|
|
|
* Copyright (C) 1995-2000 Peter Mattis and Spencer Kimball
|
|
|
|
*
|
|
|
|
* gimpitem.c
|
|
|
|
* Copyright (C) Jehan
|
|
|
|
*
|
|
|
|
* This library is free software: you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 3 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library 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. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library. If not, see
|
|
|
|
* <https://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
#include "gimp.h"
|
|
|
|
|
2019-08-23 23:18:17 +08:00
|
|
|
#include "libgimpbase/gimpwire.h" /* FIXME kill this include */
|
|
|
|
|
|
|
|
#include "gimpplugin-private.h"
|
|
|
|
#include "gimpprocedure-private.h"
|
|
|
|
|
2019-08-13 19:59:33 +08:00
|
|
|
|
|
|
|
enum
|
|
|
|
{
|
|
|
|
PROP_0,
|
|
|
|
PROP_ID,
|
|
|
|
N_PROPS
|
|
|
|
};
|
|
|
|
|
2019-08-23 23:18:17 +08:00
|
|
|
|
2019-08-13 19:59:33 +08:00
|
|
|
struct _GimpItemPrivate
|
|
|
|
{
|
|
|
|
gint id;
|
|
|
|
};
|
|
|
|
|
2019-08-15 18:12:25 +08:00
|
|
|
|
2019-08-13 19:59:33 +08:00
|
|
|
static void gimp_item_set_property (GObject *object,
|
|
|
|
guint property_id,
|
|
|
|
const GValue *value,
|
|
|
|
GParamSpec *pspec);
|
|
|
|
static void gimp_item_get_property (GObject *object,
|
|
|
|
guint property_id,
|
|
|
|
GValue *value,
|
|
|
|
GParamSpec *pspec);
|
|
|
|
|
2019-08-23 23:18:17 +08:00
|
|
|
|
2019-08-13 19:59:33 +08:00
|
|
|
G_DEFINE_ABSTRACT_TYPE_WITH_PRIVATE (GimpItem, gimp_item, G_TYPE_OBJECT)
|
|
|
|
|
|
|
|
#define parent_class gimp_item_parent_class
|
|
|
|
|
|
|
|
static GParamSpec *props[N_PROPS] = { NULL, };
|
|
|
|
|
2019-08-23 23:18:17 +08:00
|
|
|
|
2019-08-13 19:59:33 +08:00
|
|
|
static void
|
|
|
|
gimp_item_class_init (GimpItemClass *klass)
|
|
|
|
{
|
|
|
|
GObjectClass *object_class = G_OBJECT_CLASS (klass);
|
|
|
|
|
|
|
|
object_class->set_property = gimp_item_set_property;
|
|
|
|
object_class->get_property = gimp_item_get_property;
|
|
|
|
|
|
|
|
props[PROP_ID] =
|
|
|
|
g_param_spec_int ("id",
|
|
|
|
"The item id",
|
|
|
|
"The item id for internal use",
|
|
|
|
0, G_MAXINT32, 0,
|
|
|
|
GIMP_PARAM_READWRITE |
|
|
|
|
G_PARAM_CONSTRUCT_ONLY);
|
|
|
|
|
|
|
|
g_object_class_install_properties (object_class, N_PROPS, props);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
gimp_item_init (GimpItem *item)
|
|
|
|
{
|
|
|
|
item->priv = gimp_item_get_instance_private (item);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
gimp_item_set_property (GObject *object,
|
|
|
|
guint property_id,
|
|
|
|
const GValue *value,
|
|
|
|
GParamSpec *pspec)
|
|
|
|
{
|
|
|
|
GimpItem *item = GIMP_ITEM (object);
|
|
|
|
|
|
|
|
switch (property_id)
|
|
|
|
{
|
|
|
|
case PROP_ID:
|
|
|
|
item->priv->id = g_value_get_int (value);
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
gimp_item_get_property (GObject *object,
|
|
|
|
guint property_id,
|
|
|
|
GValue *value,
|
|
|
|
GParamSpec *pspec)
|
|
|
|
{
|
|
|
|
GimpItem *item = GIMP_ITEM (object);
|
|
|
|
|
|
|
|
switch (property_id)
|
|
|
|
{
|
|
|
|
case PROP_ID:
|
|
|
|
g_value_set_int (value, item->priv->id);
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* Public API. */
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* gimp_item_get_id:
|
|
|
|
* @item: The item.
|
|
|
|
*
|
|
|
|
* Returns: the item ID.
|
|
|
|
*
|
|
|
|
* Since: 3.0
|
|
|
|
**/
|
|
|
|
gint32
|
|
|
|
gimp_item_get_id (GimpItem *item)
|
|
|
|
{
|
|
|
|
return item ? item->priv->id : -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-08-15 18:12:25 +08:00
|
|
|
* gimp_item_get_by_id:
|
2019-08-13 19:59:33 +08:00
|
|
|
* @item_id: The item id.
|
|
|
|
*
|
2019-08-23 23:18:17 +08:00
|
|
|
* Returns a #GimpItem representing @item_id. Since #GimpItem is an
|
|
|
|
* abstract class, the real object type will actually be the proper
|
2019-08-13 19:59:33 +08:00
|
|
|
* subclass.
|
|
|
|
*
|
2019-08-15 18:12:25 +08:00
|
|
|
* Returns: (nullable) (transfer none): a #GimpItem for @item_id or
|
2019-08-13 19:59:33 +08:00
|
|
|
* %NULL if @item_id does not represent a valid item.
|
2019-08-23 23:18:17 +08:00
|
|
|
* The object belongs to libgimp and you must not modify
|
|
|
|
* or unref it.
|
2019-08-13 19:59:33 +08:00
|
|
|
*
|
|
|
|
* Since: 3.0
|
|
|
|
**/
|
|
|
|
GimpItem *
|
2019-08-15 18:12:25 +08:00
|
|
|
gimp_item_get_by_id (gint32 item_id)
|
2019-08-13 19:59:33 +08:00
|
|
|
{
|
2019-08-23 23:18:17 +08:00
|
|
|
if (item_id > 0)
|
2019-08-15 18:12:25 +08:00
|
|
|
{
|
2019-08-23 23:18:17 +08:00
|
|
|
GimpPlugIn *plug_in = gimp_get_plug_in ();
|
|
|
|
GimpProcedure *procedure = _gimp_plug_in_get_procedure (plug_in);
|
|
|
|
|
|
|
|
return _gimp_procedure_get_item (procedure, item_id);
|
2019-08-13 19:59:33 +08:00
|
|
|
}
|
|
|
|
|
2019-08-23 23:18:17 +08:00
|
|
|
return NULL;
|
2019-08-13 19:59:33 +08:00
|
|
|
}
|
2019-08-14 17:08:42 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* gimp_item_get_children:
|
2019-08-27 19:26:27 +08:00
|
|
|
* @item: The item.
|
|
|
|
* @num_children: (out): The number of items in the returned array.
|
|
|
|
*
|
|
|
|
* Returns the item's list of children.
|
|
|
|
*
|
|
|
|
* This procedure returns the list of items which are children of the
|
|
|
|
* specified item. The order is topmost to bottommost.
|
|
|
|
*
|
|
|
|
* Returns: (array length=num_children) (transfer container):
|
|
|
|
* The item's list of children.
|
|
|
|
* The returned array must be freed with g_free(). Item
|
|
|
|
* elements belong to libgimp and must not be unrefed.
|
|
|
|
**/
|
|
|
|
GimpItem **
|
|
|
|
gimp_item_get_children (GimpItem *item,
|
|
|
|
gint *num_children)
|
|
|
|
{
|
|
|
|
GimpItem **children;
|
|
|
|
gint *ids;
|
|
|
|
gint i;
|
|
|
|
|
|
|
|
ids = _gimp_item_get_children (item, num_children);
|
|
|
|
|
|
|
|
children = g_new (GimpItem *, *num_children);
|
|
|
|
|
|
|
|
for (i = 0; i < *num_children; i++)
|
|
|
|
children[i] = gimp_item_get_by_id (ids[i]);
|
|
|
|
|
|
|
|
g_free (ids);
|
|
|
|
|
|
|
|
return children;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* gimp_item_list_children:
|
2019-08-14 17:08:42 +08:00
|
|
|
* @item: The item.
|
|
|
|
*
|
|
|
|
* Returns the item's list of children.
|
|
|
|
*
|
|
|
|
* This procedure returns the list of items which are children of the
|
|
|
|
* specified item. The order is topmost to bottommost.
|
|
|
|
*
|
2019-08-15 18:12:25 +08:00
|
|
|
* Returns: (element-type GimpItem) (transfer container):
|
2019-08-14 17:08:42 +08:00
|
|
|
* The item's list of children.
|
2019-08-27 19:26:27 +08:00
|
|
|
* The returned ist must be freed with g_list_free(). Item
|
2019-08-23 23:18:17 +08:00
|
|
|
* elements belong to libgimp and must not be unrefed.
|
2019-08-14 17:08:42 +08:00
|
|
|
*
|
|
|
|
* Since: 3.0
|
|
|
|
**/
|
|
|
|
GList *
|
2019-08-27 19:26:27 +08:00
|
|
|
gimp_item_list_children (GimpItem *item)
|
2019-08-14 17:08:42 +08:00
|
|
|
{
|
|
|
|
GList *children = NULL;
|
|
|
|
gint *ids;
|
|
|
|
gint num_items;
|
|
|
|
gint i;
|
|
|
|
|
|
|
|
ids = _gimp_item_get_children (item, &num_items);
|
|
|
|
|
|
|
|
for (i = 0; i < num_items; i++)
|
2019-08-15 18:12:25 +08:00
|
|
|
children = g_list_prepend (children, gimp_item_get_by_id (ids[i]));
|
2019-08-14 17:08:42 +08:00
|
|
|
|
|
|
|
g_free (ids);
|
|
|
|
|
2019-08-23 23:18:17 +08:00
|
|
|
return g_list_reverse (children);
|
2019-08-14 17:08:42 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* gimp_item_get_children_deprecated: (skip)
|
|
|
|
* @item_id: The item.
|
|
|
|
* @num_children: (out): The item's number of children.
|
|
|
|
*
|
|
|
|
* Returns the item's list of children.
|
|
|
|
*
|
|
|
|
* This procedure returns the list of items which are children of the
|
|
|
|
* specified item. The order is topmost to bottommost.
|
|
|
|
*
|
|
|
|
* Returns: (array length=num_children) (element-type gint32) (transfer full):
|
|
|
|
* The item's list of children.
|
|
|
|
* The returned value must be freed with g_free().
|
|
|
|
*
|
|
|
|
* Since: 2.8
|
|
|
|
**/
|
|
|
|
gint *
|
|
|
|
gimp_item_get_children_deprecated (gint32 item_id,
|
|
|
|
gint *num_children)
|
|
|
|
{
|
2019-08-15 18:12:25 +08:00
|
|
|
return _gimp_item_get_children (gimp_item_get_by_id (item_id),
|
|
|
|
num_children);
|
2019-08-14 17:08:42 +08:00
|
|
|
}
|