diff options
author | Steve Dower <steve.dower@microsoft.com> | 2015-03-05 04:27:03 (GMT) |
---|---|---|
committer | Steve Dower <steve.dower@microsoft.com> | 2015-03-05 04:27:03 (GMT) |
commit | 2856332f5efa28c2abf9805cfdfdbf10b733b231 (patch) | |
tree | ddccca83fcd29130c1b13f63899b67ab045499a9 | |
parent | 3e2500d6db07b7b0e0a8ee7adb684d3f147e52b5 (diff) | |
download | cpython-2856332f5efa28c2abf9805cfdfdbf10b733b231.zip cpython-2856332f5efa28c2abf9805cfdfdbf10b733b231.tar.gz cpython-2856332f5efa28c2abf9805cfdfdbf10b733b231.tar.bz2 |
Add scripts for uploading Windows builds to a Linux server using pscp
-rw-r--r-- | Tools/msi/buildrelease.bat | 1 | ||||
-rw-r--r-- | Tools/msi/uploadrelease.bat | 46 | ||||
-rw-r--r-- | Tools/msi/uploadrelease.proj | 61 |
3 files changed, 108 insertions, 0 deletions
diff --git a/Tools/msi/buildrelease.bat b/Tools/msi/buildrelease.bat index 3f2a94a..09c63a6 100644 --- a/Tools/msi/buildrelease.bat +++ b/Tools/msi/buildrelease.bat @@ -140,6 +140,7 @@ if not "%OUTDIR%" EQU "" ( copy /Y "%BUILD%en-us\*.cab" "%OUTDIR%\%OUTDIR_PLAT%" copy /Y "%BUILD%en-us\*.exe" "%OUTDIR%\%OUTDIR_PLAT%" copy /Y "%BUILD%en-us\*.msi" "%OUTDIR%\%OUTDIR_PLAT%" + copy /Y "%BUILD%en-us\*.msu" "%OUTDIR%\%OUTDIR_PLAT%" ) exit /B 0 diff --git a/Tools/msi/uploadrelease.bat b/Tools/msi/uploadrelease.bat new file mode 100644 index 0000000..2064a67 --- /dev/null +++ b/Tools/msi/uploadrelease.bat @@ -0,0 +1,46 @@ +@setlocal +@echo off + +set D=%~dp0 +set PCBUILD=%D%..\..\PCBuild\ + +set HOST= +set USER= +set TARGET= +set DRYRUN=false + +:CheckOpts +if "%1" EQU "-h" goto Help +if "%1" EQU "-o" (set HOST=%~2) && shift && shift && goto CheckOpts +if "%1" EQU "--host" (set HOST=%~2) && shift && shift && goto CheckOpts +if "%1" EQU "-u" (set USER=%~2) && shift && shift && goto CheckOpts +if "%1" EQU "--user" (set USER=%~2) && shift && shift && goto CheckOpts +if "%1" EQU "-t" (set TARGET=%~2) && shift && shift && goto CheckOpts +if "%1" EQU "--target" (set TARGET=%~2) && shift && shift && goto CheckOpts +if "%1" EQU "--dry-run" (set DRYRUN=true) && shift && goto CheckOpts + +if not defined PLINK where plink > "%TEMP%\plink.loc" 2> nul && set /P PLINK= < "%TEMP%\plink.loc" & del "%TEMP%\plink.loc" +if not defined PLINK where /R "%ProgramFiles(x86)%" plink > "%TEMP%\plink.loc" 2> nul && set /P PLINK= < "%TEMP%\plink.loc" & del "%TEMP%\plink.loc" +if not defined PLINK echo Cannot locate plink.exe & exit /B 1 +echo Found plink.exe at %PLINK% + +if not defined PSCP where pscp > "%TEMP%\pscp.loc" 2> nul && set /P pscp= < "%TEMP%\pscp.loc" & del "%TEMP%\pscp.loc" +if not defined PSCP where /R "%ProgramFiles(x86)%" pscp > "%TEMP%\pscp.loc" 2> nul && set /P pscp= < "%TEMP%\pscp.loc" & del "%TEMP%\pscp.loc" +if not defined PSCP echo Cannot locate pscp.exe & exit /B 1 +echo Found pscp.exe at %PSCP% + +call "%PCBUILD%env.bat" > nul 2> nul +msbuild /v:m /nologo uploadrelease.proj /t:Upload /p:Platform=x86 +msbuild /v:m /nologo uploadrelease.proj /t:Upload /p:Platform=x64 /p:IncludeDoc=false + +exit /B 0 + +:Help +echo uploadrelease.bat --host HOST --user USERNAME [--target TARGET] [--dry-run] [-h] +echo. +echo --host (-o) Specify the upload host (required) +echo --user (-u) Specify the user on the host (required) +echo --target (-t) Specify the target directory on the host +echo --dry-run Display commands and filenames without executing them +echo -h Display this help information +echo. diff --git a/Tools/msi/uploadrelease.proj b/Tools/msi/uploadrelease.proj new file mode 100644 index 0000000..a3ebe57 --- /dev/null +++ b/Tools/msi/uploadrelease.proj @@ -0,0 +1,61 @@ +<?xml version="1.0" encoding="utf-8"?> +<Project ToolsVersion="4.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> + <PropertyGroup> + <ProjectGuid>{2D69F2AB-D5D0-4344-84B5-EF6DB34A9BC9}</ProjectGuid> + <OutputName>python</OutputName> + <OutputSuffix></OutputSuffix> + + <DownloadUrlBase Condition="'$(DownloadUrlBase)' == ''">$(TARGET)</DownloadUrlBase> + <DownloadUrlBase Condition="'$(DownloadUrlBase)' == ''">/srv/www.python.org/ftp/python</DownloadUrlBase> + <IncludeDoc Condition="'$(IncludeDoc)' == ''">true</IncludeDoc> + <DryRun Condition="'$(DryRun)' == ''">false</DryRun> + </PropertyGroup> + + <Import Project="msi.props" /> + <Import Project="bundle\bundle.targets" /> + + <PropertyGroup> + <EXETarget>$(DownloadUrlBase.TrimEnd(`/`))/$(MajorVersionNumber).$(MinorVersionNumber).$(MicroVersionNumber)</EXETarget> + <MSITarget>$(DownloadUrl.TrimEnd(`/`))</MSITarget> + </PropertyGroup> + + <ItemGroup> + <File Include="$(OutputPath)\*.msi;$(OutputPath)\*.msu"> + <CopyTo>$(MSITarget)</CopyTo> + </File> + <File Include="$(OutputPath)\*.exe"> + <CopyTo>$(EXETarget)</CopyTo> + </File> + <File Include="$(PySourcePath)Doc\build\htmlhelp\python$(MajorVersionNumber)$(MinorVersionNumber)$(MicroVersionNumber)$(ReleaseLevelName).chm" Condition="$(IncludeDoc)"> + <CopyTo>$(EXETarget)</CopyTo> + </File> + </ItemGroup> + + <Target Name="_ValidateProperties"> + <Error Text="No value for Host provided" Condition="'$(Host)' == ''" /> + <Error Text="No value for User provided" Condition="'$(User)' == ''" /> + <Error Text="No path for PSCP provided" Condition="'$(PSCP)' == ''" /> + <Error Text="No path for PLINK provided" Condition="'$(PLINK)' == ''" /> + </Target> + + <Target Name="_Upload" Condition="!$(DryRun)"> + <Exec Command=""$(PLINK)" $(User)@$(Host) mkdir %(File.CopyTo) ^&^& chgrp downloads %(File.CopyTo) ^&^& chmod g-w,o+rx %(File.CopyTo) +"$(PSCP)" @(File,' ') $(User)@$(Host):%(File.CopyTo) +"$(PLINK)" $(User)@$(Host) chgrp downloads %(File.CopyTo)/* ^&^& chmod g-w,o+r %(File.CopyTo)/* +" /> + </Target> + + <Target Name="_PrintNames" Condition="$(DryRun)"> + <Exec Command="echo "$(PLINK)" $(User)@$(Host) mkdir %(File.CopyTo) ^&^& chgrp downloads %(File.CopyTo) ^&^& chmod g-w,o+rx %(File.CopyTo) +echo "$(PSCP)" @(File,' ') $(User)@$(Host):%(File.CopyTo) +echo "$(PLINK)" $(User)@$(Host) chgrp downloads %(File.CopyTo)/* ^&^& chmod g-w,o+r %(File.CopyTo)/* +echo. +echo." /> + </Target> + + <Target Name="Upload" DependsOnTargets="_ValidateProperties;_PrintNames;_Upload" /> + + <Target Name="Build"> + <Error Text="This script should be invoked using uploadrelease.bat." /> + </Target> +</Project> |