| Index | index by Group | index by Distribution | index by Vendor | index by creation date | index by Name | Mirrors | Help | Search | 
| Name: go1.23-doc | Distribution: openSUSE Tumbleweed | 
| Version: 1.23.12 | Vendor: openSUSE | 
| Release: 2.1 | Build date: Thu Aug 14 16:52:35 2025 | 
| Group: Documentation/Other | Build host: reproducible | 
| Size: 586744 | Source RPM: go1.23-1.23.12-2.1.src.rpm | 
| Packager: http://bugs.opensuse.org | |
| Url: https://go.dev/ | |
| Summary: Go documentation | |
Go examples and documentation.
BSD-3-Clause
* Thu Aug 14 2025 Jeff Kowalczyk <jkowalczyk@suse.com>
  - Packaging improvements:
    * Remove conditional gccgo bootstrap sections and gcc-go.patch.
      gccgo cannot be used in any version newer than go1.21. Removal
      simplifies go1.x package code.
    * go1.21 can optionally be bootstrapped with gccgo and serve as
      the inital version of go1.x.
    * go1.21 will be the initial version of Go in the bootstrap chain
      until gcc gccgo is updated to support a language level newer
      than go1.18.
    * Drop gcc-go.patch
    * Refs boo#1247816 bootstrap go1.21 with gccgo
    * Refs boo#1248082 drop unused gccgo bootstrap code in go1.22+
* Fri Aug 08 2025 Jeff Kowalczyk <jkowalczyk@suse.com>
  - Packaging improvements:
    * Update go_bootstrap_version to go1.21 from go1.20 to shorten
      the bootstrap chain. go1.21 can optionally be bootstrapped with
      gccgo and serve as the inital version of go1.x.
    * Refs boo#1247816 bootstrap go1.21 with gccgo
* Wed Aug 06 2025 Jeff Kowalczyk <jkowalczyk@suse.com>
  - go1.23.12 (released 2025-08-06) includes security fixes to the
    database/sql and os/exec packages, as well as bug fixes to the
    runtime.
    Refs boo#1229122 go1.23 release tracking
    CVE-2025-47906 CVE-2025-47907
    * go#74803 go#74466 boo#1247719 security: fix CVE-2025-47906 os/exec: LookPath bug: incorrect expansion of "", "." and ".." in some PATH configurations
    * go#74832 go#74831 boo#1247720 security: fix CVE-2025-47907 database/sql: incorrect results returned from Rows.Scan
    * go#74415 runtime: use-after-free of allpSnapshot in findRunnable
    * go#74693 runtime: segfaults in runtime.(*unwinder).next
    * go#74721 cmd/go: TestScript/build_trimpath_cgo fails to decode dwarf on release-branch.go1.23
    * go#74726 cmd/cgo/internal/testsanitizers: failures with signal: segmentation fault or exit status 66
* Tue Jul 08 2025 Jeff Kowalczyk <jkowalczyk@suse.com>
  - go1.23.11 (released 2025-07-08) includes security fixes to the go
    command, as well as bug fixes to the compiler, the linker, and
    the runtime.
    Refs boo#1229122 go1.23 release tracking
    CVE-2025-4674
    * go#74382 go#74380 boo#1246118 security: fix CVE-2025-4674 cmd/go: disable support for multiple vcs in one module
    * go#73907 runtime: bad frame pointer during panic during duffcopy
    * go#74289 runtime: heap mspan limit is set too late, causing data race between span allocation and conservative scanning
    * go#74293 internal/trace: stress tests triggering suspected deadlock in tracer
    * go#74362 runtime/pprof: crash "cannot read stack of running goroutine" in goroutine profile
    * go#74402 cmd/link: duplicated definition of symbol github.com/ebitengine/purego.syscall15XABI0 when running with ASAN
* Thu Jun 05 2025 Jeff Kowalczyk <jkowalczyk@suse.com>
  - go1.23.10 (released 2025-06-05) includes security fixes to the
    net/http and os packages, as well as bug fixes to the linker.
    Refs boo#1229122 go1.23 release tracking
    CVE-2025-0913 CVE-2025-4673
    * go#73719 go#73612 boo#1244157 security: fix CVE-2025-0913 os: inconsistent handling of O_CREATE|O_EXCL on Unix and Windows
    * go#73905 go#73816 boo#1244156 security: fix CVE-2025-4673 net/http: sensitive headers not cleared on cross-origin redirect
    * go#73677 runtime/debug: BuildSetting does not document DefaultGODEBUG
    * go#73831 cmd/link: Go 1.24.3 and 1.23.9 regression - duplicated definition of symbol dlopen
