Class: NATS::NUID
- Inherits:
-
Object
- Object
- NATS::NUID
- Defined in:
- lib/nats/nuid.rb
Constant Summary collapse
- DIGITS =
'0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'.split('')
- BASE =
62
- PREFIX_LENGTH =
12
- SEQ_LENGTH =
10
- TOTAL_LENGTH =
PREFIX_LENGTH + SEQ_LENGTH
- MAX_SEQ =
BASE**10
- MIN_INC =
33
- MAX_INC =
333
- INC =
MAX_INC - MIN_INC
- @@nuid =
NUID.new.extend(MonitorMixin)
Class Method Summary collapse
Instance Method Summary collapse
-
#initialize ⇒ NUID
constructor
A new instance of NUID.
- #next ⇒ Object
- #randomize_prefix! ⇒ Object
Constructor Details
Class Method Details
.next ⇒ Object
76 77 78 79 80 |
# File 'lib/nats/nuid.rb', line 76 def next @@nuid.synchronize do @@nuid.next end end |
Instance Method Details
#next ⇒ Object
38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 |
# File 'lib/nats/nuid.rb', line 38 def next @seq += @inc if @seq >= MAX_SEQ randomize_prefix! reset_sequential! end l = @seq # Do this inline 10 times to avoid even more extra allocs, # then use string interpolation of everything which works # faster for doing concat. s_10 = DIGITS[l % BASE]; # Ugly, but parallel assignment is slightly faster here... s_09, s_08, s_07, s_06, s_05, s_04, s_03, s_02, s_01 = \ (l /= BASE; DIGITS[l % BASE]), (l /= BASE; DIGITS[l % BASE]), (l /= BASE; DIGITS[l % BASE]),\ (l /= BASE; DIGITS[l % BASE]), (l /= BASE; DIGITS[l % BASE]), (l /= BASE; DIGITS[l % BASE]),\ (l /= BASE; DIGITS[l % BASE]), (l /= BASE; DIGITS[l % BASE]), (l /= BASE; DIGITS[l % BASE]) "#{@prefix}#{s_01}#{s_02}#{s_03}#{s_04}#{s_05}#{s_06}#{s_07}#{s_08}#{s_09}#{s_10}" end |
#randomize_prefix! ⇒ Object
59 60 61 62 63 64 65 |
# File 'lib/nats/nuid.rb', line 59 def randomize_prefix! @prefix = \ SecureRandom.random_bytes(PREFIX_LENGTH).each_byte .reduce('') do |prefix, n| prefix << DIGITS[n % BASE] end end |