|  |  |  | Anjuta Developers Reference Manual |  | 
|---|---|---|---|---|
#include <libanjuta/interfaces/ianjuta-symbol-manager.h> #define IANJUTA_SYMBOL_MANAGER_ERROR IAnjutaSymbolManager; IAnjutaSymbolManagerIface; GQuark ianjuta_symbol_manager_error_quark (void); IAnjutaIterable* ianjuta_symbol_manager_get_class_parents (IAnjutaSymbolManager *obj, const IAnjutaSymbol *symbol, IAnjutaSymbolField info_fields, GError **err); IAnjutaIterable* ianjuta_symbol_manager_get_members (IAnjutaSymbolManager *obj, const IAnjutaSymbol *symbol, IAnjutaSymbolField info_fields, gboolean global_search, GError **err); IAnjutaIterable* ianjuta_symbol_manager_get_parent_scope (IAnjutaSymbolManager *obj, const IAnjutaSymbol *symbol, const gchar *filename, IAnjutaSymbolField info_fields, GError **err); IAnjutaIterable* ianjuta_symbol_manager_get_scope (IAnjutaSymbolManager *obj, const gchar *filename, gulong line, IAnjutaSymbolField info_fields, GError **err); IAnjutaSymbol* ianjuta_symbol_manager_get_symbol_by_id (IAnjutaSymbolManager *obj, gint symbol_id, IAnjutaSymbolField info_fields, GError **err); IAnjutaIterable* ianjuta_symbol_manager_get_symbol_more_info (IAnjutaSymbolManager *obj, const IAnjutaSymbol *symbol, IAnjutaSymbolField info_fields, GError **err); IAnjutaIterable* ianjuta_symbol_manager_search (IAnjutaSymbolManager *obj, IAnjutaSymbolType match_types, gboolean include_types, IAnjutaSymbolField info_fields, const gchar *match_name, gboolean partial_name_match, gboolean global_symbols_search, gboolean global_tags_search, gint results_limit, gint results_offset, GError **err);
#define IANJUTA_SYMBOL_MANAGER_ERROR ianjuta_symbol_manager_error_quark()
typedef struct {
	GTypeInterface g_iface;
	
	IAnjutaIterable* (*get_class_parents) (IAnjutaSymbolManager *obj, const IAnjutaSymbol *symbol,  IAnjutaSymbolField info_fields, GError **err);
	IAnjutaIterable* (*get_members) (IAnjutaSymbolManager *obj, const IAnjutaSymbol *symbol,  IAnjutaSymbolField info_fields,  gboolean global_search, GError **err);
	IAnjutaIterable* (*get_parent_scope) (IAnjutaSymbolManager *obj, const IAnjutaSymbol *symbol,  const gchar *filename,  IAnjutaSymbolField info_fields, GError **err);
	IAnjutaIterable* (*get_scope) (IAnjutaSymbolManager *obj, const gchar* filename,  gulong line,  IAnjutaSymbolField info_fields, GError **err);
	IAnjutaSymbol* (*get_symbol_by_id) (IAnjutaSymbolManager *obj, gint symbol_id,  IAnjutaSymbolField info_fields, GError **err);
	IAnjutaIterable* (*get_symbol_more_info) (IAnjutaSymbolManager *obj, const IAnjutaSymbol *symbol,  IAnjutaSymbolField info_fields, GError **err);
	IAnjutaIterable* (*search) (IAnjutaSymbolManager *obj, IAnjutaSymbolType match_types,  gboolean include_types,  IAnjutaSymbolField info_fields,  const gchar *match_name,  gboolean partial_name_match,  gboolean global_symbols_search,  gboolean global_tags_search,  gint results_limit,  gint results_offset, GError **err);
} IAnjutaSymbolManagerIface;
IAnjutaIterable* ianjuta_symbol_manager_get_class_parents (IAnjutaSymbolManager *obj, const IAnjutaSymbol *symbol, IAnjutaSymbolField info_fields, GError **err);
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| Returns : | 
IAnjutaIterable* ianjuta_symbol_manager_get_members (IAnjutaSymbolManager *obj, const IAnjutaSymbol *symbol, IAnjutaSymbolField info_fields, gboolean global_search, GError **err);
Database query. The returned IAnjutaIterable object must be unrefed after use.
| 
 | Self | 