* Tue May 06 2025 Jeff Kowalczyk <jkowalczyk@suse.com>
  - go1.23.9 (released 2025-05-06) includes fixes to the runtime and
    the linker.
    Refs boo#1229122 go1.23 release tracking
    * go#73091 cmd/link: linkname directive on userspace variable can override runtime variable
    * go#73380 runtime, x/sys/unix: Connectx is broken on darwin/amd64
* Tue Apr 01 2025 Jeff Kowalczyk <jkowalczyk@suse.com>
  - go1.23.8 (released 2025-04-01) includes security fixes to the
    net/http package, as well as bug fixes to the runtime and the go
    command.
    Refs boo#1229122 go1.23 release tracking
    CVE-2025-22871
    * go#72010 go#71988 boo#1240550 security: fix CVE-2025-22871 net/http: reject bare LF in chunked encoding
    * go#72114 runtime: process hangs for mips hardware
    * go#72871 runtime: cgo callback on extra M treated as external code after nested cgo callback returns
    * go#72937 internal/godebugs: winsymlink and winreadlinkvolume have incorrect defaults for Go 1.22
* Tue Mar 04 2025 Jeff Kowalczyk <jkowalczyk@suse.com>
  - go1.23.7 (released 2025-03-04) includes security fixes to the
    net/http package, as well as bug fixes to cgo, the compiler, and
    the reflect, runtime, and syscall packages.
    Refs boo#1229122 go1.23 release tracking
    CVE-2025-22870
    * go#71985 go#71984 boo#1238572 security: fix CVE-2025-22870 net/http, x/net/proxy, x/net/http/httpproxy: proxy bypass using IPv6 zone IDs
    * go#71727 runtime: usleep computes wrong tv_nsec on s390x
    * go#71839 runtime: recover added in range-over-func loop body doesn't stop panic propagation / segfaults printing error
    * go#71848 os: spurious SIGCHILD on running child process
    * go#71875 reflect: Value.Seq panicking on functional iterator methods
    * go#71915 reflect: Value.Seq iteration value types not matching the type of given int types
    * go#71962 runtime/cgo: does not build with -Wdeclaration-after-statement
* Tue Feb 04 2025 Jeff Kowalczyk <jkowalczyk@suse.com>
  - go1.23.6 (released 2025-02-04) includes security fixes to the
    crypto/elliptic package, as well as bug fixes to the compiler and
    the go command.
    Refs boo#1229122 go1.23 release tracking
    CVE-2025-22866
    * go#71423 go#71383 boo#1236801 security: fix CVE-2025-22866 crypto/internal/fips140/nistec: p256NegCond is variable time on ppc64le
    * go#71263 cmd/go/internal/modfetch/codehost: test fails with git 2.47.1
    * go#71230 cmd/compile: broken write barrier
* Thu Jan 16 2025 Jeff Kowalczyk <jkowalczyk@suse.com>
  - go1.23.5 (released 2025-01-16) includes security fixes to the
    crypto/x509 and net/http packages, as well as bug fixes to the
    compiler, the runtime, and the net package.
    Refs boo#1229122 go1.23 release tracking
    CVE-2024-45341 CVE-2024-45336
    * go#71208 go#71156 boo#1236045 security: fix CVE-2024-45341 crypto/x509: usage of IPv6 zone IDs can bypass URI name constraints
    * go#71211 go#70530 boo#1236046 security: fix CVE-2024-45336 net/http: sensitive headers incorrectly sent after cross-domain redirect
    * go#69988 runtime: severe performance drop for cgo calls in go1.22.5
    * go#70517 cmd/compile/internal/importer: flip enable alias to true
    * go#70789 os: io.Copy(net.Conn, os.Stdin) on MacOS terminate immediately without waiting for input
    * go#71104 crypto/tls: TestVerifyConnection/TLSv12 failures
    * go#71147 internal/trace: TestTraceCPUProfile/Stress failures
* Thu Dec 05 2024 Adrian Schröter <adrian@suse.de>
  - Enable loongarch64 builds
