All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros
kanzi::DataSource Class Referenceabstract

DataSource is the base class for data sources. More...

#include <kanzi/data/data_source.hpp>

Inheritance diagram for kanzi::DataSource:
kanzi::Resource kanzi::Object

Classes

struct  ModifiedSubscription
 Subscription entry. More...
 

Public Types

typedef function< void()> ModifiedFunction
 Callback function type for change subscriptions. More...
 
typedef shared_ptr< void > ModifiedSubscriptionToken
 Token type that can be used to identify the change subscription. More...
 

Public Member Functions

virtual DataObjectSharedPtr getRoot ()=0
 Retrieves the root object of the underlying data tree. More...
 
ModifiedSubscriptionToken addModifiedNotificationHandler (ModifiedFunction callback)
 Adds message handler, that can be used to monitor when the contents of the data source are modified. More...
 
void removeModifiedNotificationHandler (ModifiedSubscriptionToken token)
 Removes and stops monitoring the contents of the data source for given subscription. More...
 
virtual void loadFromKZB (const KzuResourceLoaderThreadContext *threadContext, KzcInputStream *inputStream, const KzuBinaryFileInfo *file) KZ_OVERRIDE
 Function for loading the resource from .KZB. More...
 
- Public Member Functions inherited from kanzi::Resource
KzcMemoryManagergetMemoryManager () const
 
 Resource (Domain *domain, string_view name)
 
virtual ~Resource ()
 
virtual void finishLoadingOverride (const KzuResourceLoaderThreadContext *threadContext)
 Function for finishing the loading of the resource. More...
 
virtual void unloadOverride ()
 Unload function for resource. More...
 
virtual kzUint getCPUMemoryUsage () const
 Function for getting the memory usage of a resource. More...
 
void setKZB (const KzuBinaryDirectory *binaryDirectory, kzString path)
 
void setLoaded ()
 
kzString getName () const
 Accessor. More...
 
void load ()
 
void unload ()
 
bool isLoaded () const
 
void kzuResourceLoad_private (const KzuResourceLoaderThreadContext *threadContext)
 Private function for kzuResourceLoad() with specified thread context. More...
 
void kzuResourceFinishLoading_private (const KzuResourceLoaderThreadContext *threadContext)
 Private function for finishing the loading of the resource. More...
 
KzuResourceLoadingStrategy getLoadingStrategy () const
 
void setLoadingStrategy (KzuResourceLoadingStrategy loadingStrategy)
 
bool getKeepAlive () const
 Tells if the resource has keep alive flag set. More...
 
void setKeepAlive (bool keepAlive)
 Sets the keep alive flag. More...
 
- Public Member Functions inherited from kanzi::Object
 Object (Domain *domain)
 
virtual ~Object ()
 
DomaingetDomain () const
 Returns the domain the object belongs to. More...
 
KzuPropertyManager * getPropertyManager () const
 Returns the property manager of the object. More...
 
KzuTaskSchedulergetTaskScheduler () const
 Returns the task scheduler of the object. More...
 
KzuMessageDispatchergetMessageDispatcher () const
 Returns the message dispatcher of the object. More...
 
ResourceManagergetResourceManager () const
 Returns the resource manager of the object. More...
 
virtual const MetaclassgetDynamicMetaclass () const
 Returns the metaclass of the dynamic type of the object. More...
 
bool isTypeOf (const Metaclass *objectType) const
 Determines if the type of this object is the given type or derived from it. More...
 
template<typename DataType >
void setProperty (const PropertyType< DataType > &propertyType, typename PropertyType< DataType >::DataType value)
 Sets the local value of a property. More...
 
void setProperty (const PropertyType< ResourceID > &propertyType, ResourceSharedPtr value)
 Sets the local value of a resource id property with a resource pointer. More...
 
template<typename DataType >
DataType getProperty (const PropertyType< DataType > &propertyType) const
 Returns the current value of a property. More...
 
template<typename DataType >
bool getProperty (const PropertyType< DataType > &propertyType, typename PropertyType< DataType >::DataType &value) const
 Evaluates the property value in the same way as the overload above but does not default to the value in property metadata if there are no inputs to the property value. More...
 
template<typename DataType >
void setAbstractProperty (AbstractPropertyType abstractPropertyType, typename PropertyType< DataType >::DataType value)
 
void setAbstractProperty (AbstractPropertyType abstractPropertyType, ResourceSharedPtr value)
 
template<typename DataType >
DataType getAbstractProperty (AbstractPropertyType abstractPropertyType) const
 
template<typename DataType >
bool getAbstractProperty (AbstractPropertyType abstractPropertyType, typename PropertyType< DataType >::DataType &value) const
 
bool hasValue (AbstractPropertyType propertyType) const
 Evaluates whether there are any inputs into the property value. More...
 
bool hasLocalValue (AbstractPropertyType propertyType) const
 Evaluates whether there is a local value set for the property. More...
 
void removeLocalValue (AbstractPropertyType propertyType)
 Removes the local value associated with the property. More...
 
