Skip to content

Latest commit

 

History

History
550 lines (349 loc) · 12.3 KB

docs.md

File metadata and controls

550 lines (349 loc) · 12.3 KB

@ebusd/ebus-typespec

TypeSpec library for defining eBUS messages and emitting to ebusd CSV.

Install

npm install @ebusd/ebus-typespec

Emitter

Usage

  1. Via the command line
tsp compile . --emit=@ebusd/ebus-typespec
  1. Via the config
emit:
  - "@ebusd/ebus-typespec"

Emitter options

includes

Type: boolean

Emit includes files as includes instead of inline (incomplete!)

translations

Type: string

File name with translations to use.

withMinMax

Type: boolean

Emit min+max values

Linter

Usage

Add the following in tspconfig.yaml:

linter:
  extends:
    - ebus/recommended

RuleSets

Available ruleSets:

Rules

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.

Decorators

Ebus

@auth

Define authentication level.

@Ebus.auth(value: valueof string)
Target

Model

Parameters
Name Type Description
value valueof scalar string the authentication level (e.g. 'install').

@base

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[])
Target

Model

Parameters
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.

@chain

Define chained message IDs.

@Ebus.chain(length: valueof uint8, dd: valueof Ebus.symbol[], ...dds: valueof Ebus.symbol[][])
Target

Model

Parameters
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.

@condition

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[])
Target

union Namespace | Model | UnionVariant

Parameters
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).

@constValue

Define the const value.

@Ebus.constValue(value: valueof numeric | string)
Target

union numeric | boolean | ModelProperty

Parameters
Name Type Description
value valueof union numeric | string the const value.

@divisor

Define the divisor.

@Ebus.divisor(value: valueof numeric)
Target

union numeric | plainTime | ModelProperty

Parameters
Name Type Description
value valueof scalar numeric the divisor.

@example

Define a data example.

@Ebus.example(desc: valueof string, q: valueof string | Ebus.symbol[], a?: valueof string | Ebus.symbol[])
Target

Model

Parameters
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.

@ext

Define the extension message ID to be combined with a base ID.

@Ebus.ext(...dd: valueof Ebus.symbol[])
Target

Model

Parameters
Name Type Description
dd valueof model Ebus.symbol[] message ID extensions parts.

@factor

Define the factor.

@Ebus.factor(value: valueof numeric)
Target

union numeric | plainTime | ModelProperty

Parameters
Name Type Description
value valueof scalar numeric the factor.

@id

Define the whole message ID.

@Ebus.id(pb: valueof Ebus.pb, sb: valueof Ebus.sb, ...dd: valueof Ebus.symbol[])
Target

Model

Parameters
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.

@in

Define message part inbound from target.

@Ebus.in(writeOnly?: valueof boolean)
Target

ModelProperty

Parameters
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).

@inherit

Define the inherited model(s).

@Ebus.inherit(...models: Model[])
Target

Model

Parameters
Name Type Description
models model Model[] inherited models.

@out

Define message part outbound to target.

@Ebus.out(writeOnly?: valueof boolean)
Target

ModelProperty

Parameters
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).

@passive

Define passive only.

@Ebus.passive
Target

Model

Parameters

None

@poll

Define the poll priority (only for active read).

@Ebus.poll(value?: valueof uint8)
Target

Model

Parameters
Name Type Description
value valueof scalar uint8 the poll priority (between 1 and 9).

@qq

Define the source address.

@Ebus.qq(value?: valueof Ebus.source)
Target

Model

Parameters
Name Type Description
value valueof scalar Ebus.source the source address QQ.

@unit

Define the unit.

@Ebus.unit(value: valueof string)
Target

union numeric | ModelProperty

Parameters
Name Type Description
value valueof scalar string the unit.

@values

Define the known values.

@Ebus.values(values: Enum)
Target

union numeric | boolean | ModelProperty

Parameters
Name Type Description
values Enum the known values.

@write

Define write direction.

@Ebus.write(toSource?: valueof boolean)
Target

Model

Parameters
Name Type Description
toSource valueof scalar boolean true to use the source address pendant of the target address instead of the target address.

@zz

Define the target address.

@Ebus.zz(value?: valueof Ebus.target)
Target

union Model | Namespace

Parameters
Name Type Description
value valueof scalar Ebus.target the target address ZZ.

Ebus.Internal

@bcd

Define BCD encoding.

@Ebus.Internal.bcd
Target

Scalar

Parameters

None

@hex

Define HEX encoding.

@Ebus.Internal.hex
Target

Scalar

Parameters

None

@maxBits

Define the max bits.

@Ebus.Internal.maxBits(value: valueof uint8)
Target

scalar numeric

Parameters
Name Type Description
value valueof scalar uint8 the max bits.

@reverse

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
Target

Scalar

Parameters

None