From d71b08b2dccf94c3ceaeda99526679bc0cfc3b8a Mon Sep 17 00:00:00 2001 From: Arlo Godfrey Date: Tue, 29 Oct 2024 15:31:42 -0500 Subject: [PATCH] Fixed a regex issue with UseTargetFrameworks.ps1 when enabling 'all' --- MultiTarget/UseTargetFrameworks.ps1 | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/MultiTarget/UseTargetFrameworks.ps1 b/MultiTarget/UseTargetFrameworks.ps1 index 54a1aa0a..2f84ee54 100644 --- a/MultiTarget/UseTargetFrameworks.ps1 +++ b/MultiTarget/UseTargetFrameworks.ps1 @@ -42,6 +42,7 @@ $DroidTfm = "AndroidLibTargetFramework"; $NetstandardTfm = "DotnetStandardCommonTargetFramework"; $fileContents = Get-Content -Path $PSScriptRoot/AvailableTargetFrameworks.props +$newFileContents = $fileContents; # 'all' represents many '$MultiTargets' values if ($MultiTargets.Contains("all")) { @@ -105,10 +106,12 @@ $targetFrameworksToRemove = @( $NetstandardTfm ).Where({ -not $desiredTfmValues.Contains($_) }) -$targetFrameworksToRemoveRegexPartial = $targetFrameworksToRemove -join "|"; - -$newFileContents = $fileContents -replace "<(?:$targetFrameworksToRemoveRegexPartial).+?>.+?>", ''; +# When targetFrameworksToRemoveRegexPartial is empty, the regex will match everything. +# To work around this, check if there's anything to remove before doing it. +if ($targetFrameworksToRemove.Length -gt 0) { + $targetFrameworksToRemoveRegexPartial = "$($targetFrameworksToRemove -join "|")"; + $newFileContents = $fileContents -replace "<(?:$targetFrameworksToRemoveRegexPartial).+?>.+?>", ''; +} Set-Content -Force -Path $PSScriptRoot/EnabledTargetFrameworks.props -Value $newFileContents; - -Write-Output "Done. Please close and regenerate your solution. Do not commit these changes to the tooling repository." +Write-Output "Done. Please close and regenerate your solution. Do not commit these changes to the tooling repository." \ No newline at end of file