On this page
Go release target using a VERSION file as source of truth, with GoReleaser integration for binaries and module proxy notification for libs.
#rlsbl.targets.go
#rlsbl.targets.go
Go release target using a VERSION file as source of truth, with GoReleaser integration for binaries and module proxy notification for libs.
#_go_archive_fn
def _go_archive_fn(spec, name)Return (asset_pattern, extract_cmd, binary_name) for a Go/goreleaser build.
#GoTarget
Release target for Go projects (go.mod + VERSION file).
#name
def name(self)#detect
def detect(self, dir_path)#read_name
def read_name(self, dir_path, ctx)Read the last segment of the module path from go.mod.
#read_metadata
def read_metadata(self, dir_path)Go modules have no license/description in go.mod.
#_is_library
def _is_library(self, dir_path)Return True if the project has no package main in root .go files or cmd/ layout.
#_has_root_main
def _has_root_main(self, dir_path)Return True if there's a main.go at the project root with package main.
#_has_version_var
def _has_version_var(self, dir_path)Return True if any root-level .go file declares a Version variable.
#_has_cmd_main
def _has_cmd_main(self, dir_path)Return True if there's a single cmd/*/main.go with package main.
Returns False if there are multiple cmd/ subdirectories (multi-binary repos where cmd/ is the correct layout) or no cmd/ entries at all.
#read_version
def read_version(self, dir_path)Read version from the VERSION file.
#write_version
def write_version(self, dir_path, version, ctx)Write the new version to the VERSION file.
Returns a list of relative file paths that were modified.
#version_file
def version_file(self, dir_path=None)#tag_format
def tag_format(self, version)#companion_tags
def companion_tags(self, name, version, path=None)Return Go module proxy companion tags for monorepo packages.
When path is set (monorepo member), the Go module proxy needs a tag of the form {path}/v{version} to resolve the module. This tag is identical to the Go target's primary monorepo_tag_format output, so it is only useful as a companion when a different target (e.g. npm) is the primary release target and produces a non-Go-compatible primary tag.
#monorepo_tag_format
def monorepo_tag_format(self, name, version, path=None)#monorepo_tag_glob
def monorepo_tag_glob(self, name, path=None)#template_dir
def template_dir(self)#template_vars
def template_vars(self, dir_path, ctx)Extract template variables from go.mod and .rlsbl/config.json.
#template_mappings
def template_mappings(self, ctx)#shared_template_mappings
def shared_template_mappings(self, ctx)#check_project_exists
def check_project_exists(self, dir_path)#get_project_init_hint
def get_project_init_hint(self)#dev_install_command
def dev_install_command(self, project_dir)