Skip to content

Commit

Permalink
docs(DB): Finish all the database docs.
Browse files Browse the repository at this point in the history
Add all DB annotations.

Address some of the remaining items in #ni#211.

Fixes ni#209

BREAKING CHANGE:

list all the renames and breakages
  • Loading branch information
d-bohls committed Mar 12, 2018
1 parent 730305b commit 99f0728
Show file tree
Hide file tree
Showing 21 changed files with 1,776 additions and 297 deletions.
4 changes: 4 additions & 0 deletions docs/api_reference/database.rst
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,11 @@ nixnet.database
database/database
database/ecu
database/frame
database/lin_sched
database/lin_sched_entry
database/pdu
database/signal
database/subframe
database/collection
database/dbc_attributes
database/dbc_signal_value_table
7 changes: 7 additions & 0 deletions docs/api_reference/database/lin_sched.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
nixnet.database.linsched
========================

.. automodule:: nixnet.database._lin_sched
:members:
:inherited-members:
:show-inheritance:
7 changes: 7 additions & 0 deletions docs/api_reference/database/lin_sched_entry.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
nixnet.database.linsched_entry
==============================

.. automodule:: nixnet.database._lin_sched_entry
:members:
:inherited-members:
:show-inheritance:
7 changes: 7 additions & 0 deletions docs/api_reference/database/pdu.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
nixnet.database.pdu
===================

.. automodule:: nixnet.database._pdu
:members:
:inherited-members:
:show-inheritance:
Binary file added docs/api_reference/database/pdusrequired.gif
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
7 changes: 7 additions & 0 deletions docs/api_reference/database/subframe.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
nixnet.database.subframe
========================

.. automodule:: nixnet.database._subframe
:members:
:inherited-members:
:show-inheritance:
12 changes: 6 additions & 6 deletions nixnet/_cconsts.py
Original file line number Diff line number Diff line change
Expand Up @@ -477,7 +477,7 @@
NX_PROP_CLST_FRM_REFS = (0x00000004 | NX_CLASS_CLUSTER | NX_PRPTYPE_1_DREF)
NX_PROP_CLST_NAME = (0x00000005 | NX_CLASS_CLUSTER | NX_PRPTYPE_STRING)
NX_PROP_CLST_PDU_REFS = (0x00000008 | NX_CLASS_CLUSTER | NX_PRPTYPE_1_DREF)
NX_PROP_CLST_PD_US_REQD = (0x0000000A | NX_CLASS_CLUSTER | NX_PRPTYPE_BOOL)
NX_PROP_CLST_PDUS_REQD = (0x0000000A | NX_CLASS_CLUSTER | NX_PRPTYPE_BOOL)
NX_PROP_CLST_PROTOCOL = (0x00000006 | NX_CLASS_CLUSTER | NX_PRPTYPE_U32)
NX_PROP_CLST_SIG_REFS = (0x00000007 | NX_CLASS_CLUSTER | NX_PRPTYPE_1_DREF)
NX_PROP_CLST_CAN_IO_MODE = (0x00000010 | NX_CLASS_CLUSTER | NX_PRPTYPE_U32)
Expand Down Expand Up @@ -618,8 +618,8 @@
NX_PROP_ECU_LIN_CONFIG_NAD = (0x00000023 | NX_CLASS_ECU | NX_PRPTYPE_U32)
NX_PROP_ECU_LIN_SUPPLIER_ID = (0x00000024 | NX_CLASS_ECU | NX_PRPTYPE_U32)
NX_PROP_ECU_LIN_FUNCTION_ID = (0x00000025 | NX_CLASS_ECU | NX_PRPTYPE_U32)
NX_PROP_ECU_LINP_2MIN = (0x00000026 | NX_CLASS_ECU | NX_PRPTYPE_F64)
NX_PROP_ECU_LINS_TMIN = (0x00000027 | NX_CLASS_ECU | NX_PRPTYPE_F64)
NX_PROP_ECU_LIN_P2_MIN = (0x00000026 | NX_CLASS_ECU | NX_PRPTYPE_F64)
NX_PROP_ECU_LIN_ST_MIN = (0x00000027 | NX_CLASS_ECU | NX_PRPTYPE_F64)
NX_PROP_ECU_J1939_PREFERRED_ADDRESS = (0x00000028 | NX_CLASS_ECU | NX_PRPTYPE_U32)
NX_PROP_ECU_J1939_NODE_NAME = (0x00000029 | NX_CLASS_ECU | NX_PRPTYPE_U64)

