@fgv/ts-bcp47 0.5.0 → 0.5.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (32) hide show
  1. package/bcp47/languageRegistryData.d.ts +88 -0
  2. package/bcp47/languageRegistryData.d.ts.map +1 -0
  3. package/bcp47/languageRegistryData.js +144 -0
  4. package/bcp47/languageTag.d.ts +6 -0
  5. package/bcp47/languageTag.d.ts.map +1 -1
  6. package/bcp47/languageTag.js +3 -1
  7. package/bcp47/match/chooser.d.ts +1 -1
  8. package/bcp47/match/chooser.js +1 -1
  9. package/bcp47/overrides/defaultRegistries.js +2 -2
  10. package/bcp47/overrides/overridesRegistry.d.ts +2 -0
  11. package/bcp47/overrides/overridesRegistry.d.ts.map +1 -1
  12. package/bcp47/overrides/overridesRegistry.js +16 -5
  13. package/data/unsd/m49.json +251 -0
  14. package/iana/defaultRegistries.js +2 -2
  15. package/iana/language-subtags/jarConverters.d.ts +12 -12
  16. package/iana/language-subtags/jarConverters.d.ts.map +1 -1
  17. package/iana/language-subtags/jarConverters.js +1 -1
  18. package/iana/language-subtags/subtagRegistry.d.ts +2 -0
  19. package/iana/language-subtags/subtagRegistry.d.ts.map +1 -1
  20. package/iana/language-subtags/subtagRegistry.js +11 -1
  21. package/iana/language-tag-extensions/extensionsRegistry.d.ts +2 -0
  22. package/iana/language-tag-extensions/extensionsRegistry.d.ts.map +1 -1
  23. package/iana/language-tag-extensions/extensionsRegistry.js +11 -1
  24. package/iana/languageRegistries.d.ts +1 -0
  25. package/iana/languageRegistries.d.ts.map +1 -1
  26. package/iana/languageRegistries.js +8 -1
  27. package/package.json +1 -1
  28. package/unsd/defaultRegistries.js +2 -2
  29. package/unsd/regionCodes.d.ts +4 -2
  30. package/unsd/regionCodes.d.ts.map +1 -1
  31. package/unsd/regionCodes.js +18 -8
  32. package/data/unsd/m49.csv +0 -250
