Top |
Functions
GQuark | tracker_miner_error_quark () |
void | tracker_miner_start () |
void | tracker_miner_stop () |
gboolean | tracker_miner_is_started () |
gboolean | tracker_miner_is_paused () |
void | tracker_miner_pause () |
gboolean | tracker_miner_resume () |
TrackerSparqlConnection * | tracker_miner_get_connection () |
Properties
TrackerSparqlConnection * | connection | Read / Write / Construct Only |
gdouble | progress | Read / Write / Construct |
gint | remaining-time | Read / Write / Construct |
gchar * | status | Read / Write / Construct |
Types and Values
#define | TRACKER_MINER_DBUS_INTERFACE |
#define | TRACKER_MINER_DBUS_NAME_PREFIX |
#define | TRACKER_MINER_DBUS_PATH_PREFIX |
#define | TRACKER_MINER_ERROR_DOMAIN |
#define | TRACKER_MINER_ERROR |
struct | TrackerMiner |
TrackerMinerClass | |
enum | TrackerMinerError |
Object Hierarchy
GObject ╰── TrackerMiner ├── TrackerDecorator ├── TrackerMinerFS ╰── TrackerMinerOnline
Description
TrackerMiner is an abstract base class to help developing data miners for tracker-store, being an abstract class it doesn't do much by itself, but provides the basic signaling and control over the actual indexing task.
TrackerMiner implements the GInitable interface, and thus, all objects of
types inheriting from TrackerMiner must be initialized with g_initable_init()
just after creation (or directly created with g_initable_new()
).
Functions
tracker_miner_error_quark ()
GQuark
tracker_miner_error_quark (void
);
Gives the caller the GQuark used to identify TrackerMiner errors in GError structures. The GQuark is used as the domain for the error.
Since: 0.8
tracker_miner_start ()
void
tracker_miner_start (TrackerMiner *miner
);
Tells the miner to start processing data.
Since: 0.8
tracker_miner_stop ()
void
tracker_miner_stop (TrackerMiner *miner
);
Tells the miner to stop processing data.
Since: 0.8
tracker_miner_is_started ()
gboolean
tracker_miner_is_started (TrackerMiner *miner
);
Returns TRUE if the miner has been started.
Since: 0.8
tracker_miner_is_paused ()
gboolean
tracker_miner_is_paused (TrackerMiner *miner
);
Returns TRUE if the miner is paused.
Since: 0.10
tracker_miner_pause ()
void
tracker_miner_pause (TrackerMiner *miner
);
Asks miner
to pause. This call may be called multiple times,
but “paused” will only be emitted the first time.
The same number of tracker_miner_resume()
calls are expected
in order to resume operations.
tracker_miner_resume ()
gboolean
tracker_miner_resume (TrackerMiner *miner
);
Asks the miner to resume processing. This needs to be called
as many times as tracker_miner_pause()
calls were done
previously. This function will return TRUE when the miner
is actually resumed.
tracker_miner_get_connection ()
TrackerSparqlConnection *
tracker_miner_get_connection (TrackerMiner *miner
);
Gets the TrackerSparqlConnection initialized by miner
Since: 0.10
Types and Values
TRACKER_MINER_DBUS_INTERFACE
#define TRACKER_MINER_DBUS_INTERFACE "org.freedesktop.Tracker1.Miner"
The name of the D-Bus interface to use for all data miners that inter-operate with Tracker.
Since: 0.8.
TRACKER_MINER_DBUS_NAME_PREFIX
#define TRACKER_MINER_DBUS_NAME_PREFIX "org.freedesktop.Tracker1.Miner."
D-Bus name prefix to use for all data miners. This allows custom
miners to be written using TRACKER_MINER_DBUS_NAME_PREFIX
+ "Files" for
example and would show up on D-Bus under
"org.freedesktop.Tracker1.Miner.Files".
Since: 0.8.
TRACKER_MINER_DBUS_PATH_PREFIX
#define TRACKER_MINER_DBUS_PATH_PREFIX "/org/freedesktop/Tracker1/Miner/"
D-Bus path prefix to use for all data miners. This allows custom
miners to be written using TRACKER_MINER_DBUS_PATH_PREFIX
+ "Files" for
example and would show up on D-Bus under
"/org/freedesktop/Tracker1/Miner/Files".
Since: 0.8.
TRACKER_MINER_ERROR_DOMAIN
#define TRACKER_MINER_ERROR_DOMAIN "TrackerMiner"
Used as the domain for any GErrors reported by TrackerMiner
objects.
Since: 0.8.
TRACKER_MINER_ERROR
#define TRACKER_MINER_ERROR tracker_miner_error_quark()
Returns the GQuark
used for GErrors and for TrackerMiner
implementations. This calls tracker_miner_error_quark()
.
Since: 0.8.
TrackerMinerClass
typedef struct { GObjectClass parent_class; /* signals */ void (* started) (TrackerMiner *miner); void (* stopped) (TrackerMiner *miner); void (* paused) (TrackerMiner *miner); void (* resumed) (TrackerMiner *miner); void (* progress) (TrackerMiner *miner, const gchar *status, gdouble progress, gint remaining_time); /* <Private> */ gpointer padding[10]; } TrackerMinerClass;
Virtual methods left to implement.
enum TrackerMinerError
Possible errors returned when calling TrackerMiner APIs or subclassed miners where the error is generic to all miners.
Members
No name was given when creating the miner. The name is crucial for D-Bus presence and a host of other things. |
||
The name trying to be used for the miner was not available, possibly because the miner is already running with the same name in another process. |
||
Given by miners when an API is used at the time the miner itself is paused and such actions should be avoided. |
||
The pause request has already been given by the same application with the same reason. Duplicate pause calls with the same reason by the same application can not be carried out. |
||
When pausing a miner, a cookie
(or |
Property Details
The “connection”
property
“connection” TrackerSparqlConnection *
The SPARQL connection to use. For compatibility reasons, if not set
at construct time, one shall be obtained through
tracker_sparql_connection_get()
.
Flags: Read / Write / Construct Only
Since: 2.0
The “progress”
property
“progress” gdouble
Miner progress.
Flags: Read / Write / Construct
Allowed values: [0,1]
Default value: 0
The “remaining-time”
property
“remaining-time” gint
Estimated remaining time to finish processing.
Flags: Read / Write / Construct
Allowed values: >= -1
Default value: -1
Signal Details
The “paused”
signal
void user_function (TrackerMiner *miner, gpointer user_data)
the ::paused signal is emitted whenever
there is any reason to pause, either
internal (through tracker_miner_pause()
) or
external (through DBus, see TrackerMinerManager).
Flags: Run Last
Since: 0.8
The “progress”
signal
void user_function (TrackerMiner *miner, gchar *status, gdouble progress, gint remaining_time, gpointer user_data)
the ::progress signal will be emitted by TrackerMiner implementations
to indicate progress about the data mining process. status
will
contain a translated string with the current miner status and progress
will indicate how much has been processed so far. remaining_time
will
give the number expected of seconds to finish processing, 0 if the
value cannot be estimated, and -1 if its not applicable.
Parameters
miner |
the TrackerMiner |
|
status |
miner status |
|
progress |
a gdouble indicating miner progress, from 0 to 1. |
|
remaining_time |
a gint indicating the reamaining processing time, in seconds. |
|
user_data |
user data set when the signal handler was connected. |
Flags: Run Last
Since: 0.12
The “resumed”
signal
void user_function (TrackerMiner *miner, gpointer user_data)
the ::resumed signal is emitted whenever
all reasons to pause have disappeared, see
tracker_miner_resume()
and TrackerMinerManager.
Flags: Run Last
Since: 0.8
The “started”
signal
void user_function (TrackerMiner *miner, gpointer user_data)
the ::started signal is emitted in the miner
right after it has been started through
tracker_miner_start()
.
Flags: Run Last
Since: 0.8
The “stopped”
signal
void user_function (TrackerMiner *miner, gpointer user_data)
the ::stopped signal is emitted in the miner
right after it has been stopped through
tracker_miner_stop()
.
Flags: Run Last
Since: 0.8