You've already forked opentelemetry-go
mirror of
https://github.com/open-telemetry/opentelemetry-go.git
synced 2026-06-03 18:35:08 +02:00
cf2a4a180f
This PR contains the following updates: | Package | Change | [Age](https://docs.renovatebot.com/merge-confidence/) | [Confidence](https://docs.renovatebot.com/merge-confidence/) | |---|---|---|---| | [mvdan.cc/gofumpt](https://redirect.github.com/mvdan/gofumpt) | `v0.9.2` → `v0.10.0` |  |  | --- ### Release Notes <details> <summary>mvdan/gofumpt (mvdan.cc/gofumpt)</summary> ### [`v0.10.0`](https://redirect.github.com/mvdan/gofumpt/blob/HEAD/CHANGELOG.md#v0100---2026-05-04) [Compare Source](https://redirect.github.com/mvdan/gofumpt/compare/v0.9.2...v0.10.0) This release is based on Go 1.26's gofmt, and requires Go 1.25 or later. A new rule is introduced to drop unnecessary parentheses around expressions where the inner expression is unambiguous on its own, such as `f((3))`. Parentheses are kept where they are useful, such as on binary expressions. See [#​44](https://redirect.github.com/mvdan/gofumpt/issues/44). A new rule is introduced to require multi-line function calls to match the opening and closing parenthesis in terms of the use of newlines. See [#​74](https://redirect.github.com/mvdan/gofumpt/issues/74). The `-extra` flag now accepts a comma-separated list of rule names to enable individual extra rules, rather than enabling all of them at once. See [#​339](https://redirect.github.com/mvdan/gofumpt/issues/339). The following changes are included as well: - Avoid crashing on `go.mod` files without a `module` directive - [#​350](https://redirect.github.com/mvdan/gofumpt/issues/350) - Avoid failing when an ignored directory cannot be read - [#​351](https://redirect.github.com/mvdan/gofumpt/issues/351) - Avoid prefixing more kinds of commented-out Go code with spaces - [#​230](https://redirect.github.com/mvdan/gofumpt/issues/230) - Avoid prefixing a shebang comment with a space - [#​237](https://redirect.github.com/mvdan/gofumpt/issues/237) - Narrow the newlines on assignments rule to ignore complex cases - [#​354](https://redirect.github.com/mvdan/gofumpt/issues/354) - Fix three bugs which caused a second gofumpt run to make changes - [#​132](https://redirect.github.com/mvdan/gofumpt/issues/132), [#​345](https://redirect.github.com/mvdan/gofumpt/issues/345) </details> --- ### Configuration 📅 **Schedule**: (UTC) - Branch creation - At any time (no schedule defined) - Automerge - At any time (no schedule defined) 🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied. ♻ **Rebasing**: Whenever PR is behind base branch, or you tick the rebase/retry checkbox. 🔕 **Ignore**: Close this PR and you won't be reminded about this update again. --- - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box --- This PR was generated by [Mend Renovate](https://mend.io/renovate/). View the [repository job log](https://developer.mend.io/github/open-telemetry/opentelemetry-go). <!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0My4xNTkuMiIsInVwZGF0ZWRJblZlciI6IjQzLjE1OS4yIiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6WyJTa2lwIENoYW5nZWxvZyIsImRlcGVuZGVuY2llcyJdfQ==--> --------- Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> Co-authored-by: Tyler Yahn <codingalias@gmail.com>
80 lines
2.1 KiB
Go
80 lines
2.1 KiB
Go
// Copyright The OpenTelemetry Authors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
//go:build aix || darwin || dragonfly || freebsd || linux || netbsd || openbsd || solaris || zos
|
|
|
|
package resource // import "go.opentelemetry.io/otel/sdk/resource"
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
|
|
"golang.org/x/sys/unix"
|
|
)
|
|
|
|
type unameProvider func(buf *unix.Utsname) (err error)
|
|
|
|
var defaultUnameProvider unameProvider = unix.Uname
|
|
|
|
var currentUnameProvider = defaultUnameProvider
|
|
|
|
func setDefaultUnameProvider() {
|
|
setUnameProvider(defaultUnameProvider)
|
|
}
|
|
|
|
func setUnameProvider(unameProvider unameProvider) {
|
|
currentUnameProvider = unameProvider
|
|
}
|
|
|
|
// platformOSDescription returns a human readable OS version information string.
|
|
// The final string combines OS release information (where available) and the
|
|
// result of the `uname` system call.
|
|
func platformOSDescription() (string, error) {
|
|
uname, err := uname()
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
osRelease := osRelease()
|
|
if osRelease != "" {
|
|
return fmt.Sprintf("%s (%s)", osRelease, uname), nil
|
|
}
|
|
|
|
return uname, nil
|
|
}
|
|
|
|
// uname issues a uname(2) system call (or equivalent on systems which doesn't
|
|
// have one) and formats the output in a single string, similar to the output
|
|
// of the `uname` commandline program. The final string resembles the one
|
|
// obtained with a call to `uname -snrvm`.
|
|
func uname() (string, error) {
|
|
var utsName unix.Utsname
|
|
|
|
err := currentUnameProvider(&utsName)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
return fmt.Sprintf(
|
|
"%s %s %s %s %s",
|
|
unix.ByteSliceToString(utsName.Sysname[:]),
|
|
unix.ByteSliceToString(utsName.Nodename[:]),
|
|
unix.ByteSliceToString(utsName.Release[:]),
|
|
unix.ByteSliceToString(utsName.Version[:]),
|
|
unix.ByteSliceToString(utsName.Machine[:]),
|
|
), nil
|
|
}
|
|
|
|
// getFirstAvailableFile returns an *os.File of the first available
|
|
// file from a list of candidate file paths.
|
|
func getFirstAvailableFile(candidates []string) (*os.File, error) {
|
|
for _, c := range candidates {
|
|
file, err := os.Open(c)
|
|
if err == nil {
|
|
return file, nil
|
|
}
|
|
}
|
|
|
|
return nil, fmt.Errorf("no candidate file available: %v", candidates)
|
|
}
|