1
0
mirror of https://github.com/vlang/v.git synced 2023-08-10 21:13:21 +03:00

rand: further bridge gap b/w rand module and PRNG interface (#13719)

This commit is contained in:
Subhomoy Haldar
2022-03-12 13:11:12 +05:30
committed by GitHub
parent a3e9409196
commit 40504e8600
4 changed files with 142 additions and 52 deletions

View File

@@ -1,16 +1,14 @@
module rand
import time
// init initializes the default RNG.
fn init() {
default_rng = new_default()
}
pub fn string(len int) string {
fn internal_string_from_set(mut rng PRNG, charset string, len int) string {
result := ''
#
#const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
#const characters = charset.str;
#const charactersLength = characters.length;
#for (let i = 0;i < len.val;i++)
#result.str += characters.charAt(Math.random() * charactersLength);
@@ -22,18 +20,7 @@ const (
ulid_encoding = '0123456789ABCDEFGHJKMNPQRSTVWXYZ'
)
// ulid generates an Unique Lexicographically sortable IDentifier.
// See https://github.com/ulid/spec .
// Note: ULIDs can leak timing information, if you make them public, because
// you can infer the rate at which some resource is being created, like
// users or business transactions.
// (https://news.ycombinator.com/item?id=14526173)
pub fn ulid() string {
return ulid_at_millisecond(u64(time.utc().unix_time_milli()))
}
// ulid_at_millisecond does the same as `ulid` but takes a custom Unix millisecond timestamp via `unix_time_milli`.
pub fn ulid_at_millisecond(unix_time_milli u64) string {
fn internal_ulid_at_millisecond(mut rng PRNG, unix_time_milli u64) string {
mut buf := []byte{cap: 27}
mut t := unix_time_milli
mut i := 9
@@ -43,7 +30,7 @@ pub fn ulid_at_millisecond(unix_time_milli u64) string {
i--
}
mut x := default_rng.u64()
mut x := rng.u64()
i = 10
for i < 19 {
buf[i] = rand.ulid_encoding[int(x & 0x1f)]
@@ -52,7 +39,7 @@ pub fn ulid_at_millisecond(unix_time_milli u64) string {
i++
}
x = default_rng.u64()
x = rng.u64()
for i < 26 {
buf[i] = rand.ulid_encoding[int(x & 0x1f)]
x = x >> 5