UNPKG

macintosh

Version:

A robust macintosh encoder/decoder written in JavaScript.

78 lines (51 loc) 3.19 kB
# macintosh [![Build status](https://github.com/mathiasbynens/macintosh/workflows/run-checks/badge.svg)](https://github.com/mathiasbynens/macintosh/actions?query=workflow%3Arun-checks) [![macintosh on npm](https://img.shields.io/npm/v/macintosh)](https://www.npmjs.com/package/macintosh) _macintosh_ is a robust JavaScript implementation of [the macintosh character encoding as defined by the Encoding Standard](https://encoding.spec.whatwg.org/#macintosh). This encoding is known under the following names: csmacintosh, mac, macintosh, and x-mac-roman. ## Installation Via [npm](https://www.npmjs.com/): ```bash npm install macintosh ``` In a browser or in [Node.js](https://nodejs.org/): ```js import {encode, decode, labels} from 'macintosh'; // or… import * as macintosh from 'macintosh'; ``` ## API ### `macintosh.labels` An array of strings, each representing a [label](https://encoding.spec.whatwg.org/#label) for this encoding. ### `macintosh.encode(input, options)` This function takes a plain text string (the `input` parameter) and encodes it according to macintosh. The return value is an environment-agnostic `Uint16Array` of which each element represents an octet as per macintosh. ```js const encodedData = macintosh.encode(text); ``` The optional `options` object and its `mode` property can be used to set the error mode. The two available error modes are `'fatal'` (the default) or `'replacement'`. (Note: This differs from [the spec](https://encoding.spec.whatwg.org/#error-mode), which recognizes “fatal” and HTML” modes for encoders. The reason behind this difference is that the spec algorithm is aimed at producing HTML, whereas this library encodes into an environment-agnostic `Uint16Array` of bytes.) ```js const encodedData = macintosh.encode(text, { mode: 'replacement' }); // If `text` contains a symbol that cannot be represented in macintosh, // instead of throwing an error, it becomes 0xFFFD. ``` ### `macintosh.decode(input, options)` This function decodes `input` according to macintosh. The `input` parameter can either be a `Uint16Array` of which each element represents an octet as per macintosh, or a ‘byte string’ (i.e. a string of which each item represents an octet as per macintosh). ```js const text = macintosh.decode(encodedData); ``` The optional `options` object and its `mode` property can be used to set the [error mode](https://encoding.spec.whatwg.org/#error-mode). For decoding, the error mode can be `'replacement'` (the default) or `'fatal'`. ```js const text = macintosh.decode(encodedData, { mode: 'fatal' }); // If `encodedData` contains an invalid byte for the macintosh encoding, // instead of replacing it with U+FFFD in the output, an error is thrown. ``` ## Notes [Similar modules for other single-byte legacy encodings are available.](https://www.npmjs.com/browse/keyword/legacy-encoding) ## Author | [![twitter/mathias](https://gravatar.com/avatar/24e08a9ea84deb17ae121074d0f17125?s=70)](https://twitter.com/mathias "Follow @mathias on Twitter") | |---| | [Mathias Bynens](https://mathiasbynens.be/) | ## License _macintosh_ is available under the [MIT](https://mths.be/mit) license.