@@ -0,0 +1,88 @@
1
+ import * as Iana from '../iana';
2
+ import { Subtags } from './common';
3
+ /**
4
+ * Returns all of the data in the IANA language subtags registry for
5
+ * a set of supplied {@link Bcp47.Subtags | subtags}.
6
+ * @public
7
+ */
8
+ export declare class LanguageRegistryData {
9
+ /**
10
+ * @internal
11
+ */
12
+ protected _iana: Iana.LanguageRegistries;
13
+ /**
14
+ * @internal
15
+ */
16
+ protected _subtags: Subtags;
17
+ /**
18
+ * @internal
19
+ */
20
+ protected _primaryLanguage?: Iana.LanguageSubtags.Model.RegisteredLanguage | false;
21
+ /**
22
+ * @internal
23
+ */
24
+ protected _extlangs?: Iana.LanguageSubtags.Model.RegisteredExtLang[] | false;
25
+ /**
26
+ * @internal
27
+ */
28
+ protected _script?: Iana.LanguageSubtags.Model.RegisteredScript | false;
29
+ /**
30
+ * @internal
31
+ */
32
+ protected _region?: Iana.LanguageSubtags.Model.RegisteredRegion | false;
33
+ /**
34
+ * @internal
35
+ */
36
+ protected _grandfathered?: Iana.LanguageSubtags.Model.RegisteredGrandfatheredTag | false;
37
+ /**
38
+ * Constructs a new {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}
39
+ * from a supplied {@link Bcp47.Subtags | subtags} and {@link Iana.LanguageRegistries | language registries}.
40
+ * @public
41
+ */
42
+ constructor(subtags: Subtags, iana: Iana.LanguageRegistries);
43
+ /**
44
+ * Registry data associated with the primary language subtag of the language tag from
45
+ * which this {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}
46
+ * was constructed, or `undefined` if the primary language is missing or invalid.
47
+ * @public
48
+ */
49
+ get primaryLanguage(): Iana.LanguageSubtags.Model.RegisteredLanguage | undefined;
50
+ /**
51
+ * Registry data associated with the extlang subtag of the language tag from
52
+ * which this {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}
53
+ * was constructed, or `undefined` if extlang is missing or invalid.
54
+ * @public
55
+ */
56
+ get extlangs(): Iana.LanguageSubtags.Model.RegisteredExtLang[] | undefined;
57
+ /**
58
+ * Registry data associated with the script of the language tag from
59
+ * which this {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}
60
+ * was constructed, or `undefined` if the script cannot be determined.
61
+ *
62
+ * Note that script will default to the registry `Suppress-Script` value of the
63
+ * primary language if no script subtag is present.
64
+ * @public
65
+ */
66
+ get script(): Iana.LanguageSubtags.Model.RegisteredScript | undefined;
67
+ /**
68
+ * Registry data associated with the region subtag of the language tag from
69
+ * which this {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}
70
+ * was constructed, or `undefined` if the region is missing or invalid.
71
+ * @public
72
+ */
73
+ get region(): Iana.LanguageSubtags.Model.RegisteredRegion | undefined;
74
+ /**
75
+ * Registry data for grandfathered tags, or `undefined` if the tag is not recognized
76
+ * as a grandfathered tag.
77
+ * @public
78
+ */
79
+ get grandfathered(): Iana.LanguageSubtags.Model.RegisteredGrandfatheredTag | undefined;
80
+ /**
81
+ * @returns A string representation of the subtags from which this
82
+ * {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}
83
+ * was created.
84
+ * @public
85
+ */
86
+ toString(): string;
87
+ }
88
+ //# sourceMappingURL=languageRegistryData.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"languageRegistryData.d.ts","sourceRoot":"","sources":["../../src/bcp47/languageRegistryData.ts"],"names":[],"mappings":"AAsBA,OAAO,KAAK,IAAI,MAAM,SAAS,CAAC;AAEhC,OAAO,EAAE,OAAO,EAAmB,MAAM,UAAU,CAAC;AAEpD;;;;GAIG;AACH,qBAAa,oBAAoB;IAC7B;;OAEG;IACH,SAAS,CAAC,KAAK,EAAE,IAAI,CAAC,kBAAkB,CAAC;IACzC;;OAEG;IACH,SAAS,CAAC,QAAQ,EAAE,OAAO,CAAC;IAC5B;;OAEG;IACH,SAAS,CAAC,gBAAgB,CAAC,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,kBAAkB,GAAG,KAAK,CAAC;IACnF;;OAEG;IACH,SAAS,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,iBAAiB,EAAE,GAAG,KAAK,CAAC;IAC7E;;OAEG;IACH,SAAS,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,gBAAgB,GAAG,KAAK,CAAC;IACxE;;OAEG;IACH,SAAS,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,gBAAgB,GAAG,KAAK,CAAC;IACxE;;OAEG;IACH,SAAS,CAAC,cAAc,CAAC,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,0BAA0B,GAAG,KAAK,CAAC;IAEzF;;;;OAIG;gBACgB,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,kBAAkB;IAKlE;;;;;OAKG;IACH,IAAW,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,kBAAkB,GAAG,SAAS,CAKtF;IAED;;;;;OAKG;IACH,IAAW,QAAQ,IAAI,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,iBAAiB,EAAE,GAAG,SAAS,CAYhF;IAED;;;;;;;;OAQG;IACH,IAAW,MAAM,IAAI,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,gBAAgB,GAAG,SAAS,CAgB3E;IAED;;;;;OAKG;IACH,IAAW,MAAM,IAAI,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,gBAAgB,GAAG,SAAS,CAU3E;IAED;;;;OAIG;IACH,IAAW,aAAa,IAAI,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,0BAA0B,GAAG,SAAS,CAU5F;IAED;;;;;OAKG;IACI,QAAQ,IAAI,MAAM;CAG5B"}
@@ -0,0 +1,144 @@
1
+ "use strict";
2
+ /*
3
+ * Copyright (c) 2022 Erik Fortune
4
+ *
5
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ * of this software and associated documentation files (the "Software"), to deal
7
+ * in the Software without restriction, including without limitation the rights
8
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ * copies of the Software, and to permit persons to whom the Software is
10
+ * furnished to do so, subject to the following conditions:
11
+ *
12
+ * The above copyright notice and this permission notice shall be included in all
13
+ * copies or substantial portions of the Software.
14
+ *
15
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ * SOFTWARE.
22
+ */
23
+ Object.defineProperty(exports, "__esModule", { value: true });
24
+ exports.LanguageRegistryData = void 0;
25
+ const common_1 = require("./common");
26
+ /**
27
+ * Returns all of the data in the IANA language subtags registry for
28
+ * a set of supplied {@link Bcp47.Subtags | subtags}.
29
+ * @public
30
+ */
31
+ class LanguageRegistryData {
32
+ /**
33
+ * Constructs a new {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}
34
+ * from a supplied {@link Bcp47.Subtags | subtags} and {@link Iana.LanguageRegistries | language registries}.
35
+ * @public
36
+ */
37
+ constructor(subtags, iana) {
38
+ this._iana = iana;
39
+ this._subtags = subtags;
40
+ }
41
+ /**
42
+ * Registry data associated with the primary language subtag of the language tag from
43
+ * which this {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}
44
+ * was constructed, or `undefined` if the primary language is missing or invalid.
45
+ * @public
46
+ */
47
+ get primaryLanguage() {
48
+ var _a;
49
+ if (this._primaryLanguage === undefined) {
50
+ this._primaryLanguage = (_a = this._iana.subtags.languages.tryGet(this._subtags.primaryLanguage)) !== null && _a !== void 0 ? _a : false;
51
+ }
52
+ return this._primaryLanguage ? this._primaryLanguage : undefined;
53
+ }
54
+ /**
55
+ * Registry data associated with the extlang subtag of the language tag from
56
+ * which this {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}
57
+ * was constructed, or `undefined` if extlang is missing or invalid.
58
+ * @public
59
+ */
60
+ get extlangs() {
61
+ if (this._extlangs === undefined) {
62
+ if (this._subtags.extlangs !== undefined) {
63
+ this._extlangs = this._subtags.extlangs
64
+ .map((e) => this._iana.subtags.extlangs.tryGet(e))
65
+ .filter((e) => e !== undefined);
66
+ }
67
+ if (!this._subtags.extlangs || this._subtags.extlangs.length === 0) {
68
+ this._extlangs = false;
69
+ }
70
+ }
71
+ return this._extlangs ? this._extlangs : undefined;
72
+ }
73
+ /**
74
+ * Registry data associated with the script of the language tag from
75
+ * which this {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}
76
+ * was constructed, or `undefined` if the script cannot be determined.
77
+ *
78
+ * Note that script will default to the registry `Suppress-Script` value of the
79
+ * primary language if no script subtag is present.
80
+ * @public
81
+ */
82
+ get script() {
83
+ var _a;
84
+ if (this._script === undefined) {
85
+ if (this._subtags.script) {
86
+ this._script = this._iana.subtags.scripts.tryGet(this._subtags.script);
87
+ }
88
+ if (!this._script) {
89
+ const suppressed = (_a = this.primaryLanguage) === null || _a === void 0 ? void 0 : _a.suppressScript;
90
+ if (suppressed) {
91
+ this._script = this._iana.subtags.scripts.tryGet(suppressed);
92
+ }
93
+ }
94
+ if (!this._script) {
95
+ this._script = false;
96
+ }
97
+ }
98
+ return this._script ? this._script : undefined;
99
+ }
100
+ /**
101
+ * Registry data associated with the region subtag of the language tag from
102
+ * which this {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}
103
+ * was constructed, or `undefined` if the region is missing or invalid.
104
+ * @public
105
+ */
106
+ get region() {
107
+ if (this._region === undefined) {
108
+ if (this._subtags.region) {
109
+ this._region = this._iana.subtags.regions.tryGet(this._subtags.region);
110
+ }
111
+ if (!this._region) {
112
+ this._region = false;
113
+ }
114
+ }
115
+ return this._region ? this._region : undefined;
116
+ }
117
+ /**
118
+ * Registry data for grandfathered tags, or `undefined` if the tag is not recognized
119
+ * as a grandfathered tag.
120
+ * @public
121
+ */
122
+ get grandfathered() {
123
+ if (this._grandfathered === undefined) {
124
+ if (this._subtags.grandfathered) {
125
+ this._grandfathered = this._iana.subtags.grandfathered.tryGet(this._subtags.grandfathered);
126
+ }
127
+ if (!this._grandfathered) {
128
+ this._grandfathered = false;
129
+ }
130
+ }
131
+ return this._grandfathered ? this._grandfathered : undefined;
132
+ }
133
+ /**
134
+ * @returns A string representation of the subtags from which this
135
+ * {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}
136
+ * was created.
137
+ * @public
138
+ */
139
+ toString() {
140
+ return (0, common_1.subtagsToString)(this._subtags);
141
+ }
142
+ }
143
+ exports.LanguageRegistryData = LanguageRegistryData;
144
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"languageRegistryData.js","sourceRoot":"","sources":["../../src/bcp47/languageRegistryData.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2022 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n\nimport * as Iana from '../iana';\n\nimport { Subtags, subtagsToString } from './common';\n\n/**\n * Returns all of the data in the IANA language subtags registry for\n * a set of supplied {@link Bcp47.Subtags | subtags}.\n * @public\n */\nexport class LanguageRegistryData {\n    /**\n     * @internal\n     */\n    protected _iana: Iana.LanguageRegistries;\n    /**\n     * @internal\n     */\n    protected _subtags: Subtags;\n    /**\n     * @internal\n     */\n    protected _primaryLanguage?: Iana.LanguageSubtags.Model.RegisteredLanguage | false;\n    /**\n     * @internal\n     */\n    protected _extlangs?: Iana.LanguageSubtags.Model.RegisteredExtLang[] | false;\n    /**\n     * @internal\n     */\n    protected _script?: Iana.LanguageSubtags.Model.RegisteredScript | false;\n    /**\n     * @internal\n     */\n    protected _region?: Iana.LanguageSubtags.Model.RegisteredRegion | false;\n    /**\n     * @internal\n     */\n    protected _grandfathered?: Iana.LanguageSubtags.Model.RegisteredGrandfatheredTag | false;\n\n    /**\n     * Constructs a new {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}\n     * from a supplied {@link Bcp47.Subtags | subtags} and {@link Iana.LanguageRegistries | language registries}.\n     * @public\n     */\n    public constructor(subtags: Subtags, iana: Iana.LanguageRegistries) {\n        this._iana = iana;\n        this._subtags = subtags;\n    }\n\n    /**\n     * Registry data associated with the primary language subtag of the language tag from\n     * which this {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}\n     * was constructed, or `undefined` if the primary language is missing or invalid.\n     * @public\n     */\n    public get primaryLanguage(): Iana.LanguageSubtags.Model.RegisteredLanguage | undefined {\n        if (this._primaryLanguage === undefined) {\n            this._primaryLanguage = this._iana.subtags.languages.tryGet(this._subtags.primaryLanguage) ?? false;\n        }\n        return this._primaryLanguage ? this._primaryLanguage : undefined;\n    }\n\n    /**\n     * Registry data associated with the extlang subtag of the language tag from\n     * which this {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}\n     * was constructed, or `undefined` if extlang is missing or invalid.\n     * @public\n     */\n    public get extlangs(): Iana.LanguageSubtags.Model.RegisteredExtLang[] | undefined {\n        if (this._extlangs === undefined) {\n            if (this._subtags.extlangs !== undefined) {\n                this._extlangs = this._subtags.extlangs\n                    .map((e) => this._iana.subtags.extlangs.tryGet(e))\n                    .filter((e): e is Iana.LanguageSubtags.Model.RegisteredExtLang => e !== undefined);\n            }\n            if (!this._subtags.extlangs || this._subtags.extlangs.length === 0) {\n                this._extlangs = false;\n            }\n        }\n        return this._extlangs ? this._extlangs : undefined;\n    }\n\n    /**\n     * Registry data associated with the script of the language tag from\n     * which this {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}\n     * was constructed, or `undefined` if the script cannot be determined.\n     *\n     * Note that script will default to the registry `Suppress-Script` value of the\n     * primary language if no script subtag is present.\n     * @public\n     */\n    public get script(): Iana.LanguageSubtags.Model.RegisteredScript | undefined {\n        if (this._script === undefined) {\n            if (this._subtags.script) {\n                this._script = this._iana.subtags.scripts.tryGet(this._subtags.script);\n            }\n            if (!this._script) {\n                const suppressed = this.primaryLanguage?.suppressScript;\n                if (suppressed) {\n                    this._script = this._iana.subtags.scripts.tryGet(suppressed);\n                }\n            }\n            if (!this._script) {\n                this._script = false;\n            }\n        }\n        return this._script ? this._script : undefined;\n    }\n\n    /**\n     * Registry data associated with the region subtag of the language tag from\n     * which this {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}\n     * was constructed, or `undefined` if the region is missing or invalid.\n     * @public\n     */\n    public get region(): Iana.LanguageSubtags.Model.RegisteredRegion | undefined {\n        if (this._region === undefined) {\n            if (this._subtags.region) {\n                this._region = this._iana.subtags.regions.tryGet(this._subtags.region);\n            }\n            if (!this._region) {\n                this._region = false;\n            }\n        }\n        return this._region ? this._region : undefined;\n    }\n\n    /**\n     * Registry data for grandfathered tags, or `undefined` if the tag is not recognized\n     * as a grandfathered tag.\n     * @public\n     */\n    public get grandfathered(): Iana.LanguageSubtags.Model.RegisteredGrandfatheredTag | undefined {\n        if (this._grandfathered === undefined) {\n            if (this._subtags.grandfathered) {\n                this._grandfathered = this._iana.subtags.grandfathered.tryGet(this._subtags.grandfathered);\n            }\n            if (!this._grandfathered) {\n                this._grandfathered = false;\n            }\n        }\n        return this._grandfathered ? this._grandfathered : undefined;\n    }\n\n    /**\n     * @returns A string representation of the subtags from which this\n     * {@link Bcp47.LanguageTagRegistryData | Bcp47.LanguageTagRegistryData}\n     * was created.\n     * @public\n     */\n    public toString(): string {\n        return subtagsToString(this._subtags);\n    }\n}\n"]}
@@ -3,6 +3,7 @@ import { Result } from '@fgv/ts-utils';
3
3
  import { Subtags } from './common';
