|  |  |  | GNOME Dictionary Library Reference Manual |  | 
|---|---|---|---|---|
#define GDICT_TYPE_DATABASE #define GDICT_TYPE_STRATEGY #define GDICT_TYPE_MATCH #define GDICT_TYPE_DEFINITION GdictDatabase; GdictStrategy; GdictMatch; GdictDefinition; GdictContext; GdictContextIface; #define GDICT_CONTEXT_ERROR enum GdictContextError; GQuark gdict_context_error_quark (void); GdictDatabase* gdict_database_ref (GdictDatabase *db); void gdict_database_unref (GdictDatabase *db); const gchar* gdict_database_get_name (GdictDatabase *db); const gchar* gdict_database_get_full_name (GdictDatabase *db); GType gdict_strategy_get_type (void); GdictStrategy* gdict_strategy_ref (GdictStrategy *strat); void gdict_strategy_unref (GdictStrategy *strat); const gchar* gdict_strategy_get_name (GdictStrategy *strat); const gchar* gdict_strategy_get_description (GdictStrategy *strat); GType gdict_match_get_type (void); GdictMatch* gdict_match_ref (GdictMatch *match); void gdict_match_unref (GdictMatch *match); const gchar* gdict_match_get_word (GdictMatch *match); const gchar* gdict_match_get_database (GdictMatch *match); GType gdict_definition_get_type (void); GdictDefinition* gdict_definition_ref (GdictDefinition *def); void gdict_definition_unref (GdictDefinition *def); gint gdict_definition_get_total (GdictDefinition *def); const gchar* gdict_definition_get_word (GdictDefinition *def); const gchar* gdict_definition_get_database (GdictDefinition *def); const gchar* gdict_definition_get_text (GdictDefinition *def); GType gdict_context_get_type (void); void gdict_context_set_local_only (GdictContext *context, gboolean local_only); gboolean gdict_context_get_local_only (GdictContext *context); gboolean gdict_context_lookup_databases (GdictContext *context, GError **error); gboolean gdict_context_lookup_strategies (GdictContext *context, GError **error); gboolean gdict_context_match_word (GdictContext *context, const gchar *database, const gchar *strategy, const gchar *word, GError **error); gboolean gdict_context_define_word (GdictContext *context, const gchar *database, const gchar *word, GError **error);
GdictContext is an abstract interface used to uniformly access dictionary transport objects. Each implementation of GdictContext must provide functions for accessing the list of databases available on a dictionary source and the available matching strategies; a function for retrieving all words matching to a string, inside one (or more) of those databases and using one of those strategies; a function for querying one (or more) of those databases for a definition of a word.
Implementations of the GdictContext interface should query their dictionary sources asynchronously; methods of the GdictContext interface should return immediately, and each time a new database, strategy, match or definition is found, a signal should be fired by those implementations.
typedef struct _GdictDatabase GdictDatabase;
A GdictDatabase represents a database inside a dictionary source.
typedef struct _GdictStrategy GdictStrategy;
A GdictStrategy represents a matching strategy inside a dictionary source.
typedef struct _GdictMatch GdictMatch;
A GdictMatch represents a single match for a word inside a dictionary source.
typedef struct _GdictDefinition GdictDefinition;
A GdictDefinition represents a single definition for a word inside a dictionary source.
typedef struct _GdictContext GdictContext;
The GdictClientContext struct contains private data only.
typedef struct {
  GTypeInterface base_iface;
  
  /* methods, not signals */
  gboolean (*get_databases)     (GdictContext  *context,
  			         GError       **error);
  gboolean (*get_strategies)    (GdictContext  *context,
  			         GError       **error);
  gboolean (*match_word)        (GdictContext  *context,
  			         const gchar   *database,
  			         const gchar   *strategy,
  			         const gchar   *word,
  			         GError       **error);
  gboolean (*define_word)       (GdictContext  *context,
  			         const gchar   *database,
  			         const gchar   *word,
  			         GError       **error);  
  
  /* signals */
  void (*lookup_start)     (GdictContext    *context);
  void (*lookup_end)       (GdictContext    *context);
  
  void (*database_found)   (GdictContext    *context,
  			    GdictDatabase   *database);
  void (*strategy_found)   (GdictContext    *context,
  			    GdictStrategy   *strategy);
  void (*match_found)      (GdictContext    *context,
  			    GdictMatch      *match);
  void (*definition_found) (GdictContext    *context,
  			    GdictDefinition *definition);
  
  /* fired each time there's an error; the GError is owned
   * by the context, and should never be modified or freed
   */
  void (*error)            (GdictContext    *context,
  			    const GError    *error);
  /* padding for future expansion */
  void (*_gdict_context_1) (void);
  void (*_gdict_context_2) (void);
  void (*_gdict_context_3) (void);
  void (*_gdict_context_4) (void);
} GdictContextIface;
typedef enum {
  GDICT_CONTEXT_ERROR_PARSE,
  GDICT_CONTEXT_ERROR_NOT_IMPLEMENTED,
  GDICT_CONTEXT_ERROR_INVALID_DATABASE,
  GDICT_CONTEXT_ERROR_INVALID_STRATEGY,
  GDICT_CONTEXT_ERROR_INVALID_COMMAND,
  GDICT_CONTEXT_ERROR_NO_MATCH,
  GDICT_CONTEXT_ERROR_NO_DATABASES,
  GDICT_CONTEXT_ERROR_NO_STRATEGIES
} GdictContextError;
These identify the various errors that can occur while calling GdictContext functions. Implementations should use these general error codes, but might provide other errors.
GdictDatabase* gdict_database_ref (GdictDatabase *db);
Increases the reference count of db by one.
| db: | a GdictDatabase | 
| Returns : | dbwith its reference count increased | 
Since 1.0
void gdict_database_unref (GdictDatabase *db);
Decreases the reference count of db by one.  If the reference count reaches
zero, db is destroyed.
| db: | a GdictDatabase | 
Since 1.0
const gchar* gdict_database_get_name (GdictDatabase *db);
Gets the short name of the database, to be used with functions like
gdict_context_match_word() or gdict_context_define_word().
| db: | a GdictDatabase | 
| Returns : | the short name of the database. The string is owned by the GdictDatabase object, and should never be modified or freed. | 
Since 1.0
const gchar* gdict_database_get_full_name (GdictDatabase *db);
Gets the full name of the database, suitable for display.
| db: | a GdictDatabase | 
| Returns : | the full name of the database. The string is owned by the GdictDatabase object, and should never be modified or freed. | 
Since 1.0
GdictStrategy* gdict_strategy_ref (GdictStrategy *strat);
Increases the reference count of strat by one.
| strat: | a GdictStrategy | 
| Returns : | the GdictStrategy object with its reference count increased | 
Since 1.0
void gdict_strategy_unref (GdictStrategy *strat);
Decreases the reference count of strat by one.  If the reference count
reaches zero, the GdictStrategy object is freed.
| strat: | a GdictStrategy | 
Since 1.0
const gchar* gdict_strategy_get_name (GdictStrategy *strat);
FIXME
| strat: | a GdictStrategy | 
| Returns : | FIXME | 
Since 1.0
const gchar* gdict_strategy_get_description (GdictStrategy *strat);
FIXME
| strat: | a GdictStrategy | 
| Returns : | FIXME | 
Since 1.0
GdictMatch* gdict_match_ref (GdictMatch *match);
FIXME
| match: | a GdictMatch | 
| Returns : | FIXME | 
Since 1.0
void gdict_match_unref (GdictMatch *match);
FIXME
| match: | a GdictMatch | 
Since 1.0
const gchar* gdict_match_get_word (GdictMatch *match);
FIXME
| match: | a GdictMatch | 
| Returns : | FIXME | 
Since 1.0
const gchar* gdict_match_get_database (GdictMatch *match);
FIXME
| match: | a GdictMatch | 
| Returns : | FIXME | 
Since 1.0
GdictDefinition* gdict_definition_ref (GdictDefinition *def);
Increases the reference count of def by one.
| def: | a GdictDefinition | 
| Returns : | the GdictDefinition object with its reference count increased. | 
Since 1.0
void gdict_definition_unref (GdictDefinition *def);
Decreases the reference count of def by one.  If the reference count
reaches zero, the GdictDefinition object is freed.
| def: | a GdictDefinition | 
Since 1.0
gint gdict_definition_get_total (GdictDefinition *def);
Retrieves the total number of definitions that were found on a dictionary.
| def: | a GdictDefinition | 
| Returns : | the number of definitions. | 
Since 1.0
const gchar* gdict_definition_get_word (GdictDefinition *def);
Retrieves the word used by the dictionary database to store the definition.
| def: | a GdictDefinition | 
| Returns : | a word. The returned string is owned by the GdictDefinition object and should not be modified or freed. | 
Since 1.0
const gchar* gdict_definition_get_database (GdictDefinition *def);
Retrieves the full name of the dictionary database where the definition is stored.
| def: | a GdictDefinition | 
| Returns : | the full name of a database. The returned string is owned by the GdictDefinition object and should not be modified or freed. | 
Since 1.0
const gchar* gdict_definition_get_text (GdictDefinition *def);
Retrieves the text of the definition.
| def: | a GdictDefinition | 
| Returns : | the text of the definition. The returned string is owned by the GdictDefinition object, and should not be modified or freed. | 
Since 1.0
void gdict_context_set_local_only (GdictContext *context, gboolean local_only);
Sets whether only local resources will be used when querying for databases, strategies, matches or definitions.
| context: | a GdictContext | 
| local_only: | TRUEif only local resources will be used | 
Since 1.0
gboolean gdict_context_get_local_only (GdictContext *context);
Gets whether only local resources will be used when querying.
| context: | a GdictContext | 
| Returns : | TRUEif only local resources will be used. | 
Since 1.0
gboolean gdict_context_lookup_databases (GdictContext *context, GError **error);
Query context for the list of databases available.  Each time a
database is found, the "database-found" signal is fired.
| context: | a GdictContext | 
| error: | return location for a GError, or NULL | 
| Returns : | TRUEif the query was successfully started. | 
Since 1.0
gboolean gdict_context_lookup_strategies (GdictContext *context, GError **error);
Query context for the list of matching strategies available.  Each
time a new strategy is found, the "strategy-found" signal is fired.
| context: | a GdictContext | 
| error: | return location for a GError, or NULL | 
| Returns : | TRUEif the query was successfully started. | 
Since 1.0
gboolean gdict_context_match_word (GdictContext *context, const gchar *database, const gchar *strategy, const gchar *word, GError **error);
Query context for a list of word matching word inside database,
using strategy as a matching strategy.  Each time a matching word
is found, the "match-found" signal is fired.
| context: | a GdictContext | 
| database: | a database name to search into, or NULLfor the
   default database | 
| strategy: | a strategy name to use for matching, or NULLfor
   the default strategy | 
| word: | the word to match | 
| error: | return location for a GError, or NULL | 
| Returns : | TRUEif the query was successfully started. | 
Since 1.0
gboolean gdict_context_define_word (GdictContext *context, const gchar *database, const gchar *word, GError **error);
Query context for a list of definitions of word inside database.  Each
time a new definition is found, the "definition-found" signal is fired.
| context: | a GdictContext | 
| database: | a database name to search into, or NULLfor the
   default database | 
| word: | the word to search | 
| error: | return location for a GError, or NULL | 
| Returns : | TRUEif the query was successfully sent. | 
Since 1.0