build-scripts/g++-fat.sh
author Sam Lantinga
Tue, 10 Jan 2017 08:54:33 -0800
changeset 10806 36f40b8cc979
parent 10176 3115d38204aa
permissions -rwxr-xr-x
Fixed bugs 2570, 3145, improved OpenGL ES context support on Windows and X11

Mark Callow

The attached patch does the following for the X11 and Windows platforms, the only ones where SDL attempts to use context_create_es_profile:

- Adds SDL_HINT_OPENGL_ES_DRIVER by which the application can
say to use the OpenGL ES driver & EGL rather than the Open GL
driver. (For bug #2570)
- Adds code to {WIN,X11}_GL_InitExtensions to determine the maximum
OpenGL ES version supported by the OpenGL driver (for bug #3145)
- Modifies the test that determines whether to use the OpenGL
driver or the real OpenGL ES driver to take into account the
hint, the requested and supported ES version and whether ES 1.X
is being requested. (For bug #2570 & bug #3145)
- Enables the testgles2 test for __WINDOWS__ and __LINUX__ and adds
the test to the VisualC projects.

With the fix in place I have run testdraw2, testgl and testgles2 without any issues and have run my own apps that use OpenGL, OpenGL ES 3 and OpenGL ES 1.1.
slouken@7255
     1
#!/bin/sh
slouken@7255
     2
#
slouken@7255
     3
# Build Universal binaries on Mac OS X, thanks Ryan!
slouken@7255
     4
#
slouken@7255
     5
# Usage: ./configure CXX="sh g++-fat.sh" && make && rm -rf x86 x64
slouken@7255
     6
slouken@7255
     7
DEVELOPER="`xcode-select -print-path`/Platforms/MacOSX.platform/Developer"
slouken@7255
     8
slime73@10176
     9
# Intel 32-bit compiler flags (10.6 runtime compatibility)
slime73@10176
    10
GCC_COMPILE_X86="g++ -arch i386 -mmacosx-version-min=10.6 \
slouken@7255
    11
-I/usr/local/include"
slouken@7255
    12
slime73@10176
    13
GCC_LINK_X86="-mmacosx-version-min=10.6"
slouken@7255
    14
slouken@7255
    15
# Intel 64-bit compiler flags (10.6 runtime compatibility)
slouken@7255
    16
GCC_COMPILE_X64="g++ -arch x86_64 -mmacosx-version-min=10.6 \
slouken@7255
    17
-I/usr/local/include"
slouken@7255
    18
slouken@7255
    19
GCC_LINK_X64="-mmacosx-version-min=10.6"
slouken@7255
    20
slouken@7255
    21
# Output both PowerPC and Intel object files
slouken@7255
    22
args="$*"
slouken@7255
    23
compile=yes
slouken@7255
    24
link=yes
slouken@7255
    25
while test x$1 != x; do
slouken@7255
    26
    case $1 in
slouken@7255
    27
        --version) exec g++ $1;;
slouken@7255
    28
        -v) exec g++ $1;;
slouken@7255
    29
        -V) exec g++ $1;;
slouken@7255
    30
        -print-prog-name=*) exec g++ $1;;
slouken@7255
    31
        -print-search-dirs) exec g++ $1;;
slouken@7255
    32
        -E) GCC_COMPILE_X86="$GCC_COMPILE_X86 -E"
slouken@7255
    33
            GCC_COMPILE_X64="$GCC_COMPILE_X64 -E"
slouken@7255
    34
            compile=no; link=no;;
slouken@7255
    35
        -c) link=no;;
slouken@7255
    36
        -o) output=$2;;
icculus@9221
    37
        *.c|*.cc|*.cpp|*.S|*.m|*.mm) source=$1;;
slouken@7255
    38
    esac
slouken@7255
    39
    shift
slouken@7255
    40
done
slouken@7255
    41
if test x$link = xyes; then
slouken@7255
    42
    GCC_COMPILE_X86="$GCC_COMPILE_X86 $GCC_LINK_X86"
slouken@7255
    43
    GCC_COMPILE_X64="$GCC_COMPILE_X64 $GCC_LINK_X64"
slouken@7255
    44
fi
slouken@7255
    45
if test x"$output" = x; then
slouken@7255
    46
    if test x$link = xyes; then
slouken@7255
    47
        output=a.out
slouken@7255
    48
    elif test x$compile = xyes; then
slouken@7255
    49
        output=`echo $source | sed -e 's|.*/||' -e 's|\(.*\)\.[^\.]*|\1|'`.o
slouken@7255
    50
    fi
slouken@7255
    51
fi
slouken@7255
    52
slouken@7255
    53
# Compile X86 32-bit
slouken@7255
    54
if test x"$output" != x; then
slouken@7255
    55
    dir=x86/`dirname $output`
slouken@7255
    56
    if test -d $dir; then
slouken@7255
    57
        :
slouken@7255
    58
    else
slouken@7255
    59
        mkdir -p $dir
slouken@7255
    60
    fi
slouken@7255
    61
fi
slouken@7255
    62
set -- $args
slouken@7255
    63
while test x$1 != x; do
slouken@7255
    64
    if test -f "x86/$1" && test "$1" != "$output"; then
slouken@7255
    65
        x86_args="$x86_args x86/$1"
slouken@7255
    66
    else
slouken@7255
    67
        x86_args="$x86_args $1"
slouken@7255
    68
    fi
slouken@7255
    69
    shift
slouken@7255
    70
done
slouken@7255
    71
$GCC_COMPILE_X86 $x86_args || exit $?
slouken@7255
    72
if test x"$output" != x; then
slouken@7255
    73
    cp $output x86/$output
slouken@7255
    74
fi
slouken@7255
    75
slouken@7255
    76
# Compile X86 32-bit
slouken@7255
    77
if test x"$output" != x; then
slouken@7255
    78
    dir=x64/`dirname $output`
slouken@7255
    79
    if test -d $dir; then
slouken@7255
    80
        :
slouken@7255
    81
    else
slouken@7255
    82
        mkdir -p $dir
slouken@7255
    83
    fi
slouken@7255
    84
fi
slouken@7255
    85
set -- $args
slouken@7255
    86
while test x$1 != x; do
slouken@7255
    87
    if test -f "x64/$1" && test "$1" != "$output"; then
slouken@7255
    88
        x64_args="$x64_args x64/$1"
slouken@7255
    89
    else
slouken@7255
    90
        x64_args="$x64_args $1"
slouken@7255
    91
    fi
slouken@7255
    92
    shift
slouken@7255
    93
done
slouken@7255
    94
$GCC_COMPILE_X64 $x64_args || exit $?
slouken@7255
    95
if test x"$output" != x; then
slouken@7255
    96
    cp $output x64/$output
slouken@7255
    97
fi
slouken@7255
    98
slouken@7255
    99
if test x"$output" != x; then
slouken@7255
   100
    lipo -create -o $output x86/$output x64/$output
slouken@7255
   101
fi