4
4
  import { TagNormalization } from './normalization/common';
5
5
  import { TagValidity } from './validation/common';
6
+ import { LanguageRegistryData } from './languageRegistryData';
6
7
  import { ScriptSubtag } from '../iana/language-subtags';
7
8
  /**
8
9
  * Initialization options for parsing or creation of {@link Bcp47.LanguageTag | language tag} objects.
@@ -37,6 +38,11 @@ export declare class LanguageTag {
37
38
  * A string representation of this language tag.
38
39
  */
39
40
  readonly tag: string;
41
+ /**
42
+ * Details about this language tag from the IANA language
43
+ * registries.
44
+ */
45
+ readonly registry: LanguageRegistryData;
40
46
  /**
41
47
  * @internal
42
48
  */
@@ -1 +1 @@
1
- {"version":3,"file":"languageTag.d.ts","sourceRoot":"","sources":["../../src/bcp47/languageTag.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"languageTag.d.ts","sourceRoot":"","sources":["../../src/bcp47/languageTag.ts"],"names":[],"mappings":"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"}
@@ -50,6 +50,7 @@ const ts_utils_1 = require("@fgv/ts-utils");
50
50
  const common_1 = require("./common");
51
51
  const common_2 = require("./normalization/common");
52
52
  const common_3 = require("./validation/common");
53
+ const languageRegistryData_1 = require("./languageRegistryData");
53
54
  const languageTagParser_1 = require("./languageTagParser");
54
55
  const normalization_1 = require("./normalization");
55
56
  const validation_1 = require("./validation");
@@ -76,6 +77,7 @@ class LanguageTag {
76
77
  this._validity = validity;
77
78
  this.tag = (0, common_1.subtagsToString)(subtags);
78
79
  this._iana = iana;
80
+ this.registry = new languageRegistryData_1.LanguageRegistryData(this.subtags, iana);
79
81
  if (validity === 'strictly-valid') {
80
82
  this._isStrictlyValid = true;
81
83
  this._isValid = true;
@@ -339,4 +341,4 @@ class LanguageTag {
339
341
  }
340
342
  }
341
343
  exports.LanguageTag = LanguageTag;
342
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"languageTag.js","sourceRoot":"","sources":["../../src/bcp47/languageTag.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2022 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n\nimport * as Iana from '../iana';\n\nimport { Result, captureResult, succeed } from '@fgv/ts-utils';\nimport { Subtags, UndeterminedLanguage, subtagsToString } from './common';\nimport { TagNormalization, mostNormalized } from './normalization/common';\nimport { TagValidity, mostValid } from './validation/common';\n\nimport { LanguageTagParser } from './languageTagParser';\nimport { NormalizeTag } from './normalization';\nimport { ScriptSubtag } from '../iana/language-subtags';\nimport { ValidateTag } from './validation';\n\n/**\n * Initialization options for parsing or creation of {@link Bcp47.LanguageTag | language tag} objects.\n * @public\n */\nexport interface LanguageTagInitOptions {\n    /**\n     * Desired {@link Bcp47.TagValidity | validity level} (optional).\n     */\n    validity?: TagValidity;\n    /**\n     * Desired {@link Bcp47.TagNormalization | normalization level} (optional).\n     */\n    normalization?: TagNormalization;\n    /**\n     * The {@link Iana.LanguageRegistries | IANA language subtag and extension registries} to\n     * be used for the request (optional).\n     */\n    iana?: Iana.LanguageRegistries;\n}\n\n/**\n * Represents a single BCP-47 language tag.\n * @public\n */\nexport class LanguageTag {\n    /**\n     * The individual {@link Bcp47.Subtags | subtags} for\n     * this language tag.\n     */\n    public readonly subtags: Readonly<Subtags>;\n\n    /**\n     * A string representation of this language tag.\n     */\n    public readonly tag: string;\n\n    /**\n     * @internal\n     */\n    protected readonly _iana: Iana.LanguageRegistries;\n\n    /**\n     * @internal\n     */\n    protected _validity: TagValidity;\n\n    /**\n     * @internal\n     */\n    protected _normalization: TagNormalization;\n\n    /**\n     * @internal\n     */\n    protected _isValid: undefined | boolean;\n\n    /**\n     * @internal\n     */\n    protected _isStrictlyValid: undefined | boolean;\n\n    /**\n     * @internal\n     */\n    protected _isCanonical: undefined | boolean;\n\n    /**\n     * @internal\n     */\n    protected _isPreferred: undefined | boolean;\n\n    /**\n     * @internal\n     */\n    protected _suppressedScript: undefined | ScriptSubtag | false;\n\n    /**\n     * Constructs a {@link Bcp47.LanguageTag | LanguageTag }.\n     * @param subtags - The {@link Bcp47.Subtags | subtags } from\n     * which the tag is constructed.\n     * @param validity - Known {@link Bcp47.TagValidity | validation level} of the\n     * supplied subtags.\n     * @param normalization - Known {@link Bcp47.TagNormalization | normalization level}\n     * of the supplied subtags.\n     * @param iana - The {@link Iana.LanguageRegistries} used to validate and normalize\n     * this tag.\n     * @internal\n     */\n    protected constructor(subtags: Subtags, validity: TagValidity, normalization: TagNormalization, iana: Iana.LanguageRegistries) {\n        this.subtags = Object.freeze({ ...subtags });\n        this._normalization = normalization;\n        this._validity = validity;\n        this.tag = subtagsToString(subtags);\n        this._iana = iana;\n\n        if (validity === 'strictly-valid') {\n            this._isStrictlyValid = true;\n            this._isValid = true;\n        } else if (validity === 'valid') {\n            this._isValid = true;\n        }\n\n        if (normalization === 'preferred') {\n            this._isPreferred = true;\n            this._isCanonical = true;\n        } else if (normalization === 'canonical') {\n            this._isCanonical = true;\n        }\n    }\n\n    /**\n     * The effective script of this language tag, if known.\n     * The effective script is the script subtag in the tag itself,\n     * if present, or the `Suppress-Script` defined in the\n     * {@link https://www.iana.org/assignments/language-subtag-registry/language-subtag-registry | IANA subtag registry}\n     * for the primary language of this tag.  Can be `undefined`\n     * if neither the tag nor the IANA registry define a script.\n     */\n    public get effectiveScript(): ScriptSubtag | undefined {\n        return this.subtags.script ?? this.getSuppressedScript();\n    }\n\n    /**\n     * Determines if this tag represents the special `undetermined` language.\n     */\n    public get isUndetermined(): boolean {\n        // istanbul ignore next\n        return this.subtags.primaryLanguage?.toLowerCase() === UndeterminedLanguage;\n    }\n\n    /**\n     * Whether this language tag is valid.\n     */\n    public get isValid(): boolean {\n        if (this._isValid === undefined) {\n            this._isValid = ValidateTag.isValid(this.subtags);\n            if (this._isValid) {\n                this._validity = 'valid';\n            }\n        }\n        return this._isValid === true;\n    }\n\n    /**\n     * Whether if this language tag is strictly valid.\n     */\n    public get isStrictlyValid(): boolean {\n        if (this._isStrictlyValid === undefined) {\n            this._isStrictlyValid = ValidateTag.isStrictlyValid(this.subtags);\n            if (this._isStrictlyValid) {\n                this._validity = 'strictly-valid';\n            }\n        }\n        return this._isStrictlyValid === true;\n    }\n\n    /**\n     * Whether this language tag is in canonical form.\n     */\n    public get isCanonical(): boolean {\n        if (this._isCanonical === undefined) {\n            this._isCanonical = ValidateTag.isCanonical(this.subtags);\n            if (this._isCanonical) {\n                this._normalization = 'canonical';\n            }\n        }\n        return this._isCanonical === true;\n    }\n\n    /**\n     * Whether this language tag is in preferred form.\n     */\n    public get isPreferred(): boolean {\n        if (this._isPreferred === undefined) {\n            this._isPreferred = ValidateTag.isInPreferredForm(this.subtags);\n            if (this._isPreferred) {\n                this._normalization = 'preferred';\n            }\n        }\n        return this._isPreferred === true;\n    }\n\n    /**\n     * Creates a new {@link Bcp47.LanguageTag | language tag} from a supplied `string` tag\n     * using optional configuration, if supplied.\n     * @param tag - The `string` tag from which the {@link Bcp47.LanguageTag | language tag}\n     * is te be constructed.\n     * @param options - (optional) set of {@link Bcp47.LanguageTagInitOptions | init options}\n     * to guide the validation and normalization of this tag.\n     * @returns `Success` with the new {@link Bcp47.LanguageTag | language tag} or `Failure`\n     * with details if an error occurs.\n     */\n    public static createFromTag(tag: string, options?: LanguageTagInitOptions): Result<LanguageTag> {\n        options = this._getOptions(options);\n\n        return LanguageTagParser.parse(tag, options.iana).onSuccess((subtags) => {\n            return this._createTransformed(subtags, 'unknown', 'unknown', options);\n        });\n    }\n\n    /**\n     * Creates a new {@link Bcp47.LanguageTag | language tag} from a supplied\n     * {@link Bcp47.Subtags | subtags} using optional configuration,\n     * if supplied.\n     * @param tag - The {@link Bcp47.Subtags | subtags} from which the\n     * {@link Bcp47.LanguageTag | language tag} is te be constructed.\n     * @param options - (optional) set of {@link Bcp47.LanguageTagInitOptions | init options}\n     * to guide the validation and normalization of this tag.\n     * @returns `Success` with the new {@link Bcp47.LanguageTag | language tag} or `Failure`\n     * with details if an error occurs.\n     */\n    public static createFromSubtags(subtags: Subtags, options?: LanguageTagInitOptions): Result<LanguageTag> {\n        return this._createTransformed(subtags, 'unknown', 'unknown', options);\n    }\n\n    /**\n     * Creates a new {@link Bcp47.LanguageTag | language tag} from a supplied `string`\n     * tag or {@link Bcp47.Subtags | subtags} using optional configuration,\n     * if supplied.\n     * @param from - The `string` tag or {@link Bcp47.Subtags | subtags} from\n     * which the {@link Bcp47.LanguageTag | language tag} is te be constructed.\n     * @param options - (optional) set of {@link Bcp47.LanguageTagInitOptions | init options}\n     * to guide the validation and normalization of this tag.\n     * @returns `Success` with the new {@link Bcp47.LanguageTag | language tag} or `Failure`\n     * with details if an error occurs.\n     */\n    public static create(from: string | Subtags, options?: LanguageTagInitOptions): Result<LanguageTag> {\n        if (typeof from === 'string') {\n            return this.createFromTag(from, options);\n        } else {\n            return this.createFromSubtags(from, options);\n        }\n    }\n\n    /**\n     * Constructs a new {@link Bcp47.LanguageTag | language tag} by applying appropriate transformations\n     * to as supplied {@link Bcp47.Subtags | Bcp47.Subtags}.\n     * @param subtags - The {@link Bcp47.Subtags | subtags} which represent the tag.\n     * @param fromValidity - The {@link Bcp47.TagValidity | validation level} of the supplied subtags.\n     * @param fromNormalization - The {@link Bcp47.TagNormalization | normalization level} fo the\n     * supplied subtags.\n     * @param partialOptions - Any {@link Bcp47.LanguageTagInitOptions | initialization options}.\n     * @returns `Success` with the corresponding {@link Bcp47.LanguageTag | language tag} or `Failure`\n     * with details if an error occurs.\n     * @internal\n     */\n    protected static _createTransformed(\n        subtags: Subtags,\n        fromValidity: TagValidity,\n        fromNormalization: TagNormalization,\n        partialOptions?: LanguageTagInitOptions\n    ): Result<LanguageTag> {\n        const options = this._getOptions(partialOptions);\n        return ValidateTag.validateSubtags(subtags, options.validity, fromValidity)\n            .onSuccess(() => {\n                return NormalizeTag.normalizeSubtags(subtags, options.normalization, fromNormalization);\n            })\n            .onSuccess((normalized) => {\n                const validity = mostValid(fromValidity, options.validity);\n                const normalization = mostNormalized(fromNormalization, options.normalization);\n                return captureResult(() => new LanguageTag(normalized, validity, normalization, options.iana));\n            });\n    }\n\n    /**\n     * Gets a fully-specified {@link Bcp47.LanguageTagInitOptions} from partial or undefined\n     * options, substituting defaults as appropriate.\n     * @param options - The {@link Bcp47.LanguageTagInitOptions} to be expanded, or `undefined`\n     * for default options.\n     * @returns Fully-specified {@link Bcp47.LanguageTagInitOptions | init options}.\n     * @internal\n     */\n    protected static _getOptions(options?: LanguageTagInitOptions): Required<LanguageTagInitOptions> {\n        return {\n            iana: options?.iana ?? Iana.DefaultRegistries.languageRegistries,\n            validity: options?.validity ?? 'well-formed',\n            normalization: options?.normalization ?? 'none',\n        };\n    }\n\n    /**\n     * Returns the `Suppress-Script` value defined for the primary language of this tag,\n     * regardless of whether a different script is defined in this subtag.\n     * @returns The suppress-script defined for the primary language, or undefined if\n     * the primary language is invalid or has no defined suppressed script.\n     */\n    public getSuppressedScript(): ScriptSubtag | undefined {\n        if (this._suppressedScript === undefined) {\n            this._suppressedScript = false;\n            if (this.subtags.primaryLanguage) {\n                const language = this._iana.subtags.languages.tryGet(this.subtags.primaryLanguage);\n                if (language?.suppressScript !== undefined) {\n                    this._suppressedScript = language.suppressScript;\n                }\n            }\n        }\n        return this._suppressedScript ? this._suppressedScript : undefined;\n    }\n\n    /**\n     * Gets a confirmed valid representation of this language tag.\n     * @returns `Success` with a valid representation of this {@link Bcp47.LanguageTag | language tag},\n     * or `Failure` with details if the tag cannot be validated.\n     */\n    public toValid(): Result<LanguageTag> {\n        if (this.isValid) {\n            return succeed(this);\n        }\n        const options: LanguageTagInitOptions = {\n            iana: this._iana,\n            validity: 'valid',\n            normalization: this._normalization,\n        };\n        return LanguageTag._createTransformed(this.subtags, this._validity, this._normalization, options);\n    }\n\n    /**\n     * Gets a confirmed strictly valid representation of this language tag.\n     * @returns `Success` with a strictly valid representation of this {@link Bcp47.LanguageTag | language tag},\n     * or `Failure` with details if the tag cannot be strictly validated.\n     */\n    public toStrictlyValid(): Result<LanguageTag> {\n        if (this.isStrictlyValid) {\n            return succeed(this);\n        }\n        const options: LanguageTagInitOptions = {\n            iana: this._iana,\n            validity: 'strictly-valid',\n            normalization: this._normalization,\n        };\n        return LanguageTag._createTransformed(this.subtags, this._validity, this._normalization, options);\n    }\n\n    /**\n     * Gets a confirmed canonical representation of this language tag.\n     * @returns `Success` with a canonical representation of this {@link Bcp47.LanguageTag | language tag},\n     * or `Failure` with details if the tag cannot be normalized to canonical form.\n     */\n    public toCanonical(): Result<LanguageTag> {\n        if (this.isCanonical) {\n            return succeed(this);\n        }\n        const options: LanguageTagInitOptions = {\n            iana: this._iana,\n            validity: this._validity,\n            normalization: 'canonical',\n        };\n        return LanguageTag._createTransformed(this.subtags, this._validity, this._normalization, options);\n    }\n\n    /**\n     * Gets a confirmed preferred representation of this language tag.\n     * @returns `Success` with a preferred representation of this {@link Bcp47.LanguageTag | language tag},\n     * or `Failure` with details if the tag cannot be normalized to preferred form.\n     */\n    public toPreferred(): Result<LanguageTag> {\n        if (this.isPreferred) {\n            return succeed(this);\n        }\n        const options: LanguageTagInitOptions = {\n            iana: this._iana,\n            validity: 'valid', // preferred requires validity\n            normalization: 'preferred',\n        };\n        return LanguageTag._createTransformed(this.subtags, this._validity, this._normalization, options);\n    }\n\n    /**\n     * Gets a string representation of this language tag.\n     * @returns A string representation of this language tag.\n     */\n    public toString(): string {\n        return this.tag;\n    }\n}\n"]}
344
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"languageTag.js","sourceRoot":"","sources":["../../src/bcp47/languageTag.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2022 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n\nimport * as Iana from '../iana';\n\nimport { Result, captureResult, succeed } from '@fgv/ts-utils';\nimport { Subtags, UndeterminedLanguage, subtagsToString } from './common';\nimport { TagNormalization, mostNormalized } from './normalization/common';\nimport { TagValidity, mostValid } from './validation/common';\n\nimport { LanguageRegistryData } from './languageRegistryData';\nimport { LanguageTagParser } from './languageTagParser';\nimport { NormalizeTag } from './normalization';\nimport { ScriptSubtag } from '../iana/language-subtags';\nimport { ValidateTag } from './validation';\n\n/**\n * Initialization options for parsing or creation of {@link Bcp47.LanguageTag | language tag} objects.\n * @public\n */\nexport interface LanguageTagInitOptions {\n    /**\n     * Desired {@link Bcp47.TagValidity | validity level} (optional).\n     */\n    validity?: TagValidity;\n    /**\n     * Desired {@link Bcp47.TagNormalization | normalization level} (optional).\n     */\n    normalization?: TagNormalization;\n    /**\n     * The {@link Iana.LanguageRegistries | IANA language subtag and extension registries} to\n     * be used for the request (optional).\n     */\n    iana?: Iana.LanguageRegistries;\n}\n\n/**\n * Represents a single BCP-47 language tag.\n * @public\n */\nexport class LanguageTag {\n    /**\n     * The individual {@link Bcp47.Subtags | subtags} for\n     * this language tag.\n     */\n    public readonly subtags: Readonly<Subtags>;\n\n    /**\n     * A string representation of this language tag.\n     */\n    public readonly tag: string;\n\n    /**\n     * Details about this language tag from the IANA language\n     * registries.\n     */\n    public readonly registry: LanguageRegistryData;\n\n    /**\n     * @internal\n     */\n    protected readonly _iana: Iana.LanguageRegistries;\n\n    /**\n     * @internal\n     */\n    protected _validity: TagValidity;\n\n    /**\n     * @internal\n     */\n    protected _normalization: TagNormalization;\n\n    /**\n     * @internal\n     */\n    protected _isValid: undefined | boolean;\n\n    /**\n     * @internal\n     */\n    protected _isStrictlyValid: undefined | boolean;\n\n    /**\n     * @internal\n     */\n    protected _isCanonical: undefined | boolean;\n\n    /**\n     * @internal\n     */\n    protected _isPreferred: undefined | boolean;\n\n    /**\n     * @internal\n     */\n    protected _suppressedScript: undefined | ScriptSubtag | false;\n\n    /**\n     * Constructs a {@link Bcp47.LanguageTag | LanguageTag }.\n     * @param subtags - The {@link Bcp47.Subtags | subtags } from\n     * which the tag is constructed.\n     * @param validity - Known {@link Bcp47.TagValidity | validation level} of the\n     * supplied subtags.\n     * @param normalization - Known {@link Bcp47.TagNormalization | normalization level}\n     * of the supplied subtags.\n     * @param iana - The {@link Iana.LanguageRegistries} used to validate and normalize\n     * this tag.\n     * @internal\n     */\n    protected constructor(subtags: Subtags, validity: TagValidity, normalization: TagNormalization, iana: Iana.LanguageRegistries) {\n        this.subtags = Object.freeze({ ...subtags });\n        this._normalization = normalization;\n        this._validity = validity;\n        this.tag = subtagsToString(subtags);\n        this._iana = iana;\n        this.registry = new LanguageRegistryData(this.subtags, iana);\n\n        if (validity === 'strictly-valid') {\n            this._isStrictlyValid = true;\n            this._isValid = true;\n        } else if (validity === 'valid') {\n            this._isValid = true;\n        }\n\n        if (normalization === 'preferred') {\n            this._isPreferred = true;\n            this._isCanonical = true;\n        } else if (normalization === 'canonical') {\n            this._isCanonical = true;\n        }\n    }\n\n    /**\n     * The effective script of this language tag, if known.\n     * The effective script is the script subtag in the tag itself,\n     * if present, or the `Suppress-Script` defined in the\n     * {@link https://www.iana.org/assignments/language-subtag-registry/language-subtag-registry | IANA subtag registry}\n     * for the primary language of this tag.  Can be `undefined`\n     * if neither the tag nor the IANA registry define a script.\n     */\n    public get effectiveScript(): ScriptSubtag | undefined {\n        return this.subtags.script ?? this.getSuppressedScript();\n    }\n\n    /**\n     * Determines if this tag represents the special `undetermined` language.\n     */\n    public get isUndetermined(): boolean {\n        // istanbul ignore next\n        return this.subtags.primaryLanguage?.toLowerCase() === UndeterminedLanguage;\n    }\n\n    /**\n     * Whether this language tag is valid.\n     */\n    public get isValid(): boolean {\n        if (this._isValid === undefined) {\n            this._isValid = ValidateTag.isValid(this.subtags);\n            if (this._isValid) {\n                this._validity = 'valid';\n            }\n        }\n        return this._isValid === true;\n    }\n\n    /**\n     * Whether if this language tag is strictly valid.\n     */\n    public get isStrictlyValid(): boolean {\n        if (this._isStrictlyValid === undefined) {\n            this._isStrictlyValid = ValidateTag.isStrictlyValid(this.subtags);\n            if (this._isStrictlyValid) {\n                this._validity = 'strictly-valid';\n            }\n        }\n        return this._isStrictlyValid === true;\n    }\n\n    /**\n     * Whether this language tag is in canonical form.\n     */\n    public get isCanonical(): boolean {\n        if (this._isCanonical === undefined) {\n            this._isCanonical = ValidateTag.isCanonical(this.subtags);\n            if (this._isCanonical) {\n                this._normalization = 'canonical';\n            }\n        }\n        return this._isCanonical === true;\n    }\n\n    /**\n     * Whether this language tag is in preferred form.\n     */\n    public get isPreferred(): boolean {\n        if (this._isPreferred === undefined) {\n            this._isPreferred = ValidateTag.isInPreferredForm(this.subtags);\n            if (this._isPreferred) {\n                this._normalization = 'preferred';\n            }\n        }\n        return this._isPreferred === true;\n    }\n\n    /**\n     * Creates a new {@link Bcp47.LanguageTag | language tag} from a supplied `string` tag\n     * using optional configuration, if supplied.\n     * @param tag - The `string` tag from which the {@link Bcp47.LanguageTag | language tag}\n     * is te be constructed.\n     * @param options - (optional) set of {@link Bcp47.LanguageTagInitOptions | init options}\n     * to guide the validation and normalization of this tag.\n     * @returns `Success` with the new {@link Bcp47.LanguageTag | language tag} or `Failure`\n     * with details if an error occurs.\n     */\n    public static createFromTag(tag: string, options?: LanguageTagInitOptions): Result<LanguageTag> {\n        options = this._getOptions(options);\n\n        return LanguageTagParser.parse(tag, options.iana).onSuccess((subtags) => {\n            return this._createTransformed(subtags, 'unknown', 'unknown', options);\n        });\n    }\n\n    /**\n     * Creates a new {@link Bcp47.LanguageTag | language tag} from a supplied\n     * {@link Bcp47.Subtags | subtags} using optional configuration,\n     * if supplied.\n     * @param tag - The {@link Bcp47.Subtags | subtags} from which the\n     * {@link Bcp47.LanguageTag | language tag} is te be constructed.\n     * @param options - (optional) set of {@link Bcp47.LanguageTagInitOptions | init options}\n     * to guide the validation and normalization of this tag.\n     * @returns `Success` with the new {@link Bcp47.LanguageTag | language tag} or `Failure`\n     * with details if an error occurs.\n     */\n    public static createFromSubtags(subtags: Subtags, options?: LanguageTagInitOptions): Result<LanguageTag> {\n        return this._createTransformed(subtags, 'unknown', 'unknown', options);\n    }\n\n    /**\n     * Creates a new {@link Bcp47.LanguageTag | language tag} from a supplied `string`\n     * tag or {@link Bcp47.Subtags | subtags} using optional configuration,\n     * if supplied.\n     * @param from - The `string` tag or {@link Bcp47.Subtags | subtags} from\n     * which the {@link Bcp47.LanguageTag | language tag} is te be constructed.\n     * @param options - (optional) set of {@link Bcp47.LanguageTagInitOptions | init options}\n     * to guide the validation and normalization of this tag.\n     * @returns `Success` with the new {@link Bcp47.LanguageTag | language tag} or `Failure`\n     * with details if an error occurs.\n     */\n    public static create(from: string | Subtags, options?: LanguageTagInitOptions): Result<LanguageTag> {\n        if (typeof from === 'string') {\n            return this.createFromTag(from, options);\n        } else {\n            return this.createFromSubtags(from, options);\n        }\n    }\n\n    /**\n     * Constructs a new {@link Bcp47.LanguageTag | language tag} by applying appropriate transformations\n     * to as supplied {@link Bcp47.Subtags | Bcp47.Subtags}.\n     * @param subtags - The {@link Bcp47.Subtags | subtags} which represent the tag.\n     * @param fromValidity - The {@link Bcp47.TagValidity | validation level} of the supplied subtags.\n     * @param fromNormalization - The {@link Bcp47.TagNormalization | normalization level} fo the\n     * supplied subtags.\n     * @param partialOptions - Any {@link Bcp47.LanguageTagInitOptions | initialization options}.\n     * @returns `Success` with the corresponding {@link Bcp47.LanguageTag | language tag} or `Failure`\n     * with details if an error occurs.\n     * @internal\n     */\n    protected static _createTransformed(\n        subtags: Subtags,\n        fromValidity: TagValidity,\n        fromNormalization: TagNormalization,\n        partialOptions?: LanguageTagInitOptions\n    ): Result<LanguageTag> {\n        const options = this._getOptions(partialOptions);\n        return ValidateTag.validateSubtags(subtags, options.validity, fromValidity)\n            .onSuccess(() => {\n                return NormalizeTag.normalizeSubtags(subtags, options.normalization, fromNormalization);\n            })\n            .onSuccess((normalized) => {\n                const validity = mostValid(fromValidity, options.validity);\n                const normalization = mostNormalized(fromNormalization, options.normalization);\n                return captureResult(() => new LanguageTag(normalized, validity, normalization, options.iana));\n            });\n    }\n\n    /**\n     * Gets a fully-specified {@link Bcp47.LanguageTagInitOptions} from partial or undefined\n     * options, substituting defaults as appropriate.\n     * @param options - The {@link Bcp47.LanguageTagInitOptions} to be expanded, or `undefined`\n     * for default options.\n     * @returns Fully-specified {@link Bcp47.LanguageTagInitOptions | init options}.\n     * @internal\n     */\n    protected static _getOptions(options?: LanguageTagInitOptions): Required<LanguageTagInitOptions> {\n        return {\n            iana: options?.iana ?? Iana.DefaultRegistries.languageRegistries,\n            validity: options?.validity ?? 'well-formed',\n            normalization: options?.normalization ?? 'none',\n        };\n    }\n\n    /**\n     * Returns the `Suppress-Script` value defined for the primary language of this tag,\n     * regardless of whether a different script is defined in this subtag.\n     * @returns The suppress-script defined for the primary language, or undefined if\n     * the primary language is invalid or has no defined suppressed script.\n     */\n    public getSuppressedScript(): ScriptSubtag | undefined {\n        if (this._suppressedScript === undefined) {\n            this._suppressedScript = false;\n            if (this.subtags.primaryLanguage) {\n                const language = this._iana.subtags.languages.tryGet(this.subtags.primaryLanguage);\n                if (language?.suppressScript !== undefined) {\n                    this._suppressedScript = language.suppressScript;\n                }\n            }\n        }\n        return this._suppressedScript ? this._suppressedScript : undefined;\n    }\n\n    /**\n     * Gets a confirmed valid representation of this language tag.\n     * @returns `Success` with a valid representation of this {@link Bcp47.LanguageTag | language tag},\n     * or `Failure` with details if the tag cannot be validated.\n     */\n    public toValid(): Result<LanguageTag> {\n        if (this.isValid) {\n            return succeed(this);\n        }\n        const options: LanguageTagInitOptions = {\n            iana: this._iana,\n            validity: 'valid',\n            normalization: this._normalization,\n        };\n        return LanguageTag._createTransformed(this.subtags, this._validity, this._normalization, options);\n    }\n\n    /**\n     * Gets a confirmed strictly valid representation of this language tag.\n     * @returns `Success` with a strictly valid representation of this {@link Bcp47.LanguageTag | language tag},\n     * or `Failure` with details if the tag cannot be strictly validated.\n     */\n    public toStrictlyValid(): Result<LanguageTag> {\n        if (this.isStrictlyValid) {\n            return succeed(this);\n        }\n        const options: LanguageTagInitOptions = {\n            iana: this._iana,\n            validity: 'strictly-valid',\n            normalization: this._normalization,\n        };\n        return LanguageTag._createTransformed(this.subtags, this._validity, this._normalization, options);\n    }\n\n    /**\n     * Gets a confirmed canonical representation of this language tag.\n     * @returns `Success` with a canonical representation of this {@link Bcp47.LanguageTag | language tag},\n     * or `Failure` with details if the tag cannot be normalized to canonical form.\n     */\n    public toCanonical(): Result<LanguageTag> {\n        if (this.isCanonical) {\n            return succeed(this);\n        }\n        const options: LanguageTagInitOptions = {\n            iana: this._iana,\n            validity: this._validity,\n            normalization: 'canonical',\n        };\n        return LanguageTag._createTransformed(this.subtags, this._validity, this._normalization, options);\n    }\n\n    /**\n     * Gets a confirmed preferred representation of this language tag.\n     * @returns `Success` with a preferred representation of this {@link Bcp47.LanguageTag | language tag},\n     * or `Failure` with details if the tag cannot be normalized to preferred form.\n     */\n    public toPreferred(): Result<LanguageTag> {\n        if (this.isPreferred) {\n            return succeed(this);\n        }\n        const options: LanguageTagInitOptions = {\n            iana: this._iana,\n            validity: 'valid', // preferred requires validity\n            normalization: 'preferred',\n        };\n        return LanguageTag._createTransformed(this.subtags, this._validity, this._normalization, options);\n    }\n\n    /**\n     * Gets a string representation of this language tag.\n     * @returns A string representation of this language tag.\n     */\n    public toString(): string {\n        return this.tag;\n    }\n}\n"]}
@@ -24,7 +24,7 @@ export interface MatchingLanguage {
24
24
  languageTag: LanguageTag;
25
25
  }
26
26
  /**
27
- * Options for {@link Bcp47.filter | language tag list filter} functions.
27
+ * Options for {@link Bcp47.choose | language tag list filter} functions.
28
28
  * @public
29
29
  */
30
30
  export interface LanguageChooserOptions {
@@ -89,4 +89,4 @@ class LanguageChooser {
89
89
  }
90
90
  }
91
91
  exports.LanguageChooser = LanguageChooser;
92
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chooser.js","sourceRoot":"","sources":["../../../src/bcp47/match/chooser.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2022 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n\nimport * as Iana from '../../iana';\n\nimport { LanguageSimilarityMatcher } from './similarity';\nimport { LanguageTag } from '../languageTag';\nimport { Subtags } from '../common';\n\n/**\n * Represents a single matching filtered language.\n * @public\n */\nexport interface MatchingLanguage {\n    /**\n     * Numeric indication of how well the language matches,\n     * from perfect (`1.0`) to not at all (`0.0`).  When\n     * matching an ordered list, languages at the front of\n     * the desired language list are always higher quality.\n     */\n    quality: number;\n    /**\n     * The `string` tag of the matched language.\n     */\n    tag: string;\n    /**\n     * The matched {@link Bcp47.LanguageTag | language tag}.\n     */\n    languageTag: LanguageTag;\n}\n\n/**\n * Options for {@link Bcp47.filter | language tag list filter} functions.\n * @public\n */\nexport interface LanguageChooserOptions {\n    /**\n     * Indicates whether to return the matching language from the\n     * desired list or the available list. Default is `'availableLanguage'`.\n     */\n    use?: 'desiredLanguage' | 'availableLanguage';\n\n    /**\n     * Indicates how to filter the language list - `'primaryLanguage'`\n     * indicates the each primary language should appear only once in\n     * the list in its most similar form.  A filter value of `'none'`\n     * reports all matching variants of any primary language in order\n     * of similarity.  Default is `'primaryLanguage'`\n     */\n    filter?: 'primaryLanguage' | 'none';\n\n    /**\n     * An optional {@link Bcp47.LanguageSpec | language specification}\n     * indicating a language to be returned if the filter call would\n     * otherwise return an empty list (i.e. no languages match).\n     */\n    ultimateFallback?: string | Subtags | LanguageTag;\n}\n\n/**\n * Default values for a{@link Bcp47.LanguageFilterOptions}.\n * @public\n */\nexport const defaultLanguageChooserOptions: LanguageChooserOptions = Object.freeze({\n    use: 'availableLanguage',\n    filter: 'primaryLanguage',\n});\n\n/**\n * Helper to compare a list of 'desired' languages to a list of 'available' language\n * and return the intersection in order of preference, taking tag semantics into account.\n * @public\n */\nexport class LanguageChooser {\n    /**\n     * @internal\n     */\n    protected readonly _matcher: LanguageSimilarityMatcher;\n\n    public constructor(iana?: Iana.LanguageRegistries) {\n        this._matcher = new LanguageSimilarityMatcher(iana);\n    }\n\n    public chooseLanguageTagsWithDetails(\n        desiredLanguages: LanguageTag[],\n        availableLanguages: LanguageTag[],\n        options?: LanguageChooserOptions\n    ): MatchingLanguage[] {\n        const matched = new Map<string, MatchingLanguage>();\n        const decrement = desiredLanguages.length < 10 ? 0.1 : 1.0 / desiredLanguages.length;\n        let base = 1.0;\n\n        // fill any missing fields from the default\n        options = { ...defaultLanguageChooserOptions, ...options };\n\n        for (const want of desiredLanguages) {\n            base -= decrement;\n            for (const have of availableLanguages) {\n                const similarity = this._matcher.matchLanguageTags(want, have);\n                if (similarity > 0.0) {\n                    const quality = base + similarity * decrement;\n                    const languageTag = options.use === 'availableLanguage' ? have : want;\n                    const tag = languageTag.tag;\n                    const key = options.filter === 'primaryLanguage' ? languageTag.subtags.primaryLanguage ?? tag : tag;\n\n                    const match: MatchingLanguage = {\n                        quality,\n                        tag,\n                        languageTag,\n                    };\n\n                    const existing = matched.get(key);\n                    if (!existing || existing.quality < quality) {\n                        matched.set(key, match);\n                    }\n                }\n            }\n        }\n\n        const values = Array.from(matched.values());\n        if (values.length > 1) {\n            // want descending order\n            values.sort((m1, m2) => m2.quality - m1.quality);\n        } else if (values.length === 0 && options.ultimateFallback) {\n            const languageTag =\n                options.ultimateFallback instanceof LanguageTag\n                    ? options.ultimateFallback\n                    : LanguageTag.create(options.ultimateFallback).orDefault();\n            if (languageTag) {\n                return [{ languageTag, tag: languageTag.tag, quality: 0 }];\n            }\n        }\n        return values;\n    }\n\n    public filterLanguageTags(\n        desiredLanguages: LanguageTag[],\n        availableLanguages: LanguageTag[],\n        options?: LanguageChooserOptions\n    ): LanguageTag[] {\n        return this.chooseLanguageTagsWithDetails(desiredLanguages, availableLanguages, options).map((t) => t.languageTag);\n    }\n}\n"]}
92
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chooser.js","sourceRoot":"","sources":["../../../src/bcp47/match/chooser.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2022 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n\nimport * as Iana from '../../iana';\n\nimport { LanguageSimilarityMatcher } from './similarity';\nimport { LanguageTag } from '../languageTag';\nimport { Subtags } from '../common';\n\n/**\n * Represents a single matching filtered language.\n * @public\n */\nexport interface MatchingLanguage {\n    /**\n     * Numeric indication of how well the language matches,\n     * from perfect (`1.0`) to not at all (`0.0`).  When\n     * matching an ordered list, languages at the front of\n     * the desired language list are always higher quality.\n     */\n    quality: number;\n    /**\n     * The `string` tag of the matched language.\n     */\n    tag: string;\n    /**\n     * The matched {@link Bcp47.LanguageTag | language tag}.\n     */\n    languageTag: LanguageTag;\n}\n\n/**\n * Options for {@link Bcp47.choose | language tag list filter} functions.\n * @public\n */\nexport interface LanguageChooserOptions {\n    /**\n     * Indicates whether to return the matching language from the\n     * desired list or the available list. Default is `'availableLanguage'`.\n     */\n    use?: 'desiredLanguage' | 'availableLanguage';\n\n    /**\n     * Indicates how to filter the language list - `'primaryLanguage'`\n     * indicates the each primary language should appear only once in\n     * the list in its most similar form.  A filter value of `'none'`\n     * reports all matching variants of any primary language in order\n     * of similarity.  Default is `'primaryLanguage'`\n     */\n    filter?: 'primaryLanguage' | 'none';\n\n    /**\n     * An optional {@link Bcp47.LanguageSpec | language specification}\n     * indicating a language to be returned if the filter call would\n     * otherwise return an empty list (i.e. no languages match).\n     */\n    ultimateFallback?: string | Subtags | LanguageTag;\n}\n\n/**\n * Default values for a{@link Bcp47.LanguageFilterOptions}.\n * @public\n */\nexport const defaultLanguageChooserOptions: LanguageChooserOptions = Object.freeze({\n    use: 'availableLanguage',\n    filter: 'primaryLanguage',\n});\n\n/**\n * Helper to compare a list of 'desired' languages to a list of 'available' language\n * and return the intersection in order of preference, taking tag semantics into account.\n * @public\n */\nexport class LanguageChooser {\n    /**\n     * @internal\n     */\n    protected readonly _matcher: LanguageSimilarityMatcher;\n\n    public constructor(iana?: Iana.LanguageRegistries) {\n        this._matcher = new LanguageSimilarityMatcher(iana);\n    }\n\n    public chooseLanguageTagsWithDetails(\n        desiredLanguages: LanguageTag[],\n        availableLanguages: LanguageTag[],\n        options?: LanguageChooserOptions\n    ): MatchingLanguage[] {\n        const matched = new Map<string, MatchingLanguage>();\n        const decrement = desiredLanguages.length < 10 ? 0.1 : 1.0 / desiredLanguages.length;\n        let base = 1.0;\n\n        // fill any missing fields from the default\n        options = { ...defaultLanguageChooserOptions, ...options };\n\n        for (const want of desiredLanguages) {\n            base -= decrement;\n            for (const have of availableLanguages) {\n                const similarity = this._matcher.matchLanguageTags(want, have);\n                if (similarity > 0.0) {\n                    const quality = base + similarity * decrement;\n                    const languageTag = options.use === 'availableLanguage' ? have : want;\n                    const tag = languageTag.tag;\n                    const key = options.filter === 'primaryLanguage' ? languageTag.subtags.primaryLanguage ?? tag : tag;\n\n                    const match: MatchingLanguage = {\n                        quality,\n                        tag,\n                        languageTag,\n                    };\n\n                    const existing = matched.get(key);\n                    if (!existing || existing.quality < quality) {\n                        matched.set(key, match);\n                    }\n                }\n            }\n        }\n\n        const values = Array.from(matched.values());\n        if (values.length > 1) {\n            // want descending order\n            values.sort((m1, m2) => m2.quality - m1.quality);\n        } else if (values.length === 0 && options.ultimateFallback) {\n            const languageTag =\n                options.ultimateFallback instanceof LanguageTag\n                    ? options.ultimateFallback\n                    : LanguageTag.create(options.ultimateFallback).orDefault();\n            if (languageTag) {\n                return [{ languageTag, tag: languageTag.tag, quality: 0 }];\n            }\n        }\n        return values;\n    }\n\n    public filterLanguageTags(\n        desiredLanguages: LanguageTag[],\n        availableLanguages: LanguageTag[],\n        options?: LanguageChooserOptions\n    ): LanguageTag[] {\n        return this.chooseLanguageTagsWithDetails(desiredLanguages, availableLanguages, options).map((t) => t.languageTag);\n    }\n}\n"]}
@@ -29,7 +29,7 @@ const overridesRegistry_1 = require("./overridesRegistry");
29
29
  class DefaultRegistries {
30
30
  static get overridesRegistry() {
31
31
  if (!this._overridesRegistry) {
32
- this._overridesRegistry = overridesRegistry_1.OverridesRegistry.loadJson('data/bcp/overrides.json').orThrow();
32
+ this._overridesRegistry = overridesRegistry_1.OverridesRegistry.loadDefault().orThrow();
33
33
  }
34
34
  return this._overridesRegistry;
35
35
  }
@@ -39,4 +39,4 @@ exports.DefaultRegistries = DefaultRegistries;
39
39
  * @internal
40
40
  */
41
41
  DefaultRegistries._overridesRegistry = undefined;
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdFJlZ2lzdHJpZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYmNwNDcvb3ZlcnJpZGVzL2RlZmF1bHRSZWdpc3RyaWVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQkc7OztBQUVILDJEQUF3RDtBQUV4RDs7R0FFRztBQUNILE1BQWEsaUJBQWlCO0lBTW5CLE1BQU0sS0FBSyxpQkFBaUI7UUFDL0IsSUFBSSxDQUFDLElBQUksQ0FBQyxrQkFBa0IsRUFBRTtZQUMxQixJQUFJLENBQUMsa0JBQWtCLEdBQUcscUNBQWlCLENBQUMsUUFBUSxDQUFDLHlCQUF5QixDQUFDLENBQUMsT0FBTyxFQUFFLENBQUM7U0FDN0Y7UUFDRCxPQUFPLElBQUksQ0FBQyxrQkFBa0IsQ0FBQztJQUNuQyxDQUFDOztBQVhMLDhDQVlDO0FBWEc7O0dBRUc7QUFDWSxvQ0FBa0IsR0FBdUIsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAyMiBFcmlrIEZvcnR1bmVcbiAqXG4gKiBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmcgYSBjb3B5XG4gKiBvZiB0aGlzIHNvZnR3YXJlIGFuZCBhc3NvY2lhdGVkIGRvY3VtZW50YXRpb24gZmlsZXMgKHRoZSBcIlNvZnR3YXJlXCIpLCB0byBkZWFsXG4gKiBpbiB0aGUgU29mdHdhcmUgd2l0aG91dCByZXN0cmljdGlvbiwgaW5jbHVkaW5nIHdpdGhvdXQgbGltaXRhdGlvbiB0aGUgcmlnaHRzXG4gKiB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsIGRpc3RyaWJ1dGUsIHN1YmxpY2Vuc2UsIGFuZC9vciBzZWxsXG4gKiBjb3BpZXMgb2YgdGhlIFNvZnR3YXJlLCBhbmQgdG8gcGVybWl0IHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgaXNcbiAqIGZ1cm5pc2hlZCB0byBkbyBzbywgc3ViamVjdCB0byB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnM6XG4gKlxuICogVGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UgYW5kIHRoaXMgcGVybWlzc2lvbiBub3RpY2Ugc2hhbGwgYmUgaW5jbHVkZWQgaW4gYWxsXG4gKiBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2YgdGhlIFNvZnR3YXJlLlxuICpcbiAqIFRIRSBTT0ZUV0FSRSBJUyBQUk9WSURFRCBcIkFTIElTXCIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsIEVYUFJFU1MgT1JcbiAqIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8gVEhFIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZLFxuICogRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC4gSU4gTk8gRVZFTlQgU0hBTEwgVEhFXG4gKiBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSXG4gKiBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQU4gQUNUSU9OIE9GIENPTlRSQUNULCBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLFxuICogT1VUIE9GIE9SIElOIENPTk5FQ1RJT04gV0lUSCBUSEUgU09GVFdBUkUgT1IgVEhFIFVTRSBPUiBPVEhFUiBERUFMSU5HUyBJTiBUSEVcbiAqIFNPRlRXQVJFLlxuICovXG5cbmltcG9ydCB7IE92ZXJyaWRlc1JlZ2lzdHJ5IH0gZnJvbSAnLi9vdmVycmlkZXNSZWdpc3RyeSc7XG5cbi8qKlxuICogQHB1YmxpY1xuICovXG5leHBvcnQgY2xhc3MgRGVmYXVsdFJlZ2lzdHJpZXMge1xuICAgIC8qKlxuICAgICAqIEBpbnRlcm5hbFxuICAgICAqL1xuICAgIHByaXZhdGUgc3RhdGljIF9vdmVycmlkZXNSZWdpc3RyeT86IE92ZXJyaWRlc1JlZ2lzdHJ5ID0gdW5kZWZpbmVkO1xuXG4gICAgcHVibGljIHN0YXRpYyBnZXQgb3ZlcnJpZGVzUmVnaXN0cnkoKTogT3ZlcnJpZGVzUmVnaXN0cnkge1xuICAgICAgICBpZiAoIXRoaXMuX292ZXJyaWRlc1JlZ2lzdHJ5KSB7XG4gICAgICAgICAgICB0aGlzLl9vdmVycmlkZXNSZWdpc3RyeSA9IE92ZXJyaWRlc1JlZ2lzdHJ5LmxvYWRKc29uKCdkYXRhL2JjcC9vdmVycmlkZXMuanNvbicpLm9yVGhyb3coKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdGhpcy5fb3ZlcnJpZGVzUmVnaXN0cnk7XG4gICAgfVxufVxuIl19
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdFJlZ2lzdHJpZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYmNwNDcvb3ZlcnJpZGVzL2RlZmF1bHRSZWdpc3RyaWVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQkc7OztBQUVILDJEQUF3RDtBQUV4RDs7R0FFRztBQUNILE1BQWEsaUJBQWlCO0lBTW5CLE1BQU0sS0FBSyxpQkFBaUI7UUFDL0IsSUFBSSxDQUFDLElBQUksQ0FBQyxrQkFBa0IsRUFBRTtZQUMxQixJQUFJLENBQUMsa0JBQWtCLEdBQUcscUNBQWlCLENBQUMsV0FBVyxFQUFFLENBQUMsT0FBTyxFQUFFLENBQUM7U0FDdkU7UUFDRCxPQUFPLElBQUksQ0FBQyxrQkFBa0IsQ0FBQztJQUNuQyxDQUFDOztBQVhMLDhDQVlDO0FBWEc7O0dBRUc7QUFDWSxvQ0FBa0IsR0FBdUIsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAyMiBFcmlrIEZvcnR1bmVcbiAqXG4gKiBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmcgYSBjb3B5XG4gKiBvZiB0aGlzIHNvZnR3YXJlIGFuZCBhc3NvY2lhdGVkIGRvY3VtZW50YXRpb24gZmlsZXMgKHRoZSBcIlNvZnR3YXJlXCIpLCB0byBkZWFsXG4gKiBpbiB0aGUgU29mdHdhcmUgd2l0aG91dCByZXN0cmljdGlvbiwgaW5jbHVkaW5nIHdpdGhvdXQgbGltaXRhdGlvbiB0aGUgcmlnaHRzXG4gKiB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsIGRpc3RyaWJ1dGUsIHN1YmxpY2Vuc2UsIGFuZC9vciBzZWxsXG4gKiBjb3BpZXMgb2YgdGhlIFNvZnR3YXJlLCBhbmQgdG8gcGVybWl0IHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgaXNcbiAqIGZ1cm5pc2hlZCB0byBkbyBzbywgc3ViamVjdCB0byB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnM6XG4gKlxuICogVGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UgYW5kIHRoaXMgcGVybWlzc2lvbiBub3RpY2Ugc2hhbGwgYmUgaW5jbHVkZWQgaW4gYWxsXG4gKiBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2YgdGhlIFNvZnR3YXJlLlxuICpcbiAqIFRIRSBTT0ZUV0FSRSBJUyBQUk9WSURFRCBcIkFTIElTXCIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsIEVYUFJFU1MgT1JcbiAqIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8gVEhFIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZLFxuICogRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC4gSU4gTk8gRVZFTlQgU0hBTEwgVEhFXG4gKiBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSXG4gKiBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQU4gQUNUSU9OIE9GIENPTlRSQUNULCBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLFxuICogT1VUIE9GIE9SIElOIENPTk5FQ1RJT04gV0lUSCBUSEUgU09GVFdBUkUgT1IgVEhFIFVTRSBPUiBPVEhFUiBERUFMSU5HUyBJTiBUSEVcbiAqIFNPRlRXQVJFLlxuICovXG5cbmltcG9ydCB7IE92ZXJyaWRlc1JlZ2lzdHJ5IH0gZnJvbSAnLi9vdmVycmlkZXNSZWdpc3RyeSc7XG5cbi8qKlxuICogQHB1YmxpY1xuICovXG5leHBvcnQgY2xhc3MgRGVmYXVsdFJlZ2lzdHJpZXMge1xuICAgIC8qKlxuICAgICAqIEBpbnRlcm5hbFxuICAgICAqL1xuICAgIHByaXZhdGUgc3RhdGljIF9vdmVycmlkZXNSZWdpc3RyeT86IE92ZXJyaWRlc1JlZ2lzdHJ5ID0gdW5kZWZpbmVkO1xuXG4gICAgcHVibGljIHN0YXRpYyBnZXQgb3ZlcnJpZGVzUmVnaXN0cnkoKTogT3ZlcnJpZGVzUmVnaXN0cnkge1xuICAgICAgICBpZiAoIXRoaXMuX292ZXJyaWRlc1JlZ2lzdHJ5KSB7XG4gICAgICAgICAgICB0aGlzLl9vdmVycmlkZXNSZWdpc3RyeSA9IE92ZXJyaWRlc1JlZ2lzdHJ5LmxvYWREZWZhdWx0KCkub3JUaHJvdygpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB0aGlzLl9vdmVycmlkZXNSZWdpc3RyeTtcbiAgICB9XG59XG4iXX0=
@@ -17,6 +17,8 @@ export declare class OverridesRegistry {
17
17
  readonly overrides: Map<LanguageSubtag, LanguageOverride>;
18
18
  protected constructor();
19
19
  static create(overrides: LanguageOverride[]): Result<OverridesRegistry>;
20
+ static createFromJson(from: unknown): Result<OverridesRegistry>;
21
+ static loadDefault(): Result<OverridesRegistry>;
20
22
  static loadJson(path: string): Result<OverridesRegistry>;
21
23
  /**
22
24
  * Converts a file {@link Bcp47.Overrides.Model.LanguageOverrideRecord | LanguageOverrideRecord }
@@ -1 +1 @@
1
- {"version":3,"file":"overridesRegistry.d.ts","sourceRoot":"","sources":["../../../src/bcp47/overrides/overridesRegistry.ts"],"names":[],"mappings":"AAuBA,OAAO,KAAK,KAAK,MAAM,SAAS,CAAC;AAEjC,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3E,OAAO,EAAE,MAAM,EAAuB,MAAM,eAAe,CAAC;AAE5D;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC7B,QAAQ,EAAE,cAAc,CAAC;IACzB,eAAe,CAAC,EAAE,YAAY,CAAC;IAC/B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,EAAE,GAAG,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;CACxC;AAED;;GAEG;AACH,qBAAa,iBAAiB;IAC1B,SAAgB,SAAS,EAAE,GAAG,CAAC,cAAc,EAAE,gBAAgB,CAAC,CAAC;IAEjE,SAAS;WAIK,MAAM,CAAC,SAAS,EAAE,gBAAgB,EAAE,GAAG,MAAM,CAAC,iBAAiB,CAAC;WAMhE,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAAC,iBAAiB,CAAC;IAU/D;;;;;;;;OAQG;IACH,SAAS,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,KAAK,CAAC,sBAAsB,GAAG,MAAM,CAAC,gBAAgB,CAAC;CAmBvG"}
1
+ {"version":3,"file":"overridesRegistry.d.ts","sourceRoot":"","sources":["../../../src/bcp47/overrides/overridesRegistry.ts"],"names":[],"mappings":"AAuBA,OAAO,KAAK,KAAK,MAAM,SAAS,CAAC;AAEjC,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3E,OAAO,EAAE,MAAM,EAAuB,MAAM,eAAe,CAAC;AAG5D;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC7B,QAAQ,EAAE,cAAc,CAAC;IACzB,eAAe,CAAC,EAAE,YAAY,CAAC;IAC/B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,EAAE,GAAG,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;CACxC;AAED;;GAEG;AACH,qBAAa,iBAAiB;IAC1B,SAAgB,SAAS,EAAE,GAAG,CAAC,cAAc,EAAE,gBAAgB,CAAC,CAAC;IAEjE,SAAS;WAIK,MAAM,CAAC,SAAS,EAAE,gBAAgB,EAAE,GAAG,MAAM,CAAC,iBAAiB,CAAC;WAMhE,cAAc,CAAC,IAAI,EAAE,OAAO,GAAG,MAAM,CAAC,iBAAiB,CAAC;WAWxD,WAAW,IAAI,MAAM,CAAC,iBAAiB,CAAC;WAIxC,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAAC,iBAAiB,CAAC;IAI/D;;;;;;;;OAQG;IACH,SAAS,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,KAAK,CAAC,sBAAsB,GAAG,MAAM,CAAC,gBAAgB,CAAC;CAmBvG"}