ethers.js/src.ts/wordlists/wordlist.ts

60 lines
1.8 KiB
TypeScript
Raw Normal View History

2022-09-05 23:14:43 +03:00
import { defineProperties } from "../utils/index.js";
2022-11-28 05:45:42 +03:00
/**
* A Wordlist represents a collection of language-specific
* words used to encode and devoce [[BIP-39]] encoded data
* by mapping words to 11-bit values and vice versa.
*/
2022-09-05 23:14:43 +03:00
export abstract class Wordlist {
locale!: string;
2022-11-28 05:45:42 +03:00
/**
* Creates a new Wordlist instance.
*
* Sub-classes MUST call this if they provide their own constructor,
* passing in the locale string of the language.
*
* Generally there is no need to create instances of a Wordlist,
* since each language-specific Wordlist creates an instance and
* there is no state kept internally, so they are safe to share.
*/
2022-09-05 23:14:43 +03:00
constructor(locale: string) {
defineProperties<Wordlist>(this, { locale });
}
2022-11-28 05:45:42 +03:00
/**
* Sub-classes may override this to provide a language-specific
* method for spliting %%phrase%% into individual words.
*
* By default, %%phrase%% is split using any sequences of
* white-space as defined by regular expressions (i.e. ``/\s+/``).
*/
split(phrase: string): Array<string> {
return phrase.toLowerCase().split(/\s+/g)
2022-09-05 23:14:43 +03:00
}
2022-11-28 05:45:42 +03:00
/**
* Sub-classes may override this to provider a language-specific
* method for joining %%words%% into a phrase.
*
* By default, %%words%% are joined by a single space.
*/
2022-09-05 23:14:43 +03:00
join(words: Array<string>): string {
return words.join(" ");
}
2022-11-28 05:45:42 +03:00
/**
* Maps an 11-bit value into its coresponding word in the list.
*
* Sub-classes MUST override this.
*/
2022-09-05 23:14:43 +03:00
abstract getWord(index: number): string;
2022-11-28 05:45:42 +03:00
/**
* Maps a word to its corresponding 11-bit value.
*
* Sub-classes MUST override this.
*/
2022-09-05 23:14:43 +03:00
abstract getWordIndex(word: string): number;
}