* Tue Dec 03 2024 Jeff Kowalczyk <jkowalczyk@suse.com>
  - go1.23.4 (released 2024-12-03) includes fixes to the compiler,
    the runtime, the trace command, and the syscall package.
    Refs boo#1229122 go1.23 release tracking
    * go#70644 crypto/rsa: new key generation prohibitively slow under race detector
    * go#70645 proposal: go/types: add Scope.Node convenience getter
    * go#70646 x/tools/gopls: unimported completion corrupts import decl (client=BBEdit)
    * go#70648 crypto/tls: TestHandshakeClientECDHEECDSAAESGCM/TLSv12 failures
    * go#70649 x/benchmarks/sweet/cmd/sweet: TestSweetEndToEnd failures
    * go#70650 crypto/tls: TestGetClientCertificate/TLSv13 failures
    * go#70651 x/tools/go/gcexportdata: simplify implementation assuming go >= 1.21
    * go#70654 cmd/go: Incorrect output from go list
    * go#70655 x/build/cmd/relui: add workflows for some remaining manual recurring Go major release cycle tasks
    * go#70657 proposal: bufio: Scanner.IterText/Scanner.IterBytes
    * go#70658 x/net/http2: stuck extended CONNECT requests
    * go#70659 os: TestRootDirFS failures on linux-mips64 and linux-mips64le arch-mips
    * go#70660 crypto/ecdsa: TestRFC6979 failures on s390x
    * go#70664 x/mobile: target maccatalyst cannot find OpenGLES header
    * go#70665 x/tools/gopls: refactor.extract.variable fails at package level
    * go#70666 x/tools/gopls: panic in GetIfaceStubInfo
    * go#70667 proposal: crypto/x509: support extracting X25519 public keys from certificates
    * go#70668 proposal: x/mobile: better support for unrecovered panics
    * go#70669 cmd/go: local failure in TestScript/build_trimpath_cgo
    * go#70670 cmd/link: unused functions aren't getting deadcoded from the binary
    * go#70674 x/pkgsite: package removal request for https://pkg.go.dev/github.com/uisdevsquad/go-test/debugmate
    * go#70675 cmd/go/internal/lockedfile: mountrpc flake in TestTransform on plan9
    * go#70677 all: remote file server I/O flakiness with "Bad fid" errors on plan9
    * go#70678 internal/poll: deadlock on 'Intel(R) Xeon(R) Platinum' when an FD is closed
    * go#70679 mime/multipart: With go 1.23.3, mime/multipart does not link
* Wed Nov 06 2024 Jeff Kowalczyk <jkowalczyk@suse.com>
  - go1.23.3 (released 2024-11-06) includes fixes to the linker, the
    runtime, and the net/http, os, and syscall packages.
    Refs boo#1229122 go1.23 release tracking
    * go#69258 runtime: corrupted GoroutineProfile stack traces
    * go#69259 runtime: multi-arch build via qemu fails to exec go binary
    * go#69640 os: os.checkPidfd() crashes with SIGSYS
    * go#69746 runtime: TestGdbAutotmpTypes failures
    * go#69848 cmd/compile: syscall.Syscall15: nosplit stack over 792 byte limit
    * go#69865 runtime: MutexProfile missing root frames in go1.23
    * go#69882 time,runtime: too many concurrent timer firings for short time.Ticker
    * go#69978 time,runtime: too many concurrent timer firings for short, fast-resetting time.Timer
    * go#69992 cmd/link: LC_UUID not generated by go linker, resulting in failure to access local network on macOS 15
    * go#70001 net/http/pprof: coroutines + pprof makes the program panic
    * go#70020 net/http: short writes with FileServer on macos
* Tue Oct 01 2024 Jeff Kowalczyk <jkowalczyk@suse.com>
  - go1.23.2 (released 2024-10-01) includes fixes to the compiler,
    cgo, the runtime, and the maps, os, os/exec, time, and unique
    packages.
    Refs boo#1229122 go1.23 release tracking
    * go#69119 os: double close pidfd if caller uses pidfd updated by os.StartProcess
    * go#69156 maps: segmentation violation in maps.Clone
    * go#69219 cmd/cgo: alignment issue with int128 inside of a struct
    * go#69240 unique: fatal error: found pointer to free object
    * go#69333 runtime,time: timer.Stop returns false even when no value is read from the channel
    * go#69383 unique: large string still referenced, after interning only a small substring
    * go#69402 os/exec: resource leak on exec failure
    * go#69511 cmd/compile: mysterious crashes and non-determinism with range over func