Expand Down Expand Up @@ -718,9 +718,9 @@
NX_CAN_LAST_ERR_BIT0 = 5
NX_CAN_LAST_ERR_CRC = 6

NX_CA_NIO_MODE_CAN = 0
NX_CA_NIO_MODE_CAN_FD = 1
NX_CA_NIO_MODE_CAN_FD_BRS = 2
NX_CAN_IO_MODE_CAN = 0
NX_CAN_IO_MODE_CAN_FD = 1
NX_CAN_IO_MODE_CAN_FD_BRS = 2

NX_FLEX_RAY_POC_STATE_DEFAULT_CONFIG = 0
NX_FLEX_RAY_POC_STATE_READY = 1
Expand Down
151 changes: 146 additions & 5 deletions nixnet/_enums.py
Original file line number Diff line number Diff line change
Expand Up @@ -1394,10 +1394,28 @@ class CanLastErr(enum.Enum):


class CanIoMode(enum.Enum):
"""CAN IO Mode."""
CAN = _cconsts.NX_CA_NIO_MODE_CAN
CAN_FD = _cconsts.NX_CA_NIO_MODE_CAN_FD
CAN_FD_BRS = _cconsts.NX_CA_NIO_MODE_CAN_FD_BRS
"""CAN IO Mode.
Values:
CAN:
This is the default CAN 2.0 A/B standard I/O mode as defined in ISO 11898-1:2003.
A fixed baud rate is used for transfer,
and the payload length is limited to 8 bytes.
CAN_FD:
This is the CAN FD mode as specified in the CAN with `Flexible Data-Rate specification`,
version 1.0. Payload lengths up to 64 are allowed,
but they are transmitted at a single fixed baud rate
(defined by :any:`Cluster.can_fd_baud_rate` or :any:`Interface.can_fd_baud_rate`).
CAN_FD_BRS:
This is the CAN FD as specified in the `CAN with Flexible Data-Rate` specification,
version 1.0, with the optional Baud Rate Switching enabled.
The same payload lengths as CAN FD mode are allowed; additionally,
the data portion of the CAN frame is transferred at a different (higher) baudrate
(defined by :any:`Cluster.can_fd_baud_rate` or :any:`Interface.can_fd_baud_rate`).
"""
CAN = _cconsts.NX_CAN_IO_MODE_CAN
CAN_FD = _cconsts.NX_CAN_IO_MODE_CAN_FD
CAN_FD_BRS = _cconsts.NX_CAN_IO_MODE_CAN_FD_BRS


class FlexRayPocState(enum.Enum):
Expand Down Expand Up @@ -1540,6 +1558,20 @@ class LinLastErr(enum.Enum):


class LinProtocolVer(enum.Enum):
"""LIN protocol version
Values:
VER_1_2:
Version 1.2
VER_1_3:
Version 1.3
VER_2_0:
Version 2.0
VER_2_1:
Version 2.1
VER_2_2:
Version 2.2
"""
VER_1_2 = _cconsts.NX_LIN_PROTOCOL_VER_1_2
VER_1_3 = _cconsts.NX_LIN_PROTOCOL_VER_1_3
VER_2_0 = _cconsts.NX_LIN_PROTOCOL_VER_2_0
Expand All @@ -1561,6 +1593,24 @@ class GetDbcAttributeMode(enum.Enum):


