Class Specifications for Embedded Hardware Components
ECMA TR/109 — First Edition, Adopted June 2021
- Introduction
- Scope
- References
- Abbreviations
- Status
- Contributions
- Relation to ECMA-4xx, ECMAScript® embedded systems API specification
Class specifications for embedded hardware components is a project of Ecma International's Technical Committee 53 with the goal of collecting and disseminating ECMAScript class definitions for specific embedded hardware components. An embedded hardware component is a physical device in an embedded system, such as:
- Microcontrollers
- Sensors
- Actuators
- I/O providers and expanders
- Displays
Class specifications for embedded hardware components is a repository of individual class definition documents developed by committee members, hardware component manufacturers, and the community. These class definitions describe how the Class Patterns and Host Provider specified in ECMA-419, ECMAScript® embedded systems API specification are applied to specific hardware components. The repository is publicly available at https://github.com/EcmaTC53/spec/tree/master/docs/Hardware%20Components.
This Ecma Technical Report describes a repository of embedded hardware component class definitions developed by TC53 members and other contributors to document ECMAScript modules for specific hardware components. It is assumed that the reader is familiar with ECMA-419, ECMAScript® embedded systems API specification.
The following documents, in whole or in part, are normatively referenced in this document and are indispensable for its application. For dated references, only the edition cited applies. For undated references, the latest edition of the referenced document (including any amendments) applies.
ECMA-419, ECMAScript® embedded systems API specification
TC53 Ecma International Technical Committee 53
Development of the Class Specifications for Embedded Hardware Components repository is an on-going and open-ended process. Each class definition describes the ECMAScript module for a specific hardware component or embedded host. Because countless such hardware components and hosts exist and new hardware components and hosts are continuously being developed, there will never be a full and complete set of class definitions in the repository.
As of February 2021, the repository consists of example class definitions created by members of TC53. As additional definitions are contributed by TC53 members, hardware component manufacturers, and the community, the repository will be continuously updated at https://github.com/EcmaTC53/spec/tree/master/docs/Hardware%20Components, which references the git master
branch of the repository.
The class specifications for embedded hardware components repository is initially composed of contributions from TC53 members. It is anticipated that additional contributions will come primarily from hardware component manufacturers and members of the community.
ECMA-419, ECMAScript® embedded systems API specification provides normative definitions of class patterns and the host provider. For example, the sensor class pattern defines the requirements and guidelines for ECMAScript Modules that provide access to sensor hardware. The class specifications for embedded hardware components repository is a non-normative collection of documentation for specific instances of those class patterns—i.e., ECMAScript modules for specific hardware components and embedded hosts.
The Class Patterns in ECMA-419, ECMAScript® embedded systems API specification specify the baseline API for hardware components that fill common roles in an embedded system: sensor, display, IO provider, etc. The implementation of a class for a specific hardware component adapts the API to the unique capabilities of the component. This is done in ways permitted by the class pattern. The class specifications for embedded hardware components describe the ways in which a specific hardware component has adapted a given class pattern.
These are some ways that the class patterns may be adapted to provide access to the diverse capabilities of individual hardware components:
- Adding methods
- Removing methods unsupported by the hardware
- Adding properties to options objects
- Adding values for existing properties
In addition, the specification gives the host responsibility for some choices. The documents for hosts in class specifications for embedded hardware components describe those choices. They include:
- Modules that are available
- Values of pin specifiers
- Values of port specifiers
"COPYRIGHT NOTICE
© 2021 Ecma International
This document may be copied, published and distributed to others, and certain derivative works of it may be prepared, copied, published, and distributed, in whole or in part, provided that the above copyright notice and this Copyright License and Disclaimer are included on all such copies and derivative works. The only derivative works that are permissible under this Copyright License and Disclaimer are:
(i) works which incorporate all or portion of this document for the purpose of providing commentary or explanation (such as an annotated version of the document),
(ii) works which incorporate all or portion of this document for the purpose of incorporating features that provide accessibility,
(iii) translations of this document into languages other than English and into different formats and
(iv) works by making use of this specification in standard conformant products by implementing (e.g. by copy and paste wholly or partly) the functionality therein.
However, the content of this document itself may not be modified in any way, including by removing the copyright notice or references to Ecma International, except as required to translate it into languages other than English or into a different format.
The official version of an Ecma International document is the English language version on the Ecma International website. In the event of discrepancies between a translated version and the official version, the official version shall govern.
The limited permissions granted above are perpetual and will not be revoked by Ecma International or its successors or assigns.
This document and the information contained herein is provided on an "AS IS" basis and ECMA INTERNATIONAL DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION HEREIN WILL NOT INFRINGE ANY OWNERSHIP RIGHTS OR ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE."