mirror of
https://github.com/apricote/releaser-pleaser.git
synced 2026-01-13 21:21:03 +00:00
This change reverses the responsibility for which files the updaters are run on. Now each updater can specify the list of files and wether the files should be created when they do not exist yet. This simplifies the handling of each update in releaserpleaser.go, as we can just iterate over all updaters and call it for each file of that updater. Also update the flags to allow users to easily define which updaters should run.
39 lines
1,020 B
Go
39 lines
1,020 B
Go
package updater
|
|
|
|
import (
|
|
"regexp"
|
|
"strings"
|
|
)
|
|
|
|
// PackageJson creates an updater that modifies the version field in package.json files
|
|
func PackageJson() Updater {
|
|
return packagejson{}
|
|
}
|
|
|
|
type packagejson struct{}
|
|
|
|
func (p packagejson) Files() []string {
|
|
return []string{"package.json"}
|
|
}
|
|
|
|
func (p packagejson) CreateNewFiles() bool {
|
|
return false
|
|
}
|
|
|
|
func (p packagejson) Update(info ReleaseInfo) func(content string) (string, error) {
|
|
return func(content string) (string, error) {
|
|
// We strip the "v" prefix to match npm versioning convention
|
|
version := strings.TrimPrefix(info.Version, "v")
|
|
|
|
// Regex to match "version": "..." with flexible whitespace and quote styles
|
|
versionRegex := regexp.MustCompile(`("version"\s*:\s*)"[^"]*"`)
|
|
|
|
// Check if the file contains a version field
|
|
if !versionRegex.MatchString(content) {
|
|
return content, nil
|
|
}
|
|
|
|
// Replace the version value while preserving the original formatting
|
|
return versionRegex.ReplaceAllString(content, `${1}"`+version+`"`), nil
|
|
}
|
|
}
|