Add tag repos script
This commit is contained in:
parent
7235918051
commit
d7785d6187
|
|
@ -0,0 +1,66 @@
|
||||||
|
#!/usr/bin/env pwsh
|
||||||
|
|
||||||
|
<#
|
||||||
|
.SYNOPSIS
|
||||||
|
Tags each repo according to VersionPrefix in version.props of that repo
|
||||||
|
.PARAMETER Push
|
||||||
|
Push all updated tags
|
||||||
|
.PARAMETER ForceUpdateTag
|
||||||
|
This will call git tag --force
|
||||||
|
#>
|
||||||
|
[cmdletbinding(SupportsShouldProcess = $true)]
|
||||||
|
param(
|
||||||
|
[switch]$Push = $false,
|
||||||
|
[switch]$ForceUpdateTag = $false
|
||||||
|
)
|
||||||
|
|
||||||
|
Set-StrictMode -Version 2
|
||||||
|
$ErrorActionPreference = 'Stop'
|
||||||
|
|
||||||
|
Import-Module -Scope Local -Force "$PSScriptRoot/common.psm1"
|
||||||
|
|
||||||
|
Assert-Git
|
||||||
|
|
||||||
|
$RepoRoot = Resolve-Path "$PSScriptRoot/../"
|
||||||
|
|
||||||
|
Get-Submodules $RepoRoot -Shipping | % {
|
||||||
|
Push-Location $_.path | Out-Null
|
||||||
|
try {
|
||||||
|
|
||||||
|
if (-not $_.versionPrefix) {
|
||||||
|
Write-Warning "Could not determine tag version for $(_.path)"
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$tag = $_.versionPrefix
|
||||||
|
Write-Host "$($_.module) => $tag"
|
||||||
|
|
||||||
|
$gitTagArgs = @()
|
||||||
|
if ($ForceUpdateTag) {
|
||||||
|
$gitTagArgs += '--force'
|
||||||
|
}
|
||||||
|
|
||||||
|
Invoke-Block { & git tag @gitTagArgs $tag }
|
||||||
|
|
||||||
|
if ($Push) {
|
||||||
|
$gitPushArgs = @()
|
||||||
|
if ($WhatIfPreference) {
|
||||||
|
$gitPushArgs += '--dry-run'
|
||||||
|
}
|
||||||
|
Invoke-Block { & git push --dry-run @gitPushArgs origin "refs/tags/${tag}" }
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($WhatIfPreference) {
|
||||||
|
Invoke-Block { & git tag -d $tag } | Out-Null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch {
|
||||||
|
Write-Host -ForegroundColor Red "Could not update $_"
|
||||||
|
throw
|
||||||
|
}
|
||||||
|
finally {
|
||||||
|
Pop-Location
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -0,0 +1,66 @@
|
||||||
|
function Assert-Git {
|
||||||
|
if (!(Get-Command git -ErrorAction Ignore)) {
|
||||||
|
Write-Error 'git is required to execute this script'
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function Invoke-Block([scriptblock]$cmd) {
|
||||||
|
$cmd | Out-String | Write-Verbose
|
||||||
|
& $cmd
|
||||||
|
|
||||||
|
# Need to check both of these cases for errors as they represent different items
|
||||||
|
# - $?: did the powershell script block throw an error
|
||||||
|
# - $lastexitcode: did a windows command executed by the script block end in error
|
||||||
|
if ((-not $?) -or ($lastexitcode -ne 0)) {
|
||||||
|
Write-Warning $error[0]
|
||||||
|
throw "Command failed to execute: $cmd"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function Get-Submodules {
|
||||||
|
param(
|
||||||
|
[Parameter(Mandatory = $true)]
|
||||||
|
[string]$RepoRoot,
|
||||||
|
[switch]$Shipping
|
||||||
|
)
|
||||||
|
|
||||||
|
$moduleConfigFile = Join-Path $RepoRoot ".gitmodules"
|
||||||
|
$submodules = @()
|
||||||
|
|
||||||
|
[xml] $submoduleConfig = Get-Content "$RepoRoot/build/submodules.props"
|
||||||
|
$repos = $submoduleConfig.Project.ItemGroup.Repository | % { $_.Include }
|
||||||
|
|
||||||
|
Get-ChildItem "$RepoRoot/modules/*" -Directory `
|
||||||
|
| ? { (-not $Shipping) -or $($repos -contains $($_.Name)) -or $_.Name -eq 'Templating' } `
|
||||||
|
| % {
|
||||||
|
Push-Location $_ | Out-Null
|
||||||
|
Write-Verbose "Attempting to get submodule info for $_"
|
||||||
|
|
||||||
|
if (Test-Path 'version.props') {
|
||||||
|
[xml] $versionXml = Get-Content 'version.props'
|
||||||
|
$versionPrefix = $versionXml.Project.PropertyGroup.VersionPrefix
|
||||||
|
} else {
|
||||||
|
$versionPrefix = ''
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
$data = @{
|
||||||
|
path = $_
|
||||||
|
module = $_.Name
|
||||||
|
commit = $(git rev-parse HEAD)
|
||||||
|
newCommit = $null
|
||||||
|
changed = $false
|
||||||
|
branch = $(git config -f $moduleConfigFile --get submodule.modules/$($_.Name).branch )
|
||||||
|
versionPrefix = $versionPrefix
|
||||||
|
}
|
||||||
|
|
||||||
|
$submodules += $data
|
||||||
|
}
|
||||||
|
finally {
|
||||||
|
Pop-Location | Out-Null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $submodules
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue