Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(241)

Unified Diff: mathrand.go

Issue 1243323002: Refactor a bit. (Closed) Base URL: https://github.com/luci/gae.git@master
Patch Set: fix golint Created 5 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « impl/prod/taskqueue.go ('k') | mathrand_test.go » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: mathrand.go
diff --git a/mathrand.go b/mathrand.go
deleted file mode 100644
index 35c335c91e4915b1801f6c757b2349b216022df7..0000000000000000000000000000000000000000
--- a/mathrand.go
+++ /dev/null
@@ -1,45 +0,0 @@
-// Copyright 2015 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-package gae
-
-import (
- "math/rand"
-
- "github.com/luci/luci-go/common/clock"
- "golang.org/x/net/context"
-)
-
-// TODO(riannucci): Extract this into its own package. It's used by taskqueue,
-// but otherwise isn't related to gae services at all.
-
-// MathRandFactory is the function signature for factory methods compatible with
-// SetMathRandFactory.
-type MathRandFactory func(context.Context) *rand.Rand
-
-// GetMathRand gets a *"math/rand".Rand from the context. If one hasn't been
-// set, this creates a new Rand object with a Source initialized from the
-// current time clock.Now(c).UnixNano().
-func GetMathRand(c context.Context) *rand.Rand {
- if f, ok := c.Value(mathRandKey).(MathRandFactory); ok && f != nil {
- return f(c)
- }
- return rand.New(rand.NewSource(clock.Now(c).UnixNano()))
-}
-
-// SetMathRandFactory sets the function to produce *"math/rand".Rand instances,
-// as returned by the GetMathRand method.
-func SetMathRandFactory(c context.Context, mrf MathRandFactory) context.Context {
- return context.WithValue(c, mathRandKey, mrf)
-}
-
-// SetMathRand sets the current *"math/rand".Rand object in the context. Useful
-// for testing with a quick mock. This is just a shorthand SetMathRandFactory
-// invocation to set a factory which always returns the same object.
-func SetMathRand(c context.Context, r *rand.Rand) context.Context {
- if r == nil {
- return SetMathRandFactory(c, nil)
- }
- return SetMathRandFactory(c, func(context.Context) *rand.Rand { return r })
-}
« no previous file with comments | « impl/prod/taskqueue.go ('k') | mathrand_test.go » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698