From 9dd942a5ac8fec313c417f37283a66abc4fad5fc Mon Sep 17 00:00:00 2001 From: Jim Mathies Date: Tue, 24 Apr 2012 14:28:19 -0500 Subject: [PATCH] Bug 737969 - Win8 Metro build config. r=ted --- config/autoconf.mk.in | 1 + configure.in | 66 ++++++++++++++++++++++++++++++------ js/src/config/autoconf.mk.in | 2 ++ js/src/configure.in | 41 +++++++++++++++++----- 4 files changed, 92 insertions(+), 18 deletions(-) diff --git a/config/autoconf.mk.in b/config/autoconf.mk.in index 7930a5ee720..8fceba770c0 100644 --- a/config/autoconf.mk.in +++ b/config/autoconf.mk.in @@ -550,6 +550,7 @@ MOZ_ENABLE_DWRITE_FONT = @MOZ_ENABLE_DWRITE_FONT@ MOZ_ENABLE_D2D_SURFACE = @MOZ_ENABLE_D2D_SURFACE@ MOZ_ENABLE_D3D9_LAYER = @MOZ_ENABLE_D3D9_LAYER@ MOZ_ENABLE_D3D10_LAYER = @MOZ_ENABLE_D3D10_LAYER@ +MOZ_METRO = @MOZ_METRO@ MOZ_GTK2_CFLAGS = @MOZ_GTK2_CFLAGS@ MOZ_GTK2_LIBS = @MOZ_GTK2_LIBS@ diff --git a/configure.in b/configure.in index 15161e1e065..8b336c7a086 100644 --- a/configure.in +++ b/configure.in @@ -678,25 +678,49 @@ fi dnl ======================================================== dnl Special win32 checks dnl ======================================================== -WINVER=502 -dnl Target the Windows 7 SDK by default -WINSDK_TARGETVER=601 + +# With win8, sdk target=602, WINVER=602 +MOZ_ARG_ENABLE_BOOL(metro, +[ --enable-metro Enable Windows Metro build targets], + MOZ_METRO=1, + MOZ_METRO=) +if test -n "$MOZ_METRO"; then + AC_DEFINE(MOZ_METRO) + # Target the Windows 8 Kit + WINSDK_TARGETVER=602 + # Allow a higher api set + WINVER=602 +else + # Target the Windows 7 SDK by default + WINSDK_TARGETVER=601 + WINVER=502 +fi + +if test -n "$MOZ_METRO"; then + case "$target" in + *-mingw*) + ;; + *) + AC_MSG_ERROR([Metro builds only valid on the windows platform.]); + ;; + esac +fi MOZ_ARG_WITH_STRING(windows-version, [ --with-windows-version=WINSDK_TARGETVER - Highest Windows version to target using this SDK - 601: Windows 7], + Windows SDK version to target. Lowest version + currently allowed is 601 (Win7), highest is 602 (Win8)], WINSDK_TARGETVER=$withval) +# Currently only two sdk versions allowed, 601 and 602 case "$WINSDK_TARGETVER" in -601) +601|602) MOZ_WINSDK_TARGETVER=0${WINSDK_TARGETVER}0000 ;; *) - AC_MSG_ERROR([Invalid value for --with-windows-version ($WINSDK_TARGETVER), must be 601]); + AC_MSG_ERROR([Invalid value for --with-windows-version ($WINSDK_TARGETVER)]); ;; - esac case "$target" in @@ -778,6 +802,16 @@ case "$target" in WIN32_REDIST_DIR=`cd "$WIN32_REDIST_DIR" && pwd` fi + dnl Confirm we have the pri tools on win8 builds + if test -n "$MOZ_METRO"; then + AC_MSG_CHECKING([for makepri]) + AC_CHECK_PROGS(MAKEPRI, makepri, "") + if test -z "MAKEPRI" ; then + AC_MSG_ERROR([makepri.exe is required for generating metro browser install components. It should be in the Win8 SDK.]) + fi + AC_SUBST(MAKEPRI) + fi + dnl Ensure that mt.exe is 'Microsoft (R) Manifest Tool', dnl not something else like "magnetic tape manipulation utility". MSMT_TOOL=`mt 2>&1|grep 'Microsoft (R) Manifest Tool'` @@ -966,7 +1000,7 @@ EOF AC_MSG_ERROR([windres version $WINDRES_VERSION or higher is required to build.]) fi - MOZ_WINSDK_MAXVER=0x06010000 + MOZ_WINSDK_MAXVER=0x06020000 fi # !GNU_CC AC_DEFINE_UNQUOTED(WINVER,0x$WINVER) @@ -983,7 +1017,18 @@ EOF AC_MSG_RESULT("no") AC_MSG_ERROR([You are targeting Windows version 0x$MOZ_WINSDK_TARGETVER, but your SDK only supports up to version $MOZ_WINSDK_MAXVER. Install and use an updated SDK, or target a lower version using --with-windows-version. Alternatively, try running the Windows SDK Configuration Tool and selecting a newer SDK. See https://developer.mozilla.org/En/Windows_SDK_versions for more details on fixing this.]) fi - + + # Make sure the sdk / code we're targeting has the right toolset + AC_MSG_CHECKING([SDK and tools are in sync]) + if test -n "$MOZ_METRO"; then + if test "$MOZ_MSVCVERSION" -gt "10"; then + AC_MSG_RESULT("yes") + else + AC_MSG_RESULT("no") + AC_MSG_ERROR([Your MOZ_MSVCVERSION equals $MOZ_MSVCVERSION and you've enabled metro build support. You can't target metro without msvc 11 or higher. Disable metro support or switch to a newer set of tools.]) + fi + fi + AC_DEFINE_UNQUOTED(MOZ_WINSDK_TARGETVER,0x$MOZ_WINSDK_TARGETVER) # Definitions matching sdkddkver.h AC_DEFINE_UNQUOTED(MOZ_NTDDI_WIN7, 0x06010000) @@ -8445,6 +8490,7 @@ AC_SUBST(MOZ_D3DX9_CAB) AC_SUBST(MOZ_D3DCOMPILER_CAB) AC_SUBST(MOZ_D3DX9_DLL) AC_SUBST(MOZ_D3DCOMPILER_DLL) +AC_SUBST(MOZ_METRO) AC_SUBST(MOZ_ANDROID_HISTORY) AC_SUBST(MOZ_WEBSMS_BACKEND) diff --git a/js/src/config/autoconf.mk.in b/js/src/config/autoconf.mk.in index 23b776cc903..35d50a269c4 100644 --- a/js/src/config/autoconf.mk.in +++ b/js/src/config/autoconf.mk.in @@ -335,6 +335,8 @@ HAVE_ARM_SIMD= @HAVE_ARM_SIMD@ JS_SHARED_LIBRARY = @JS_SHARED_LIBRARY@ HAVE_LINUX_PERF_EVENT_H = @HAVE_LINUX_PERF_EVENT_H@ +MOZ_METRO = @MOZ_METRO@ + # We only want to do the pymake sanity on Windows, other os's can cope ifeq ($(HOST_OS_ARCH),WINNT) # Ensure invariants between GNU Make and pymake diff --git a/js/src/configure.in b/js/src/configure.in index 25e8a26f92c..e5b0f7a68be 100644 --- a/js/src/configure.in +++ b/js/src/configure.in @@ -663,25 +663,49 @@ fi dnl Special win32 checks dnl ======================================================== -WINVER=502 -dnl Target the Windows 7 SDK by default -WINSDK_TARGETVER=601 + +# With win8, sdk target=602, WINVER=602 +MOZ_ARG_ENABLE_BOOL(metro, +[ --enable-metro Enable Windows Metro build targets], + MOZ_METRO=1, + MOZ_METRO=) +if test -n "$MOZ_METRO"; then + AC_DEFINE(MOZ_METRO) + # Target the Windows 8 Kit + WINSDK_TARGETVER=602 + # Allow a higher api set + WINVER=602 +else + # Target the Windows 7 SDK by default + WINSDK_TARGETVER=601 + WINVER=502 +fi + +if test -n "$MOZ_METRO"; then + case "$target" in + *-mingw*) + ;; + *) + AC_MSG_ERROR([Metro builds only valid on the windows platform.]); + ;; + esac +fi MOZ_ARG_WITH_STRING(windows-version, [ --with-windows-version=WINSDK_TARGETVER - Highest Windows version to target using this SDK - 601: Windows 7], + Windows SDK version to target. Lowest version + currently allowed is 601, highest is 602], WINSDK_TARGETVER=$withval) +# Currently only two sdk versions allowed, 601 and 602 case "$WINSDK_TARGETVER" in -601) +601|602) MOZ_WINSDK_TARGETVER=0${WINSDK_TARGETVER}0000 ;; *) - AC_MSG_ERROR([Invalid value for --with-windows-version ($WINSDK_TARGETVER), must be 601]); + AC_MSG_ERROR([Invalid value for --with-windows-version ($WINSDK_TARGETVER)]); ;; - esac case "$target" in @@ -4859,6 +4883,7 @@ AC_SUBST(COMPILE_CXXFLAGS) AC_SUBST(LDFLAGS) AC_SUBST(LIBS) AC_SUBST(CROSS_COMPILE) +AC_SUBST(MOZ_METRO) AC_SUBST(HOST_CC) AC_SUBST(HOST_CXX)