OLD | NEW |
1 // Copyright 2015 The LUCI Authors. All rights reserved. | 1 // Copyright 2015 The LUCI Authors. All rights reserved. |
2 // Use of this source code is governed under the Apache License, Version 2.0 | 2 // Use of this source code is governed under the Apache License, Version 2.0 |
3 // that can be found in the LICENSE file. | 3 // that can be found in the LICENSE file. |
4 | 4 |
5 package info | 5 package info |
6 | 6 |
7 import ( | 7 import ( |
8 "golang.org/x/net/context" | 8 "golang.org/x/net/context" |
9 ) | 9 ) |
10 | 10 |
(...skipping 15 matching lines...) Expand all Loading... |
26 | 26 |
27 // getUnfiltered gets gets the RawInterface implementation from context without | 27 // getUnfiltered gets gets the RawInterface implementation from context without |
28 // any of the filters applied. | 28 // any of the filters applied. |
29 func getUnfiltered(c context.Context) RawInterface { | 29 func getUnfiltered(c context.Context) RawInterface { |
30 if f, ok := c.Value(infoKey).(Factory); ok && f != nil { | 30 if f, ok := c.Value(infoKey).(Factory); ok && f != nil { |
31 return f(c) | 31 return f(c) |
32 } | 32 } |
33 return nil | 33 return nil |
34 } | 34 } |
35 | 35 |
36 // Get gets the Interface implementation from context. | 36 // Raw returns the current filtered RawInterface installed in the Context. |
37 func Get(c context.Context) Interface { | 37 func Raw(c context.Context) RawInterface { |
38 ret := getUnfiltered(c) | 38 ret := getUnfiltered(c) |
39 if ret == nil { | 39 if ret == nil { |
40 return nil | 40 return nil |
41 } | 41 } |
42 for _, f := range getCurFilters(c) { | 42 for _, f := range getCurFilters(c) { |
43 ret = f(c, ret) | 43 ret = f(c, ret) |
44 } | 44 } |
45 » return infoImpl{ret} | 45 » return ret |
46 } | 46 } |
47 | 47 |
48 // SetFactory sets the function to produce RawInterface instances, as returned | 48 // SetFactory sets the function to produce RawInterface instances, as returned |
49 // by the Get method. | 49 // by the Get method. |
50 func SetFactory(c context.Context, gif Factory) context.Context { | 50 func SetFactory(c context.Context, gif Factory) context.Context { |
51 return context.WithValue(c, infoKey, gif) | 51 return context.WithValue(c, infoKey, gif) |
52 } | 52 } |
53 | 53 |
54 // Set sets the current RawInterface object in the context. Useful for testing | 54 // Set sets the current RawInterface object in the context. Useful for testing |
55 // with a quick mock. This is just a shorthand SetFactory invocation to set | 55 // with a quick mock. This is just a shorthand SetFactory invocation to set |
(...skipping 14 matching lines...) Expand all Loading... |
70 func AddFilters(c context.Context, filts ...Filter) context.Context { | 70 func AddFilters(c context.Context, filts ...Filter) context.Context { |
71 if len(filts) == 0 { | 71 if len(filts) == 0 { |
72 return c | 72 return c |
73 } | 73 } |
74 cur := getCurFilters(c) | 74 cur := getCurFilters(c) |
75 newFilts := make([]Filter, 0, len(cur)+len(filts)) | 75 newFilts := make([]Filter, 0, len(cur)+len(filts)) |
76 newFilts = append(newFilts, getCurFilters(c)...) | 76 newFilts = append(newFilts, getCurFilters(c)...) |
77 newFilts = append(newFilts, filts...) | 77 newFilts = append(newFilts, filts...) |
78 return context.WithValue(c, infoFilterKey, newFilts) | 78 return context.WithValue(c, infoFilterKey, newFilts) |
79 } | 79 } |
OLD | NEW |