class Merge(enum.Enum):
"""Cluster merge behavior
Values:
COPY_USE_SOURCE:
The target object with all dependent child objects
is removed from the target cluster and replaced by the source objects.
COPY_USE_TARGET:
The source object is ignored (the target cluster object with child objects remains unchanged).
MERGE_USE_SOURCE:
This adds child objects from the source object to child objects from the destination object.
If target object contains a child object with the same name,
the child object from the source frame replaces it.
The source object properties (for example, payload length of the frame) replace the target properties.
MERGE_USE_TARGET:
This adds child objects from the source object to child objects from the destination object.
If the target object contains a child object with the same name, it remains unchanged.
The target object properties remain unchanged (for example, payload length).
"""
COPY_USE_SOURCE = _cconsts.NXDB_MERGE_COPY_USE_SOURCE
COPY_USE_TARGET = _cconsts.NXDB_MERGE_COPY_USE_TARGET
MERGE_USE_SOURCE = _cconsts.NXDB_MERGE_MERGE_USE_SOURCE
Expand Down Expand Up @@ -1723,7 +1773,20 @@ class Protocol(enum.Enum):


class AppProtocol(enum.Enum):
"""Application Protocol."""
"""Application Protocol.
Values:
NONE:
The default application protocol.
J1939:
Indicates J1939 clusters. The value enables the following features:
* Sending/receiving long frames as the SAE J1939 specification specifies,
using the J1939 transport protocol.
* Using a special notation for J1939 identifiers.
* Using J1939 address claiming.
"""
NONE = _cconsts.NX_APP_PROTOCOL_NONE
J1939 = _cconsts.NX_APP_PROTOCOL_J1939

Expand Down Expand Up @@ -1975,6 +2038,28 @@ class FrmFlexRayTiming(enum.Enum):


class FrmCanTiming(enum.Enum):
"""CAN frame timing
Values:
CYCLIC_DATA:
The transmitting ECU transmits the CAN data frame in a cyclic (periodic) manner.
The :any:`Frame.can_transmit_time` property defines the time between cycles.
The transmitting ECU ignores CAN remote frames received for this frame.
EVENT_DATA:
The transmitting ECU transmits the CAN data frame in an event-driven manner.
The :any:`Frame.can_transmit_time` property defines the minimum interval.
For NI-XNET, the event occurs when you call write data to a session.
The transmitting ECU ignores CAN remote frames received for this frame.
CYCLIC_REMOTE:
The receiving ECU transmits the CAN remote frame in a cyclic (periodic) manner.
The :any:`Frame.can_transmit_time` property defines the time between cycles.
The transmitting ECU responds to each CAN remote frame by transmitting the associated CAN data frame.
EVENT_REMOTE:
The receiving ECU transmits the CAN remote frame in an event-driven manner.
The XNET Frame CAN:Transmit Time property defines the minimum interval.
For NI-XNET, the event occurs when you call nxWriteFrame.
The transmitting ECU responds to each CAN remote frame by transmitting the associated CAN data frame.
"""
CYCLIC_DATA = _cconsts.NX_FRM_CAN_TIMING_CYCLIC_DATA
EVENT_DATA = _cconsts.NX_FRM_CAN_TIMING_EVENT_DATA
CYCLIC_REMOTE = _cconsts.NX_FRM_CAN_TIMING_CYCLIC_REMOTE
Expand All @@ -1994,19 +2079,75 @@ class SigDataType(enum.Enum):


class LinSchedRunMode(enum.Enum):
"""LIN schedule run mode.
Values:
CONTINUOUS:
The master runs the schedule continuously.
When the last entry executes,
the schedule starts again with the first entry.
ONCE:
The master runs the schedule once (all entries),
then returns to the previously running continuous schedule (or NULL).
If requests are submitted for multiple run-once schedules,
each run-once executes in succession based on its :any:`LinSched.priority`,
then the master returns to the continuous schedule (or NULL).
NULL:
All communication stops immediately.
A schedule with this run mode is called a null schedule.
"""
CONTINUOUS = _cconsts.NX_LIN_SCHED_RUN_MODE_CONTINUOUS
ONCE = _cconsts.NX_LIN_SCHED_RUN_MODE_ONCE
NULL = _cconsts.NX_LIN_SCHED_RUN_MODE_NULL


