README: add deprecation notice
[nautilus-actions.git] / src / api / fma-object-id.h
bloba0558c33ecfc7d0948de6817d8438d75d77efc5d
1 /*
2 * FileManager-Actions
3 * A file-manager extension which offers configurable context menu actions.
5 * Copyright (C) 2005 The GNOME Foundation
6 * Copyright (C) 2006-2008 Frederic Ruaudel and others (see AUTHORS)
7 * Copyright (C) 2009-2015 Pierre Wieser and others (see AUTHORS)
9 * FileManager-Actions is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License as
11 * published by the Free Software Foundation; either version 2 of
12 * the License, or (at your option) any later version.
14 * FileManager-Actions is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 * General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with FileManager-Actions; see the file COPYING. If not, see
21 * <http://www.gnu.org/licenses/>.
23 * Authors:
24 * Frederic Ruaudel <grumz@grumz.net>
25 * Rodrigo Moya <rodrigo@gnome-db.org>
26 * Pierre Wieser <pwieser@trychlos.org>
27 * ... and many others (see AUTHORS)
30 #ifndef __FILEMANAGER_ACTIONS_API_OBJECT_ID_H__
31 #define __FILEMANAGER_ACTIONS_API_OBJECT_ID_H__
33 /**
34 * SECTION: object-id
35 * @title: FMAObjectId
36 * @short_description: The Identified Object Base Class Definition
37 * @include: filemanager-actions/fma-object-id.h
39 * This is a pure virtual class, i.e. not an instantiatable one.
40 * It serves as the base class for #FMAObject -derived object which have
41 * a unique Id, i.e. for #FMAObjectItem and #FMAObjectProfile.
44 #include "fma-object.h"
46 G_BEGIN_DECLS
48 #define FMA_TYPE_OBJECT_ID ( fma_object_id_get_type())
49 #define FMA_OBJECT_ID( object ) ( G_TYPE_CHECK_INSTANCE_CAST( object, FMA_TYPE_OBJECT_ID, FMAObjectId ))
50 #define FMA_OBJECT_ID_CLASS( klass ) ( G_TYPE_CHECK_CLASS_CAST( klass, FMA_TYPE_OBJECT_ID, FMAObjectIdClass ))
51 #define FMA_IS_OBJECT_ID( object ) ( G_TYPE_CHECK_INSTANCE_TYPE( object, FMA_TYPE_OBJECT_ID ))
52 #define FMA_IS_OBJECT_ID_CLASS( klass ) ( G_TYPE_CHECK_CLASS_TYPE(( klass ), FMA_TYPE_OBJECT_ID ))
53 #define FMA_OBJECT_ID_GET_CLASS( object ) ( G_TYPE_INSTANCE_GET_CLASS(( object ), FMA_TYPE_OBJECT_ID, FMAObjectIdClass ))
55 typedef struct _FMAObjectIdPrivate FMAObjectIdPrivate;
57 typedef struct {
58 /*< private >*/
59 FMAObject parent;
60 FMAObjectIdPrivate *private;
62 FMAObjectId;
64 typedef struct _FMAObjectIdClassPrivate FMAObjectIdClassPrivate;
66 /**
67 * FMAObjectIdClass:
68 * @new_id: Allocate a new id to an existing FMAObjectId.
70 * The #FMAObjectIdClass defines some methods available to derived classes.
72 typedef struct {
73 /*< private >*/
74 FMAObjectClass parent;
75 FMAObjectIdClassPrivate *private;
77 /*< public >*/
78 /**
79 * new_id:
80 * @object: a FMAObjectId object.
81 * @new_parent: possibly the new FMAObjectId parent, or NULL.
82 * If not NULL, this should actually be a FMAObjectItem.
84 * If @object is a FMAObjectProfile, then @new_parent must be a
85 * not null FMAObjectAction. This function ensures that the new
86 * profile name does not already exist in the given @new_parent.
88 * This is a pure virtual function which should be implemented by
89 * the actual class. Actually, we asks for the most-derived class
90 * which implements this function.
92 * Returns: a new id suitable for this @object.
94 * Since: 2.30
96 gchar * ( *new_id )( const FMAObjectId *object, const FMAObjectId *new_parent );
98 FMAObjectIdClass;
100 GType fma_object_id_get_type ( void );
102 gint fma_object_id_sort_alpha_asc ( const FMAObjectId *a, const FMAObjectId *b );
103 gint fma_object_id_sort_alpha_desc ( const FMAObjectId *a, const FMAObjectId *b );
105 void fma_object_id_prepare_for_paste( FMAObjectId *object, gboolean relabel, gboolean renumber, FMAObjectId *parent );
106 void fma_object_id_set_copy_of_label( FMAObjectId *object );
107 void fma_object_id_set_new_id ( FMAObjectId *object, const FMAObjectId *new_parent );
109 G_END_DECLS
111 #endif /* __FILEMANAGER_ACTIONS_API_OBJECT_ID_H__ */