| // Copyright 2020 The Go 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 export_test |
| |
| import ( |
| "context" |
| "errors" |
| "os" |
| "time" |
| |
| "golang.org/x/tools/internal/event" |
| "golang.org/x/tools/internal/event/core" |
| "golang.org/x/tools/internal/event/export" |
| "golang.org/x/tools/internal/event/keys" |
| "golang.org/x/tools/internal/event/label" |
| ) |
| |
| func ExampleLog() { |
| ctx := context.Background() |
| event.SetExporter(timeFixer(export.LogWriter(os.Stdout, false))) |
| anInt := keys.NewInt("myInt", "an integer") |
| aString := keys.NewString("myString", "a string") |
| event.Log(ctx, "my event", anInt.Of(6)) |
| event.Error(ctx, "error event", errors.New("an error"), aString.Of("some string value")) |
| // Output: |
| // 2020/03/05 14:27:48 my event |
| // myInt=6 |
| // 2020/03/05 14:27:48 error event: an error |
| // myString="some string value" |
| } |
| |
| func timeFixer(output event.Exporter) event.Exporter { |
| at, _ := time.Parse(time.RFC3339Nano, "2020-03-05T14:27:48Z") |
| return func(ctx context.Context, ev core.Event, lm label.Map) context.Context { |
| copy := core.CloneEvent(ev, at) |
| return output(ctx, copy, lm) |
| } |
| } |