forked from discourse/discourse
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbase62.rb
35 lines (31 loc) · 829 Bytes
/
base62.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
# Modified version of: https://github.com/steventen/base62-rb
module Base62
KEYS ||= "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ".freeze
KEYS_HASH ||= KEYS.each_char.with_index.to_h
BASE ||= KEYS.length
# Encodes base10 (decimal) number to base62 string.
def self.encode(num)
return "0" if num == 0
return nil if num < 0
str = ""
while num > 0
# prepend base62 charaters
str = KEYS[num % BASE] + str
num = num / BASE
end
str
end
# Decodes base62 string to a base10 (decimal) number.
def self.decode(str)
num = 0
i = 0
len = str.length - 1
# while loop is faster than each_char or other 'idiomatic' way
while i < str.length
pow = BASE**(len - i)
num += KEYS_HASH[str[i]] * pow
i += 1
end
num
end
end