class LinSchedEntryType(enum.Enum):
"""LIN schedule entry type.
Values:
UNCONDITIONAL:
A single frame transfers in this slot.
SPORADIC:
The master transmits in this slot.
The master can select from multiple frames to transmit.
Only updated frames are transmitted.
When more than one frame is updated,
the master decides by priority which frame to send.
The other updated frame remains pending
and can be sent when this schedule entry is processed the following time.
The order of unconditional frames in :any:`LinSchedEntry.frames`
(the first frame has the highest priority) determines the frame priority.
EVENT_TRIGGERED:
Multiple slaves can transmit an unconditional frame in this slot.
The slave transmits the frame only if at least one frame signal has been updated.
When a collision occurs (multiple slaves try to transmit in the same slot),
this is detected and resolved using a different schedule
specified in the :any:`LinSchedEntry.collision_resolving_schedule` property.
The resolving schedule runs once,
starting in the subsequent slot after the collision,
and automatically returns to the previous schedule
at the subsequent position where the collision occurred.
NODE_CONFIG_SERVICE:
The schedule entry contains a node configuration service.
The node configuration service is defined as raw data bytes
in the XNET LIN Schedule Entry
:any:`Node Configuration:Free Format:Data Bytes<LinSchedEntry.nc_ff_data_bytes>`
property.
"""
UNCONDITIONAL = _cconsts.NX_LIN_SCHED_ENTRY_TYPE_UNCONDITIONAL
SPORADIC = _cconsts.NX_LIN_SCHED_ENTRY_TYPE_SPORADIC
EVENT_TRIGGERED = _cconsts.NX_LIN_SCHED_ENTRY_TYPE_EVENT_TRIGGERED
NODE_CONFIG_SERVICE = _cconsts.NX_LIN_SCHED_ENTRY_TYPE_NODE_CONFIG_SERVICE


class FrmLinChecksum(enum.Enum):
"""LIN frame checksum
Values:
* CLASSIC
* ENHANCED
"""
CLASSIC = _cconsts.NX_FRM_LIN_CHECKSUM_CLASSIC
ENHANCED = _cconsts.NX_FRM_LIN_CHECKSUM_ENHANCED

Expand Down
20 changes: 10 additions & 10 deletions nixnet/_props.py
Original file line number Diff line number Diff line change
Expand Up @@ -2504,13 +2504,13 @@ def get_cluster_pdu_refs(
)


def get_cluster_pd_us_reqd(
def get_cluster_pdus_required(
ref, # type: int
):
# type: (...) -> bool
return _cprops.get_database_bool(
ref,
_cconsts.NX_PROP_CLST_PD_US_REQD,
_cconsts.NX_PROP_CLST_PDUS_REQD,
)


Expand Down Expand Up @@ -4968,46 +4968,46 @@ def set_ecu_lin_function_id(
)


def get_ecu_linp_2min(
def get_ecu_lin_p2_min(
ref, # type: int
):
# type: (...) -> float
return _cprops.get_database_f64(
ref,
_cconsts.NX_PROP_ECU_LINP_2MIN,
_cconsts.NX_PROP_ECU_LIN_P2_MIN,
)


def set_ecu_linp_2min(
def set_ecu_lin_p2_min(
ref, # type: int
value, # type: float
):
# type: (...) -> None
_cprops.set_database_f64(
ref,
_cconsts.NX_PROP_ECU_LINP_2MIN,
_cconsts.NX_PROP_ECU_LIN_P2_MIN,
value,
)


def get_ecu_lins_tmin(
def get_ecu_lin_st_min(
ref, # type: int
):
# type: (...) -> float
return _cprops.get_database_f64(
ref,
_cconsts.NX_PROP_ECU_LINS_TMIN,
_cconsts.NX_PROP_ECU_LIN_ST_MIN,
)


def set_ecu_lins_tmin(
def set_ecu_lin_st_min(
ref, # type: int
value, # type: float
):
# type: (...) -> None
_cprops.set_database_f64(
ref,
_cconsts.NX_PROP_ECU_LINS_TMIN,
_cconsts.NX_PROP_ECU_LIN_ST_MIN,
value,
)

Expand Down
Loading

0 comments on commit 99f0728

Please sign in to comment.