You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
68 lines
1.3 KiB
68 lines
1.3 KiB
'use strict'; |
|
|
|
var alphabet = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz-_'.split('') |
|
, length = 64 |
|
, map = {} |
|
, seed = 0 |
|
, i = 0 |
|
, prev; |
|
|
|
/** |
|
* Return a string representing the specified number. |
|
* |
|
* @param {Number} num The number to convert. |
|
* @returns {String} The string representation of the number. |
|
* @api public |
|
*/ |
|
function encode(num) { |
|
var encoded = ''; |
|
|
|
do { |
|
encoded = alphabet[num % length] + encoded; |
|
num = Math.floor(num / length); |
|
} while (num > 0); |
|
|
|
return encoded; |
|
} |
|
|
|
/** |
|
* Return the integer value specified by the given string. |
|
* |
|
* @param {String} str The string to convert. |
|
* @returns {Number} The integer value represented by the string. |
|
* @api public |
|
*/ |
|
function decode(str) { |
|
var decoded = 0; |
|
|
|
for (i = 0; i < str.length; i++) { |
|
decoded = decoded * length + map[str.charAt(i)]; |
|
} |
|
|
|
return decoded; |
|
} |
|
|
|
/** |
|
* Yeast: A tiny growing id generator. |
|
* |
|
* @returns {String} A unique id. |
|
* @api public |
|
*/ |
|
function yeast() { |
|
var now = encode(+new Date()); |
|
|
|
if (now !== prev) return seed = 0, prev = now; |
|
return now +'.'+ encode(seed++); |
|
} |
|
|
|
// |
|
// Map each character to its index. |
|
// |
|
for (; i < length; i++) map[alphabet[i]] = i; |
|
|
|
// |
|
// Expose the `yeast`, `encode` and `decode` functions. |
|
// |
|
yeast.encode = encode; |
|
yeast.decode = decode; |
|
module.exports = yeast;
|
|
|