mirror of
https://github.com/fleschutz/PowerShell.git
synced 2025-02-19 11:11:29 +01:00
Update new-branch.ps1
This commit is contained in:
parent
e0e866de16
commit
7507d59a2a
@ -1,12 +1,12 @@
|
|||||||
<#
|
<#
|
||||||
.SYNOPSIS
|
.SYNOPSIS
|
||||||
Creates and switches to a new branch in a Git repository
|
Create a New Git Branch
|
||||||
.DESCRIPTION
|
.DESCRIPTION
|
||||||
This PowerShell script creates and switches to a new branch in a Git repository.
|
This PowerShell script creates and switches to a new branch in a Git repository.
|
||||||
.PARAMETER BranchName
|
.PARAMETER BranchName
|
||||||
Specifies the branch name
|
Specifies the branch name (or needs to be entered)
|
||||||
.PARAMETER RepoDir
|
.PARAMETER RepoDir
|
||||||
Specifies the path to the Git repository
|
Specifies the path to the Git repository (or working directory per default)
|
||||||
.EXAMPLE
|
.EXAMPLE
|
||||||
PS> ./new-branch test123
|
PS> ./new-branch test123
|
||||||
.LINK
|
.LINK
|
||||||
@ -22,6 +22,7 @@ try {
|
|||||||
|
|
||||||
$StopWatch = [system.diagnostics.stopwatch]::startNew()
|
$StopWatch = [system.diagnostics.stopwatch]::startNew()
|
||||||
|
|
||||||
|
"⏳ Step 1/4: Checking requirements... "
|
||||||
if (-not(test-path "$RepoDir" -pathType container)) { throw "Can't access directory: $RepoDir" }
|
if (-not(test-path "$RepoDir" -pathType container)) { throw "Can't access directory: $RepoDir" }
|
||||||
set-location "$RepoDir"
|
set-location "$RepoDir"
|
||||||
|
|
||||||
@ -29,17 +30,18 @@ try {
|
|||||||
if ($lastExitCode -ne "0") { throw "Can't execute 'git' - make sure Git is installed and available" }
|
if ($lastExitCode -ne "0") { throw "Can't execute 'git' - make sure Git is installed and available" }
|
||||||
|
|
||||||
$RepoDirName = (get-item "$RepoDir").Name
|
$RepoDirName = (get-item "$RepoDir").Name
|
||||||
"🢃 Fetching updates for Git repository 📂$RepoDirName ..."
|
"⏳ Step 2/4: Fetching updates..."
|
||||||
|
|
||||||
& git fetch --all --recurse-submodules --prune --prune-tags --force
|
& git fetch --all --recurse-submodules --prune --prune-tags --force
|
||||||
if ($lastExitCode -ne "0") { throw "'git fetch' failed" }
|
if ($lastExitCode -ne "0") { throw "'git fetch' failed" }
|
||||||
|
|
||||||
|
"⏳ Step 3/4: Checkout and push new branch..."
|
||||||
& git checkout -b "$BranchName"
|
& git checkout -b "$BranchName"
|
||||||
if ($lastExitCode -ne "0") { throw "'git checkout -b $BranchName' failed" }
|
if ($lastExitCode -ne "0") { throw "'git checkout -b $BranchName' failed" }
|
||||||
|
|
||||||
& git push origin "$BranchName"
|
& git push origin "$BranchName"
|
||||||
if ($lastExitCode -ne "0") { throw "'git push origin $BranchName' failed" }
|
if ($lastExitCode -ne "0") { throw "'git push origin $BranchName' failed" }
|
||||||
|
|
||||||
|
"⏳ Step 4/4: Updating submodules..."
|
||||||
& git submodule update --init --recursive
|
& git submodule update --init --recursive
|
||||||
if ($lastExitCode -ne "0") { throw "'git submodule update' failed" }
|
if ($lastExitCode -ne "0") { throw "'git submodule update' failed" }
|
||||||
|
|
||||||
@ -49,4 +51,4 @@ try {
|
|||||||
} catch {
|
} catch {
|
||||||
"⚠️ Error: $($Error[0]) ($($MyInvocation.MyCommand.Name):$($_.InvocationInfo.ScriptLineNumber))"
|
"⚠️ Error: $($Error[0]) ($($MyInvocation.MyCommand.Name):$($_.InvocationInfo.ScriptLineNumber))"
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user