| 
 | |
| 
 | Kind of infos you would like to have available on the resulting Symbols. | 
| 
 | fixme | 
| 
 | Error propagation and reporting. | 
| Returns : | 
IAnjutaIterable* ianjuta_symbol_manager_get_parent_scope (IAnjutaSymbolManager *obj, const IAnjutaSymbol *symbol, const gchar *filename, IAnjutaSymbolField info_fields, GError **err);
Find the parent scope given a symbol
The returned IAnjutaIterable object should contain just one element if the 
query is successful, 
no element or NULL is returned if function went wrong.	
The returned IAnjutaIterable object must be unrefed after use.
| 
 | Self | 
| 
 | Symbol which you want to know the parent scope of. | 
| 
 | Can be NULL. Full path filename where to search for the parent scope symbol. | 
| 
 | Kind of infos you would like to have available on the resulting Symbols. | 
| 
 | Error propagation and reporting. | 
| Returns : | 
IAnjutaIterable* ianjuta_symbol_manager_get_scope (IAnjutaSymbolManager *obj, const gchar *filename, gulong line, IAnjutaSymbolField info_fields, GError **err);
Get the scope specified by the line of the file.
Returns Iterator should contain just one element if the query is successful, no element or NULL is returned if function went wrong.
| 
 | Self | 
| 
 | full path of the file. lineline offilenamein which symbol exist. | 
| 
 | |
| 
 | Kind of infos you would like to have available on the resulting Symbols. | 
| 
 | Error propagation and reporting. | 
| Returns : | an iterator | 
IAnjutaSymbol* ianjuta_symbol_manager_get_symbol_by_id (IAnjutaSymbolManager *obj, gint symbol_id, IAnjutaSymbolField info_fields, GError **err);
A symbol is identified by an unique id. If you have its id you can also have its object IAnjutaSymbol.
| 
 | Self symbol_idunique id of the symbol you want to know about. | 
| 
 | |
| 
 | Kind of infos you would like to have available on the resulting Symbols. returnNULL on error. | 
| 
 | |
| Returns : | 
IAnjutaIterable* ianjuta_symbol_manager_get_symbol_more_info (IAnjutaSymbolManager *obj, const IAnjutaSymbol *symbol, IAnjutaSymbolField info_fields, GError **err);
While at first sight this function may seem as useless, in a deeper inspection you can see that you can achieve speed improvements for example avoiding to pass many info_fields requests to a search query, which itself could require complicated joins between engine tables, slowing down the thing. It's up to you to see which method is more performant.
| 
 | Self symbolsymbol of which you want to know more infos about. | 
| 
 | |
| 
 | Kind of infos you would like to have available on the resulting Symbols. | 
| 
 | Error propagation and reporting. | 
| Returns : | 
IAnjutaIterable* ianjuta_symbol_manager_search (IAnjutaSymbolManager *obj, IAnjutaSymbolType match_types, gboolean include_types, IAnjutaSymbolField info_fields, const gchar *match_name, gboolean partial_name_match, gboolean global_symbols_search, gboolean global_tags_search, gint results_limit, gint results_offset, GError **err);
Database query. The returned IAnjutaIterable object must be unrefed after use.
| 
 | Self | 
| 
 | If passed IANJUTA_TYPE_MAX the function will not perfom any filter. | 
| 
 | Should the result contain or exclude the match_types? TRUE to include them, FALSE to exclude. For example use may want all symbols but classes. | 
| 
 | Kind of infos you would like to have available on the resulting Symbols. | 
| 
 | fixme | 
| 
 | if TRUE it will search for match_name%, it FALSE for the exact
					string match_name. | 
| 
 | if TRUE it will search only for public/extern functions. If FALSE it will search also for static/private functions. | 
| 
 | If TRUE it'll search only for system tags, using pkg-config to retrieve installed packages infos. If FALSE only current project's symbols will be searched. | 
| 
 | Limit results to an upper bound. -1 If you don't want to use this par. | 
| 
 | Skip results_offset results. -1 If you don't want to use this par. results_limitLimit results to an upper bound. -1 If you don't want to use this par.results_offsetSkip results_offset results. -1 If you don't want to use this par. | 
| 
 | Error propagation and reporting. | 
| Returns : |