TypeSpec library for defining eBUS messages and emitting to ebusd CSV.
npm install @ebusd/ebus-typespec
- Via the command line
tsp compile . --emit=@ebusd/ebus-typespec
- Via the config
emit:
- "@ebusd/ebus-typespec"
Type: boolean
Emit includes files as includes instead of inline (incomplete!)
Type: string
File name with translations to use.
Type: boolean
Emit min+max values
Add the following in tspconfig.yaml
:
linter:
extends:
- ebus/recommended
Available ruleSets:
Name | Description |
---|---|
ebus/no-function |
Make sure function is not used. |
ebus/no-interface |
Make sure interface is not used. |
ebus/no-intrinsic |
Make sure intrinsic is not used. |
ebus/no-literal |
Make sure literal is not used. |
ebus/no-object |
Make sure object is not used. |
ebus/no-operation |
Make sure operation is not used. |
ebus/no-projection |
Make sure projection is not used. |
ebus/no-template |
Make sure template is not used. |
ebus/no-tuple |
Make sure tuple is not used. |
ebus/no-union |
Make sure union is not used. |
@auth
@base
@chain
@condition
@constValue
@divisor
@example
@ext
@factor
@id
@in
@inherit
@out
@passive
@poll
@qq
@unit
@values
@write
@zz
Define authentication level.
@Ebus.auth(value: valueof string)
Model
Name | Type | Description |
---|---|---|
value | valueof scalar string |
the authentication level (e.g. 'install'). |
Define the base message ID to be combined with an extension ID.
@Ebus.base(pb: valueof Ebus.pb, sb: valueof Ebus.sb, ...dd: valueof Ebus.symbol[])
Model
Name | Type | Description |
---|---|---|
pb | valueof scalar Ebus.pb |
the primary message ID. |
sb | valueof scalar Ebus.sb |
the secondary message ID. |
dd | valueof model Ebus.symbol[] |
further message ID parts. |
Define chained message IDs.
@Ebus.chain(length: valueof uint8, dd: valueof Ebus.symbol[], ...dds: valueof Ebus.symbol[][])
Model
Name | Type | Description |
---|---|---|
length | valueof scalar uint8 |
the (maximum) length of a single message part of this chain, or 0 for default (=24). |
dd | valueof model Ebus.symbol[] |
second message ID part the chain is built from (first one taken from id or ext decorator). |
dds | valueof model Ebus.symbol[][] |
list of further message ID parts the chain is built from. |
Define the condition(s) for the whole message (if given multiple times, all conditions must be met).
@Ebus.condition(property: ModelProperty | Model, ...values: valueof string[])
union Namespace | Model | UnionVariant
Name | Type | Description |
---|---|---|
property | union ModelProperty | Model |
the referenced model property, or a model in case of existance check or single property only. |
values | valueof model string[] |
the optional alternative values the property needs to match (one of the values must match for the condition to be met). |
Define the const value.
@Ebus.constValue(value: valueof numeric | string)
union numeric | boolean | ModelProperty
Name | Type | Description |
---|---|---|
value | valueof union numeric | string |
the const value. |
Define the divisor.
@Ebus.divisor(value: valueof numeric)
union numeric | plainTime | ModelProperty
Name | Type | Description |
---|---|---|
value | valueof scalar numeric |
the divisor. |
Define a data example.
@Ebus.example(desc: valueof string, q: valueof string | Ebus.symbol[], a?: valueof string | Ebus.symbol[])
Model
Name | Type | Description |
---|---|---|
desc | valueof scalar string |
a text describing the example. |
q | valueof union string | Ebus.symbol[] |
the query part of the message, i.e. pb, sb, and dd bytes sent to the target. |
a | valueof union string | Ebus.symbol[] |
the answer part of the message, i.e. dd bytes received from the target. |
Define the extension message ID to be combined with a base ID.
@Ebus.ext(...dd: valueof Ebus.symbol[])
Model
Name | Type | Description |
---|---|---|
dd | valueof model Ebus.symbol[] |
message ID extensions parts. |
Define the factor.
@Ebus.factor(value: valueof numeric)
union numeric | plainTime | ModelProperty
Name | Type | Description |
---|---|---|
value | valueof scalar numeric |
the factor. |
Define the whole message ID.
@Ebus.id(pb: valueof Ebus.pb, sb: valueof Ebus.sb, ...dd: valueof Ebus.symbol[])
Model
Name | Type | Description |
---|---|---|
pb | valueof scalar Ebus.pb |
the primary message ID. |
sb | valueof scalar Ebus.sb |
the secondary message ID. |
dd | valueof model Ebus.symbol[] |
further message ID parts. |
Define message part inbound from target.
@Ebus.in(writeOnly?: valueof boolean)
ModelProperty
Name | Type | Description |
---|---|---|
writeOnly | valueof scalar boolean |
optional true to put in only if write direction, false to put in only if read direction (alyways if absent). |
Define the inherited model(s).
@Ebus.inherit(...models: Model[])
Model
Name | Type | Description |
---|---|---|
models | model Model[] |
inherited models. |
Define message part outbound to target.
@Ebus.out(writeOnly?: valueof boolean)
ModelProperty
Name | Type | Description |
---|---|---|
writeOnly | valueof scalar boolean |
optional true to put in only if write direction, false to put in only if read direction (alyways if absent). |
Define passive only.
@Ebus.passive
Model
None
Define the poll priority (only for active read).
@Ebus.poll(value?: valueof uint8)
Model
Name | Type | Description |
---|---|---|
value | valueof scalar uint8 |
the poll priority (between 1 and 9). |
Define the source address.
@Ebus.qq(value?: valueof Ebus.source)
Model
Name | Type | Description |
---|---|---|
value | valueof scalar Ebus.source |
the source address QQ. |
Define the unit.
@Ebus.unit(value: valueof string)
union numeric | ModelProperty
Name | Type | Description |
---|---|---|
value | valueof scalar string |
the unit. |
Define the known values.
@Ebus.values(values: Enum)
union numeric | boolean | ModelProperty
Name | Type | Description |
---|---|---|
values | Enum |
the known values. |
Define write direction.
@Ebus.write(toSource?: valueof boolean)
Model
Name | Type | Description |
---|---|---|
toSource | valueof scalar boolean |
true to use the source address pendant of the target address instead of the target address. |
Define the target address.
@Ebus.zz(value?: valueof Ebus.target)
union Model | Namespace
Name | Type | Description |
---|---|---|
value | valueof scalar Ebus.target |
the target address ZZ. |
Define BCD encoding.
@Ebus.Internal.bcd
Scalar
None
Define HEX encoding.
@Ebus.Internal.hex
Scalar
None
Define the max bits.
@Ebus.Internal.maxBits(value: valueof uint8)
scalar numeric
Name | Type | Description |
---|---|---|
value | valueof scalar uint8 |
the max bits. |
Define reverse representation. For numeric types this means most significant byte first (big-endian) instead of least significant byte first (little-endian). For date/time types coded as sequence of individual parts this means reverse sequence (i.e. year,month,day instead of day,month,year for dates and seconds,minutes,hours instead of hours,minutes,seconds for times).
@Ebus.Internal.reverse
Scalar
None