void copyLocalValues (const Object &other)
 Copies all local values from another object. More...
 
virtual void onPropertyChanged (AbstractPropertyType propertyType, KzuPropertyNotificationReason reason)
 Virtual function to handle property change notifications. More...
 
AppliedStyleEntryapplyObjectStyle (kanzi::StyleSharedPtr style)
 Applies a style to an object. More...
 
void unapplyObjectStyle (AppliedStyleEntry *appliedStyleEntry)
 
void applyObjectStyles ()
 Apply all styles for an object node. More...
 
void unapplyObjectStyles ()
 Unapplies and removes all applied styles. More...
 

Static Public Member Functions

static
PropertyTypeEditorInfoSharedPtr 
makeEditorInfo ()
 
- Static Public Member Functions inherited from kanzi::Object
static const MetaclassgetStaticMetaclass ()
 Returns the metaclass of Object class. More...
 
static
PropertyTypeEditorInfoSharedPtr 
makeEditorInfo ()
 Default implementation that returns empty editor info. More...
 

Protected Types

typedef shared_ptr
< ModifiedSubscription
ModifiedSubscriptionSharedPtr
 
typedef vector
< ModifiedSubscriptionSharedPtr
ModifiedSubscriptionContainer
 
- Protected Types inherited from kanzi::Object
typedef vector
< AppliedStyleEntry * > 
AppliedStyleContainer
 Applied style container. More...
 

Protected Member Functions

 DataSource (Domain *domain, string_view name)
 Standard constructor. More...
 
void notifyModified ()
 Notifies all subscriptions that this data source has been modified. More...
 
- Protected Member Functions inherited from kanzi::Resource
KzuResourceLoadState getLoadState ()
 Access. More...
 
- Protected Member Functions inherited from kanzi::Object
void initialize ()
 
void onCopy (const Object &other)
 

Protected Attributes

ModifiedSubscriptionContainer m_subscriptions
 
- Protected Attributes inherited from kanzi::Object
AppliedStyleContainer m_appliedStyles
 Listing of applied styles applied to this object. More...
 

Detailed Description

DataSource is the base class for data sources.

The objective is to provide a resource type that can be used to feed data from external source to UI.

The data source can be assigned to node by using Node.DataContext property. It should point the chosen data resource, which will define data for the node and it's subtree. Once the data is set through the property, it is then possible to utilize bindings to reference the data.

Data context property value should be either: 1) Uri that defines the resource 2) Resource id that defines the resource in resource dictionary 3) Path that allows to navigate further within the current data context (for example: $.car.cluster)

Standard data binding can be used to bind the data objects to the UI. The format of the binding is: {DataContext.path.to.data}. For example: {DataContext.car.cluster.speed}

Data context bindings support all standard kanzi binding features, like expressions.

Member Typedef Documentation

typedef function<void()> kanzi::DataSource::ModifiedFunction

Callback function type for change subscriptions.

Token type that can be used to identify the change subscription.

Constructor & Destructor Documentation

kanzi::DataSource::DataSource ( Domain domain,
string_view  name 
)
protected

Standard constructor.

Parameters
domainThe UI domain the new resource belongs to.
nameName of the data source.

Member Function Documentation

static PropertyTypeEditorInfoSharedPtr kanzi::DataSource::makeEditorInfo ( )
static
virtual DataObjectSharedPtr kanzi::DataSource::getRoot ( )
pure virtual

Retrieves the root object of the underlying data tree.

Needs to be implemented by the derived class.

Returns
Returns data object that is the root of the data tree.
ModifiedSubscriptionToken kanzi::DataSource::addModifiedNotificationHandler ( ModifiedFunction  callback)

Adds message handler, that can be used to monitor when the contents of the data source are modified.

Parameters
callbackCallback function, that is invoked when modification occurs.
Returns
Token that can be used to unsubscribe the notification handler.
void kanzi::DataSource::removeModifiedNotificationHandler ( ModifiedSubscriptionToken  token)

Removes and stops monitoring the contents of the data source for given subscription.

Parameters
tokenToken that identifies the subscription.
virtual void kanzi::DataSource::loadFromKZB ( const KzuResourceLoaderThreadContext threadContext,
KzcInputStream inputStream,
const KzuBinaryFileInfo file 
)
virtual

Function for loading the resource from .KZB.

This function is called when loading the data from .KZB file. Implementations should call super class loadFromKZB before reading anything else from inputStream. This function is called from arbitrary loading threads. The parameter threadContext contains thread safe memory manager and a thread specific Property manager which can be locked with the threadLock in the threadContext. This function may not access resource manager or the UIDomain due to race conditions.

Reimplemented from kanzi::Resource.

void kanzi::DataSource::notifyModified ( )
protected

Notifies all subscriptions that this data source has been modified.

Should be called by derived classes whenever the root content object is reloaded.

Member Data Documentation

ModifiedSubscriptionContainer kanzi::DataSource::m_subscriptions
protected

The documentation for this class was generated from the following file: