mirror of
https://github.com/Fishwaldo/open-zwave.git
synced 2025-07-20 03:48:30 +00:00
No functional changes. GetValueStoreKey has 2 overloads and they return identical results, the math is correct, this was questioned here: https://github.com/domoticz/domoticz/issues/3727
367 lines
12 KiB
C++
367 lines
12 KiB
C++
//-----------------------------------------------------------------------------
|
|
//
|
|
// ValueID.h
|
|
//
|
|
// Unique identifier for a Value object
|
|
//
|
|
// Copyright (c) 2010 Mal Lansell <openzwave@lansell.org>
|
|
//
|
|
// SOFTWARE NOTICE AND LICENSE
|
|
//
|
|
// This file is part of OpenZWave.
|
|
//
|
|
// OpenZWave is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU Lesser General Public License as published
|
|
// by the Free Software Foundation, either version 3 of the License,
|
|
// or (at your option) any later version.
|
|
//
|
|
// OpenZWave is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU Lesser General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Lesser General Public License
|
|
// along with OpenZWave. If not, see <http://www.gnu.org/licenses/>.
|
|
//
|
|
//-----------------------------------------------------------------------------
|
|
|
|
#ifndef _ValueID_H
|
|
#define _ValueID_H
|
|
|
|
#include <string>
|
|
#include <assert.h>
|
|
|
|
#include "ValueIDIndexes.h"
|
|
#include "Defs.h"
|
|
|
|
class TiXmlElement;
|
|
|
|
namespace OpenZWave
|
|
{
|
|
|
|
namespace Internal
|
|
{
|
|
namespace VC
|
|
{
|
|
class Value;
|
|
class ValueStore;
|
|
}
|
|
;
|
|
}
|
|
;
|
|
|
|
/** \defgroup ValueID ValueID Support
|
|
*
|
|
* ValueID's in OZW expose device functionality to the application. Many different
|
|
* types of ValueID's are exposed, and they represent the state of a device (such as a
|
|
* switch on or off) or configuration parameters of a device.
|
|
*/
|
|
|
|
/** \brief Provides a unique ID for a value reported by a Z-Wave device.
|
|
* \ingroup ValueID
|
|
*
|
|
* The ValueID is used to uniquely identify a value reported by a
|
|
* Z-Wave device.
|
|
* <p>
|
|
* The ID is built by packing various identifying characteristics into a single
|
|
* 32-bit number - the Z-Wave driver index, device node ID, the command class and
|
|
* command class instance that handles the value, plus an index for the value
|
|
* to distinguish it among all the other values managed by that command class
|
|
* instance. The type (bool, byte, string etc) of the value is also stored.
|
|
* <p>
|
|
* The packing of the ID is such that a list of Values sorted by ValueID
|
|
* will be in a sensible order for display to the user.
|
|
*/
|
|
|
|
class OPENZWAVE_EXPORT ValueID
|
|
{
|
|
public:
|
|
/**
|
|
* Value Genres
|
|
* The classification of a value to enable low level system or configuration parameters to be filtered by the application.
|
|
* \see GetGenre
|
|
*/
|
|
enum ValueGenre
|
|
{
|
|
ValueGenre_Basic = 0, /**< The 'level' as controlled by basic commands. Usually duplicated by another command class. */
|
|
ValueGenre_User, /**< Basic values an ordinary user would be interested in. */
|
|
ValueGenre_Config, /**< Device-specific configuration parameters. These cannot be automatically discovered via Z-Wave, and are usually described in the user manual instead. */
|
|
ValueGenre_System, /**< Values of significance only to users who understand the Z-Wave protocol */
|
|
ValueGenre_Count /**< A count of the number of genres defined. Not to be used as a genre itself. */
|
|
};
|
|
|
|
/**
|
|
* Value Types
|
|
* The type of data represented by the value object.
|
|
* \see GetType
|
|
*/
|
|
enum ValueType
|
|
{
|
|
ValueType_Bool = 0, /**< Boolean, true or false */
|
|
ValueType_Byte, /**< 8-bit unsigned value */
|
|
ValueType_Decimal, /**< Represents a non-integer value as a string, to avoid floating point accuracy issues. */
|
|
ValueType_Int, /**< 32-bit signed value */
|
|
ValueType_List, /**< List from which one item can be selected */
|
|
ValueType_Schedule, /**< Complex type used with the Climate Control Schedule command class */
|
|
ValueType_Short, /**< 16-bit signed value */
|
|
ValueType_String, /**< Text string */
|
|
ValueType_Button, /**< A write-only value that is the equivalent of pressing a button to send a command to a device */
|
|
ValueType_Raw, /**< A collection of bytes */
|
|
ValueType_BitSet, /**< A collection of Bits */
|
|
ValueType_Max = ValueType_BitSet /**< The highest-number type defined. Not to be used as a type itself. */
|
|
};
|
|
|
|
/**
|
|
* Get the Home ID of the driver that controls the node containing the value.
|
|
* \return the Home ID.
|
|
*/
|
|
uint32 GetHomeId() const
|
|
{
|
|
return m_homeId;
|
|
}
|
|
|
|
/**
|
|
* Get the Home ID of the driver that controls the node containing the value.
|
|
* \return the node id.
|
|
*/
|
|
uint8 GetNodeId() const
|
|
{
|
|
return ((uint8) ((m_id & 0xff000000) >> 24));
|
|
}
|
|
|
|
/**
|
|
* Get the genre of the value. The genre classifies a value to enable
|
|
* low-level system or configuration parameters to be filtered out by the application
|
|
* \return the value's genre.
|
|
* \see ValueGenre
|
|
*/
|
|
ValueGenre GetGenre() const
|
|
{
|
|
return ((ValueGenre) ((m_id & 0x00c00000) >> 22));
|
|
}
|
|
|
|
/**
|
|
* Get the genre of the value as a String. The genre classifies a value to enable
|
|
* low-level system or configuration parameters to be filtered out by the application
|
|
* \return the value's genre.
|
|
* \see ValueGenre, ValueID::GetGenre
|
|
*/
|
|
string GetGenreAsString() const;
|
|
|
|
/**
|
|
* Get the Z-Wave command class that created and manages this value. Knowledge of
|
|
* command classes is not required to use OpenZWave, but this information is
|
|
* exposed in case it is of interest.
|
|
* \return the value's command class.
|
|
*/
|
|
uint8 GetCommandClassId() const
|
|
{
|
|
return ((uint8) ((m_id & 0x003fc000) >> 14));
|
|
}
|
|
|
|
/**
|
|
* Get the command class instance of this value. It is possible for there to be
|
|
* multiple instances of a command class, although currently it appears that
|
|
* only the SensorMultilevel command class ever does this. Knowledge of
|
|
* instances and command classes is not required to use OpenZWave, but this
|
|
* information is exposed in case it is of interest.
|
|
* \return the instance of the value's command class.
|
|
*/
|
|
uint8 GetInstance() const
|
|
{
|
|
return ((uint8) (((m_id & 0xff0)) >> 4));
|
|
}
|
|
|
|
/**
|
|
* Get the value index. The index is used to identify one of multiple
|
|
* values created and managed by a command class. In the case of configurable
|
|
* parameters (handled by the configuration command class), the index is the
|
|
* same as the parameter ID. Knowledge of command classes is not required
|
|
* to use OpenZWave, but this information is exposed in case it is of interest.
|
|
* \return the value index within the command class.
|
|
*/
|
|
uint16 GetIndex() const
|
|
{
|
|
return ((uint16) ((m_id1 & 0xFFFF0000) >> 16));
|
|
}
|
|
|
|
/**
|
|
* Get the type of the value. The type describes the data held by the value
|
|
* and enables the user to select the correct value accessor method in the
|
|
* Manager class.
|
|
* \return the value's type.
|
|
* \see ValueType, Manager::GetValueAsBool, Manager::GetValueAsByte, Manager::GetValueAsFloat, Manager::GetValueAsInt, Manager::GetValueAsShort, Manager::GetValueAsString, Manager::GetValueListSelection.
|
|
*/
|
|
ValueType GetType() const
|
|
{
|
|
return ((ValueType) (m_id & 0x0000000f));
|
|
}
|
|
|
|
/**
|
|
* Get the type of the value as a String. The type describes the data held by the value
|
|
* and enables the user to select the correct value accessor method in the
|
|
* Manager class.
|
|
* \return the value's type.
|
|
* \see ValueType, Manager::GetValueAsBool, Manager::GetValueAsByte, Manager::GetValueAsFloat, Manager::GetValueAsInt, Manager::GetValueAsShort, Manager::GetValueAsString, Manager::GetValueListSelection, ValueID::GetType
|
|
*/
|
|
string GetTypeAsString() const;
|
|
|
|
/**
|
|
* Get a 64Bit Integer that represents this ValueID. This Integer is not guaranteed to be the same
|
|
* across restarts of OpenZWave.
|
|
* \return a uint64 integer
|
|
*/
|
|
uint64 GetId() const
|
|
{
|
|
return (uint64) (((uint64) m_id1 << 32) | m_id);
|
|
}
|
|
|
|
// Comparison Operators
|
|
bool operator ==(ValueID const& _other) const
|
|
{
|
|
return ((m_homeId == _other.m_homeId) && (m_id == _other.m_id) && (m_id1 == _other.m_id1));
|
|
}
|
|
bool operator !=(ValueID const& _other) const
|
|
{
|
|
return ((m_homeId != _other.m_homeId) || (m_id != _other.m_id) || (m_id1 != _other.m_id1));
|
|
}
|
|
bool operator <(ValueID const& _other) const
|
|
{
|
|
if (m_homeId == _other.m_homeId)
|
|
{
|
|
if (m_id == _other.m_id)
|
|
{
|
|
return (m_id1 < _other.m_id1);
|
|
}
|
|
else
|
|
{
|
|
return (m_id < _other.m_id);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
return (m_homeId < _other.m_homeId);
|
|
}
|
|
}
|
|
bool operator >(ValueID const& _other) const
|
|
{
|
|
if (m_homeId == _other.m_homeId)
|
|
{
|
|
if (m_id == _other.m_id)
|
|
{
|
|
return (m_id1 > _other.m_id1);
|
|
}
|
|
else
|
|
{
|
|
return (m_id > _other.m_id);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
return (m_homeId > _other.m_homeId);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Construct a value ID from its component parts.
|
|
* This method is public only to allow ValueIDs to be saved and recreated by the application.
|
|
* Only ValueIDs that have been reported by OpenZWave notifications should ever be used.
|
|
* \param _homeId Home ID of the PC Z-Wave Controller that manages the device.
|
|
* \param _nodeId Node ID of the device reporting the value.
|
|
* \param _genre classification of the value to enable low level system or configuration parameters to be filtered out.
|
|
* \param _commandClassId ID of command class that creates and manages this value.
|
|
* \param _instance Instance index of the command class.
|
|
* \param _valueIndex Index of the value within all the values created by the command class instance.
|
|
* \param _type Type of value (bool, byte, string etc).
|
|
* \return The ValueID.
|
|
* \see ValueID
|
|
*/
|
|
ValueID(uint32 const _homeId, uint8 const _nodeId, ValueGenre const _genre, uint8 const _commandClassId, uint8 const _instance, uint16 const _valueIndex, ValueType const _type) :
|
|
m_homeId(_homeId)
|
|
{
|
|
m_id = (((uint32) _nodeId) << 24) | (((uint32) _genre) << 22) | (((uint32) _commandClassId) << 14) | (((uint32) (_instance & 0xFF)) << 4) | ((uint32) _type);
|
|
m_id1 = (((uint32) _valueIndex) << 16);
|
|
}
|
|
|
|
/* construct a ValueID based on the HomeID and the unit64 returned from GetID
|
|
* \param _homeId - The HomeID
|
|
* \param id - The ID returned from ValueID::GetID
|
|
* \see ValueID::GetId
|
|
*/
|
|
ValueID(uint32 _homeId, uint64 id) :
|
|
m_homeId(_homeId)
|
|
{
|
|
m_id = ((uint32) (id & 0xFFFFFFFF));
|
|
m_id1 = (uint32) (id >> 32);
|
|
}
|
|
|
|
// Construct a value id for use in notifications
|
|
ValueID(uint32 const _homeId, uint8 const _nodeId) :
|
|
m_id1(0), m_homeId(_homeId)
|
|
{
|
|
m_id = ((uint32) _nodeId) << 24;
|
|
}
|
|
ValueID(uint32 const _homeId, uint8 const _nodeId, uint32 const _instance) :
|
|
m_homeId(_homeId)
|
|
{
|
|
m_id = (((uint32) _nodeId) << 24) | (((uint32) _instance) << 4);
|
|
m_id1 = 0;
|
|
}
|
|
|
|
// Default constructor
|
|
ValueID() :
|
|
m_id(0), m_id1(0), m_homeId(0)
|
|
{
|
|
|
|
}
|
|
|
|
// Not all parts of the ValueID are necessary to uniquely identify the value. In the case of a
|
|
// Node's ValueStore, we can ignore the home ID, node ID, genre and type and still be left with
|
|
// a unique integer than can be used as a key to look up values. The two GetValueStoreKey methods
|
|
// below are helpers to enable command classes to easily access their values from the ValueStore.
|
|
|
|
// Get the key from our own m_id
|
|
uint32 GetValueStoreKey() const
|
|
{
|
|
/* 0xIIIICCii
|
|
* I = Index
|
|
* C = CC
|
|
* i = Instance
|
|
*/
|
|
/* CC Index Instance */
|
|
return (((m_id & 0x003fc000) >> 6) | (m_id1 & 0xffff0000) | ((m_id & 0xFF0) >> 4));
|
|
}
|
|
|
|
// Generate a key from its component parts
|
|
static uint32 GetValueStoreKey(uint8 const _commandClassId, uint8 const _instance, uint16 const _valueIndex)
|
|
{
|
|
|
|
uint32 key = (((uint32) _instance)) | (((uint32) _commandClassId) << 8) | (((uint32) (_valueIndex & 0xFFFF)) << 16);
|
|
|
|
return key;
|
|
}
|
|
|
|
private:
|
|
|
|
// ID Packing:
|
|
// Bits
|
|
// 24-31: 8 bits. Node ID of device
|
|
// 22-23: 2 bits. genre of value (see ValueGenre enum).
|
|
// 14-21: 8 bits. ID of command class that created and manages this value.
|
|
// 12-13 Unused.
|
|
// 04-11: 8 bits. Instance of the Value
|
|
// 00-03: 4 bits. Type of value (bool, byte, string etc).
|
|
uint32 m_id;
|
|
|
|
// ID1 Packing:
|
|
// Bits
|
|
// 16-31 16 bits. Instance Index of the command class.
|
|
uint32 m_id1;
|
|
|
|
// Unique PC interface identifier
|
|
uint32 m_homeId;
|
|
};
|
|
|
|
} // namespace OpenZWave
|
|
|
|
#endif
|