* Thu Sep 05 2024 Jeff Kowalczyk <jkowalczyk@suse.com>
  - go1.23.1 (released 2024-09-05) includes security fixes to the
    encoding/gob, go/build/constraint, and go/parser packages, as
    well as bug fixes to the compiler, the go command, the runtime,
    and the database/sql, go/types, os, runtime/trace, and unique
    packages.
    Refs boo#1229122 go1.23 release tracking
    CVE-2024-34155 CVE-2024-34156 CVE-2024-34158
    - go#69143 go#69138 boo#1230252 security: fix CVE-2024-34155 go/parser: stack exhaustion in all Parse* functions
    - go#69145 go#69139 boo#1230253 security: fix CVE-2024-34156 encoding/gob: stack exhaustion in Decoder.Decode
    - go#69149 go#69141 boo#1230254 security: fix CVE-2024-34158 go/build/constraint: stack exhaustion in Parse
    - go#68812 os: TestChtimes failures
    - go#68894 go/types: 'under' panics on Alias type
    - go#68905 cmd/compile: error in Go 1.23.0 with generics, type aliases and indexing
    - go#68907 os: CopyFS overwrites existing file in destination.
    - go#68973 cmd/cgo: aix c-archive corrupting stack
    - go#68992 unique: panic when calling unique.Make with string casted as any
    - go#68994 cmd/go: any invocation creates read-only telemetry configuration file under GOMODCACHE
    - go#68995 cmd/go: multi-arch build via qemu fails to exec go binary
    - go#69041 database/sql: panic in database/sql.(*connRequestSet).deleteIndex
    - go#69087 runtime/trace: crash during traceAdvance when collecting call stack for cgo-calling goroutine
    - go#69094 cmd/go: breaking change in 1.23rc2 with version constraints in GOPATH mode
