2021-05-06 18:53:02 +02:00
|
|
|
|
<#
|
2021-07-13 21:10:02 +02:00
|
|
|
|
.SYNOPSIS
|
|
|
|
|
clean-repos.ps1 [<parent-dir>]
|
|
|
|
|
.DESCRIPTION
|
|
|
|
|
Cleans all Git repositories under the current/given directory from untracked files (including submodules)
|
|
|
|
|
.EXAMPLE
|
|
|
|
|
PS> .\clean-repos.ps1 C:\MyRepos
|
|
|
|
|
.LINK
|
|
|
|
|
https://github.com/fleschutz/PowerShell
|
|
|
|
|
.NOTES
|
|
|
|
|
Author: Markus Fleschutz / License: CC0
|
2021-05-06 18:53:02 +02:00
|
|
|
|
#>
|
|
|
|
|
|
|
|
|
|
param($ParentDir = "$PWD")
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
$StopWatch = [system.diagnostics.stopwatch]::startNew()
|
|
|
|
|
|
|
|
|
|
if (-not(test-path "$ParentDir" -pathType container)) { throw "Can't access directory: $ParentDir" }
|
|
|
|
|
|
|
|
|
|
$Null = (git --version)
|
|
|
|
|
if ($lastExitCode -ne "0") { throw "Can't execute 'git' - make sure Git is installed and available" }
|
|
|
|
|
|
2021-05-07 14:47:06 +02:00
|
|
|
|
$Folders = (get-childItem "$ParentDir" -attributes Directory)
|
2021-07-02 15:15:29 +02:00
|
|
|
|
$FolderCount = $Folders.Count
|
2021-05-07 14:57:54 +02:00
|
|
|
|
$ParentDirName = (get-item "$ParentDir").Name
|
2021-07-04 20:46:39 +02:00
|
|
|
|
"Found $FolderCount subfolders in 📂$ParentDirName, cleaning from untracked files..."
|
2021-05-06 18:53:02 +02:00
|
|
|
|
|
2021-07-02 15:18:40 +02:00
|
|
|
|
[int]$Step = 1
|
2021-05-07 14:47:06 +02:00
|
|
|
|
foreach ($Folder in $Folders) {
|
|
|
|
|
$FolderName = (get-item "$Folder").Name
|
2021-07-04 20:46:39 +02:00
|
|
|
|
"🧹 Cleaning 📂$FolderName ($Step/$FolderCount)..."
|
2021-05-07 14:47:06 +02:00
|
|
|
|
|
2021-07-02 11:46:01 +02:00
|
|
|
|
& git -C "$Folder" clean -xfd -f # force + recurse into dirs + don't use the standard ignore rules
|
|
|
|
|
if ($lastExitCode -ne "0") { throw "'git clean -xfd -f' failed" }
|
2021-05-06 18:53:02 +02:00
|
|
|
|
|
2021-07-02 11:46:01 +02:00
|
|
|
|
& git -C "$Folder" submodule foreach --recursive git clean -xfd -f
|
|
|
|
|
if ($lastExitCode -ne "0") { throw "'git clean -xfd -f' in submodules failed" }
|
2021-07-02 15:18:40 +02:00
|
|
|
|
|
|
|
|
|
$Step++
|
2021-05-06 18:53:02 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[int]$Elapsed = $StopWatch.Elapsed.TotalSeconds
|
2021-07-02 15:15:29 +02:00
|
|
|
|
"✔️ cleaned $FolderCount Git repositories at 📂$ParentDirName in $Elapsed sec"
|
2021-05-06 18:53:02 +02:00
|
|
|
|
exit 0
|
|
|
|
|
} catch {
|
|
|
|
|
write-error "⚠️ Error in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])"
|
|
|
|
|
exit 1
|
|
|
|
|
}
|