Skip to content

Commit

Permalink
Merge pull request #174 from philippgille/add-replace-function-in-mag…
Browse files Browse the repository at this point in the history
…efile

Add replace function in Magefile
  • Loading branch information
philippgille authored Jan 27, 2024
2 parents d2e37e6 + 003d515 commit ac2f444
Showing 1 changed file with 53 additions and 0 deletions.
53 changes: 53 additions & 0 deletions magefiles/magefile.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@ package main

import (
"errors"
"os"
"path/filepath"
"runtime"

"github.com/bitfield/script"
Expand Down Expand Up @@ -83,3 +85,54 @@ func Clean() error {
p.Wait()
return p.Error()
}

// Replace replaces the tagged/versioned gokv dependencies with the local version.
// This is useful before tagging/releasing a new version of a helper package,
// to ensure all store implementations work with those latest helper package versions.
func Replace() error {
rootDir, err := os.Getwd()
if err != nil {
return err
}

impls, err := script.File("./build/implementations").Slice()
if err != nil {
return err
}
replaceText := `
replace (
github.com/philippgille/gokv => ../
github.com/philippgille/gokv/encoding => ../encoding
github.com/philippgille/gokv/test => ../test
github.com/philippgille/gokv/util => ../util
github.com/philippgille/gokv/sql => ../sql
)
`
for _, impl := range impls {
modFile := filepath.Join(".", impl, "go.mod")
content, err := os.ReadFile(modFile)
if err != nil {
return err
}
newContent := string(content) + replaceText

err = os.WriteFile(modFile, []byte(newContent), os.ModePerm)
if err != nil {
return err
}

err = os.Chdir(filepath.Join(".", impl))
if err != nil {
return err
}
err = sh.Run("go", "mod", "tidy")
if err != nil {
return err
}
err = os.Chdir(rootDir)
if err != nil {
return err
}
}
return nil
}

0 comments on commit ac2f444

Please # to comment.