Path: blob/master/node_modules/any-base/src/converter.js
1126 views
'use strict';12/**3* Converter4*5* @param {string|Array} srcAlphabet6* @param {string|Array} dstAlphabet7* @constructor8*/9function Converter(srcAlphabet, dstAlphabet) {10if (!srcAlphabet || !dstAlphabet || !srcAlphabet.length || !dstAlphabet.length) {11throw new Error('Bad alphabet');12}13this.srcAlphabet = srcAlphabet;14this.dstAlphabet = dstAlphabet;15}1617/**18* Convert number from source alphabet to destination alphabet19*20* @param {string|Array} number - number represented as a string or array of points21*22* @returns {string|Array}23*/24Converter.prototype.convert = function(number) {25var i, divide, newlen,26numberMap = {},27fromBase = this.srcAlphabet.length,28toBase = this.dstAlphabet.length,29length = number.length,30result = typeof number === 'string' ? '' : [];3132if (!this.isValid(number)) {33throw new Error('Number "' + number + '" contains of non-alphabetic digits (' + this.srcAlphabet + ')');34}3536if (this.srcAlphabet === this.dstAlphabet) {37return number;38}3940for (i = 0; i < length; i++) {41numberMap[i] = this.srcAlphabet.indexOf(number[i]);42}43do {44divide = 0;45newlen = 0;46for (i = 0; i < length; i++) {47divide = divide * fromBase + numberMap[i];48if (divide >= toBase) {49numberMap[newlen++] = parseInt(divide / toBase, 10);50divide = divide % toBase;51} else if (newlen > 0) {52numberMap[newlen++] = 0;53}54}55length = newlen;56result = this.dstAlphabet.slice(divide, divide + 1).concat(result);57} while (newlen !== 0);5859return result;60};6162/**63* Valid number with source alphabet64*65* @param {number} number66*67* @returns {boolean}68*/69Converter.prototype.isValid = function(number) {70var i = 0;71for (; i < number.length; ++i) {72if (this.srcAlphabet.indexOf(number[i]) === -1) {73return false;74}75}76return true;77};7879module.exports = Converter;8081