* Tue Aug 13 2024 Jeff Kowalczyk <jkowalczyk@suse.com>
  - go1.23 (released 2024-08-13) is a major release of Go.
    go1.23.x minor releases will be provided through August 2025.
    https://github.com/golang/go/wiki/Go-Release-Cycle
    go1.23 arrives six months after go1.22. Most of its changes are
    in the implementation of the toolchain, runtime, and libraries.
    As always, the release maintains the Go 1 promise of
    compatibility. We expect almost all Go programs to continue to
    compile and run as before.
    Refs boo#1229122 go1.23 release tracking
    * Language change: Go 1.23 makes the (Go 1.22) "range-over-func"
      experiment a part of the language. The "range" clause in a
      "for-range" loop now accepts iterator functions of the
      following types:
      func(func() bool)
      func(func(K) bool)
      func(func(K, V) bool)
      as range expressions. Calls of the iterator argument function
      produce the iteration values for the "for-range" loop. For
      details see the iter package documentation and the language
      spec. For motivation see the 2022 "range-over-func" discussion.
    * Language change: Go 1.23 includes preview support for generic
      type aliases. Building the toolchain with
      GOEXPERIMENT=aliastypeparams enables this feature within a
      package. (Using generic alias types across package boundaries
      is not yet supported.)
    * Opt-in Telemetry: Starting in Go 1.23, the Go toolchain can
      collect usage and breakage statistics that help the Go team
      understand how the Go toolchain is used and how well it is
      working. We refer to these statistics as Go telemetry.
      Go telemetry is an opt-in system, controlled by the go
      telemetry command. By default, the toolchain programs collect
      statistics in counter files that can be inspected locally but
      are otherwise unused (go telemetry local).
      To help us keep Go working well and understand Go usage, please
      consider opting in to Go telemetry by running go telemetry
      on. In that mode, anonymous counter reports are uploaded to
      telemetry.go.dev weekly, where they are aggregated into graphs
      and also made available for download by any Go contributors or
      users wanting to analyze the data. See "Go Telemetry" for more
      details about the Go Telemetry system.
    * go command: Setting the GOROOT_FINAL environment variable no
      longer has an effect (#62047). Distributions that install the
      go command to a location other than $GOROOT/bin/go should
      install a symlink instead of relocating or copying the go
      binary.
    * go command: The new go env -changed flag causes the command to
      print only those settings whose effective value differs from
      the default value that would be obtained in an empty
      environment with no prior uses of the -w flag.
    * go command: The new go mod tidy -diff flag causes the command
      not to modify the files but instead print the necessary changes
      as a unified diff. It exits with a non-zero code if updates are
      needed.
    * go command: The go list -m -json command now includes new Sum
      and GoModSum fields. This is similar to the existing behavior
      of the go mod download -json command.
    * go command: The new godebug directive in go.mod and go.work
      declares a GODEBUG setting to apply for the work module or
      workspace in use.
    * go vet: The go vet subcommand now includes the stdversion
      analyzer, which flags references to symbols that are too new
      for the version of Go in effect in the referring file. (The
      effective version is determined by the go directive in the
      file's enclosing go.mod file, and by any //go:build constraints
      in the file.)
      For example, it will report a diagnostic for a reference to the
      reflect.TypeFor function (introduced in go1.22) from a file in
      a module whose go.mod file specifies go 1.21.
    * cgo: cmd/cgo supports the new -ldflags flag for passing flags
      to the C linker. The go command uses it automatically, avoiding
      "argument list too long" errors with a very large CGO_LDFLAGS.
    * go trace: The trace tool now better tolerates partially broken
      traces by attempting to recover what trace data it can. This
      functionality is particularly helpful when viewing a trace that
      was collected during a program crash, since the trace data
      leading up to the crash will now be recoverable under most
      circumstances.
    * Runtime: The traceback printed by the runtime after an
      unhandled panic or other fatal error now indents the second and
      subsequent lines of the error message (for example, the
      argument to panic) by a single tab, so that it can be
      unambiguously distinguished from the stack trace of the first
      goroutine. See go#64590 for discussion.
    * Compiler: The build time overhead to building with Profile
      Guided Optimization has been reduced significantly. Previously,
      large builds could see 100%+ build time increase from enabling
      PGO. In Go 1.23, overhead should be in the single digit
      percentages.
    * Compiler: The compiler in Go 1.23 can now overlap the stack
      frame slots of local variables accessed in disjoint regions of
      a function, which reduces stack usage for Go applications.
    * Compiler: For 386 and amd64, the compiler will use information
      from PGO to align certain hot blocks in loops. This improves
      performance an additional 1-1.5% at a cost of an additional
      0.1% text and binary size. This is currently only implemented
      on 386 and amd64 because it has not shown an improvement on
      other platforms. Hot block alignment can be disabled with
    - gcflags=[<packages>=]-d=alignhot=0.
    * Linker: The linker now disallows using a //go:linkname
      directive to refer to internal symbols in the standard library
      (including the runtime) that are not marked with //go:linkname
      on their definitions. Similarly, the linker disallows
      references to such symbols from assembly code. For backward
      compatibility, existing usages of //go:linkname found in a
      large open-source code corpus remain supported. Any new
      references to standard library internal symbols will be
      disallowed.
    * Linker: A linker command line flag -checklinkname=0 can be used
      to disable this check, for debugging and experimenting
      purposes.
    * Linker: When building a dynamically linked ELF binary
      (including PIE binary), the new -bindnow flag enables immediate
      function binding.
    * Standard library changes:
    * timer: 1.23 makes two significant changes to the implementation
      of time.Timer and time.Ticker.
      First, Timers and Tickers that are no longer referred to by the
      program become eligible for garbage collection immediately,
      even if their Stop methods have not been called. Earlier
      versions of Go did not collect unstopped Timers until after
      they had fired and never collected unstopped Tickers.
      Second, the timer channel associated with a Timer or Ticker is
      now unbuffered, with capacity 0. The main effect of this change
      is that Go now guarantees that for any call to a Reset or Stop
      method, no stale values prepared before that call will be sent
      or received after the call. Earlier versions of Go used
      channels with a one-element buffer, making it difficult to use
      Reset and Stop correctly. A visible effect of this change is
      that len and cap of timer channels now returns 0 instead of 1,
      which may affect programs that poll the length to decide
      whether a receive on the timer channel will succeed. Such code
      should use a non-blocking receive instead.
      These new behaviors are only enabled when the main Go program
      is in a module with a go.mod go line using Go 1.23.0 or
      later. When Go 1.23 builds older programs, the old behaviors
      remain in effect. The new GODEBUG setting asynctimerchan=1 can
      be used to revert back to asynchronous channel behaviors even
      when a program names Go 1.23.0 or later in its go.mod file.
    * unique: The new unique package provides facilities for
      canonicalizing values (like "interning" or "hash-consing").
      Any value of comparable type may be canonicalized with the new
      Make[T] function, which produces a reference to a canonical
      copy of the value in the form of a Handle[T]. Two Handle[T] are
      equal if and only if the values used to produce the handles are
      equal, allowing programs to deduplicate values and reduce their
      memory footprint. Comparing two Handle[T] values is efficient,
      reducing down to a simple pointer comparison.
    * iter: The new iter package provides the basic definitions for
      working with user-defined iterators.
    * slices: The slices package adds several functions that work
      with iterators:
    - All returns an iterator over slice indexes and values.
    - Values returns an iterator over slice elements.
    - Backward returns an iterator that loops over a slice backward.
    - Collect collects values from an iterator into a new slice.
    - AppendSeq appends values from an iterator to an existing slice.
    - Sorted collects values from an iterator into a new slice, and then sorts the slice.
    - SortedFunc is like Sorted but with a comparison function.
    - SortedStableFunc is like SortFunc but uses a stable sort algorithm.
    - Chunk returns an iterator over consecutive sub-slices of up to n elements of a slice.
    * maps: The maps package adds several functions that work with
      iterators:
    - All returns an iterator over key-value pairs from a map.
    - Keys returns an iterator over keys in a map.
    - Values returns an iterator over values in a map.
    - Insert adds the key-value pairs from an iterator to an existing map.
    - Collect collects key-value pairs from an iterator into a new map and returns it.
    * structs: The new structs package provides types for struct
      fields that modify properties of the containing struct type
      such as memory layout.
      In this release, the only such type is HostLayout which
      indicates that a structure with a field of that type has a
      layout that conforms to host platform expectations.
    * Minor changes to the standard library: As always, there are
      various minor changes and updates to the library, made with the
      Go 1 promise of compatibility in mind.
    * archive/tar: If the argument to FileInfoHeader implements the
      new FileInfoNames interface, then the interface methods will be
      used to set the Uname/Gname of the file header. This allows
      applications to override the system-dependent Uname/Gname
      lookup.
    * crypto/tls: The TLS client now supports the Encrypted Client
      Hello draft specification. This feature can be enabled by
      setting the Config.EncryptedClientHelloConfigList field to an
      encoded ECHConfigList for the host that is being connected to.
    * crypto/tls: The QUICConn type used by QUIC implementations
      includes new events reporting on the state of session
      resumption, and provides a way for the QUIC layer to add data
      to session tickets and session cache entries.
    * crypto/tls: 3DES cipher suites were removed from the default
      list used when Config.CipherSuites is nil. The default can be
      reverted by adding tls3des=1 to the GODEBUG environment
      variable.
    * crypto/tls: The experimental post-quantum key exchange
      mechanism X25519Kyber768Draft00 is now enabled by default when
      Config.CurvePreferences is nil. The default can be reverted by
      adding tlskyber=0 to the GODEBUG environment variable.
    * crypto/tls: Go 1.23 changed the behavior of X509KeyPair and
      LoadX509KeyPair to populate the Certificate.Leaf field of the
      returned Certificate. The new x509keypairleaf GODEBUG setting
      is added for this behavior.
    * crypto/x509: CreateCertificateRequest now correctly supports
      RSA-PSS signature algorithms.
    * crypto/x509: CreateCertificateRequest and CreateRevocationList
      now verify the generated signature using the signer's public
      key. If the signature is invalid, an error is returned. This
      has been the behavior of CreateCertificate since Go 1.16.
    * crypto/x509: The x509sha1 GODEBUG setting will be removed in
      the next Go major release (Go 1.24). This will mean that
      crypto/x509 will no longer support verifying signatures on
      certificates that use SHA-1 based signature algorithms.
    * crypto/x509: The new ParseOID function parses a dot-encoded
      ASN.1 Object Identifier string. The OID type now implements the
      encoding.BinaryMarshaler, encoding.BinaryUnmarshaler,
      encoding.TextMarshaler, encoding.TextUnmarshaler interfaces.
      database/sql
    * crypto/x509: Errors returned by driver.Valuer implementations
      are now wrapped for improved error handling during operations
      like DB.Query, DB.Exec, and DB.QueryRow.
    * debug/elf: The debug/elf package now defines
      PT_OPENBSD_NOBTCFI. This ProgType is used to disable Branch
      Tracking Control Flow Integrity (BTCFI) enforcement on OpenBSD
      binaries.
    * debug/elf: Now defines the symbol type constants STT_RELC,
      STT_SRELC, and STT_GNU_IFUNC.
    * encoding/binary The new Encode and Decode functions are byte
      slice equivalents to Read and Write. Append allows marshaling
      multiple data into the same byte slice.
    * go/ast: The new Preorder function returns a convenient iterator
      over all the nodes of a syntax tree.
    * go/types: The Func type, which represents a function or method
      symbol, now has a Func.Signature method that returns the
      function's type, which is always a Signature.
    * go/types: The Alias type now has an Rhs method that returns the
      type on the right-hand side of its declaration: given type A =
      B, the Rhs of A is B. (go#66559)
    * go/types: The methods Alias.Origin, Alias.SetTypeParams,
      Alias.TypeParams, and Alias.TypeArgs have been added. They are
      needed for generic alias types.
    * go/types: By default, go/types now produces Alias type nodes
      for type aliases. This behavior can be controlled by the
      GODEBUG gotypesalias flag. Its default has changed from 0 in Go
      1.22 to 1 in Go 1.23.
    * math/rand/v2: The Uint function and Rand.Uint method have been
      added. They were inadvertently left out of Go 1.22.
    * math/rand/v2: The new ChaCha8.Read method implements the
      io.Reader interface.
    * net: The new type KeepAliveConfig permits fine-tuning the
      keep-alive options for TCP connections, via a new
      TCPConn.SetKeepAliveConfig method and new KeepAliveConfig
      fields for Dialer and ListenConfig.
    * net: The DNSError type now wraps errors caused by timeouts or
      cancellation. For example, errors.Is(someDNSErr,
      context.DeadlineExceedeed) will now report whether a DNS error
      was caused by a timeout.
    * net: The new GODEBUG setting netedns0=0 disables sending EDNS0
      additional headers on DNS requests, as they reportedly break
      the DNS server on some modems.
    * net/http: Cookie now preserves double quotes surrounding a
      cookie value. The new Cookie.Quoted field indicates whether the
      Cookie.Value was originally quoted.
    * net/http: The new Request.CookiesNamed method retrieves all
      cookies that match the given name.
    * net/http: The new Cookie.Partitioned field identifies cookies
      with the Partitioned attribute.
    * net/http: The patterns used by ServeMux now allow one or more
      spaces or tabs after the method name. Previously, only a single
      space was permitted.
    * net/http: The new ParseCookie function parses a Cookie header
      value and returns all the cookies which were set in it. Since
      the same cookie name can appear multiple times the returned
      Values can contain more than one value for a given key.
    * net/http: The new ParseSetCookie function parses a Set-Cookie
      header value and returns a cookie. It returns an error on
      syntax error.
    * net/http: ServeContent, ServeFile, and ServeFileFS now remove
      the Cache-Control, Content-Encoding, Etag, and Last-Modified
      headers when serving an error. These headers usually apply to
      the non-error content, but not to the text of errors.
    * net/http: Middleware which wraps a ResponseWriter and applies
      on-the-fly encoding, such as Content-Encoding: gzip, will not
      function after this change. The previous behavior of
      ServeContent, ServeFile, and ServeFileFS may be restored by
      setting GODEBUG=httpservecontentkeepheaders=1.
      Note that middleware which changes the size of the served
      content (such as by compressing it) already does not function
      properly when ServeContent handles a Range request. On-the-fly
      compression should use the Transfer-Encoding header instead of
      Content-Encoding.
    * net/http: For inbound requests, the new Request.Pattern field
      contains the ServeMux pattern (if any) that matched the
      request. This field is not set when GODEBUG=httpmuxgo121=1 is
      set.
    * net/http/httptest: The new NewRequestWithContext method creates
      an incoming request with a context.Context.
    * net/netip: In Go 1.22 and earlier, using reflect.DeepEqual to
      compare an Addr holding an IPv4 address to one holding the
      IPv4-mapped IPv6 form of that address incorrectly returned
      true, even though the Addr values were different when comparing
      with == or Addr.Compare. This bug is now fixed and all three
      approaches now report the same result.
    * os: The Stat function now sets the ModeSocket bit for files
      that are Unix sockets on Windows. These files are identified by
      having a reparse tag set to IO_REPARSE_TAG_AF_UNIX.
    * os: On Windows, the mode bits reported by Lstat and Stat for
      reparse points changed. Mount points no longer have ModeSymlink
      set, and reparse points that are not symlinks, Unix sockets, or
      dedup files now always have ModeIrregular set. This behavior is
      controlled by the winsymlink setting. For Go 1.23, it defaults
      to winsymlink=1. Previous versions default to winsymlink=0.
    * os: The CopyFS function copies an io/fs.FS into the local
      filesystem.
    * os: On Windows, Readlink no longer tries to normalize volumes
      to drive letters, which was not always even possible. This
      behavior is controlled by the winreadlinkvolume setting. For Go
      1.23, it defaults to winreadlinkvolume=1. Previous versions
      default to winreadlinkvolume=0.
    * os: On Linux with pidfd support (generally Linux v5.4+),
      Process-related functions and methods use pidfd (rather than
      PID) internally, eliminating potential mistargeting when a PID
      is reused by the OS. Pidfd support is fully transparent to a
      user, except for additional process file descriptors that a
      process may have.
    * path/filepath: The new Localize function safely converts a
      slash-separated path into an operating system path.
    * path/filepath: On Windows, EvalSymlinks no longer evaluates
      mount points, which was a source of many inconsistencies and
      bugs. This behavior is controlled by the winsymlink
      setting. For Go 1.23, it defaults to winsymlink=1. Previous
      versions default to winsymlink=0.
    * path/filepath: On Windows, EvalSymlinks no longer tries to
      normalize volumes to drive letters, which was not always even
      possible. This behavior is controlled by the winreadlinkvolume
      setting. For Go 1.23, it defaults to
      winreadlinkvolume=1. Previous versions default to
      winreadlinkvolume=0.
    * reflect: The new methods synonymous with the methods of the
      same name in Value are added to Type:
    - Type.OverflowComplex
    - Type.OverflowFloat
    - Type.OverflowInt
    - Type.OverflowUint
    * reflect: The new SliceAt function is analogous to NewAt, but
      for slices.
    * reflect: The Value.Pointer and Value.UnsafePointer methods now
      support values of kind String.
    * reflect: The new methods Value.Seq and Value.Seq2 return
      sequences that iterate over the value as though it were used in
      a for/range loop. The new methods Type.CanSeq and Type.CanSeq2
      report whether calling Value.Seq and Value.Seq2, respectively,
      will succeed without panicking.
    * runtime/debug: The SetCrashOutput function allows the user to
      specify an alternate file to which the runtime should write its
      fatal crash report. It may be used to construct an automated
      reporting mechanism for all unexpected crashes, not just those
      in goroutines that explicitly use recover.
    * runtime/pprof: The maximum stack depth for alloc, mutex, block,
      threadcreate and goroutine profiles has been raised from 32 to
      128 frames.
    * runtime/trace: The runtime now explicitly flushes trace data
      when a program crashes due to an uncaught panic. This means
      that more complete trace data will be available in a trace if
      the program crashes while tracing is active.
    * slices: The Repeat function returns a new slice that repeats
      the provided slice the given number of times.
    * sync: The Map.Clear method deletes all the entries, resulting
      in an empty Map. It is analogous to clear.
    * sync/atomic: The new And and Or operators apply a bitwise AND
      or OR to the given input, returning the old value.
    * syscall: The syscall package now defines WSAENOPROTOOPT on
      Windows.
    * syscall: The GetsockoptInt function is now supported on
      Windows.
    * testing/fstest: TestFS now returns a structured error that can
      be unwrapped (via method Unwrap() []error). This allows
      inspecting errors using errors.Is or errors.As.
    * text/template: Templates now support the new "else with"
      action, which reduces template complexity in some use cases.
    * time: Parse and ParseInLocation now return an error if the time
      zone offset is out of range.
    * unicode/utf16: The RuneLen function returns the number of
      16-bit words in the UTF-16 encoding of the rune. It returns -1
      if the rune is not a valid value to encode in UTF-16.
    * Port: Darwin: As announced in the Go 1.22 release notes, Go
      1.23 requires macOS 11 Big Sur or later; support for previous
      versions has been discontinued.
    * Port: Linux: Go 1.23 is the last release that requires Linux
      kernel version 2.6.32 or later. Go 1.24 will require Linux
      kernel version 3.17 or later, with an exception that systems
      running 3.10 or later will continue to be supported if the
      kernel has been patched to support the getrandom system call.
    * Port: OpenBSD: Go 1.23 adds experimental support for OpenBSD on
      64-bit RISC-V (GOOS=openbsd, GOARCH=riscv64).
    * Port: ARM64: Go 1.23 introduces a new GOARM64 environment
      variable, which specifies the minimum target version of the
      ARM64 architecture at compile time. Allowed values are v8.{0-9}
      and v9.{0-5}. This may be followed by an option specifying
      extensions implemented by target hardware. Valid options are
      ,lse and ,crypto.
      The GOARM64 environment variable defaults to v8.0.
    * Port: RISC-V: Go 1.23 introduces a new GORISCV64 environment
      variable, which selects the RISC-V user-mode application
      profile for which to compile. Allowed values are rva20u64 and
      rva22u64.
      The GORISCV64 environment variable defaults to rva20u64.
    * Port: Wasm: The go_wasip1_wasm_exec script in GOROOT/misc/wasm
      has dropped support for versions of wasmtime < 14.0.0.
* Tue Jul 16 2024 Jeff Kowalczyk <jkowalczyk@suse.com>
  - go1.23rc2 (released 2024-07-16) is a release candidate version of
    go1.23 cut from the master branch at the revision tagged
    go1.23rc2.
* Fri Jun 21 2024 Jeff Kowalczyk <jkowalczyk@suse.com>
  - go1.23rc1 (released 2024-06-21) is a release candidate version of
    go1.23 cut from the master branch at the revision tagged
    go1.23rc1.
    * go1.23 now requires the final point release of go1.20 or later
      for bootstrap. Go upstream expects that go1.24 will require the
      final point release of Go 1.23 or later for bootstrap.
/usr/share/doc/packages/go/1.23/asm.html /usr/share/doc/packages/go/1.23/go1.17_spec.html /usr/share/doc/packages/go/1.23/go_mem.html /usr/share/doc/packages/go/1.23/go_spec.html /usr/share/doc/packages/go/1.23/godebug.md
Generated by rpm2html 1.8.1
Fabrice Bellet, Fri Oct 24 23:31:51 2025