[Feature][ZXW-88]merge P50 version

Only Configure: No
Affected branch: master
Affected module: unknown
Is it affected on both ZXIC and MTK: only ZXIC
Self-test: Yes
Doc Update: No

Change-Id: I34667719d9e0e7e29e8e4368848601cde0a48408
diff --git a/ap/lib/libcurl/curl-7.86.0/projects/build-openssl.bat b/ap/lib/libcurl/curl-7.86.0/projects/build-openssl.bat
new file mode 100755
index 0000000..106a2a3
--- /dev/null
+++ b/ap/lib/libcurl/curl-7.86.0/projects/build-openssl.bat
@@ -0,0 +1,729 @@
+@echo off

+rem ***************************************************************************

+rem *                                  _   _ ____  _

+rem *  Project                     ___| | | |  _ \| |

+rem *                             / __| | | | |_) | |

+rem *                            | (__| |_| |  _ <| |___

+rem *                             \___|\___/|_| \_\_____|

+rem *

+rem * Copyright (C) 2012 - 2022, Steve Holme, <steve_holme@hotmail.com>.

+rem *

+rem * This software is licensed as described in the file COPYING, which

+rem * you should have received as part of this distribution. The terms

+rem * are also available at https://curl.se/docs/copyright.html.

+rem *

+rem * You may opt to use, copy, modify, merge, publish, distribute and/or sell

+rem * copies of the Software, and permit persons to whom the Software is

+rem * furnished to do so, under the terms of the COPYING file.

+rem *

+rem * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY

+rem * KIND, either express or implied.

+rem * 

+rem * SPDX-License-Identifier: curl

+rem *

+rem ***************************************************************************

+

+:begin

+  rem Check we are running on a Windows NT derived OS

+  if not "%OS%" == "Windows_NT" goto nodos

+

+  rem Set our variables

+  setlocal ENABLEDELAYEDEXPANSION

+  set BUILD_CONFIG=

+  set BUILD_PLATFORM=

+  set SAVED_PATH=

+  set SOURCE_PATH=

+  set TMP_BUILD_PATH=

+  set TMP_INSTALL_PATH=

+  set VC_VER=

+

+  rem Ensure we have the required arguments

+  if /i "%~1" == "" goto syntax

+

+  rem Calculate the program files directory

+  if defined PROGRAMFILES (

+    set "PF=%PROGRAMFILES%"

+    set OS_PLATFORM=x86

+  )

+  if defined PROGRAMFILES(x86) (

+    rem Visual Studio was x86-only prior to 14.3

+    if /i "%~1" == "vc14.3" (

+      set "PF=%PROGRAMFILES%"

+    ) else (

+      set "PF=%PROGRAMFILES(x86)%"

+    )

+    set OS_PLATFORM=x64

+  )

+

+:parseArgs

+  if not "%~1" == "" (

+    if /i "%~1" == "vc10" (

+      set VC_VER=10.0

+      set VC_DESC=VC10

+      set "VC_PATH=Microsoft Visual Studio 10.0\VC"

+    ) else if /i "%~1" == "vc11" (

+      set VC_VER=11.0

+      set VC_DESC=VC11

+      set "VC_PATH=Microsoft Visual Studio 11.0\VC"

+    ) else if /i "%~1" == "vc12" (

+      set VC_VER=12.0

+      set VC_DESC=VC12

+      set "VC_PATH=Microsoft Visual Studio 12.0\VC"

+    ) else if /i "%~1" == "vc14" (

+      set VC_VER=14.0

+      set VC_DESC=VC14

+      set "VC_PATH=Microsoft Visual Studio 14.0\VC"

+    ) else if /i "%~1" == "vc14.1" (

+      set VC_VER=14.1

+      set VC_DESC=VC14.10

+

+      rem Determine the VC14.1 path based on the installed edition in descending

+      rem order (Enterprise, then Professional and finally Community)

+      if exist "%PF%\Microsoft Visual Studio\2017\Enterprise\VC" (

+        set "VC_PATH=Microsoft Visual Studio\2017\Enterprise\VC"

+      ) else if exist "%PF%\Microsoft Visual Studio\2017\Professional\VC" (

+        set "VC_PATH=Microsoft Visual Studio\2017\Professional\VC"

+      ) else (

+        set "VC_PATH=Microsoft Visual Studio\2017\Community\VC"

+      )

+    ) else if /i "%~1" == "vc14.2" (

+      set VC_VER=14.2

+      set VC_DESC=VC14.20

+

+      rem Determine the VC14.2 path based on the installed edition in descending

+      rem order (Enterprise, then Professional and finally Community)

+      if exist "%PF%\Microsoft Visual Studio\2019\Enterprise\VC" (

+        set "VC_PATH=Microsoft Visual Studio\2019\Enterprise\VC"

+      ) else if exist "%PF%\Microsoft Visual Studio\2019\Professional\VC" (

+        set "VC_PATH=Microsoft Visual Studio\2019\Professional\VC"

+      ) else (

+        set "VC_PATH=Microsoft Visual Studio\2019\Community\VC"

+      )

+    ) else if /i "%~1" == "vc14.3" (

+      set VC_VER=14.3

+      set VC_DESC=VC14.30

+

+      rem Determine the VC14.3 path based on the installed edition in descending

+      rem order (Enterprise, then Professional and finally Community)

+      if exist "%PF%\Microsoft Visual Studio\2022\Enterprise\VC" (

+        set "VC_PATH=Microsoft Visual Studio\2022\Enterprise\VC"

+      ) else if exist "%PF%\Microsoft Visual Studio\2022\Professional\VC" (

+        set "VC_PATH=Microsoft Visual Studio\2022\Professional\VC"

+      ) else (

+        set "VC_PATH=Microsoft Visual Studio\2022\Community\VC"

+      )

+    ) else if /i "%~1%" == "x86" (

+      set BUILD_PLATFORM=x86

+    ) else if /i "%~1%" == "x64" (

+      set BUILD_PLATFORM=x64

+    ) else if /i "%~1%" == "debug" (

+      set BUILD_CONFIG=debug

+    ) else if /i "%~1%" == "release" (

+      set BUILD_CONFIG=release

+    ) else if /i "%~1" == "-?" (

+      goto syntax

+    ) else if /i "%~1" == "-h" (

+      goto syntax

+    ) else if /i "%~1" == "-help" (

+      goto syntax

+    ) else if /i "%~1" == "-VSpath" (

+      if "%~2" == "" (

+        echo.

+        echo Error. Please provide VS Path.

+        goto error

+      ) else (

+        set "ABS_VC_PATH=%~2\VC"

+        shift

+      )

+    ) else if /i "%~1" == "-perlpath" (

+      if "%~2" == "" (

+        echo.

+        echo Error. Please provide Perl root Path.

+        goto error

+      ) else (

+        set "PERL_PATH=%~2"

+        shift

+      )

+    ) else (

+      if not defined START_DIR (

+        set "START_DIR=%~1%"

+      ) else (

+        goto unknown

+      )

+    )

+

+    shift & goto parseArgs

+  )

+

+:prerequisites

+  rem Compiler is a required parameter

+  if not defined VC_VER goto syntax

+

+  rem Default the start directory if one isn't specified

+  if not defined START_DIR set START_DIR=..\..\openssl

+

+  if not defined ABS_VC_PATH (

+    rem Check we have a program files directory

+    if not defined PF goto nopf

+    set "ABS_VC_PATH=%PF%\%VC_PATH%"

+  )

+

+  rem Check we have Visual Studio installed

+  if not exist "%ABS_VC_PATH%" goto novc

+

+  if not defined PERL_PATH (

+    rem Check we have Perl in our path

+    perl --version <NUL 1>NUL 2>&1

+    if errorlevel 1 (

+      rem It isn't so check we have it installed and set the path if it is

+      if exist "%SystemDrive%\Perl" (

+        set "PATH=%SystemDrive%\Perl\bin;%PATH%"

+      ) else (

+        if exist "%SystemDrive%\Perl64" (

+          set "PATH=%SystemDrive%\Perl64\bin;%PATH%"

+        ) else (

+          goto noperl

+        )

+      )

+    )

+  ) else (

+    set "PATH=%PERL_PATH%\Perl\bin;%PATH%"

+  )

+

+  rem Check the start directory exists

+  if not exist "%START_DIR%" goto noopenssl

+

+:setup

+  if "%BUILD_PLATFORM%" == "" (

+    if "%VC_VER%" == "6.0" (

+      set BUILD_PLATFORM=x86

+    ) else if "%VC_VER%" == "7.0" (

+      set BUILD_PLATFORM=x86

+    ) else if "%VC_VER%" == "7.1" (

+      set BUILD_PLATFORM=x86

+    ) else (

+      set BUILD_PLATFORM=%OS_PLATFORM%

+    )

+  )

+

+  if "%BUILD_PLATFORM%" == "x86" (

+    set VCVARS_PLATFORM=x86

+  ) else if "%BUILD_PLATFORM%" == "x64" (

+    if "%VC_VER%" == "10.0" set VCVARS_PLATFORM=%BUILD_PLATFORM%

+    if "%VC_VER%" == "11.0" set VCVARS_PLATFORM=amd64

+    if "%VC_VER%" == "12.0" set VCVARS_PLATFORM=amd64

+    if "%VC_VER%" == "14.0" set VCVARS_PLATFORM=amd64

+    if "%VC_VER%" == "14.1" set VCVARS_PLATFORM=amd64

+    if "%VC_VER%" == "14.2" set VCVARS_PLATFORM=amd64

+    if "%VC_VER%" == "14.3" set VCVARS_PLATFORM=amd64

+  )

+

+  if exist "%START_DIR%\ms\do_ms.bat" (

+    set LEGACY_BUILD=TRUE

+  ) else (

+    set LEGACY_BUILD=FALSE

+  )

+

+:start

+  echo.

+  set "SAVED_PATH=%CD%"

+

+  if "%VC_VER%" == "14.1" (

+    call "%ABS_VC_PATH%\Auxiliary\Build\vcvarsall" %VCVARS_PLATFORM%

+  ) else if "%VC_VER%" == "14.2" (

+    call "%ABS_VC_PATH%\Auxiliary\Build\vcvarsall" %VCVARS_PLATFORM%

+  ) else if "%VC_VER%" == "14.3" (

+    call "%ABS_VC_PATH%\Auxiliary\Build\vcvarsall" %VCVARS_PLATFORM%

+  ) else (

+    call "%ABS_VC_PATH%\vcvarsall" %VCVARS_PLATFORM%

+  )

+

+  echo.

+

+  cd /d "%START_DIR%" || (echo Error: Failed cd start & exit /B 1)

+  rem Save the full path of the openssl source dir

+  set "SOURCE_PATH=%CD%"

+

+  rem Set temporary paths for building and installing OpenSSL. If a temporary

+  rem path is not the same as the source path then it is *removed* after the

+  rem installation is completed.

+  rem

+  rem For legacy OpenSSL the temporary build path must be the source path.

+  rem

+  rem For OpenSSL 1.1.x the temporary paths must be separate not a descendant

+  rem of the other, otherwise pdb files will be lost between builds.

+  rem https://github.com/openssl/openssl/issues/10005

+  rem

+  if "%LEGACY_BUILD%" == "TRUE" (

+    set "TMP_BUILD_PATH=%SOURCE_PATH%"

+    set "TMP_INSTALL_PATH=%SOURCE_PATH%"

+  ) else (

+    set "TMP_BUILD_PATH=%SOURCE_PATH%\build\tmp_build"

+    set "TMP_INSTALL_PATH=%SOURCE_PATH%\build\tmp_install"

+  )

+

+  goto %BUILD_PLATFORM%

+

+:x64

+  rem Calculate our output directory

+  set OUTDIR=build\Win64\%VC_DESC%

+  if not exist %OUTDIR% md %OUTDIR%

+

+  if not "%BUILD_CONFIG%" == "release" (

+    rem Configuring 64-bit Static Library Debug Build

+    call :configure x64 debug static %LEGACY_BUILD%

+

+    rem Perform the build

+    call :build x64 static %LEGACY_BUILD%

+

+    rem Perform the install

+    call :install debug static %LEGACY_BUILD%

+

+    rem Configuring 64-bit Shared Library Debug Build

+    call :configure x64 debug shared %LEGACY_BUILD%

+

+    rem Perform the build

+    call :build x64 shared %LEGACY_BUILD%

+

+    rem Perform the install

+    call :install debug shared %LEGACY_BUILD%

+  )

+

+  if not "%BUILD_CONFIG%" == "debug" (

+    rem Configuring 64-bit Static Library Release Build

+    call :configure x64 release static %LEGACY_BUILD%

+

+    rem Perform the build

+    call :build x64 static %LEGACY_BUILD%

+

+    rem Perform the install

+    call :install release static %LEGACY_BUILD%

+

+    rem Configuring 64-bit Shared Library Release Build

+    call :configure x64 release shared %LEGACY_BUILD%

+

+    rem Perform the build

+    call :build x64 shared %LEGACY_BUILD%

+

+    rem Perform the install

+    call :install release shared %LEGACY_BUILD%

+  )

+

+  goto success

+

+:x86

+  rem Calculate our output directory

+  set OUTDIR=build\Win32\%VC_DESC%

+  if not exist %OUTDIR% md %OUTDIR%

+

+  if not "%BUILD_CONFIG%" == "release" (

+    rem Configuring 32-bit Static Library Debug Build

+    call :configure x86 debug static %LEGACY_BUILD%

+

+    rem Perform the build

+    call :build x86 static %LEGACY_BUILD%

+

+    rem Perform the install

+    call :install debug static %LEGACY_BUILD%

+

+    rem Configuring 32-bit Shared Library Debug Build

+    call :configure x86 debug shared %LEGACY_BUILD%

+

+    rem Perform the build

+    call :build x86 shared %LEGACY_BUILD%

+

+    rem Perform the install

+    call :install debug shared %LEGACY_BUILD%

+  )

+

+  if not "%BUILD_CONFIG%" == "debug" (

+    rem Configuring 32-bit Static Library Release Build

+    call :configure x86 release static %LEGACY_BUILD%

+

+    rem Perform the build

+    call :build x86 static %LEGACY_BUILD%

+

+    rem Perform the install

+    call :install release static %LEGACY_BUILD%

+

+    rem Configuring 32-bit Shared Library Release Build

+    call :configure x86 release shared %LEGACY_BUILD%

+

+    rem Perform the build

+    call :build x86 shared %LEGACY_BUILD%

+

+    rem Perform the install

+    call :install release shared %LEGACY_BUILD%

+  )

+

+  goto success

+

+rem Function to configure the build.

+rem

+rem %1 - Platform (x86 or x64)

+rem %2 - Configuration (release or debug)

+rem %3 - Build Type (static or shared)

+rem %4 - Build type (TRUE for legacy aka pre v1.1.0; otherwise FALSE)

+rem

+:configure

+  setlocal

+

+  if "%1" == "" exit /B 1

+  if "%2" == "" exit /B 1

+  if "%3" == "" exit /B 1

+  if "%4" == "" exit /B 1

+

+  if not exist "%TMP_BUILD_PATH%" mkdir "%TMP_BUILD_PATH%"

+  cd /d "%TMP_BUILD_PATH%" || (echo Error: Failed cd build & exit /B 1)

+

+  if "%4" == "TRUE" (

+    rem Calculate the configure options

+    if "%1" == "x86" (

+      if "%2" == "debug" (

+        set options=debug-VC-WIN32

+      ) else if "%2" == "release" (

+        set options=VC-WIN32

+      ) else (

+        exit /B 1

+      )

+

+      set options=!options! no-asm

+    ) else if "%1" == "x64" (

+      if "%2" == "debug" (

+        set options=debug-VC-WIN64A

+      ) else if "%2" == "release" (

+        set options=VC-WIN64A

+      ) else (

+        exit /B 1

+      )

+    ) else (

+      exit /B 1

+    )

+  ) else if "%4" == "FALSE" (

+    rem Has configure already been ran?

+    if exist makefile (

+      rem Clean up the previous build

+      nmake clean

+

+      rem Remove the old makefile

+      del makefile 1>nul

+    )

+

+    rem Calculate the configure options

+    if "%1" == "x86" (

+      set options=VC-WIN32

+    ) else if "%1" == "x64" (

+      set options=VC-WIN64A

+    ) else (

+      exit /B 1

+    )

+

+    if "%2" == "debug" (

+      set options=!options! --debug

+    ) else if "%2" == "release" (

+      set options=!options! --release

+    ) else (

+      exit /B 1

+    )

+

+    if "%3" == "static" (

+      set options=!options! no-shared

+    ) else if not "%3" == "shared" (

+      exit /B 1

+    )

+

+    set options=!options! no-asm

+  ) else (

+    exit /B 1

+  )

+

+  rem Run the configure

+  perl "%SOURCE_PATH%\Configure" %options% "--prefix=%TMP_INSTALL_PATH%"

+

+  exit /B %ERRORLEVEL%

+

+rem Main build function.

+rem

+rem %1 - Platform (x86 or x64)

+rem %2 - Build Type (static or shared)

+rem %3 - Build type (TRUE for legacy aka pre v1.1.0; otherwise FALSE)

+rem

+:build

+  setlocal

+

+  if "%1" == "" exit /B 1

+  if "%2" == "" exit /B 1

+  if "%3" == "" exit /B 1

+

+  cd /d "%TMP_BUILD_PATH%" || (echo Error: Failed cd build & exit /B 1)

+

+  if "%3" == "TRUE" (

+    if "%1" == "x86" (

+      call ms\do_ms.bat

+    ) else if "%1" == "x64" (

+      call ms\do_win64a.bat

+    ) else (

+      exit /B 1

+    )

+

+    if "%2" == "static" (

+      nmake -f ms\nt.mak

+    ) else if "%2" == "shared" (

+      nmake -f ms\ntdll.mak

+    ) else (

+      exit /B 1

+    )

+  ) else if "%3" == "FALSE" (

+    nmake

+  ) else (

+    exit /B 1

+  )

+

+  exit /B 0

+

+rem Main installation function.

+rem

+rem %1 - Configuration (release or debug)

+rem %2 - Build Type (static or shared)

+rem %3 - Build type (TRUE for legacy aka pre v1.1.0; otherwise FALSE)

+rem

+:install

+  setlocal

+

+  if "%1" == "" exit /B 1

+  if "%2" == "" exit /B 1

+  if "%3" == "" exit /B 1

+

+  rem Copy the generated files to our directory structure

+  if "%3" == "TRUE" (

+    rem There's no actual installation for legacy OpenSSL, the files are copied

+    rem from the build dir (for legacy this is same as source dir) to the final

+    rem location.

+    cd /d "%SOURCE_PATH%" || (echo Error: Failed cd source & exit /B 1)

+    if "%1" == "debug" (

+      if "%2" == "static" (

+        rem Move the output directories

+        if exist "%OUTDIR%\LIB Debug" (

+          copy /y out32.dbg\* "%OUTDIR%\LIB Debug" 1>nul

+          rd out32.dbg /s /q

+        ) else (

+          move out32.dbg "%OUTDIR%\LIB Debug" 1>nul

+        )

+

+        rem Move the PDB files

+        move tmp32.dbg\lib.pdb "%OUTDIR%\LIB Debug" 1>nul

+

+        rem Remove the intermediate directories

+        rd tmp32.dbg /s /q

+      ) else if "%2" == "shared" (

+        if exist "%OUTDIR%\DLL Debug" (

+          copy /y out32dll.dbg\* "%OUTDIR%\DLL Debug" 1>nul

+          rd out32dll.dbg /s /q

+        ) else (

+          move out32dll.dbg "%OUTDIR%\DLL Debug" 1>nul

+        )

+

+        rem Move the PDB files

+        move tmp32dll.dbg\lib.pdb "%OUTDIR%\DLL Debug" 1>nul

+

+        rem Remove the intermediate directories

+        rd tmp32dll.dbg /s /q

+      ) else (

+        exit /B 1

+      )

+    ) else if "%1" == "release" (

+      if "%2" == "static" (

+        rem Move the output directories

+        if exist "%OUTDIR%\LIB Release" (

+          copy /y out32\* "%OUTDIR%\LIB Release" 1>nul

+          rd out32 /s /q

+        ) else (

+          move out32 "%OUTDIR%\LIB Release" 1>nul

+        )

+

+        rem Move the PDB files

+        move tmp32\lib.pdb "%OUTDIR%\LIB Release" 1>nul

+

+        rem Remove the intermediate directories

+        rd tmp32 /s /q

+      ) else if "%2" == "shared" (

+        if exist "%OUTDIR%\DLL Release" (

+          copy /y out32dll\* "%OUTDIR%\DLL Release" 1>nul

+          rd out32dll /s /q

+        ) else (

+          move out32dll "%OUTDIR%\DLL Release" 1>nul

+        )

+

+        rem Move the PDB files

+        move tmp32dll\lib.pdb "%OUTDIR%\DLL Release" 1>nul

+

+        rem Remove the intermediate directories

+        rd tmp32dll /s /q

+      ) else (

+        exit /B 1

+      )

+    )

+  ) else if "%3" == "FALSE" (

+    cd /d "%TMP_BUILD_PATH%" || (echo Error: Failed cd build & exit /B 1)

+

+    rem Perform the installation

+    nmake install_sw

+

+    cd /d "%SOURCE_PATH%" || (echo Error: Failed cd source & exit /B 1)

+

+    rem Move the output directories

+    if "%1" == "debug" (

+      if "%2" == "static" (

+        if not exist "%OUTDIR%\LIB Debug" (

+          mkdir "%OUTDIR%\LIB Debug" 1>nul

+        )

+

+        move "%TMP_INSTALL_PATH%\lib\*.lib" "%OUTDIR%\LIB Debug" 1>nul

+        move "%TMP_INSTALL_PATH%\lib\*.pdb" "%OUTDIR%\LIB Debug" 1>nul

+        move "%TMP_INSTALL_PATH%\bin\*.exe" "%OUTDIR%\LIB Debug" 1>nul

+        move "%TMP_INSTALL_PATH%\bin\*.pdb" "%OUTDIR%\LIB Debug" 1>nul

+        xcopy /E /I /Y "%TMP_INSTALL_PATH%\include" "%OUTDIR%\LIB Debug\include" 1>nul

+      ) else if "%2" == "shared" (

+        if not exist "%OUTDIR%\DLL Debug" (

+          mkdir "%OUTDIR%\DLL Debug" 1>nul

+        )

+

+        move "%TMP_INSTALL_PATH%\lib\*.lib" "%OUTDIR%\DLL Debug" 1>nul

+        move "%TMP_INSTALL_PATH%\lib\engines-1_1\*.dll" "%OUTDIR%\DLL Debug" 1>nul

+        move "%TMP_INSTALL_PATH%\lib\engines-1_1\*.pdb" "%OUTDIR%\DLL Debug" 1>nul

+        move "%TMP_INSTALL_PATH%\bin\*.dll" "%OUTDIR%\DLL Debug" 1>nul

+        move "%TMP_INSTALL_PATH%\bin\*.exe" "%OUTDIR%\DLL Debug" 1>nul

+        move "%TMP_INSTALL_PATH%\bin\*.pdb" "%OUTDIR%\DLL Debug" 1>nul

+        xcopy /E /I /Y "%TMP_INSTALL_PATH%\include" "%OUTDIR%\DLL Debug\include" 1>nul

+      ) else (

+        exit /B 1

+      )

+    ) else if "%1" == "release" (

+      if "%2" == "static" (

+        if not exist "%OUTDIR%\LIB Release" (

+          mkdir "%OUTDIR%\LIB Release" 1>nul

+        )

+

+        move "%TMP_INSTALL_PATH%\lib\*.lib" "%OUTDIR%\LIB Release" 1>nul

+        move "%TMP_INSTALL_PATH%\lib\*.pdb" "%OUTDIR%\LIB Release" 1>nul

+        move "%TMP_INSTALL_PATH%\bin\*.exe" "%OUTDIR%\LIB Release" 1>nul

+        move "%TMP_INSTALL_PATH%\bin\*.pdb" "%OUTDIR%\LIB Release" 1>nul

+        xcopy /E /I /Y "%TMP_INSTALL_PATH%\include" "%OUTDIR%\LIB Release\include" 1>nul

+      ) else if "%2" == "shared" (

+        if not exist "%OUTDIR%\DLL Release" (

+          mkdir "%OUTDIR%\DLL Release" 1>nul

+        )

+

+        move "%TMP_INSTALL_PATH%\lib\*.lib" "%OUTDIR%\DLL Release" 1>nul

+        move "%TMP_INSTALL_PATH%\lib\engines-1_1\*.dll" "%OUTDIR%\DLL Release" 1>nul

+        move "%TMP_INSTALL_PATH%\lib\engines-1_1\*.pdb" "%OUTDIR%\DLL Release" 1>nul

+        move "%TMP_INSTALL_PATH%\bin\*.dll" "%OUTDIR%\DLL Release" 1>nul

+        move "%TMP_INSTALL_PATH%\bin\*.exe" "%OUTDIR%\DLL Release" 1>nul

+        move "%TMP_INSTALL_PATH%\bin\*.pdb" "%OUTDIR%\DLL Release" 1>nul

+        xcopy /E /I /Y "%TMP_INSTALL_PATH%\include" "%OUTDIR%\DLL Release\include" 1>nul

+      ) else (

+        exit /B 1

+      )

+    ) else (

+      exit /B 1

+    )

+

+    rem Remove the output directories

+    if not "%SOURCE_PATH%" == "%TMP_BUILD_PATH%" (

+      rd "%TMP_BUILD_PATH%" /s /q

+    )

+    if not "%SOURCE_PATH%" == "%TMP_INSTALL_PATH%" (

+      rd "%TMP_INSTALL_PATH%" /s /q

+    )

+  ) else (

+    exit /B 1

+  )

+

+  exit /B 0

+

+:syntax

+  rem Display the help

+  echo.

+  echo Usage: build-openssl ^<compiler^> [platform] [configuration] [directory] [-VSpath] ["VSpath"] [-perlpath] ["perlpath"]

+  echo.

+  echo Compiler:

+  echo.

+  echo vc10      - Use Visual Studio 2010

+  echo vc11      - Use Visual Studio 2012

+  echo vc12      - Use Visual Studio 2013

+  echo vc14      - Use Visual Studio 2015

+  echo vc14.1    - Use Visual Studio 2017

+  echo vc14.2    - Use Visual Studio 2019

+  echo vc14.3    - Use Visual Studio 2022

+  echo.

+  echo Platform:

+  echo.

+  echo x86       - Perform a 32-bit build

+  echo x64       - Perform a 64-bit build

+  echo.

+  echo Configuration:

+  echo.

+  echo debug     - Perform a debug build

+  echo release   - Perform a release build

+  echo.

+  echo Other:

+  echo.

+  echo directory - Specifies the OpenSSL source directory

+  echo.

+  echo -VSpath - Specify the custom VS path if Visual Studio is not located at

+  echo           "C:\<ProgramFiles>\Microsoft Visual Studio <version>"

+  echo           For e.g. -VSpath "C:\apps\MVS14"

+  echo.

+  echo -perlpath - Specify the custom perl root path if perl is not located at

+  echo             "C:\Perl" and it is a portable copy of perl and not

+  echo             installed on the win system.

+  echo             For e.g. -perlpath "D:\strawberry-perl-5.24.3.1-64bit-portable"

+  goto error

+

+:unknown

+  echo.

+  echo Error: Unknown argument '%1'

+  goto error

+

+:nodos

+  echo.

+  echo Error: Only a Windows NT based Operating System is supported

+  goto error

+

+:nopf

+  echo.

+  echo Error: Cannot obtain the directory for Program Files

+  goto error

+

+:novc

+  echo.

+  echo Error: %VC_DESC% is not installed

+  echo Error: Please check whether Visual compiler is installed at the path "%ABS_VC_PATH%"

+  echo Error: Please provide proper VS Path by using -VSpath

+  goto error

+

+:noperl

+  echo.

+  echo Error: Perl is not installed

+  echo Error: Please check whether Perl is installed or it is at location "C:\Perl"

+  echo Error: If Perl is portable please provide perl root path by using -perlpath

+  goto error

+

+:nox64

+  echo.

+  echo Error: %VC_DESC% does not support 64-bit builds

+  goto error

+

+:noopenssl

+  echo.

+  echo Error: Cannot locate OpenSSL source directory

+  goto error

+

+:error

+  if "%OS%" == "Windows_NT" endlocal

+  exit /B 1

+

+:success

+  cd /d "%SAVED_PATH%"

+  endlocal

+  exit /B 0