| Top |  |  |  |  | 
| #define | AS_TYPE_STORE | 
| struct | AsStoreClass | 
| enum | AsStoreLoadFlags | 
| enum | AsStoreAddFlags | 
| enum | AsStoreWatchFlags | 
| enum | AsStoreError | 
| #define | AS_STORE_ERROR | 
| AsStore | 
This store contains both an array of AsApp's but also a pair of hashes to quickly retrieve an application from the ID or package name.
Applications can also be removed, and the whole store can be loaded and saved to a compressed XML file.
See also: AsApp
guint
as_store_get_size (AsStore *store);
Gets the size of the store after deduplication and prioritization has taken place.
Since: 0.1.0
gboolean as_store_from_file (AsStore *store,GFile *file,const gchar *icon_root,GCancellable *cancellable,GError **error);
Parses an AppStream XML or DEP-11 YAML file and adds any valid applications to the store.
If the root node does not have a 'origin' attribute, then the method
as_store_set_origin() should be called *before* this function if cached
icons are required.
Since: 0.1.0
gboolean as_store_from_bytes (AsStore *store,GBytes *bytes,GCancellable *cancellable,GError **error);
Parses an appstream store presented as an archive. This is typically a .cab file containing firmware files.
Since: 0.5.2
gboolean as_store_from_xml (AsStore *store,const gchar *data,const gchar *icon_root,GError **error);
Parses AppStream XML file and adds any valid applications to the store.
If the root node does not have a 'origin' attribute, then the method
as_store_set_origin() should be called *before* this function if cached
icons are required.
Since: 0.1.1
gboolean as_store_load (AsStore *store,AsStoreLoadFlags flags,GCancellable *cancellable,GError **error);
Loads the store from the default locations.
Since: 0.1.2
gboolean as_store_load_path (AsStore *store,const gchar *path,GCancellable *cancellable,GError **error);
Loads the store from a specific path.
Since: 0.2.2
void
as_store_remove_all (AsStore *store);
Removes all applications from the store.
Since: 0.2.5
GPtrArray *
as_store_get_apps (AsStore *store);
Gets an array of all the valid applications in the store.
Since: 0.1.0
GPtrArray * as_store_get_apps_by_id (AsStore *store,const gchar *id);
Gets an array of all the applications that match a specific ID, ignoring the prefix type.
Since: 0.5.12
GPtrArray * as_store_get_apps_by_metadata (AsStore *store,const gchar *key,const gchar *value);
Gets an array of all the applications that match a specific metadata element.
Since: 0.1.4
AsApp * as_store_get_app_by_id (AsStore *store,const gchar *id);
Finds an application in the store by ID.
Since: 0.1.0
AsApp * as_store_get_app_by_id_ignore_prefix (AsStore *store,const gchar *id);
Finds an application in the store ignoring the prefix type.
Since: 0.5.12
AsApp * as_store_get_app_by_id_with_fallbacks (AsStore *store,const gchar *id);
Finds an application in the store by either by the current desktop ID or a desktop ID that it has used previously. This allows upstream software to change their ID (e.g. from cheese.desktop to org.gnome.Cheese.desktop) without us duplicating entries in the software center.
Since: 0.4.1
AsApp * as_store_get_app_by_pkgname (AsStore *store,const gchar *pkgname);
Finds an application in the store by package name.
Since: 0.1.0
AsApp * as_store_get_app_by_pkgnames (AsStore *store,gchar **pkgnames);
Finds an application in the store by any of the possible package names.
Since: 0.4.1
AsApp * as_store_get_app_by_provide (AsStore *store,AsProvideKind kind,const gchar *value);
Finds an application in the store by something that it provides.
| store | a AsStore instance. | |
| kind | the AsProvideKind | |
| value | the provide value, e.g. "com.hughski.ColorHug2.firmware" | 
Since: 0.5.0
void as_store_add_app (AsStore *store,AsApp *app);
Adds an application to the store. If a lower priority application has already been added then this new application will replace it.
Additionally only applications where the kind is known will be added.
Since: 0.1.0
void as_store_remove_app (AsStore *store,AsApp *app);
Removes an application from the store if it exists.
Since: 0.1.0
void as_store_remove_app_by_id (AsStore *store,const gchar *id);
Removes an application from the store if it exists.
Since: 0.3.0
void
as_store_remove_apps_with_veto (AsStore *store);
Removes any applications from the store if they have any vetos.
Since: 0.5.13
GString * as_store_to_xml (AsStore *store,AsNodeToXmlFlags flags);
Outputs an XML representation of all the applications in the store.
Since: 0.1.0
gboolean as_store_to_file (AsStore *store,GFile *file,AsNodeToXmlFlags flags,GCancellable *cancellable,GError **error);
Outputs an optionally compressed XML file of all the applications in the store.
| store | a AsStore instance. | |
| file | file | |
| flags | the AsNodeToXmlFlags, e.g.  | |
| cancellable | A GCancellable, or  | |
| error | 
Since: 0.1.0
gboolean as_store_convert_icons (AsStore *store,AsIconKind kind,GError **error);
Converts all the icons in the store to a specific kind.
Since: 0.3.1
const gchar *
as_store_get_origin (AsStore *store);
Gets the metadata origin, which is used to locate icons.
Since: 0.1.1
void as_store_set_origin (AsStore *store,const gchar *origin);
Sets the metadata origin, which is used to locate icons.
Since: 0.1.1
const gchar *
as_store_get_builder_id (AsStore *store);
Gets the metadata builder identifier, which is used to work out if old metadata is compatible with this builder.
Since: 0.2.5
void as_store_set_builder_id (AsStore *store,const gchar *builder_id);
Sets the metadata builder identifier, which is used to work out if old metadata can be used.
Since: 0.2.5
const gchar *
as_store_get_destdir (AsStore *store);
Gets the destdir, which is used to prefix usr.
Since: 0.2.4
void as_store_set_destdir (AsStore *store,const gchar *destdir);
Sets the destdir, which is used to prefix usr.
Since: 0.2.4
gdouble
as_store_get_api_version (AsStore *store);
Gets the AppStream API version.
Since: 0.1.1
void as_store_set_api_version (AsStore *store,gdouble api_version);
Sets the AppStream API version.
Since: 0.1.1
AsStoreAddFlags
as_store_get_add_flags (AsStore *store);
Gets the flags used for adding applications to the store.
Since: 0.2.2
void as_store_set_add_flags (AsStore *store,AsStoreAddFlags add_flags);
Sets the flags used when adding applications to the store.
NOTE: Using AS_STORE_ADD_FLAG_PREFER_LOCAL may be a privacy risk depending on
your level of paranoia, and should not be used by default.
Since: 0.2.2
AsStoreWatchFlags
as_store_get_watch_flags (AsStore *store);
Gets the flags used for adding files to the store.
Since: 0.4.2
void as_store_set_watch_flags (AsStore *store,AsStoreWatchFlags watch_flags);
Sets the flags used when adding files to the store.
| store | a AsStore instance. | |
| watch_flags | the AsStoreWatchFlags, e.g.  | 
Since: 0.4.2
GPtrArray * as_store_validate (AsStore *store,AsAppValidateFlags flags,GError **error);
Validates infomation in the store for data applicable to the defined metadata version.
| store | a AsStore instance. | |
| flags | the AsAppValidateFlags to use, e.g.  | |
| error | 
Since: 0.2.4
void as_store_add_metadata_index (AsStore *store,const gchar *key);
Adds a metadata index key.
NOTE: if applications are removed *all* the indexes will be invalid and will have to be re-added.
Since: 0.3.0
void as_store_add_filter (AsStore *store,AsAppKind kind);
Adds a filter to the store so that only components of this type are loaded into the store. This may be useful if the client is only interested in certain types of component, or not interested in loading components it cannot process.
If no filter is set then all types of components are loaded.
Since: 0.3.5
void as_store_remove_filter (AsStore *store,AsAppKind kind);
Removed a filter from the store so that components of this type are no longer loaded into the store. This may be useful if the client is only interested in certain types of component.
If all filters are removed then all types of components are loaded.
Since: 0.3.5
struct AsStoreClass {
	GObjectClass		parent_class;
	void			(*changed) (AsStore *store);
};
The flags to use when loading the store.
| No extra flags to use | ||
| The system app-info AppStream data | ||
| The per-user app-info AppStream data | ||
| The ubuntu-specific app-install data (obsolete) | ||
| The installed AppData files | ||
| The installed desktop files | ||
| Add vetoed applications | ||
| Add flatpak user applications | ||
| Add flatpak system applications | ||
| Ignore invalid files | 
“changed” signalvoid user_function (AsStore *device, gpointer user_data)
The ::changed signal is emitted when components have been added or removed from the store.
| device | the AsStore instance that emitted the signal | |
| user_data | user data set when the signal handler was connected. | 
Flags: Run Last
Since: 0.1.2