build: use Go 1.23, require minimum 1.22 (#9651)

🥳

---------

Co-authored-by: Ross Smith II <ross@smithii.com>
This commit is contained in:
Jakob Borg 2024-08-19 20:26:08 +02:00 committed by GitHub
parent 9ef37e1485
commit 8dc826b234
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 16 additions and 27 deletions

View File

@ -7,7 +7,7 @@ on:
- infra-* - infra-*
env: env:
GO_VERSION: "~1.22.3" GO_VERSION: "~1.23.0"
CGO_ENABLED: "0" CGO_ENABLED: "0"
BUILD_USER: docker BUILD_USER: docker
BUILD_HOST: github.syncthing.net BUILD_HOST: github.syncthing.net

View File

@ -12,7 +12,7 @@ env:
# The go version to use for builds. We set check-latest to true when # The go version to use for builds. We set check-latest to true when
# installing, so we get the latest patch version that matches the # installing, so we get the latest patch version that matches the
# expression. # expression.
GO_VERSION: "~1.22.3" GO_VERSION: "~1.23.0"
# Optimize compatibility on the slow archictures. # Optimize compatibility on the slow archictures.
GO386: softfloat GO386: softfloat
@ -48,7 +48,7 @@ jobs:
runner: ["windows-latest", "ubuntu-latest", "macos-latest"] runner: ["windows-latest", "ubuntu-latest", "macos-latest"]
# The oldest version in this list should match what we have in our go.mod. # The oldest version in this list should match what we have in our go.mod.
# Variables don't seem to be supported here, or we could have done something nice. # Variables don't seem to be supported here, or we could have done something nice.
go: ["~1.21.7", "~1.22.3"] go: ["~1.22.6", "~1.23.0"]
runs-on: ${{ matrix.runner }} runs-on: ${{ matrix.runner }}
steps: steps:
- name: Set git to use LF - name: Set git to use LF

2
go.mod
View File

@ -1,6 +1,6 @@
module github.com/syncthing/syncthing module github.com/syncthing/syncthing
go 1.21.0 go 1.22.0
require ( require (
github.com/AudriusButkevicius/recli v0.0.7-0.20220911121932-d000ce8fbf0f github.com/AudriusButkevicius/recli v0.0.7-0.20220911121932-d000ce8fbf0f

View File

@ -11,15 +11,15 @@ package fs
import ( import (
"fmt" "fmt"
"go/version"
"os" "os"
"runtime"
"syscall" "syscall"
"unsafe" "unsafe"
"golang.org/x/sys/windows" "golang.org/x/sys/windows"
) )
const IO_REPARSE_TAG_DEDUP = 0x80000013
func readReparseTag(path string) (uint32, error) { func readReparseTag(path string) (uint32, error) {
namep, err := syscall.UTF16PtrFromString(path) namep, err := syscall.UTF16PtrFromString(path)
if err != nil { if err != nil {
@ -60,10 +60,6 @@ func isDirectoryJunction(reparseTag uint32) bool {
return reparseTag == windows.IO_REPARSE_TAG_MOUNT_POINT return reparseTag == windows.IO_REPARSE_TAG_MOUNT_POINT
} }
func isDeduplicatedFile(reparseTag uint32) bool {
return reparseTag == IO_REPARSE_TAG_DEDUP
}
type dirJunctFileInfo struct { type dirJunctFileInfo struct {
os.FileInfo os.FileInfo
} }
@ -71,21 +67,22 @@ type dirJunctFileInfo struct {
func (fi *dirJunctFileInfo) Mode() os.FileMode { func (fi *dirJunctFileInfo) Mode() os.FileMode {
// Simulate a directory and not a symlink; also set the execute // Simulate a directory and not a symlink; also set the execute
// bits so the directory can be traversed Unix-side. // bits so the directory can be traversed Unix-side.
return fi.FileInfo.Mode() ^ os.ModeSymlink | os.ModeDir | 0111 return fi.FileInfo.Mode() ^ junctionPointModeMask | os.ModeDir | 0111
} }
func (fi *dirJunctFileInfo) IsDir() bool { func (fi *dirJunctFileInfo) IsDir() bool {
return true return true
} }
type dedupFileInfo struct { var junctionPointModeMask os.FileMode
os.FileInfo
}
func (fi *dedupFileInfo) Mode() os.FileMode { func init() {
// A deduplicated file should be treated as a regular file and not an junctionPointModeMask = os.ModeSymlink
// irregular file. if version.Compare(runtime.Version(), "go1.23") >= 0 {
return fi.FileInfo.Mode() &^ os.ModeIrregular // if GODEBUG=winsymlink=0, then we are in g1.22 mode so let's check for
// os.ModeSymlink as well, as it can't hurt.
junctionPointModeMask |= os.ModeIrregular
}
} }
func (f *BasicFilesystem) underlyingLstat(name string) (os.FileInfo, error) { func (f *BasicFilesystem) underlyingLstat(name string) (os.FileInfo, error) {
@ -96,19 +93,11 @@ func (f *BasicFilesystem) underlyingLstat(name string) (os.FileInfo, error) {
if err == nil { if err == nil {
// NTFS directory junctions can be treated as ordinary directories, // NTFS directory junctions can be treated as ordinary directories,
// see https://forum.syncthing.net/t/option-to-follow-directory-junctions-symbolic-links/14750 // see https://forum.syncthing.net/t/option-to-follow-directory-junctions-symbolic-links/14750
if fi.Mode()&os.ModeSymlink != 0 && f.junctionsAsDirs { if fi.Mode()&junctionPointModeMask != 0 && f.junctionsAsDirs {
if reparseTag, reparseErr := readReparseTag(name); reparseErr == nil && isDirectoryJunction(reparseTag) { if reparseTag, reparseErr := readReparseTag(name); reparseErr == nil && isDirectoryJunction(reparseTag) {
return &dirJunctFileInfo{fi}, nil return &dirJunctFileInfo{fi}, nil
} }
} }
// Workaround for #9120 till golang properly handles deduplicated files by
// considering them regular files.
if fi.Mode()&os.ModeIrregular != 0 {
if reparseTag, reparseErr := readReparseTag(name); reparseErr == nil && isDeduplicatedFile(reparseTag) {
return &dedupFileInfo{fi}, nil
}
}
} }
return fi, err return fi, err