https://github.com/wooorm/iso-639-3
Info on ISO 639-3
https://github.com/wooorm/iso-639-3
code iso language name
Last synced: about 1 month ago
JSON representation
Info on ISO 639-3
- Host: GitHub
- URL: https://github.com/wooorm/iso-639-3
- Owner: wooorm
- License: mit
- Created: 2014-09-30T12:38:32.000Z (about 11 years ago)
- Default Branch: main
- Last Pushed: 2023-11-01T10:37:05.000Z (about 2 years ago)
- Last Synced: 2025-03-29T10:06:53.892Z (8 months ago)
- Topics: code, iso, language, name
- Language: JavaScript
- Homepage:
- Size: 588 KB
- Stars: 58
- Watchers: 4
- Forks: 12
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- Funding: funding.yml
- License: license
Awesome Lists containing this project
README
# iso-639-3
[![Build][build-badge]][build]
[![Coverage][coverage-badge]][coverage]
[![Downloads][downloads-badge]][downloads]
[![Size][size-badge]][size]
Info on ISO 639-3.
## Contents
* [What is this?](#what-is-this)
* [When should I use this?](#when-should-i-use-this)
* [Install](#install)
* [Use](#use)
* [API](#api)
* [`iso6393`](#iso6393)
* [`iso6393To1`](#iso6393to1)
* [`iso6393To2B`](#iso6393to2b)
* [`iso6393To2T`](#iso6393to2t)
* [Types](#types)
* [Compatibility](#compatibility)
* [Security](#security)
* [Related](#related)
* [Contribute](#contribute)
* [License](#license)
## What is this?
This package contains info on [ISO 639-3][iso].
ISO 639-3 is a set of codes that defines three letter identifiers for all known
human languages, whether living, extinct, ancient, historic, or constructed.
## When should I use this?
You can use this package any time you have to deal with languages or ISO 639-3
in particular.
## Install
This package is [ESM only][esm].
In Node.js (version 14.14+, 16.0+), install with [npm][]:
```sh
npm install iso-639-3
```
In Deno with [`esm.sh`][esmsh]:
```js
import {iso6393} from 'https://esm.sh/iso-639-3@3'
```
In browsers with [`esm.sh`][esmsh]:
```html
import {iso6393} from 'https://esm.sh/iso-639-3@3?bundle'
```
## Use
```js
import {iso6393} from 'iso-639-3'
console.log(iso6393.slice(1820, 1830))
```
Yields:
```js
[
{name: 'En', type: 'living', scope: 'individual', iso6393: 'enc'},
{name: 'Ende', type: 'living', scope: 'individual', iso6393: 'end'},
{name: 'Forest Enets', type: 'living', scope: 'individual', iso6393: 'enf'},
{
name: 'English',
type: 'living',
scope: 'individual',
iso6393: 'eng',
iso6392B: 'eng',
iso6392T: 'eng',
iso6391: 'en'
},
{name: 'Tundra Enets', type: 'living', scope: 'individual', iso6393: 'enh'},
{name: 'Enlhet', type: 'living', scope: 'individual', iso6393: 'enl'},
{
name: 'Middle English (1100-1500)',
type: 'historical',
scope: 'individual',
iso6393: 'enm',
iso6392B: 'enm',
iso6392T: 'enm'
},
{name: 'Engenni', type: 'living', scope: 'individual', iso6393: 'enn'},
{name: 'Enggano', type: 'living', scope: 'individual', iso6393: 'eno'},
{name: 'Enga', type: 'living', scope: 'individual', iso6393: 'enq'}
]
```
## API
This package exports the identifier `iso6393`, `iso6393To1`, `iso6393To2B`, and
`iso6393To2T`.
There is no default export.
### `iso6393`
List of [`Language`][language]s (`Array`).
#### `Language`
Object representing a language:
* `name` (`string`)
— name (example: `'English'`)
* `type` (`string`)
— [`Type`][type] (example: `'living'`)
* `scope` (`string`)
— [`Scope`][scope] (example: `'individual'`)
* `iso6393` (`string`)
— ISO 639-3 code (example: `'eng'`)
* `iso6392B` (`string?`)
— ISO 639-2 (bibliographic) code (example: `'eng'`)
* `iso6392T` (`string?`)
— ISO 639-2 (terminologic) code (example: `'eng'`)
* `iso6391` (`string?`) — ISO 639-1 code
— ISO 639-1 code (example: `'en'`)
#### `Type`
Category of a language:
* `'living'`
— currently spoken language
(example: `nhi` for `Zacatlán-Ahuacatlán-Tepetzintla Nahuatl`)
* `'historical'`
— extinct language distinct from modern languages that descended from it
(example: `ofs` for `Old Frisian`)
* `'extinct'`
— language that went extinct recently
(example: `rbp` for `Barababaraba`)
* `'ancient'`
— language that went extinct long ago
(example: `got` for `Gothic`)
* `'constructed'`
— artificial languages, excluding programming languages
(example: `epo` for `Esperanto`)
* `'special'`
— non-language codes
(example: `und` for `Undetermined`)
#### `Scope`
Scope of a language:
* `'individual'`
— normal, single language
(example: `eng` for `English`)
* `'macrolanguage'`
— one-to-many grouping of languages, because older ISO 639s included them
(example: `ara` for `Arabic`)
* `'special'`
— non-language codes
(example: `und` for `Undetermined`)
### `iso6393To1`
Map of ISO 639-3 codes to ISO 639-1 codes (`Record`).
### `iso6393To2B`
Map of ISO 639-3 codes to bibliographic ISO 639-2 codes
(`Record`).
### `iso6393To2T`
Map of ISO 639-3 codes to terminologic ISO 639-2 codes
(`Record`).
## Types
This package is fully typed with [TypeScript][].
It exports the additional types `Language`, `Scope`, and `Type`.
## Compatibility
This package is at least compatible with all maintained versions of Node.js.
As of now, that is Node.js 14.14+ and 16.0+.
It also works in Deno and modern browsers.
## Security
This package is safe.
## Related
* [`bcp-47`](https://github.com/wooorm/bcp-47)
— Parse and serialize BCP 47 language tags
* [`bcp-47-match`](https://github.com/wooorm/bcp-47-match)
— Match BCP 47 language tags with language ranges per RFC 4647
* [`bcp-47-normalize`](https://github.com/wooorm/bcp-47-normalize)
— Normalize, canonicalize, and format BCP 47 tags
* [`iso-3166`](https://github.com/wooorm/iso-3166)
— ISO 3166 codes
* [`iso-639-2`](https://github.com/wooorm/iso-639-2)
— ISO 639-2 codes
* [`iso-15924`](https://github.com/wooorm/iso-15924)
— ISO 15924 codes
* [`un-m49`](https://github.com/wooorm/un-m49)
— UN M49 codes
## Contribute
Yes please!
See [How to Contribute to Open Source][contribute].
## License
[MIT][license] © [Titus Wormer][author]
[build-badge]: https://github.com/wooorm/iso-639-3/workflows/main/badge.svg
[build]: https://github.com/wooorm/iso-639-3/actions
[coverage-badge]: https://img.shields.io/codecov/c/github/wooorm/iso-639-3.svg
[coverage]: https://codecov.io/github/wooorm/iso-639-3
[downloads-badge]: https://img.shields.io/npm/dm/iso-639-3.svg
[downloads]: https://www.npmjs.com/package/iso-639-3
[size-badge]: https://img.shields.io/bundlephobia/minzip/iso-639-3.svg
[size]: https://bundlephobia.com/result?p=iso-639-3
[npm]: https://docs.npmjs.com/cli/install
[esmsh]: https://esm.sh
[license]: license
[author]: https://wooorm.com
[esm]: https://gist.github.com/sindresorhus/a39789f98801d908bbc7ff3ecc99d99c
[typescript]: https://www.typescriptlang.org
[contribute]: https://opensource.guide/how-to-contribute/
[iso]: https://iso639-3.sil.org
[language]: #language
[type]: #type
[scope]: #scope