|  |  |  | libjana Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Prerequisites | Signals | ||||
                    JanaStore;
void                jana_store_open                     (JanaStore *self);
JanaComponent *     jana_store_get_component            (JanaStore *self,
                                                         const gchar *uid);
JanaStoreView *     jana_store_get_view                 (JanaStore *self);
void                jana_store_add_component            (JanaStore *self,
                                                         JanaComponent *comp);
void                jana_store_modify_component         (JanaStore *self,
                                                         JanaComponent *comp);
void                jana_store_remove_component         (JanaStore *self,
                                                         JanaComponent *comp);
JanaStore is the interface for a component storage. A component store has functions to add, modify and remove components, as well as query the storage itself and retrieve specific components.
void jana_store_open (JanaStore *self);
Opens the store. Prior to opening a store, any JanaStoreView on the store will not receive any components and retrieval of components will fail. This is an asynchronous call. When the store is open and ready, the ::opened signal will be fired. Implementations of this function should return as immediately as possible and do any lengthy processing in idle time, or in a thread.
| 
 | A JanaStore | 
JanaComponent * jana_store_get_component (JanaStore *self, const gchar *uid);
Retrieves a particular JanaComponent using its unique identifier.
| 
 | A JanaStore | 
| 
 | The UID of a JanaComponent | 
| Returns : | The JanaComponent requested, or NULLif it does not exist in this 
store. | 
JanaStoreView * jana_store_get_view (JanaStore *self);
Retrieves a JanaStoreView on this JanaStore.
| 
 | A JanaStore | 
| Returns : | A new JanaStoreView. | 
void jana_store_add_component (JanaStore *self, JanaComponent *comp);
Adds a component to the store.
| 
 | A JanaStore | 
| 
 | The JanaComponent | 
void jana_store_modify_component (JanaStore *self, JanaComponent *comp);
Updates the stored component with any changes made. Does nothing if the component does not exist in the store.
| 
 | A JanaStore | 
| 
 | The JanaComponent | 
void jana_store_remove_component (JanaStore *self, JanaComponent *comp);
Removes a component from the store. Does nothing if the component does not exist in the store.
| 
 | A JanaStore | 
| 
 | The JanaComponent | 
"opened" signalvoid user_function (JanaStore *store, gpointer user_data) : Run Last
The ::opened signal is emitted after jana_store_open()
is called and the store is ready to be queried.
| 
 | the store that received the signal | 
| 
 | user data set when the signal handler was connected. |