mirror of
https://github.com/AveYo/MediaCreationTool.bat.git
synced 2025-04-04 18:10:45 +00:00
Update MediaCreationTool.bat
fix regression with 1507-1709 not getting the correct fallback esd more descriptive label for 1507-1709 that have per-edition esd fix dev -noe being present and halting script instead of auto close
This commit is contained in:
parent
beedf56672
commit
593261b0a7
@ -2,9 +2,9 @@
|
|||||||
:Universal MCT wrapper script for all Windows 10/11 versions from 1507 to 21H2!
|
:Universal MCT wrapper script for all Windows 10/11 versions from 1507 to 21H2!
|
||||||
:: Nothing but Microsoft-hosted source links and no third-party tools; script just configures an xml and starts MCT
|
:: Nothing but Microsoft-hosted source links and no third-party tools; script just configures an xml and starts MCT
|
||||||
:: Ingenious support for business editions (Enterprise / VL) selecting language, x86, x64 or AiO inside the MCT GUI
|
:: Ingenious support for business editions (Enterprise / VL) selecting language, x86, x64 or AiO inside the MCT GUI
|
||||||
:: Changelog: 2021.12.07
|
:: Changelog: 2021.12.15
|
||||||
:: - skip windows 11 upgrade checks only via auto.cmd - just ignore server label, please; local account on 11 Home
|
:: - fix regression with 1507-1709 not getting the correct fallback esd; fix dev '-noe' not autoclosing script
|
||||||
:: - write output to script folder (or C:\ESD if run from zip); do not use esd links larger than 4GB (MCT limits)
|
:: - skip 11 checks only via auto.cmd - ignore server label, please; local acc on 11 Home; output to CD or C:\ESD
|
||||||
:: 11: 22000.318 / 21H2: 19044.1288 / 21H1: 19043.1348 / 20H2: 19042.1052 / 2004: 19041.572 / 1909: 18363.1139
|
:: 11: 22000.318 / 21H2: 19044.1288 / 21H1: 19043.1348 / 20H2: 19042.1052 / 2004: 19041.572 / 1909: 18363.1139
|
||||||
|
|
||||||
::# uncomment to skip GUI dialog for MCT choice: 1507 to 2109 / 11 - or rename script: "21H2 MediaCreationTool.bat"
|
::# uncomment to skip GUI dialog for MCT choice: 1507 to 2109 / 11 - or rename script: "21H2 MediaCreationTool.bat"
|
||||||
@ -113,8 +113,9 @@ if not defined VID (set VID=%OS_VID%)
|
|||||||
|
|
||||||
::# edition fallback to ones that MCT supports
|
::# edition fallback to ones that MCT supports
|
||||||
(set MEDIA_EDITION=%MEDIA_EDITION:Embedded=Enterprise%)
|
(set MEDIA_EDITION=%MEDIA_EDITION:Embedded=Enterprise%)
|
||||||
(set MEDIA_EDITION=%MEDIA_EDITION:IoTEnterprise=Enterprise%)
|
|
||||||
(set MEDIA_EDITION=%MEDIA_EDITION:EnterpriseS=Enterprise%)
|
(set MEDIA_EDITION=%MEDIA_EDITION:EnterpriseS=Enterprise%)
|
||||||
|
(set MEDIA_EDITION=%MEDIA_EDITION:IoTEnterprise=Enterprise%)
|
||||||
|
(set MEDIA_EDITION=%MEDIA_EDITION:IoTEnterpriseS=Enterprise%)
|
||||||
|
|
||||||
::# get previous GUI selection if self elevated and skip to choice
|
::# get previous GUI selection if self elevated and skip to choice
|
||||||
for %%s in (%*) do for %%P in (1 2 3 4) do if %%~ns gtr 0 if %%~ns lss 15 if %%~xs. equ .%%P. set /a PRE=%%P& set /a MCT=%%~ns
|
for %%s in (%*) do for %%P in (1 2 3 4) do if %%~ns gtr 0 if %%~ns lss 15 if %%~xs. equ .%%P. set /a PRE=%%P& set /a MCT=%%~ns
|
||||||
@ -308,8 +309,9 @@ if %VER% leq 16299 (set MEDIA_EDITION=%MEDIA_EDITION:ProfessionalEducation=Educa
|
|||||||
if %VER% leq 10586 (set MEDIA_EDITION=%MEDIA_EDITION:Enterprise=Professional%)
|
if %VER% leq 10586 (set MEDIA_EDITION=%MEDIA_EDITION:Enterprise=Professional%)
|
||||||
if %VER% leq 15063 if %INSERT_BUSINESS%0 lss 1 (set MEDIA_EDITION=%MEDIA_EDITION:Enterprise=Professional%)
|
if %VER% leq 15063 if %INSERT_BUSINESS%0 lss 1 (set MEDIA_EDITION=%MEDIA_EDITION:Enterprise=Professional%)
|
||||||
if %VER% leq 10586 if %UNHIDE_BUSINESS%0 lss 1 (set MEDIA_EDITION=%MEDIA_EDITION:Education=Professional%)
|
if %VER% leq 10586 if %UNHIDE_BUSINESS%0 lss 1 (set MEDIA_EDITION=%MEDIA_EDITION:Education=Professional%)
|
||||||
if %VER% neq 15063 (set MEDIA_EDITION=%MEDIA_EDITION:Cloud=Professional%)
|
if %VER% neq 15063 (set MEDIA_EDITION=%MEDIA_EDITION:Cloud=Professional%)
|
||||||
if not defined EDITION if "%MEDIA_EDITION%" neq "%OS_EDITION%" set "EDITION=%MEDIA_EDITION%"
|
if "%MEDIA_EDITION%" neq "%OS_EDITION%" set "REG_EDITION=%MEDIA_EDITION%"
|
||||||
|
if defined EDITION (set EDITION=%MEDIA_EDITION%)
|
||||||
|
|
||||||
::# generic key preset - only for staged editions in MCT install.esd - see sources\product.ini
|
::# generic key preset - only for staged editions in MCT install.esd - see sources\product.ini
|
||||||
for %%s in (%MEDIA_EDITION%) do for %%K in (
|
for %%s in (%MEDIA_EDITION%) do for %%K in (
|
||||||
@ -400,7 +402,7 @@ set "0=%~f0"& powershell -nop -c "iex ([io.file]::ReadAllText($env:0)-split'[:]g
|
|||||||
set "0=%~f0"& powershell -nop -c "iex ([io.file]::ReadAllText($env:0)-split'[:]generate_AutoUnattend_xml')[1];"
|
set "0=%~f0"& powershell -nop -c "iex ([io.file]::ReadAllText($env:0)-split'[:]generate_AutoUnattend_xml')[1];"
|
||||||
|
|
||||||
::# start script-assisted MCT via powershell (to monitor setup state and take necessary action)
|
::# start script-assisted MCT via powershell (to monitor setup state and take necessary action)
|
||||||
set "0=%~f0"& start "MCT" /wait /b powershell -nop -noe -c "iex ([io.file]::ReadAllText($env:0)-split'[:]Assisted_MCT')[1];"
|
set "0=%~f0"& start "MCT" /wait /b powershell -nop -c "iex ([io.file]::ReadAllText($env:0)-split'[:]Assisted_MCT')[1];"
|
||||||
|
|
||||||
::--------------------------------------------------------------------------------------------------------------------------------
|
::--------------------------------------------------------------------------------------------------------------------------------
|
||||||
EXIT /BATCH DONE
|
EXIT /BATCH DONE
|
||||||
@ -416,10 +418,10 @@ EXIT /BATCH DONE
|
|||||||
cd -Lit("$env:ROOT\MCT")
|
cd -Lit("$env:ROOT\MCT")
|
||||||
|
|
||||||
#:: workaround for version 1703 and earlier not having media selection switches
|
#:: workaround for version 1703 and earlier not having media selection switches
|
||||||
$K = '"HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion"'
|
if ($env:VER -le 15063 -and $null -ne $env:REG_EDITION) {
|
||||||
if ($env:VER -le 15063 -and $null -ne $env:EDITION) {
|
$K = '"HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion"'; $E = $env:REG_EDITION
|
||||||
reg add $K /v EditionID /d $env:EDITION /reg:32 /f>'' 2>''; reg delete $K /v ProductName /reg:32 /f>'' 2>''
|
start -nonew cmd "/d/x/r (reg add $K /v EditionID /d $E /reg:32 /f & reg delete $K /v ProductName /reg:32 /f) >nul 2>nul"
|
||||||
reg add $K /v EditionID /d $env:EDITION /reg:64 /f>'' 2>''; reg delete $K /v ProductName /reg:64 /f>'' 2>''
|
start -nonew cmd "/d/x/r (reg add $K /v EditionID /d $E /reg:64 /f & reg delete $K /v ProductName /reg:64 /f) >nul 2>nul"
|
||||||
}
|
}
|
||||||
|
|
||||||
#:: setup file watcher to minimally track progress
|
#:: setup file watcher to minimally track progress
|
||||||
@ -486,7 +488,7 @@ EXIT /BATCH DONE
|
|||||||
if ('Auto Upgrade' -ne $env:PRESET -and $null -eq $USB) {write-host -fore Gray "Prepare", $ISO}
|
if ('Auto Upgrade' -ne $env:PRESET -and $null -eq $USB) {write-host -fore Gray "Prepare", $ISO}
|
||||||
if ('Auto Upgrade' -ne $env:PRESET -and $null -ne $USB) {write-host -fore Gray "Prepare", $USB}
|
if ('Auto Upgrade' -ne $env:PRESET -and $null -ne $USB) {write-host -fore Gray "Prepare", $USB}
|
||||||
if ('Auto Upgrade' -eq $env:PRESET) {write-host -fore Gray "Prepare", $DIR}
|
if ('Auto Upgrade' -eq $env:PRESET) {write-host -fore Gray "Prepare", $DIR}
|
||||||
$label = "${env:X}_${env:VIS}" + ($ESD -split '(?=_vol_|_ret_)')[1]
|
$label = "${env:X}_${env:VIS}" + ($ESD -split '(?=_client)')[1]
|
||||||
write-host -fore Gray "FromESD", $label; sleep 10; powershell -win $env:hide -nop -c ";"
|
write-host -fore Gray "FromESD", $label; sleep 10; powershell -win $env:hide -nop -c ";"
|
||||||
|
|
||||||
#:: watch setup files progress from the sideline (MCT has authoring control)
|
#:: watch setup files progress from the sideline (MCT has authoring control)
|
||||||
@ -544,10 +546,10 @@ EXIT /BATCH DONE
|
|||||||
}
|
}
|
||||||
|
|
||||||
#:: undo workaround for version 1703 and earlier not having media selection switches
|
#:: undo workaround for version 1703 and earlier not having media selection switches
|
||||||
if ($env:VER -le 15063 -and $null -ne $env:EDITION) {
|
if ($env:VER -le 15063 -and $null -ne $env:REG_EDITION) {
|
||||||
$K = '"HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion"'
|
$K = '"HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion"'; $E = $env:OS_EDITION; $P = $env:OS_PRODUCT
|
||||||
reg add $K /v EditionID /d $env:OS_EDITION /reg:32 /f>'' 2>''; reg add $K /v ProductName /d $env:OS_PRODUCT /reg:32 /f>'' 2>''
|
start -nonew cmd "/d/x/r (reg add $K /v EditionID /d $E /reg:32 /f & reg add $K /v ProductName /d $P /reg:32 /f) >nul 2>nul"
|
||||||
reg add $K /v EditionID /d $env:OS_EDITION /reg:64 /f>'' 2>''; reg add $K /v ProductName /d $env:OS_PRODUCT /reg:64 /f>'' 2>''
|
start -nonew cmd "/d/x/r (reg add $K /v EditionID /d $E /reg:64 /f & reg add $K /v ProductName /d $P /reg:64 /f) >nul 2>nul"
|
||||||
}
|
}
|
||||||
|
|
||||||
#:: Auto Upgrade preset starts auto.cmd from $DIR = C:\$WINDOWS.~WS\Sources\Windows
|
#:: Auto Upgrade preset starts auto.cmd from $DIR = C:\$WINDOWS.~WS\Sources\Windows
|
||||||
@ -913,18 +915,19 @@ function PRODUCTS_XML { [xml]$xml = [io.file]::ReadAllText("$pwd\products.xml",[
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
#:: clone Professional / Enterprise to work around MCT quirks when host OS is ProEdu / ProWS / EnterpriseS / Embedded
|
#:: clone Professional / Enterprise to work around MCT quirks when host OS is ProEdu / ProWS / EnterpriseS / Embedded
|
||||||
$clone = 'Embedded','IoTEnterpriseS','EnterpriseS'; $cloneN = 'EnterpriseSN'
|
$source = 'Enterprise'; $sourceN = 'EnterpriseN'; $clone = 'Embedded','IoTEnterpriseS','EnterpriseS'; $cloneN = 'EnterpriseSN'
|
||||||
if ($ver -le 16299) {$clone +='ProfessionalEducation','ProfessionalWorkstation'}; if ($ver -le 10586) {$clone +='Enterprise'}
|
if ($ver -le 10586) {$source = 'Professional'; $sourceN = 'ProfessionalN'; $clone +='Enterprise'; $cloneN+='EnterpriseN'}
|
||||||
if ($ver -le 16299) {$cloneN+='ProfessionalEducationN','ProfessionalWorkstationN'}; if ($ver -le 10586) {$cloneN+='EnterpriseN'}
|
if ($ver -le 16299) {$clone +='ProfessionalEducation','ProfessionalWorkstation'}
|
||||||
|
if ($ver -le 16299) {$cloneN+='ProfessionalEducationN','ProfessionalWorkstationN'}
|
||||||
if ($env:UNHIDE_BUSINESS -ge 1) {
|
if ($env:UNHIDE_BUSINESS -ge 1) {
|
||||||
$root.Files.File | & { process {
|
$root.Files.File | & { process {
|
||||||
if ($_.Edition -eq "Enterprise") {
|
if ($_.Edition -eq $source) {
|
||||||
foreach ($s in $clone) {
|
foreach ($s in $clone) {
|
||||||
$c = $_.Clone(); if ($c.HasAttribute('id')) {$c.RemoveAttribute('id')}
|
$c = $_.Clone(); if ($c.HasAttribute('id')) {$c.RemoveAttribute('id')}
|
||||||
$c.IsRetailOnly='False'; $c.Edition=$s; $root.Files.AppendChild($c) >''
|
$c.IsRetailOnly='False'; $c.Edition=$s; $root.Files.AppendChild($c) >''
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
elseif ($_.Edition -eq "EnterpriseN") {
|
elseif ($_.Edition -eq $sourceN) {
|
||||||
foreach ($s in $cloneN) {
|
foreach ($s in $cloneN) {
|
||||||
$c = $_.Clone(); if ($c.HasAttribute('id')) {$c.RemoveAttribute('id')}
|
$c = $_.Clone(); if ($c.HasAttribute('id')) {$c.RemoveAttribute('id')}
|
||||||
$c.IsRetailOnly='False'; $c.Edition=$s; $root.Files.AppendChild($c) >''
|
$c.IsRetailOnly='False'; $c.Edition=$s; $root.Files.AppendChild($c) >''
|
||||||
|
Loading…
Reference in New Issue
Block a user