This file is indexed.

/usr/share/gocode/src/github.com/coreos/go-log/log/sinks.go is in golang-coreos-log-dev 0.0~git20140508-2.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
package log

// Copyright 2013, CoreOS, Inc. All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//   http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
// author: David Fisher <ddf1991@gmail.com>
// based on previous package by: Cong Ding <dinggnu@gmail.com>

import (
	"fmt"
	"io"
	"sync"
)

const AsyncBuffer = 100

type Sink interface {
	Log(Fields)
}

type nullSink struct{}

func (sink *nullSink) Log(fields Fields) {}

func NullSink() Sink {
	return &nullSink{}
}

type writerSink struct {
	lock   sync.Mutex
	out    io.Writer
	format string
	fields []string
}

func (sink *writerSink) Log(fields Fields) {
	vals := make([]interface{}, len(sink.fields))
	for i, field := range sink.fields {
		var ok bool
		vals[i], ok = fields[field]
		if !ok {
			vals[i] = "???"
		}
	}

	sink.lock.Lock()
	defer sink.lock.Unlock()
	fmt.Fprintf(sink.out, sink.format, vals...)
}

func WriterSink(out io.Writer, format string, fields []string) Sink {
	return &writerSink{
		out:    out,
		format: format,
		fields: fields,
	}
}

type combinedSink struct {
	sinks []Sink
}

func (sink *combinedSink) Log(fields Fields) {
	for _, s := range sink.sinks {
		s.Log(fields)
	}
}

type priorityFilter struct {
	priority Priority
	target   Sink
}

func (filter *priorityFilter) Log(fields Fields) {
	// lower priority values indicate more important messages
	if fields["priority"].(Priority) <= filter.priority {
		filter.target.Log(fields)
	}
}

func PriorityFilter(priority Priority, target Sink) Sink {
	return &priorityFilter{
		priority: priority,
		target:   target,
	}
}