Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
MR414N-ID
GitHub Repository: MR414N-ID/botku2
Path: blob/master/node_modules/any-base/src/converter.js
1126 views
1
'use strict';
2
3
/**
4
* Converter
5
*
6
* @param {string|Array} srcAlphabet
7
* @param {string|Array} dstAlphabet
8
* @constructor
9
*/
10
function Converter(srcAlphabet, dstAlphabet) {
11
if (!srcAlphabet || !dstAlphabet || !srcAlphabet.length || !dstAlphabet.length) {
12
throw new Error('Bad alphabet');
13
}
14
this.srcAlphabet = srcAlphabet;
15
this.dstAlphabet = dstAlphabet;
16
}
17
18
/**
19
* Convert number from source alphabet to destination alphabet
20
*
21
* @param {string|Array} number - number represented as a string or array of points
22
*
23
* @returns {string|Array}
24
*/
25
Converter.prototype.convert = function(number) {
26
var i, divide, newlen,
27
numberMap = {},
28
fromBase = this.srcAlphabet.length,
29
toBase = this.dstAlphabet.length,
30
length = number.length,
31
result = typeof number === 'string' ? '' : [];
32
33
if (!this.isValid(number)) {
34
throw new Error('Number "' + number + '" contains of non-alphabetic digits (' + this.srcAlphabet + ')');
35
}
36
37
if (this.srcAlphabet === this.dstAlphabet) {
38
return number;
39
}
40
41
for (i = 0; i < length; i++) {
42
numberMap[i] = this.srcAlphabet.indexOf(number[i]);
43
}
44
do {
45
divide = 0;
46
newlen = 0;
47
for (i = 0; i < length; i++) {
48
divide = divide * fromBase + numberMap[i];
49
if (divide >= toBase) {
50
numberMap[newlen++] = parseInt(divide / toBase, 10);
51
divide = divide % toBase;
52
} else if (newlen > 0) {
53
numberMap[newlen++] = 0;
54
}
55
}
56
length = newlen;
57
result = this.dstAlphabet.slice(divide, divide + 1).concat(result);
58
} while (newlen !== 0);
59
60
return result;
61
};
62
63
/**
64
* Valid number with source alphabet
65
*
66
* @param {number} number
67
*
68
* @returns {boolean}
69
*/
70
Converter.prototype.isValid = function(number) {
71
var i = 0;
72
for (; i < number.length; ++i) {
73
if (this.srcAlphabet.indexOf(number[i]) === -1) {
74
return false;
75
}
76
}
77
return true;
78
};
79
80
module.exports = Converter;
81