File: nemo-extension-types.h

package info (click to toggle)
nemo 6.4.5-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 9,088 kB
  • sloc: ansic: 127,474; xml: 1,555; python: 1,434; sh: 57; makefile: 20
file content (80 lines) | stat: -rw-r--r-- 2,883 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
/*
 *  nemo-info-provider.h - Type definitions for Nemo extensions
 * 
 *  Copyright (C) 2003 Novell, Inc.
 *
 *  This library is free software; you can redistribute it and/or
 *  modify it under the terms of the GNU Library General Public
 *  License as published by the Free Software Foundation; either
 *  version 2 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
 *  Library General Public License for more details.
 *
 *  You should have received a copy of the GNU Library General Public
 *  License along with this library; if not, write to the Free
 *  Software Foundation, Inc., 51 Franklin Street, Suite 500, MA 02110-1335, USA.
 *
 *  Author: Dave Camp <dave@ximian.com>
 * 
 */

/* This interface is implemented by Nemo extensions that want to 
 * provide information about files.  Extensions are called when Nemo 
 * needs information about a file.  They are passed a NemoFileInfo 
 * object which should be filled with relevant information */

#ifndef NEMO_EXTENSION_TYPES_H
#define NEMO_EXTENSION_TYPES_H

#include <glib-object.h>

G_BEGIN_DECLS

/**
 * SECTION:nemo-extension-types
 * @Title: Types and Enums
 * @Short_description: Module initialization functions, enums, handle struct
 **/

/**
 * NemoOperationHandle:
 *
 * Handle for asynchronous interfaces.  These are opaque handles that must
 * be unique within an extension object.  These are returned by operations
 * that return NEMO_OPERATION_IN_PROGRESS.
 *
 * For python extensions, the handle is a dummy struct created by the nemo
 * python bindings on the extension's behalf.  It can be used as a unique
 * key for a dict, for instance, for keeping track of multiple operations
 * at once.
 */
typedef struct _NemoOperationHandle NemoOperationHandle;

/**
 * NemoOperationResult:
 * @NEMO_OPERATION_COMPLETE: Returned if the call succeeded, and the extension is done
 *  with the request.
 * @NEMO_OPERATION_FAILED: Returned if the call failed.
 * @NEMO_OPERATION_IN_PROGRESS: Returned if the extension has begun an async operation.
 *  For C extensions, if this is returned, the extension must set the handle parameter.
 *  For python extensions, handle is already filled, and unique, and can be used for
 *  identifying purposes within the extension.  In either case, the extension must call
 *  the callback closure when the operation is complete (complete_invoke.)
 */
typedef enum {
    NEMO_OPERATION_COMPLETE,
    NEMO_OPERATION_FAILED,
    NEMO_OPERATION_IN_PROGRESS
} NemoOperationResult;

void nemo_module_initialize (GTypeModule  *module);
void nemo_module_shutdown   (void);
void nemo_module_list_types (const GType **types,
				 int          *num_types);

G_END_DECLS

#endif