mirror of
https://gitea.sffempire.ru/Kolyah35/minecraft-pe-0.6.1.git
synced 2026-03-20 06:53:30 +00:00
Compare commits
31 Commits
ios-suppor
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
e0dac8a95c | ||
|
|
1cd73cfc1e | ||
|
|
c1fe428aa3 | ||
|
|
24d3b9488d | ||
|
|
f3f0918e77 | ||
|
|
e190335abe | ||
|
|
402b053432 | ||
|
|
0964e3ea4b | ||
|
|
0dc8deac93 | ||
|
|
13280cb8a7 | ||
|
|
11117cd4f6 | ||
|
|
78d218ccb1 | ||
|
|
a72c2c4094 | ||
|
|
193f63893d | ||
|
|
bb181ca838 | ||
|
|
eadbe78f6b | ||
|
|
bfc796b59f | ||
|
|
04d892c926 | ||
|
|
e469e03366 | ||
|
|
ca2af5edb4 | ||
|
|
e49f58bc89 | ||
|
|
e9914e3fbd | ||
|
|
157ef5ff05 | ||
|
|
4769d4ae72 | ||
|
|
d15051aab6 | ||
|
|
5ff8b54c4f | ||
|
|
48e3b11c4e | ||
|
|
2c132d5bc7 | ||
|
|
e0a39fb6c1 | ||
|
|
ccac464750 | ||
|
|
11e986bcf2 |
27
.github/actions/setup-cache/action.yml
vendored
Normal file
27
.github/actions/setup-cache/action.yml
vendored
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
name: Setup cache
|
||||||
|
description: Sets up sccache, CPM cache, etc.
|
||||||
|
|
||||||
|
inputs:
|
||||||
|
host:
|
||||||
|
description: 'Host platform: win or linux'
|
||||||
|
required: true
|
||||||
|
target:
|
||||||
|
description: 'Target platform: win, linux'
|
||||||
|
required: true
|
||||||
|
|
||||||
|
runs:
|
||||||
|
using: "composite"
|
||||||
|
steps:
|
||||||
|
- name: Setup sccache
|
||||||
|
uses: hendrikmuhs/ccache-action@v1.2.13
|
||||||
|
with:
|
||||||
|
variant: sccache
|
||||||
|
key: ${{ inputs.target }}-v1
|
||||||
|
|
||||||
|
- name: Setup CPM Cache
|
||||||
|
uses: actions/cache@v4
|
||||||
|
with:
|
||||||
|
path: cpm-cache
|
||||||
|
key: cpm-${{ inputs.target }}-v1-${{ hashFiles('**/CMakeLists.txt', '**/*.cmake') }}
|
||||||
|
restore-keys: |
|
||||||
|
cpm-${{ inputs.target }}-v1-
|
||||||
36
.github/workflows/android.yml
vendored
36
.github/workflows/android.yml
vendored
@@ -1,36 +0,0 @@
|
|||||||
name: Android Build
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches: [ main ]
|
|
||||||
pull_request:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
runs-on: windows-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Checkout
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: Download Android NDK r14b
|
|
||||||
shell: powershell
|
|
||||||
run: |
|
|
||||||
Invoke-WebRequest `
|
|
||||||
-Uri "http://dl.google.com/android/repository/android-ndk-r14b-windows-x86_64.zip" `
|
|
||||||
-OutFile "ndk.zip"
|
|
||||||
|
|
||||||
- name: Extract NDK
|
|
||||||
shell: powershell
|
|
||||||
run: |
|
|
||||||
Expand-Archive ndk.zip C:\
|
|
||||||
|
|
||||||
- name: Verify NDK path
|
|
||||||
shell: powershell
|
|
||||||
run: |
|
|
||||||
Test-Path "C:\android-ndk-r14b"
|
|
||||||
|
|
||||||
- name: Run build script
|
|
||||||
shell: powershell
|
|
||||||
run: |
|
|
||||||
./build.ps1
|
|
||||||
239
.github/workflows/build.yml
vendored
Normal file
239
.github/workflows/build.yml
vendored
Normal file
@@ -0,0 +1,239 @@
|
|||||||
|
name: Build Game
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
pull_request:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- '**' # every branch
|
||||||
|
- '!no-build-**' # unless marked as no-build
|
||||||
|
|
||||||
|
env:
|
||||||
|
# Customize the CMake build type here (Release, Debug, RelWithDebInfo, etc.)
|
||||||
|
BUILD_TYPE: Release
|
||||||
|
CPM_SOURCE_CACHE: ${{ github.workspace }}/cpm-cache
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: write
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build-windows:
|
||||||
|
name: Windows Build
|
||||||
|
runs-on: windows-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Setup caches
|
||||||
|
uses: ./.github/actions/setup-cache
|
||||||
|
with:
|
||||||
|
host: win
|
||||||
|
target: win
|
||||||
|
|
||||||
|
- name: Create Build Environment
|
||||||
|
# Some projects don't allow in-source building, so create a separate build directory
|
||||||
|
# We'll use this as our working directory for all subsequent commands
|
||||||
|
run: cmake -E make_directory ${{github.workspace}}/build
|
||||||
|
|
||||||
|
- name: Configure CMake
|
||||||
|
shell: powershell
|
||||||
|
working-directory: ${{github.workspace}}/build
|
||||||
|
run: cmake $env:GITHUB_WORKSPACE -DCMAKE_BUILD_TYPE=$env:BUILD_TYPE
|
||||||
|
|
||||||
|
- name: Build
|
||||||
|
working-directory: ${{github.workspace}}/build
|
||||||
|
shell: powershell
|
||||||
|
run: cmake --build . --config $env:BUILD_TYPE --target MinecraftPE
|
||||||
|
|
||||||
|
- name: Upload Artifact
|
||||||
|
uses: actions/upload-artifact@v4
|
||||||
|
with:
|
||||||
|
name: mcpe-windows
|
||||||
|
path: |
|
||||||
|
${{github.workspace}}/build/${{ env.BUILD_TYPE }}/MinecraftPE.exe
|
||||||
|
${{github.workspace}}/build/${{ env.BUILD_TYPE }}/glfw3.dll
|
||||||
|
${{github.workspace}}/build/${{ env.BUILD_TYPE }}/libpng16.dll
|
||||||
|
${{github.workspace}}/build/${{ env.BUILD_TYPE }}/OpenAL32.dll
|
||||||
|
${{github.workspace}}/build/${{ env.BUILD_TYPE }}/z.dll
|
||||||
|
|
||||||
|
build-linux:
|
||||||
|
name: Linux Build
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Setup caches
|
||||||
|
uses: ./.github/actions/setup-cache
|
||||||
|
with:
|
||||||
|
host: linux
|
||||||
|
target: linux
|
||||||
|
|
||||||
|
- name: Create Build Environment
|
||||||
|
# Some projects don't allow in-source building, so create a separate build directory
|
||||||
|
# We'll use this as our working directory for all subsequent commands
|
||||||
|
run: cmake -E make_directory ${{github.workspace}}/build
|
||||||
|
|
||||||
|
- name: Setup Environment
|
||||||
|
run: |
|
||||||
|
sudo apt-get update -qq
|
||||||
|
sudo apt-get install gcc-multilib
|
||||||
|
sudo apt-get install -y --no-install-recommends build-essential libgl-dev libwayland-dev xorg-dev libxkbcommon-dev
|
||||||
|
|
||||||
|
- name: Configure CMake
|
||||||
|
# Use a bash shell so we can use the same syntax for environment variable
|
||||||
|
# access regardless of the host operating system
|
||||||
|
shell: bash
|
||||||
|
working-directory: ${{github.workspace}}/build
|
||||||
|
run: cmake $GITHUB_WORKSPACE -DCMAKE_BUILD_TYPE=$BUILD_TYPE
|
||||||
|
|
||||||
|
- name: Build
|
||||||
|
working-directory: ${{github.workspace}}/build
|
||||||
|
shell: bash
|
||||||
|
run: cmake --build . --config $BUILD_TYPE
|
||||||
|
|
||||||
|
- name: Upload Artifact
|
||||||
|
uses: actions/upload-artifact@v4
|
||||||
|
with:
|
||||||
|
name: mcpe-linux
|
||||||
|
path: |
|
||||||
|
${{github.workspace}}/build/MinecraftPE
|
||||||
|
${{github.workspace}}/build/MinecraftPE-server
|
||||||
|
|
||||||
|
build-android: # pray to god
|
||||||
|
name: Build Android APK
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
env:
|
||||||
|
ANDROID_SDK_ROOT: ${{ github.workspace }}/android-sdk
|
||||||
|
# ANDROID_NDK_PATH: ${{ env.ANDROID_NDK_PATH }}
|
||||||
|
ANDROID_PLATFORM_API: 36
|
||||||
|
ANDROID_BUILD_TOOLS_VERSION: 36.0.0
|
||||||
|
ADB: /bin/true
|
||||||
|
# JAVA_HOME: ${{ env.JAVA_HOME }}
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Cache Android command-line tools
|
||||||
|
uses: actions/cache@v3
|
||||||
|
with:
|
||||||
|
path: ${{ github.workspace }}/android-sdk/cmdline-tools
|
||||||
|
key: android-cmdline-tools-v36
|
||||||
|
|
||||||
|
- name: Setup Android command line tools
|
||||||
|
run: |
|
||||||
|
if [ ! -d "$ANDROID_SDK_ROOT/cmdline-tools/latest" ]; then
|
||||||
|
mkdir -p "$ANDROID_SDK_ROOT/cmdline-tools"
|
||||||
|
curl -o cmdline-tools.zip -L "https://dl.google.com/android/repository/commandlinetools-linux-9477386_latest.zip"
|
||||||
|
unzip -q cmdline-tools.zip -d "$ANDROID_SDK_ROOT/cmdline-tools"
|
||||||
|
mv "$ANDROID_SDK_ROOT/cmdline-tools/cmdline-tools" "$ANDROID_SDK_ROOT/cmdline-tools/latest"
|
||||||
|
fi
|
||||||
|
yes | "$ANDROID_SDK_ROOT/cmdline-tools/latest/bin/sdkmanager" --sdk_root="$ANDROID_SDK_ROOT" "platform-tools" "platforms;android-${ANDROID_PLATFORM_API}" "build-tools;${ANDROID_BUILD_TOOLS_VERSION}"
|
||||||
|
|
||||||
|
- name: Cache Android NDK r14b
|
||||||
|
uses: actions/cache@v3
|
||||||
|
with:
|
||||||
|
path: ${{ github.workspace }}/android-ndk-r14b
|
||||||
|
key: android-ndk-r14b
|
||||||
|
|
||||||
|
- name: Install Android NDK r14b
|
||||||
|
run: |
|
||||||
|
if [ ! -d "$GITHUB_WORKSPACE/android-ndk-r14b" ]; then
|
||||||
|
curl -L -o ndk.zip "https://dl.google.com/android/repository/android-ndk-r14b-linux-x86_64.zip"
|
||||||
|
unzip -q ndk.zip -d "$GITHUB_WORKSPACE"
|
||||||
|
fi
|
||||||
|
echo "ANDROID_NDK_PATH=$GITHUB_WORKSPACE/android-ndk-r14b" >> $GITHUB_ENV
|
||||||
|
|
||||||
|
- name: Install system prerequisites
|
||||||
|
run: |
|
||||||
|
sudo apt-get update -qq
|
||||||
|
sudo apt-get install -y --no-install-recommends wget unzip curl git python3 libncurses6 libtinfo6
|
||||||
|
if ! ldconfig -p | grep -q "libncurses.so.5"; then
|
||||||
|
sudo ln -sf /lib/x86_64-linux-gnu/libncurses.so.6 /usr/lib/x86_64-linux-gnu/libncurses.so.5 || true
|
||||||
|
fi
|
||||||
|
if ! ldconfig -p | grep -q "libtinfo.so.5"; then
|
||||||
|
sudo ln -sf /lib/x86_64-linux-gnu/libtinfo.so.6 /usr/lib/x86_64-linux-gnu/libtinfo.so.5 || true
|
||||||
|
fi
|
||||||
|
|
||||||
|
- name: Setup Java 25
|
||||||
|
uses: actions/setup-java@v4
|
||||||
|
with:
|
||||||
|
distribution: temurin
|
||||||
|
java-version: 25
|
||||||
|
|
||||||
|
- name: Validate environment
|
||||||
|
run: |
|
||||||
|
echo "ANDROID_SDK_ROOT=$ANDROID_SDK_ROOT"
|
||||||
|
echo "ANDROID_NDK_PATH=$ANDROID_NDK_PATH"
|
||||||
|
echo "JAVA_HOME=$JAVA_HOME"
|
||||||
|
$ANDROID_SDK_ROOT/platform-tools/adb version || true
|
||||||
|
java -version
|
||||||
|
javac -version
|
||||||
|
|
||||||
|
- name: Run Android build script
|
||||||
|
run: |
|
||||||
|
chmod +x ./build.sh
|
||||||
|
./build.sh
|
||||||
|
|
||||||
|
- name: Upload APK
|
||||||
|
uses: actions/upload-artifact@v4
|
||||||
|
with:
|
||||||
|
name: minecraftpe-apk
|
||||||
|
path: ${{ github.workspace }}/build-apk/minecraftpe-debug.apk
|
||||||
|
|
||||||
|
publish:
|
||||||
|
name: Publish
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
needs: [ build-windows, build-linux, build-android ]
|
||||||
|
if: github.ref == 'refs/heads/main'
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Declare Version Variables
|
||||||
|
id: ref
|
||||||
|
run: |
|
||||||
|
echo "version=$(cat VERSION | xargs)" >> $GITHUB_OUTPUT
|
||||||
|
echo "hash=$(git rev-parse --short "$GITHUB_SHA")" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
- name: Download Artifacts
|
||||||
|
uses: actions/download-artifact@v4
|
||||||
|
|
||||||
|
- name: Zip Windows Artifacts
|
||||||
|
uses: vimtor/action-zip@v1.2
|
||||||
|
with:
|
||||||
|
files: ${{github.workspace}}/data/ mcpe-windows/MinecraftPE.exe mcpe-windows/glfw3.dll mcpe-windows/libpng16.dll mcpe-windows/OpenAL32.dll mcpe-windows/z.dll
|
||||||
|
dest: minecraftpe-${{ steps.ref.outputs.hash }}-windows.zip
|
||||||
|
|
||||||
|
- name: Zip Linux Artifacts
|
||||||
|
uses: vimtor/action-zip@v1.2
|
||||||
|
with:
|
||||||
|
files: ${{github.workspace}}/data/ mcpe-linux/MinecraftPE # ye, you should install libraries by urself :trollface:
|
||||||
|
dest: minecraftpe-${{ steps.ref.outputs.hash }}-linux.zip
|
||||||
|
|
||||||
|
- name: Zip Linux Server Artifacts
|
||||||
|
uses: vimtor/action-zip@v1.2
|
||||||
|
with:
|
||||||
|
files: mcpe-linux/MinecraftPE-server
|
||||||
|
dest: minecraftpe-server-${{ steps.ref.outputs.hash }}.zip
|
||||||
|
|
||||||
|
- name: Zip Android Artifact
|
||||||
|
uses: vimtor/action-zip@v1.2
|
||||||
|
with:
|
||||||
|
files: mcpe-apk/minecraftpe-debug.apk
|
||||||
|
dest: minecraftpe-${{ steps.ref.outputs.hash }}-android.zip
|
||||||
|
|
||||||
|
- name: Update Development Release
|
||||||
|
uses: andelf/nightly-release@main
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
with:
|
||||||
|
tag_name: dev
|
||||||
|
name: 'Development Release'
|
||||||
|
body: |
|
||||||
|
MinecraftPE development release for commit ${{ github.sha }}.
|
||||||
|
files: |
|
||||||
|
./minecraftpe-${{ steps.ref.outputs.hash }}-windows.zip
|
||||||
|
./minecraftpe-${{ steps.ref.outputs.hash }}-linux.zip
|
||||||
|
./minecraftpe-server-${{ steps.ref.outputs.hash }}.zip
|
||||||
|
./minecraftpe-${{ steps.ref.outputs.hash }}-android.zip
|
||||||
75
.github/workflows/cmake-multiplatform.yml
vendored
75
.github/workflows/cmake-multiplatform.yml
vendored
@@ -1,75 +0,0 @@
|
|||||||
name: CMake multiplatform
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches: [ "main" ]
|
|
||||||
pull_request:
|
|
||||||
branches: [ "main" ]
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: write
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
runs-on: ${{ matrix.os }}
|
|
||||||
|
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
os: [ubuntu-latest, windows-latest]
|
|
||||||
build_type: [Release]
|
|
||||||
include:
|
|
||||||
- os: windows-latest
|
|
||||||
c_compiler: clang
|
|
||||||
cpp_compiler: clang++
|
|
||||||
- os: ubuntu-latest
|
|
||||||
c_compiler: clang
|
|
||||||
cpp_compiler: clang++
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v4
|
|
||||||
- name: Set reusable strings
|
|
||||||
# Turn repeated input strings (such as the build output directory) into step outputs. These step outputs can be used throughout the workflow file.
|
|
||||||
id: strings
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
echo "build-output-dir=${{ github.workspace }}/build" >> "$GITHUB_OUTPUT"
|
|
||||||
|
|
||||||
- name: Setup Environment
|
|
||||||
if: ${{ matrix.os == 'ubuntu-latest' }}
|
|
||||||
run: |
|
|
||||||
sudo apt-get update -qq
|
|
||||||
sudo apt-get install gcc-multilib
|
|
||||||
sudo apt-get install -y --no-install-recommends build-essential libgl-dev libwayland-dev xorg-dev libxkbcommon-dev
|
|
||||||
|
|
||||||
- name: Configure CMake
|
|
||||||
run: >
|
|
||||||
cmake -B ${{ steps.strings.outputs.build-output-dir }}
|
|
||||||
-DCMAKE_CXX_COMPILER=${{ matrix.cpp_compiler }}
|
|
||||||
-DCMAKE_C_COMPILER=${{ matrix.c_compiler }}
|
|
||||||
-DCMAKE_BUILD_TYPE=${{ matrix.build_type }}
|
|
||||||
-S ${{ github.workspace }}
|
|
||||||
|
|
||||||
- name: Build
|
|
||||||
run: cmake --build ${{ steps.strings.outputs.build-output-dir }} --config ${{ matrix.build_type }}
|
|
||||||
|
|
||||||
- name: Install
|
|
||||||
run: cmake --install ${{ steps.strings.outputs.build-output-dir }} --config ${{ matrix.build_type }}
|
|
||||||
|
|
||||||
- name: Pack
|
|
||||||
run: |
|
|
||||||
cd ${{ steps.strings.outputs.build-output-dir }}
|
|
||||||
cpack -C ${{ matrix.build_type }}
|
|
||||||
|
|
||||||
- name: Create or Update Development Release
|
|
||||||
uses: softprops/action-gh-release@v1
|
|
||||||
with:
|
|
||||||
name: Development Build
|
|
||||||
tag_name: dev
|
|
||||||
body: |
|
|
||||||
${{ github.event.head_commit.timestamp }}
|
|
||||||
draft: false
|
|
||||||
prerelease: true
|
|
||||||
generate_release_notes: false
|
|
||||||
files: 'build/package/*.zip'
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
1
.gitignore
vendored
1
.gitignore
vendored
@@ -3,6 +3,7 @@ build/
|
|||||||
out/
|
out/
|
||||||
bin/
|
bin/
|
||||||
lib/
|
lib/
|
||||||
|
build-apk/
|
||||||
cmake-build-*/
|
cmake-build-*/
|
||||||
CMakeFiles/
|
CMakeFiles/
|
||||||
CMakeCache.txt
|
CMakeCache.txt
|
||||||
|
|||||||
202
CMakeLists.txt
202
CMakeLists.txt
@@ -11,39 +11,53 @@ if (CMAKE_CXX_COMPILER_ID STREQUAL "Clang")
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
find_package(Threads REQUIRED)
|
find_package(Threads REQUIRED)
|
||||||
|
|
||||||
find_package(OpenSSL)
|
find_package(OpenSSL)
|
||||||
if (OpenSSL_FOUND)
|
|
||||||
message(STATUS "found openssl ${OPENSSL_VERSION}")
|
if(EMSCRIPTEN)
|
||||||
|
set(AL_LIBTYPE "STATIC")
|
||||||
|
else()
|
||||||
|
set(AL_LIBTYPE "SHARED")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
CPMAddPackage("gh:madler/zlib@1.3.2")
|
# I totally shocked
|
||||||
CPMAddPackage(
|
if(EMSCRIPTEN)
|
||||||
|
set(PNG_LIB png)
|
||||||
|
|
||||||
|
add_library(zlib INTERFACE IMPORTED)
|
||||||
|
set_target_properties(zlib PROPERTIES
|
||||||
|
INTERFACE_LINK_OPTIONS "-sUSE_ZLIB=1"
|
||||||
|
)
|
||||||
|
|
||||||
|
add_library(png INTERFACE IMPORTED)
|
||||||
|
set_target_properties(png PROPERTIES
|
||||||
|
INTERFACE_LINK_OPTIONS "-sUSE_LIBPNG=1"
|
||||||
|
)
|
||||||
|
|
||||||
|
add_library(glfw INTERFACE IMPORTED)
|
||||||
|
set_target_properties(glfw PROPERTIES
|
||||||
|
INTERFACE_LINK_OPTIONS "-sUSE_GLFW=3"
|
||||||
|
)
|
||||||
|
else()
|
||||||
|
set(PNG_LIB png_shared)
|
||||||
|
|
||||||
|
CPMAddPackage(
|
||||||
|
NAME "zlib"
|
||||||
|
GIT_REPOSITORY "https://github.com/madler/zlib"
|
||||||
|
GIT_TAG "v1.3.2"
|
||||||
|
)
|
||||||
|
|
||||||
|
CPMAddPackage(
|
||||||
NAME "libpng"
|
NAME "libpng"
|
||||||
GIT_REPOSITORY "https://github.com/pnggroup/libpng.git"
|
GIT_REPOSITORY "https://github.com/pnggroup/libpng.git"
|
||||||
GIT_TAG "v1.6.55"
|
GIT_TAG "v1.6.55"
|
||||||
EXCLUDE_FROM_ALL TRUE
|
|
||||||
OPTIONS
|
OPTIONS
|
||||||
"ZLIB_ROOT ${zlib_SOURCE_DIR}"
|
"ZLIB_ROOT ${zlib_SOURCE_DIR}"
|
||||||
"ZLIB_INCLUDE_DIRS ${zlib_SOURCE_DIR}"
|
"ZLIB_INCLUDE_DIRS ${zlib_SOURCE_DIR}"
|
||||||
"PNG_TOOLS OFF"
|
"PNG_TOOLS OFF"
|
||||||
"PNG_TESTS OFF"
|
"PNG_TESTS OFF"
|
||||||
"BUILD_SHARED_LIBS ON"
|
)
|
||||||
)
|
|
||||||
|
|
||||||
CPMAddPackage(
|
CPMAddPackage(
|
||||||
NAME "openal"
|
|
||||||
GIT_REPOSITORY "https://github.com/kcat/openal-soft.git"
|
|
||||||
GIT_TAG "1.25.1"
|
|
||||||
EXCLUDE_FROM_ALL TRUE
|
|
||||||
OPTIONS
|
|
||||||
"ALSOFT_EXAMPLES OFF"
|
|
||||||
"ALSOFT_TESTS OFF"
|
|
||||||
"ALSOFT_UTILS OFF"
|
|
||||||
"BUILD_SHARED_LIBS ON"
|
|
||||||
)
|
|
||||||
|
|
||||||
CPMAddPackage(
|
|
||||||
NAME "glfw"
|
NAME "glfw"
|
||||||
GIT_REPOSITORY "https://github.com/glfw/glfw.git"
|
GIT_REPOSITORY "https://github.com/glfw/glfw.git"
|
||||||
GIT_TAG "3.4"
|
GIT_TAG "3.4"
|
||||||
@@ -52,7 +66,18 @@ CPMAddPackage(
|
|||||||
"GLFW_BUILD_EXAMPLES OFF"
|
"GLFW_BUILD_EXAMPLES OFF"
|
||||||
"GLFW_BUILD_TESTS OFF"
|
"GLFW_BUILD_TESTS OFF"
|
||||||
"GLFW_BUILD_DOCS OFF"
|
"GLFW_BUILD_DOCS OFF"
|
||||||
"BUILD_SHARED_LIBS ON"
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
CPMAddPackage(
|
||||||
|
NAME "openal"
|
||||||
|
GIT_REPOSITORY "https://github.com/kcat/openal-soft.git"
|
||||||
|
GIT_TAG "1.25.1"
|
||||||
|
OPTIONS
|
||||||
|
"ALSOFT_EXAMPLES OFF"
|
||||||
|
"ALSOFT_TESTS OFF"
|
||||||
|
"ALSOFT_UTILS OFF"
|
||||||
|
"LIBTYPE ${AL_LIBTYPE}"
|
||||||
)
|
)
|
||||||
|
|
||||||
# TODO: Clear this paths with *
|
# TODO: Clear this paths with *
|
||||||
@@ -242,11 +267,15 @@ endif()
|
|||||||
|
|
||||||
|
|
||||||
if(PLATFORM STREQUAL "PLATFORM_WIN32")
|
if(PLATFORM STREQUAL "PLATFORM_WIN32")
|
||||||
list(APPEND CLIENT_SOURCES "src/AppPlatform_win32.cpp")
|
list(APPEND CLIENT_SOURCES "src/AppPlatform_win32.cpp" "glad/src/glad.c")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(PLATFORM STREQUAL "PLATFORM_GLFW")
|
if(PLATFORM STREQUAL "PLATFORM_GLFW")
|
||||||
list(APPEND CLIENT_SOURCES "src/AppPlatform_glfw.cpp")
|
list(APPEND CLIENT_SOURCES "src/AppPlatform_glfw.cpp" "glad/src/glad.c")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(EMSCRIPTEN)
|
||||||
|
list(APPEND CLIENT_SOURCES "glad/src/glad.c")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Server
|
# Server
|
||||||
@@ -260,13 +289,10 @@ target_include_directories("${PROJECT_NAME}-server" PUBLIC
|
|||||||
"project/lib_projects/raknet/jni/RaknetSources"
|
"project/lib_projects/raknet/jni/RaknetSources"
|
||||||
)
|
)
|
||||||
|
|
||||||
target_link_libraries("${PROJECT_NAME}-server" ${CMAKE_THREAD_LIBS_INIT} png_shared)
|
target_link_libraries("${PROJECT_NAME}-server" ${CMAKE_THREAD_LIBS_INIT})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_executable(${PROJECT_NAME}
|
add_executable(${PROJECT_NAME} ${CLIENT_SOURCES})
|
||||||
${CLIENT_SOURCES}
|
|
||||||
"glad/src/glad.c"
|
|
||||||
)
|
|
||||||
|
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
set(EXTRA_LIBS "ws2_32")
|
set(EXTRA_LIBS "ws2_32")
|
||||||
@@ -277,8 +303,6 @@ if(PLATFORM STREQUAL "PLATFORM_WIN32" OR PLATFORM STREQUAL "PLATFORM_GLFW")
|
|||||||
target_compile_definitions(${PROJECT_NAME} PUBLIC "PLATFORM_DESKTOP")
|
target_compile_definitions(${PROJECT_NAME} PUBLIC "PLATFORM_DESKTOP")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
target_include_directories(${PROJECT_NAME} PUBLIC
|
target_include_directories(${PROJECT_NAME} PUBLIC
|
||||||
"${CMAKE_SOURCE_DIR}/glad/include/"
|
"${CMAKE_SOURCE_DIR}/glad/include/"
|
||||||
"${CMAKE_SOURCE_DIR}/src"
|
"${CMAKE_SOURCE_DIR}/src"
|
||||||
@@ -287,9 +311,53 @@ target_include_directories(${PROJECT_NAME} PUBLIC
|
|||||||
"lib/include"
|
"lib/include"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if(EMSCRIPTEN)
|
||||||
|
set(CMAKE_CXX_STANDARD 11)
|
||||||
|
# uuuh i hate it
|
||||||
|
set(EM_FLAGS "-pthread -sUSE_PTHREADS=1 -sSHARED_MEMORY=1")
|
||||||
|
|
||||||
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${EM_FLAGS}")
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${EM_FLAGS}")
|
||||||
|
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} ${EM_FLAGS} --preload-file ${CMAKE_SOURCE_DIR}/data@/data -sPROXY_TO_PTHREAD")
|
||||||
|
|
||||||
|
target_compile_options(${PROJECT_NAME} PUBLIC
|
||||||
|
"-Os"
|
||||||
|
"-Wno-invalid-source-encoding"
|
||||||
|
"-Wno-narrowing"
|
||||||
|
"-Wno-deprecated-register"
|
||||||
|
"-Wno-reserved-user-defined-literal"
|
||||||
|
)
|
||||||
|
|
||||||
|
target_link_options(${PROJECT_NAME} PUBLIC
|
||||||
|
"-Os"
|
||||||
|
"-sALLOW_MEMORY_GROWTH=1"
|
||||||
|
"-sFORCE_FILESYSTEM=1"
|
||||||
|
"-sLEGACY_GL_EMULATION=1"
|
||||||
|
"-sGL_UNSAFE_OPTS=0"
|
||||||
|
"-sEMULATE_FUNCTION_POINTER_CASTS=1"
|
||||||
|
"-sALLOW_TABLE_GROWTH=1"
|
||||||
|
"-sEXPORTED_RUNTIME_METHODS=['FS','stringToUTF8','UTF8ToString','cwrap','ccall','HEAP8','HEAPU8','HEAP32','HEAPU32']"
|
||||||
|
"-sEXPORTED_FUNCTIONS=['_main']"
|
||||||
|
)
|
||||||
|
|
||||||
|
if (CMAKE_BUILD_TYPE STREQUAL "Debug")
|
||||||
|
message("DEBUG MODE")
|
||||||
|
|
||||||
|
target_link_options(${PROJECT_NAME} PUBLIC
|
||||||
|
"-sASSERTIONS=2"
|
||||||
|
"-sSTACK_OVERFLOW_CHECK=2"
|
||||||
|
"-sSTACK_SIZE=5242880"
|
||||||
|
"-sGL_DEBUG=1"
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
target_compile_definitions(${PROJECT_NAME} PUBLIC "__EMSCRIPTEN__" "NO_SOUND" "NO_NETWORK")
|
||||||
|
set(EXTRA_LIBS "idbfs.js")
|
||||||
|
endif()
|
||||||
|
|
||||||
# Client
|
# Client
|
||||||
target_compile_definitions(${PROJECT_NAME} PUBLIC "OPENGL_ES" "NO_EGL" ${PLATFORM})
|
target_compile_definitions(${PROJECT_NAME} PUBLIC "OPENGL_ES" "NO_EGL" ${PLATFORM})
|
||||||
target_link_libraries(${PROJECT_NAME} zlib png_shared alsoft.common OpenAL::OpenAL glfw ${EXTRA_LIBS})
|
target_link_libraries(${PROJECT_NAME} zlib ${PNG_LIB} alsoft.common OpenAL::OpenAL glfw ${EXTRA_LIBS})
|
||||||
|
|
||||||
if (OpenSSL_FOUND)
|
if (OpenSSL_FOUND)
|
||||||
target_link_libraries(${PROJECT_NAME} OpenSSL::SSL OpenSSL::Crypto)
|
target_link_libraries(${PROJECT_NAME} OpenSSL::SSL OpenSSL::Crypto)
|
||||||
@@ -297,72 +365,24 @@ if (OpenSSL_FOUND)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
if (NOT UNIX)
|
if (NOT UNIX)
|
||||||
add_custom_command(
|
add_custom_command(
|
||||||
TARGET ${PROJECT_NAME}
|
TARGET ${PROJECT_NAME}
|
||||||
POST_BUILD
|
POST_BUILD
|
||||||
COMMAND ${CMAKE_COMMAND} -E copy_if_different $<TARGET_RUNTIME_DLLS:${PROJECT_NAME}> $<TARGET_FILE_DIR:${PROJECT_NAME}>
|
COMMAND ${CMAKE_COMMAND} -E copy_if_different $<TARGET_RUNTIME_DLLS:${PROJECT_NAME}> $<TARGET_FILE_DIR:${PROJECT_NAME}>
|
||||||
COMMAND_EXPAND_LISTS
|
COMMAND_EXPAND_LISTS
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_custom_command(
|
if(NOT EMSCRIPTEN)
|
||||||
|
add_custom_command(
|
||||||
TARGET ${PROJECT_NAME}
|
TARGET ${PROJECT_NAME}
|
||||||
POST_BUILD
|
POST_BUILD
|
||||||
COMMAND ${CMAKE_COMMAND} -E copy_directory "${CMAKE_SOURCE_DIR}/data" $<TARGET_FILE_DIR:${PROJECT_NAME}>/data
|
COMMAND ${CMAKE_COMMAND} -E copy_directory "${CMAKE_SOURCE_DIR}/data" $<TARGET_FILE_DIR:${PROJECT_NAME}>/data
|
||||||
)
|
)
|
||||||
|
else()
|
||||||
# Installing and packing
|
add_custom_command(
|
||||||
|
TARGET ${PROJECT_NAME}
|
||||||
find_package(Git REQUIRED)
|
POST_BUILD
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E copy "${CMAKE_SOURCE_DIR}/misc/web/index.html" $<TARGET_FILE_DIR:${PROJECT_NAME}>
|
||||||
execute_process(
|
)
|
||||||
COMMAND ${GIT_EXECUTABLE} log -1 --format=%h
|
|
||||||
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
|
|
||||||
OUTPUT_VARIABLE GIT_SHORTSHA
|
|
||||||
OUTPUT_STRIP_TRAILING_WHITESPACE
|
|
||||||
)
|
|
||||||
string(TOLOWER ${CMAKE_SYSTEM_NAME} SYSTEM_NAME)
|
|
||||||
set(CPACK_PACKAGE_NAME "MCPE-0.6.1-for-all")
|
|
||||||
set(CPACK_PACKAGE_FILE_NAME ${CPACK_PACKAGE_NAME}-${SYSTEM_NAME})
|
|
||||||
set(CPACK_PACKAGE_VENDOR "MCPE-0.6.1-for-all")
|
|
||||||
set(CPACK_PACKAGE_VERSION "${PROJECT_VERSION}")
|
|
||||||
set(CPACK_PACKAGE_DIRECTORY "${CMAKE_BINARY_DIR}/package")
|
|
||||||
set(CMAKE_INSTALL_PREFIX "${CMAKE_BINARY_DIR}/install")
|
|
||||||
set(CPACK_GENERATOR "ZIP")
|
|
||||||
|
|
||||||
set(GIT_REPO "https://gitea.sffempire.ru/Kolyah35/minecraft-pe-0.6.1")
|
|
||||||
|
|
||||||
install(TARGETS ${PROJECT_NAME} RUNTIME DESTINATION .)
|
|
||||||
|
|
||||||
if(NOT UNIX)
|
|
||||||
install(FILES
|
|
||||||
$<TARGET_RUNTIME_DLLS:${PROJECT_NAME}>
|
|
||||||
DESTINATION .
|
|
||||||
)
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
install(DIRECTORY "${CMAKE_SOURCE_DIR}/data" DESTINATION .)
|
|
||||||
|
|
||||||
string(TIMESTAMP CURRENT_DATE "%Y-%m-%d")
|
|
||||||
string(TIMESTAMP CURRENT_TIME "%H:%M:%S")
|
|
||||||
|
|
||||||
set(VERSION_STR "${PROJECT_VERSION}")
|
|
||||||
|
|
||||||
if(CMAKE_BUILD_TYPE STREQUAL "Debug")
|
|
||||||
set(VERSION_STR "${VERSION_STR} - Development Build")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
file(WRITE "${CMAKE_BINARY_DIR}/version.txt"
|
|
||||||
"Minecraft PE 0.6.1
|
|
||||||
|
|
||||||
Autogenerated file by cmake-${CMAKE_VERSION}
|
|
||||||
Report issues ${GIT_REPO}/issues
|
|
||||||
|
|
||||||
Build date: ${CURRENT_DATE} ${CURRENT_TIME}
|
|
||||||
Build configuration: ${CMAKE_BUILD_TYPE}
|
|
||||||
Git commit: ${GIT_SHORTSHA}
|
|
||||||
Platform: ${CMAKE_SYSTEM_NAME}")
|
|
||||||
|
|
||||||
install(FILES "${CMAKE_BINARY_DIR}/version.txt" DESTINATION .)
|
|
||||||
|
|
||||||
include(CPack)
|
|
||||||
109
README.md
109
README.md
@@ -17,9 +17,9 @@ This project aims to preserve and improve this early version of Minecraft PE.
|
|||||||
- [ ] Screen fixes
|
- [ ] Screen fixes
|
||||||
- [ ] Rewrite platform logic
|
- [ ] Rewrite platform logic
|
||||||
- [x] Fix sound
|
- [x] Fix sound
|
||||||
- [ ] Do a server connection GUI
|
- [x] Do a server connection GUI
|
||||||
- [ ] Controller support
|
- [ ] Controller support
|
||||||
- [ ] Minecraft server hosting
|
- [x] Minecraft server hosting
|
||||||
- [x] Screen fixess
|
- [x] Screen fixess
|
||||||
- [x] Fix fog
|
- [x] Fix fog
|
||||||
- [x] Add sprinting
|
- [x] Add sprinting
|
||||||
@@ -70,7 +70,7 @@ cmake --build .
|
|||||||
4. Press **Run** (or F5) to build and launch the game.
|
4. Press **Run** (or F5) to build and launch the game.
|
||||||
|
|
||||||
## Android
|
## Android
|
||||||
|
### Windows
|
||||||
1. Download **Android NDK r14b**:
|
1. Download **Android NDK r14b**:
|
||||||
http://dl.google.com/android/repository/android-ndk-r14b-windows-x86_64.zip
|
http://dl.google.com/android/repository/android-ndk-r14b-windows-x86_64.zip
|
||||||
|
|
||||||
@@ -95,3 +95,106 @@ cmake --build .
|
|||||||
# Only repackage + install (no compilation)
|
# Only repackage + install (no compilation)
|
||||||
.\build.ps1 -NoBuild
|
.\build.ps1 -NoBuild
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### Linux
|
||||||
|
1. Download **Command line tools**:
|
||||||
|
https://developer.android.com/studio#command-line-tools-only
|
||||||
|
|
||||||
|
2. Unzip it into a folder, e.g.:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
mkdir -p "$HOME/Android/Sdk/"
|
||||||
|
unzip commandlinetools-linux-*.zip -d "$HOME/Android/Sdk/"
|
||||||
|
```
|
||||||
|
|
||||||
|
3. Your structure should look like
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$HOME/Android/Sdk/cmdline-tools/bin/sdkmanager
|
||||||
|
```
|
||||||
|
|
||||||
|
> [!NOTE]
|
||||||
|
> `sdkmanager` expects the SDK to include a `cmdline-tools/latest/` folder.
|
||||||
|
> If you only have `cmdline-tools/bin`, create the required layout:
|
||||||
|
>
|
||||||
|
> ```bash
|
||||||
|
> mkdir -p "$HOME/Android/Sdk/cmdline-tools/latest"
|
||||||
|
> ln -snf ../bin "$HOME/Android/Sdk/cmdline-tools/latest/bin"
|
||||||
|
> ln -snf ../lib "$HOME/Android/Sdk/cmdline-tools/latest/lib"
|
||||||
|
> ln -snf ../source.properties "$HOME/Android/Sdk/cmdline-tools/latest/source.properties"
|
||||||
|
> ln -snf ../NOTICE.txt "$HOME/Android/Sdk/cmdline-tools/latest/NOTICE.txt"
|
||||||
|
> ```
|
||||||
|
|
||||||
|
4. Install the build tools (and platform) using `sdkmanager`
|
||||||
|
|
||||||
|
```bash
|
||||||
|
export ANDROID_SDK_ROOT="$HOME/Android/Sdk"
|
||||||
|
export PATH="$ANDROID_SDK_ROOT/cmdline-tools/latest/bin:$PATH"
|
||||||
|
|
||||||
|
sdkmanager --install "platform-tools" "platforms;android-35" "build-tools;35.0.0"
|
||||||
|
```
|
||||||
|
|
||||||
|
> [!NOTE]
|
||||||
|
> if you want build.sh to always find the SDK,
|
||||||
|
> Set ANDROID_SDK_ROOT in your shell config (~/.bashrc / ~/.profile / ~/.config/fish/config.fish), for example:
|
||||||
|
>
|
||||||
|
> ```bash
|
||||||
|
> export ANDROID_SDK_ROOT="$HOME/Android/Sdk"
|
||||||
|
> ```
|
||||||
|
>
|
||||||
|
> Then restart your shell (or `source` the file)
|
||||||
|
|
||||||
|
5. Verify the install
|
||||||
|
|
||||||
|
```bash
|
||||||
|
ls "$ANDROID_SDK_ROOT/build-tools"
|
||||||
|
```
|
||||||
|
|
||||||
|
You should see a version folder like:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
35.0.0
|
||||||
|
33.0.2
|
||||||
|
```
|
||||||
|
|
||||||
|
6. Download **Android NDK r14b**:
|
||||||
|
https://dl.google.com/android/repository/android-ndk-r14b-linux-x86_64.zip
|
||||||
|
|
||||||
|
7. Extract the archive to `/home/username/`, so that the final directory path is `/home/username/android-ndk-r14b/`
|
||||||
|
|
||||||
|
> [!WARNING]
|
||||||
|
> Make sure you don’t end up with a nested folder like `/home/username/android-ndk-r14b/android-ndk-r14b/`.
|
||||||
|
|
||||||
|
8. Re run `build.sh`
|
||||||
|
|
||||||
|
## Web
|
||||||
|
1. Download and install **emsdk**: https://emscripten.org/docs/getting_started/downloads.html
|
||||||
|
> [!NOTE]
|
||||||
|
> On arch linux you can use AUR:
|
||||||
|
> `yay -Sy emsdk`
|
||||||
|
|
||||||
|
2. Configure and build project:
|
||||||
|
```
|
||||||
|
mkdir build && cd build
|
||||||
|
cmake .. -B . -G Ninja "-DCMAKE_TOOLCHAIN_FILE=$EMSDK/upstream/emscripten/cmake/Modules/Platform/Emscripten.cmake"
|
||||||
|
cmake --build . --target MinecraftPE
|
||||||
|
```
|
||||||
|
> [!NOTE]
|
||||||
|
> If you are using VSCode with CMake plugin, you can add Emscripten kit
|
||||||
|
> 1. Press Ctrl + Shift + P
|
||||||
|
> 2. Type `CMake: Edit User-Local CMake Kits` and hit Enter
|
||||||
|
> 3. Add this:
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"name": "Emscripten",
|
||||||
|
"compilers": {
|
||||||
|
"C": "/usr/lib/emsdk/upstream/bin/clang",
|
||||||
|
"CXX": "/usr/lib/emsdk/upstream/bin/clang++"
|
||||||
|
},
|
||||||
|
"toolchainFile": "/usr/lib/emsdk/upstream/emscripten/cmake/Modules/Platform/Emscripten.cmake"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
3. Run game:
|
||||||
|
```
|
||||||
|
emrun --port 8080 .
|
||||||
|
```
|
||||||
44
build.ps1
44
build.ps1
@@ -1,18 +1,16 @@
|
|||||||
# ============================================================
|
# ============================================================
|
||||||
# MCPE 0.6.1 Android Build Script — from-scratch capable
|
|
||||||
# Works on a clean machine; creates all dirs, keystore and
|
|
||||||
# stub Java files automatically.
|
|
||||||
#
|
|
||||||
# Usage:
|
# Usage:
|
||||||
# .\build.ps1 # full build (NDK + Java + APK + install)
|
# .\build.ps1 # full build (NDK + Java + APK + install)
|
||||||
# .\build.ps1 -NoCpp # skip NDK rebuild (Java/assets changed)
|
# .\build.ps1 -NoCpp # skip NDK rebuild (Java/assets changed)
|
||||||
# .\build.ps1 -NoJava # skip Java recompile (C++ changed only)
|
# .\build.ps1 -NoJava # skip Java recompile (C++ changed only)
|
||||||
# .\build.ps1 -NoBuild # repackage + install only (no recompile)
|
# .\build.ps1 -NoBuild # repackage + install only (no recompile)
|
||||||
|
# .\build.ps1 -Clean # remove build output before building
|
||||||
# ============================================================
|
# ============================================================
|
||||||
param(
|
param(
|
||||||
[switch]$NoCpp,
|
[switch]$NoCpp,
|
||||||
[switch]$NoJava,
|
[switch]$NoJava,
|
||||||
[switch]$NoBuild
|
[switch]$NoBuild,
|
||||||
|
[switch]$Clean
|
||||||
)
|
)
|
||||||
|
|
||||||
Set-StrictMode -Version Latest
|
Set-StrictMode -Version Latest
|
||||||
@@ -66,7 +64,13 @@ function Write-Stub([string]$rel, [string]$content) {
|
|||||||
if (-not (Test-Path $full)) { [System.IO.File]::WriteAllText($full, $content); Write-Host " stub: $rel" }
|
if (-not (Test-Path $full)) { [System.IO.File]::WriteAllText($full, $content); Write-Host " stub: $rel" }
|
||||||
}
|
}
|
||||||
|
|
||||||
# ── 0. Bootstrap ─────────────────────────────────────────────
|
# ── 0. Clean (optional) ───────────────────────────────────────
|
||||||
|
if ($Clean) {
|
||||||
|
Write-Step "Cleaning build output"
|
||||||
|
Remove-Item -Recurse -Force $apkbuild -ErrorAction SilentlyContinue
|
||||||
|
}
|
||||||
|
|
||||||
|
# ── 1. Bootstrap ─────────────────────────────────────────────
|
||||||
Write-Step "Bootstrap"
|
Write-Step "Bootstrap"
|
||||||
|
|
||||||
New-Dir $apkbuild
|
New-Dir $apkbuild
|
||||||
@@ -227,16 +231,16 @@ if (-not $NoCpp -and -not $NoBuild) {
|
|||||||
}
|
}
|
||||||
Push-Location "$junctionBase/project/android/jni"
|
Push-Location "$junctionBase/project/android/jni"
|
||||||
$env:NDK_MODULE_PATH = "$junctionBase/project/lib_projects"
|
$env:NDK_MODULE_PATH = "$junctionBase/project/lib_projects"
|
||||||
# run ndk-build and capture everything; let user see full output for debugging
|
# run ndk-build and stream output directly to the console
|
||||||
$ndkOutput = & "$ndk\ndk-build.cmd" NDK_PROJECT_PATH="$junctionBase/project/android" APP_BUILD_SCRIPT="$junctionBase/project/android/jni/Android.mk" 2>&1 | Tee-Object -Variable ndkOutput
|
$ndkCmd = Join-Path $ndk 'ndk-build.cmd'
|
||||||
# dump entire output for diagnosis
|
$ndkArgs = "NDK_PROJECT_PATH=`"$junctionBase/project/android`" APP_BUILD_SCRIPT=`"$junctionBase/project/android/jni/Android.mk`""
|
||||||
Write-Host "---- NDK BUILD OUTPUT BEGIN ----"
|
|
||||||
$ndkOutput | ForEach-Object { Write-Host $_ }
|
$proc = Start-Process -FilePath $ndkCmd -ArgumentList $ndkArgs -NoNewWindow -Wait -PassThru
|
||||||
Write-Host "---- NDK BUILD OUTPUT END ----"
|
|
||||||
# optionally highlight errors/warnings afterwards
|
|
||||||
$ndkOutput | Where-Object { $_ -match "error:|warning:|libminecraftpe|In file included" }
|
|
||||||
Pop-Location
|
Pop-Location
|
||||||
Assert-ExitCode "ndk-build"
|
if ($proc.ExitCode -ne 0) {
|
||||||
|
Write-Host "ndk-build failed (exit $($proc.ExitCode))" -ForegroundColor Red
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
Copy-Item $libSrc $libDst -Force
|
Copy-Item $libSrc $libDst -Force
|
||||||
Write-Host " .so -> $libDst"
|
Write-Host " .so -> $libDst"
|
||||||
}
|
}
|
||||||
@@ -246,7 +250,7 @@ if (-not $NoJava -and -not $NoBuild) {
|
|||||||
Write-Step "Java compile"
|
Write-Step "Java compile"
|
||||||
|
|
||||||
New-Dir (Split-Path $rJava -Parent)
|
New-Dir (Split-Path $rJava -Parent)
|
||||||
& "$sdkTools\aapt.exe" package -f -M $manifest -S $res -I $androidJar -J "$apkbuild\gen" -F "$apkbuild\_rgen.apk" 2>&1 | Out-Null
|
& "$sdkTools\aapt.exe" package -f -M $manifest -S $res -I $androidJar -J "$apkbuild\gen" -F "$apkbuild\_rgen.apk"
|
||||||
Assert-ExitCode "aapt R.java"
|
Assert-ExitCode "aapt R.java"
|
||||||
Remove-Item "$apkbuild\_rgen.apk" -ea SilentlyContinue
|
Remove-Item "$apkbuild\_rgen.apk" -ea SilentlyContinue
|
||||||
|
|
||||||
@@ -258,11 +262,9 @@ if (-not $NoJava -and -not $NoBuild) {
|
|||||||
|
|
||||||
Remove-Item $classesDir -Recurse -Force -ea SilentlyContinue
|
Remove-Item $classesDir -Recurse -Force -ea SilentlyContinue
|
||||||
New-Dir $classesDir
|
New-Dir $classesDir
|
||||||
$eap = $ErrorActionPreference; $ErrorActionPreference = "Continue"
|
|
||||||
$errors = & javac --release 8 -cp $androidJar -d $classesDir @srcs 2>&1 |
|
& javac --release 8 -cp $androidJar -d $classesDir @srcs
|
||||||
Where-Object { $_ -match "error:" }
|
if ($LASTEXITCODE -ne 0) { Write-Host 'javac failed' -ForegroundColor Red; exit 1 }
|
||||||
$ErrorActionPreference = $eap
|
|
||||||
if ($errors) { Write-Host $errors -ForegroundColor Red; exit 1 }
|
|
||||||
Write-Host " javac OK"
|
Write-Host " javac OK"
|
||||||
|
|
||||||
$classFiles = Get-ChildItem $classesDir -Recurse -Filter "*.class" | Select-Object -Exp FullName
|
$classFiles = Get-ChildItem $classesDir -Recurse -Filter "*.class" | Select-Object -Exp FullName
|
||||||
|
|||||||
383
build.sh
Executable file
383
build.sh
Executable file
@@ -0,0 +1,383 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# ============================================================
|
||||||
|
# Usage:
|
||||||
|
# ./build.sh # full build (NDK + Java + APK + install)
|
||||||
|
# ./build.sh --no-cpp # skip NDK rebuild (Java/assets changed)
|
||||||
|
# ./build.sh --no-java # skip Java recompile (C++ changed only)
|
||||||
|
# ./build.sh --no-build # repackage + install only (no recompile)
|
||||||
|
# ============================================================
|
||||||
|
|
||||||
|
# lets be strict cuz we are safe like that
|
||||||
|
# *thanos snap*
|
||||||
|
set -euo pipefail
|
||||||
|
IFS=$'\n\t'
|
||||||
|
|
||||||
|
########################################
|
||||||
|
# configuration
|
||||||
|
########################################
|
||||||
|
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||||
|
REPO_ROOT="$SCRIPT_DIR"
|
||||||
|
|
||||||
|
# build output directory (similar to apkbuild in the PS script)
|
||||||
|
# maybe doing this in build.ps1 would be cleaner, than putting the apkbuild in C:
|
||||||
|
BUILD_DIR="$REPO_ROOT/build-apk"
|
||||||
|
|
||||||
|
# default Android/NDK/SDK paths (can be overridden by env vars)
|
||||||
|
ANDROID_NDK_PATH="${ANDROID_NDK_PATH:-$HOME/android-ndk-r14b}"
|
||||||
|
ANDROID_SDK_ROOT="${ANDROID_SDK_ROOT:-${ANDROID_HOME:-$HOME/Android/Sdk}}"
|
||||||
|
ANDROID_BUILD_TOOLS_VERSION="${ANDROID_BUILD_TOOLS_VERSION:-}"
|
||||||
|
ANDROID_PLATFORM_API="${ANDROID_PLATFORM_API:-}"
|
||||||
|
|
||||||
|
function fail() {
|
||||||
|
echo "ERROR: $1" >&2
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
function find_build_tools_dir() {
|
||||||
|
if [[ -n "$ANDROID_BUILD_TOOLS_VERSION" ]]; then
|
||||||
|
local candidate="$ANDROID_SDK_ROOT/build-tools/$ANDROID_BUILD_TOOLS_VERSION"
|
||||||
|
[[ -d "$candidate" ]] && echo "$candidate" && return
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ ! -d "$ANDROID_SDK_ROOT/build-tools" ]]; then
|
||||||
|
fail "Android build-tools not found under $ANDROID_SDK_ROOT/build-tools. Set ANDROID_SDK_ROOT or install Android SDK build-tools."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# picking the highest build tools version because its the easiest way rn
|
||||||
|
# i guess if it breaks then fuck you
|
||||||
|
local best
|
||||||
|
best=$(ls -1 "$ANDROID_SDK_ROOT/build-tools" | sort -V | tail -n 1)
|
||||||
|
[[ -n "$best" && -d "$ANDROID_SDK_ROOT/build-tools/$best" ]] || \
|
||||||
|
fail "No Android build-tools versions found under $ANDROID_SDK_ROOT/build-tools."
|
||||||
|
echo "$ANDROID_SDK_ROOT/build-tools/$best"
|
||||||
|
}
|
||||||
|
|
||||||
|
function find_android_platform_dir() {
|
||||||
|
if [[ -n "$ANDROID_PLATFORM_API" ]]; then
|
||||||
|
local candidate="$ANDROID_SDK_ROOT/platforms/android-$ANDROID_PLATFORM_API"
|
||||||
|
[[ -d "$candidate" ]] && echo "$candidate" && return
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ ! -d "$ANDROID_SDK_ROOT/platforms" ]]; then
|
||||||
|
fail "Android platforms not found under $ANDROID_SDK_ROOT/platforms. Install an Android platform."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# pick the highest api level installed for now
|
||||||
|
# ideally we should be able to build to any api level, but lets keep it simple for now and
|
||||||
|
# just pick the highest one available
|
||||||
|
local best
|
||||||
|
best=$(ls -1 "$ANDROID_SDK_ROOT/platforms" | grep -E '^android-[0-9]+' | sed 's/android-//' | sort -n | tail -n 1)
|
||||||
|
[[ -n "$best" ]] || fail "No Android platforms found under $ANDROID_SDK_ROOT/platforms."
|
||||||
|
echo "$ANDROID_SDK_ROOT/platforms/android-$best"
|
||||||
|
}
|
||||||
|
|
||||||
|
ANDROID_BUILD_TOOLS_DIR="$(find_build_tools_dir)"
|
||||||
|
ANDROID_PLATFORM_DIR="$(find_android_platform_dir)"
|
||||||
|
|
||||||
|
KEYSTORE_FILE="$BUILD_DIR/debug.keystore"
|
||||||
|
PACKAGE_NAME="com.mojang.minecraftpe"
|
||||||
|
|
||||||
|
# android tool binaries
|
||||||
|
AAPT="$ANDROID_BUILD_TOOLS_DIR/aapt"
|
||||||
|
ZIPALIGN="$ANDROID_BUILD_TOOLS_DIR/zipalign"
|
||||||
|
APKSIGNER="$ANDROID_BUILD_TOOLS_DIR/apksigner"
|
||||||
|
DEX_TOOL="$ANDROID_BUILD_TOOLS_DIR/d8"
|
||||||
|
ADB="${ADB:-$ANDROID_SDK_ROOT/platform-tools/adb}"
|
||||||
|
|
||||||
|
# java tool binaries
|
||||||
|
JAVA_HOME_DEFAULT="${JAVA_HOME:-}" # may be empty
|
||||||
|
|
||||||
|
# prefer javac from the jdk;
|
||||||
|
# on some systems /usr/lib/jvm/default points to a JRE only.
|
||||||
|
# If javac is missing, try to locate a JDK installation.
|
||||||
|
JAVAC_CMD=""
|
||||||
|
if command -v javac >/dev/null 2>&1; then
|
||||||
|
JAVAC_CMD="$(command -v javac)"
|
||||||
|
elif [[ -n "$JAVA_HOME_DEFAULT" && -x "$JAVA_HOME_DEFAULT/bin/javac" ]]; then
|
||||||
|
JAVAC_CMD="$JAVA_HOME_DEFAULT/bin/javac"
|
||||||
|
elif [[ -x "/usr/lib/jvm/java-8-openjdk/bin/javac" ]]; then
|
||||||
|
JAVAC_CMD="/usr/lib/jvm/java-8-openjdk/bin/javac"
|
||||||
|
elif [[ -x "/usr/lib/jvm/default/bin/javac" ]]; then
|
||||||
|
JAVAC_CMD="/usr/lib/jvm/default/bin/javac"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -z "$JAVAC_CMD" ]]; then
|
||||||
|
fail "javac not found; install a JDK and ensure javac is on PATH"
|
||||||
|
fi
|
||||||
|
|
||||||
|
KEYTOOL="" # will be detected later
|
||||||
|
|
||||||
|
# swource directories
|
||||||
|
JNI_DIR="$REPO_ROOT/project/android/jni"
|
||||||
|
JAVA_SRC_DIR="$REPO_ROOT/project/android_java/src"
|
||||||
|
ANDROID_MANIFEST="$REPO_ROOT/project/android_java/AndroidManifest.xml"
|
||||||
|
ANDROID_RES_DIR="$REPO_ROOT/project/android_java/res"
|
||||||
|
DATA_DIR="$REPO_ROOT/data"
|
||||||
|
|
||||||
|
# output files
|
||||||
|
APK_UNSIGNED="$BUILD_DIR/minecraftpe-unsigned.apk"
|
||||||
|
APK_ALIGNED="$BUILD_DIR/minecraftpe-aligned.apk"
|
||||||
|
APK_SIGNED="$BUILD_DIR/minecraftpe-debug.apk"
|
||||||
|
DEX_OUTPUT="$BUILD_DIR/classes.dex"
|
||||||
|
|
||||||
|
# flags parsed from CLI args
|
||||||
|
NO_CPP=false
|
||||||
|
NO_JAVA=false
|
||||||
|
NO_BUILD=false
|
||||||
|
|
||||||
|
########################################
|
||||||
|
# helpers
|
||||||
|
########################################
|
||||||
|
function usage() {
|
||||||
|
cat <<EOF
|
||||||
|
Usage: $0 [--no-cpp] [--no-java] [--no-build]
|
||||||
|
|
||||||
|
Options:
|
||||||
|
--no-cpp Skip the NDK (C++) build step
|
||||||
|
--no-java Skip the Java build step
|
||||||
|
--no-build Skip the compile steps; just package + install
|
||||||
|
EOF
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
function log_step() {
|
||||||
|
echo -e "\n==> $1"
|
||||||
|
}
|
||||||
|
|
||||||
|
function fail() {
|
||||||
|
echo "ERROR: $1" >&2
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
function require_cmd() {
|
||||||
|
if ! command -v "$1" >/dev/null 2>&1; then
|
||||||
|
fail "$1 not found; install it (e.g. 'sudo pacman -S $1')"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# ensure required tools are available early
|
||||||
|
require_cmd zip
|
||||||
|
require_cmd unzip
|
||||||
|
|
||||||
|
function ensure_dir() {
|
||||||
|
mkdir -p "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
function find_keytool() {
|
||||||
|
# first try JAVA_HOME if set
|
||||||
|
if [[ -n "$JAVA_HOME_DEFAULT" && -x "$JAVA_HOME_DEFAULT/bin/keytool" ]]; then
|
||||||
|
echo "$JAVA_HOME_DEFAULT/bin/keytool"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
# try common install locations
|
||||||
|
if [[ -n "${JAVA_HOME:-}" && -x "${JAVA_HOME}/bin/keytool" ]]; then
|
||||||
|
echo "${JAVA_HOME}/bin/keytool"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
if command -v keytool >/dev/null 2>&1; then
|
||||||
|
command -v keytool
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
fail "keytool not found. Set JAVA_HOME or install a JDK."
|
||||||
|
}
|
||||||
|
|
||||||
|
function write_stub_file() {
|
||||||
|
local rel_path="$1"
|
||||||
|
local content="$2"
|
||||||
|
local full_path="$BUILD_DIR/stubs/$rel_path"
|
||||||
|
|
||||||
|
ensure_dir "$(dirname "$full_path")"
|
||||||
|
if [[ ! -f "$full_path" ]]; then
|
||||||
|
echo -e "$content" > "$full_path"
|
||||||
|
echo " stub: $rel_path"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
########################################
|
||||||
|
# argument parsing
|
||||||
|
########################################
|
||||||
|
while [[ $# -gt 0 ]]; do
|
||||||
|
case "$1" in
|
||||||
|
--no-cpp) NO_CPP=true ;;
|
||||||
|
--no-java) NO_JAVA=true ;;
|
||||||
|
--no-build) NO_BUILD=true ;;
|
||||||
|
-h|--help) usage ;;
|
||||||
|
*)
|
||||||
|
echo "Unknown option: $1" >&2
|
||||||
|
usage
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
|
||||||
|
########################################
|
||||||
|
# validate required tools
|
||||||
|
########################################
|
||||||
|
KEYTOOL="$(find_keytool)"
|
||||||
|
|
||||||
|
if [[ ! -x "$AAPT" ]]; then
|
||||||
|
fail "aapt not found at $AAPT"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ ! -x "$ZIPALIGN" ]]; then
|
||||||
|
fail "zipalign not found at $ZIPALIGN"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ ! -x "$APKSIGNER" ]]; then
|
||||||
|
fail "apksigner not found at $APKSIGNER"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ ! -x "$DEX_TOOL" ]]; then
|
||||||
|
fail "d8 not found at $DEX_TOOL"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ ! -x "$ADB" ]]; then
|
||||||
|
fail "adb not found at $ADB"
|
||||||
|
fi
|
||||||
|
|
||||||
|
########################################
|
||||||
|
# bootstrap
|
||||||
|
########################################
|
||||||
|
log_step "Bootstrap"
|
||||||
|
|
||||||
|
ensure_dir "$BUILD_DIR"
|
||||||
|
ensure_dir "$BUILD_DIR/lib/arm64-v8a"
|
||||||
|
ensure_dir "$BUILD_DIR/gen"
|
||||||
|
ensure_dir "$BUILD_DIR/stubs"
|
||||||
|
|
||||||
|
# create a debug keystore if it doesn't exist
|
||||||
|
if [[ ! -f "$KEYSTORE_FILE" ]]; then
|
||||||
|
echo " generating debug.keystore..."
|
||||||
|
"$KEYTOOL" -genkeypair \
|
||||||
|
-keystore "$KEYSTORE_FILE" -storepass android -keypass android \
|
||||||
|
-alias androiddebugkey -keyalg RSA -keysize 2048 -validity 10000 \
|
||||||
|
-dname "CN=Android Debug,O=Android,C=US" >/dev/null 2>&1
|
||||||
|
echo " keystore created"
|
||||||
|
else
|
||||||
|
echo " keystore OK"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# why dont we just include the stubs lol
|
||||||
|
write_stub_file "com/mojang/android/StringValue.java" "package com.mojang.android;\npublic interface StringValue { String getStringValue(); }\n"
|
||||||
|
|
||||||
|
write_stub_file "com/mojang/android/licensing/LicenseCodes.java" "package com.mojang.android.licensing;\npublic class LicenseCodes { public static final int LICENSE_OK = 0; }\n"
|
||||||
|
|
||||||
|
write_stub_file "com/mojang/android/EditTextAscii.java" "package com.mojang.android;\nimport android.content.Context;\nimport android.text.Editable;\nimport android.text.TextWatcher;\nimport android.util.AttributeSet;\nimport android.widget.EditText;\npublic class EditTextAscii extends EditText implements TextWatcher {\n public EditTextAscii(Context c) { super(c); addTextChangedListener(this); }\n public EditTextAscii(Context c, AttributeSet a) { super(c,a); addTextChangedListener(this); }\n public EditTextAscii(Context c, AttributeSet a, int d) { super(c,a,d); addTextChangedListener(this); }\n @Override public void onTextChanged(CharSequence s,int st,int b,int co){}\n public void beforeTextChanged(CharSequence s,int st,int co,int aft){}\n public void afterTextChanged(Editable e){\n String s=e.toString(),san=sanitize(s);\n if(!s.equals(san))e.replace(0,e.length(),san);\n }\n static public String sanitize(String s){\n StringBuilder sb=new StringBuilder();\n for(int i=0;i<s.length();i++){char c=s.charAt(i);if(c<128)sb.append(c);}\n return sb.toString();\n }\n}\n"
|
||||||
|
|
||||||
|
write_stub_file "com/mojang/android/preferences/SliderPreference.java" "package com.mojang.android.preferences;\nimport android.content.Context;\nimport android.content.res.Resources;\nimport android.preference.DialogPreference;\nimport android.util.AttributeSet;\nimport android.view.Gravity;\nimport android.view.View;\nimport android.widget.LinearLayout;\nimport android.widget.SeekBar;\nimport android.widget.TextView;\npublic class SliderPreference extends DialogPreference implements SeekBar.OnSeekBarChangeListener {\n private static final String NS=\"http://schemas.android.com/apk/res/android\";\n private Context _ctx; private TextView _tv; private SeekBar _sb;\n private String _suf; private int _def,_max,_val,_min;\n public SliderPreference(Context ctx,AttributeSet a){\n super(ctx,a); _ctx=ctx;\n _suf=gStr(a,NS,\"text\",\"\"); _def=gInt(a,NS,\"defaultValue\",0);\n _max=gInt(a,NS,\"max\",100); _min=gInt(a,null,\"min\",0);\n setDefaultValue(_def);\n }\n @Override protected View onCreateDialogView(){\n LinearLayout l=new LinearLayout(_ctx); l.setOrientation(LinearLayout.VERTICAL); l.setPadding(6,6,6,6);\n _tv=new TextView(_ctx); _tv.setGravity(Gravity.CENTER_HORIZONTAL); _tv.setTextSize(32);\n l.addView(_tv,new LinearLayout.LayoutParams(-1,-2));\n _sb=new SeekBar(_ctx); _sb.setOnSeekBarChangeListener(this);\n l.addView(_sb,new LinearLayout.LayoutParams(-1,-2));\n if(shouldPersist())_val=getPersistedInt(_def);\n _sb.setMax(_max); _sb.setProgress(_val); return l;\n }\n @Override protected void onSetInitialValue(boolean r,Object d){\n super.onSetInitialValue(r,d);\n _val=r?(shouldPersist()?getPersistedInt(_def):0):(Integer)d;\n }\n public void onProgressChanged(SeekBar s,int v,boolean f){\n _val=v+_min; _tv.setText(_val+_suf);\n if(shouldPersist())persistInt(_val); callChangeListener(Integer.valueOf(_val));\n }\n public void onStartTrackingTouch(SeekBar s){}\n public void onStopTrackingTouch(SeekBar s){}\n private int gInt(AttributeSet a,String ns,String n,int d){int id=a.getAttributeResourceValue(ns,n,0);return id!=0?getContext().getResources().getInteger(id):a.getAttributeIntValue(ns,n,d);}\n private String gStr(AttributeSet a,String ns,String n,String d){int id=a.getAttributeResourceValue(ns,n,0);if(id!=0)return getContext().getResources().getString(id);String v=a.getAttributeValue(ns,n);return v!=null?v:d;}\n}\n"
|
||||||
|
|
||||||
|
write_stub_file "com/mojang/minecraftpe/MainMenuOptionsActivity.java" "package com.mojang.minecraftpe;\nimport android.app.Activity;\npublic class MainMenuOptionsActivity extends Activity {\n public static final String Internal_Game_DifficultyPeaceful=\"internal_game_difficulty_peaceful\";\n public static final String Game_DifficultyLevel=\"game_difficulty\";\n public static final String Controls_Sensitivity=\"controls_sensitivity\";\n}\n"
|
||||||
|
|
||||||
|
write_stub_file "com/mojang/minecraftpe/Minecraft_Market.java" "package com.mojang.minecraftpe;\nimport android.app.Activity; import android.content.Intent; import android.os.Bundle;\npublic class Minecraft_Market extends Activity {\n @Override protected void onCreate(Bundle s){super.onCreate(s);startActivity(new Intent(this,MainActivity.class));finish();}\n}\n"
|
||||||
|
|
||||||
|
write_stub_file "com/mojang/minecraftpe/Minecraft_Market_Demo.java" "package com.mojang.minecraftpe;\nimport android.content.Intent; import android.net.Uri;\npublic class Minecraft_Market_Demo extends MainActivity {\n @Override public void buyGame(){startActivity(new Intent(Intent.ACTION_VIEW,Uri.parse(\"market://details?id=com.mojang.minecraftpe\")));}\n @Override protected boolean isDemo(){return true;}\n}\n"
|
||||||
|
|
||||||
|
write_stub_file "com/mojang/minecraftpe/GameModeButton.java" "package com.mojang.minecraftpe;\nimport com.mojang.android.StringValue;\nimport android.content.Context; import android.util.AttributeSet;\nimport android.view.View; import android.view.View.OnClickListener;\nimport android.widget.TextView; import android.widget.ToggleButton;\npublic class GameModeButton extends ToggleButton implements OnClickListener,StringValue {\n static final int Creative=0,Survival=1;\n private int _type=0; private boolean _attached=false;\n public GameModeButton(Context c,AttributeSet a){super(c,a);setOnClickListener(this);}\n public void onClick(View v){_update();}\n @Override protected void onFinishInflate(){super.onFinishInflate();_update();}\n @Override protected void onAttachedToWindow(){if(!_attached){_update();_attached=true;}}\n private void _update(){_set(isChecked()?Survival:Creative);}\n private void _set(int i){\n _type=i<Creative?Creative:(i>Survival?Survival:i);\n int id=_type==Survival?R.string.gamemode_survival_summary:R.string.gamemode_creative_summary;\n String desc=getContext().getString(id);\n View v=getRootView().findViewById(R.id.labelGameModeDesc);\n if(desc!=null&&v instanceof TextView)((TextView)v).setText(desc);\n }\n public String getStringValue(){return new String[]{\"creative\",\"survival\"}[_type];}\n static public String getStringForType(int i){int c=i<Creative?Creative:(i>Survival?Survival:i);return new String[]{\"creative\",\"survival\"}[c];}\n}\n"
|
||||||
|
|
||||||
|
echo " stubs OK"
|
||||||
|
|
||||||
|
########################################
|
||||||
|
# ndk build
|
||||||
|
########################################
|
||||||
|
if [[ "$NO_CPP" == false && "$NO_BUILD" == false ]]; then
|
||||||
|
log_step "NDK build (arm64-v8a)"
|
||||||
|
|
||||||
|
# the original windows build script used a junction to avoid long paths here
|
||||||
|
# on linux, path lengths are *usually* fine, but we still keep things simple
|
||||||
|
pushd "$JNI_DIR" >/dev/null
|
||||||
|
|
||||||
|
export NDK_MODULE_PATH="$REPO_ROOT/project/lib_projects"
|
||||||
|
|
||||||
|
# run ndk-build and show output in case of failure
|
||||||
|
if ! "$ANDROID_NDK_PATH/ndk-build" NDK_PROJECT_PATH="$REPO_ROOT/project/android" APP_BUILD_SCRIPT="$JNI_DIR/Android.mk" 2>&1 | tee "$BUILD_DIR/ndk-build.log"; then
|
||||||
|
echo "NDK build failed. See $BUILD_DIR/ndk-build.log" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
popd >/dev/null
|
||||||
|
|
||||||
|
# copy the compiled library to the APK staging folder
|
||||||
|
cp -v "$REPO_ROOT/project/android/libs/arm64-v8a/libminecraftpe.so" "$BUILD_DIR/lib/arm64-v8a/"
|
||||||
|
|
||||||
|
echo " .so -> $BUILD_DIR/lib/arm64-v8a/libminecraftpe.so"
|
||||||
|
fi
|
||||||
|
|
||||||
|
########################################
|
||||||
|
# java compile
|
||||||
|
########################################
|
||||||
|
if [[ "$NO_JAVA" == false && "$NO_BUILD" == false ]]; then
|
||||||
|
log_step "Java compile"
|
||||||
|
|
||||||
|
ensure_dir "$(dirname "$BUILD_DIR/gen/R.java")"
|
||||||
|
|
||||||
|
# generate R.java
|
||||||
|
"$AAPT" package -f -M "$ANDROID_MANIFEST" -S "$ANDROID_RES_DIR" -I "$ANDROID_PLATFORM_DIR/android.jar" -J "$BUILD_DIR/gen" -F "$BUILD_DIR/_rgen.apk"
|
||||||
|
rm -f "$BUILD_DIR/_rgen.apk"
|
||||||
|
|
||||||
|
# collect all source files (project + stubs + generated R.java)
|
||||||
|
JAVA_SOURCES=(
|
||||||
|
$(find "$JAVA_SRC_DIR" -name "*.java" -print)
|
||||||
|
$(find "$BUILD_DIR/stubs" -name "*.java" -print)
|
||||||
|
"$BUILD_DIR/gen/R.java"
|
||||||
|
)
|
||||||
|
|
||||||
|
rm -rf "$BUILD_DIR/classes"
|
||||||
|
ensure_dir "$BUILD_DIR/classes"
|
||||||
|
|
||||||
|
# Some JDK versions (<=8) don’t support --release.
|
||||||
|
JAVAC_ARGS=(--release 8)
|
||||||
|
if "$JAVAC_CMD" -version 2>&1 | grep -qE '^javac 1\.'; then
|
||||||
|
JAVAC_ARGS=(-source 1.8 -target 1.8)
|
||||||
|
fi
|
||||||
|
|
||||||
|
"$JAVAC_CMD" "${JAVAC_ARGS[@]}" -cp "$ANDROID_PLATFORM_DIR/android.jar" -d "$BUILD_DIR/classes" "${JAVA_SOURCES[@]}"
|
||||||
|
echo " javac OK"
|
||||||
|
|
||||||
|
# convert class files into dex
|
||||||
|
JAVA_CLASS_FILES=( $(find "$BUILD_DIR/classes" -name "*.class" -print) )
|
||||||
|
"$DEX_TOOL" --min-api 21 --output "$BUILD_DIR" "${JAVA_CLASS_FILES[@]}"
|
||||||
|
echo " d8 -> $DEX_OUTPUT"
|
||||||
|
fi
|
||||||
|
|
||||||
|
########################################
|
||||||
|
# package apk
|
||||||
|
########################################
|
||||||
|
log_step "Package APK"
|
||||||
|
|
||||||
|
rm -f "$APK_UNSIGNED" "$APK_ALIGNED" "$APK_SIGNED"
|
||||||
|
|
||||||
|
"$AAPT" package -f -M "$ANDROID_MANIFEST" -S "$ANDROID_RES_DIR" -I "$ANDROID_PLATFORM_DIR/android.jar" -F "$APK_UNSIGNED"
|
||||||
|
|
||||||
|
# add classes.dex and native library into apk
|
||||||
|
pushd "$BUILD_DIR" >/dev/null
|
||||||
|
zip -q "$APK_UNSIGNED" "classes.dex"
|
||||||
|
zip -q "$APK_UNSIGNED" "lib/arm64-v8a/libminecraftpe.so"
|
||||||
|
popd >/dev/null
|
||||||
|
|
||||||
|
# add assets from data/ directory into the apk under assets/
|
||||||
|
TMP_ASSETS_DIR="$(mktemp -d)"
|
||||||
|
mkdir -p "$TMP_ASSETS_DIR/assets"
|
||||||
|
cp -r "$DATA_DIR/." "$TMP_ASSETS_DIR/assets/"
|
||||||
|
pushd "$TMP_ASSETS_DIR" >/dev/null
|
||||||
|
zip -q -r "$APK_UNSIGNED" assets
|
||||||
|
popd >/dev/null
|
||||||
|
rm -rf "$TMP_ASSETS_DIR"
|
||||||
|
|
||||||
|
"$ZIPALIGN" -p 4 "$APK_UNSIGNED" "$APK_ALIGNED"
|
||||||
|
"$APKSIGNER" sign --ks "$KEYSTORE_FILE" --ks-pass pass:android --key-pass pass:android --out "$APK_SIGNED" "$APK_ALIGNED"
|
||||||
|
|
||||||
|
echo " signed -> $APK_SIGNED"
|
||||||
|
|
||||||
|
########################################
|
||||||
|
# install
|
||||||
|
########################################
|
||||||
|
log_step "Install"
|
||||||
|
|
||||||
|
"$ADB" shell am force-stop "$PACKAGE_NAME" || true
|
||||||
|
"$ADB" uninstall "$PACKAGE_NAME" || true
|
||||||
|
"$ADB" install --no-incremental "$APK_SIGNED"
|
||||||
|
|
||||||
|
echo -e "\nDone. Enjoy MCPE 0.6.1 on your device!"
|
||||||
Binary file not shown.
|
Before Width: | Height: | Size: 90 KiB After Width: | Height: | Size: 111 KiB |
143
misc/web/index.html
Normal file
143
misc/web/index.html
Normal file
@@ -0,0 +1,143 @@
|
|||||||
|
<!doctype html>
|
||||||
|
<html lang="en-us">
|
||||||
|
<head>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
||||||
|
<title>Emscripten-Generated Code</title>
|
||||||
|
<style>
|
||||||
|
.emscripten { padding-right: 0; margin-left: auto; margin-right: auto; display: block; }
|
||||||
|
textarea.emscripten { font-family: monospace; width: 80%; }
|
||||||
|
div.emscripten { text-align: center; }
|
||||||
|
div.emscripten_border { border: 1px solid black; }
|
||||||
|
/* the canvas *must not* have any border or padding, or mouse coords will be wrong */
|
||||||
|
canvas.emscripten { border: 0px none; background-color: black; }
|
||||||
|
|
||||||
|
.spinner {
|
||||||
|
height: 50px;
|
||||||
|
width: 50px;
|
||||||
|
margin: 0px auto;
|
||||||
|
-webkit-animation: rotation .8s linear infinite;
|
||||||
|
-moz-animation: rotation .8s linear infinite;
|
||||||
|
-o-animation: rotation .8s linear infinite;
|
||||||
|
animation: rotation 0.8s linear infinite;
|
||||||
|
border-left: 10px solid rgb(0,150,240);
|
||||||
|
border-right: 10px solid rgb(0,150,240);
|
||||||
|
border-bottom: 10px solid rgb(0,150,240);
|
||||||
|
border-top: 10px solid rgb(100,0,200);
|
||||||
|
border-radius: 100%;
|
||||||
|
background-color: rgb(200,100,250);
|
||||||
|
}
|
||||||
|
@-webkit-keyframes rotation {
|
||||||
|
from {-webkit-transform: rotate(0deg);}
|
||||||
|
to {-webkit-transform: rotate(360deg);}
|
||||||
|
}
|
||||||
|
@-moz-keyframes rotation {
|
||||||
|
from {-moz-transform: rotate(0deg);}
|
||||||
|
to {-moz-transform: rotate(360deg);}
|
||||||
|
}
|
||||||
|
@-o-keyframes rotation {
|
||||||
|
from {-o-transform: rotate(0deg);}
|
||||||
|
to {-o-transform: rotate(360deg);}
|
||||||
|
}
|
||||||
|
@keyframes rotation {
|
||||||
|
from {transform: rotate(0deg);}
|
||||||
|
to {transform: rotate(360deg);}
|
||||||
|
}
|
||||||
|
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<hr/>
|
||||||
|
<figure style="overflow:visible;" id="spinner"><div class="spinner"></div><center style="margin-top:0.5em"><strong>emscripten</strong></center></figure>
|
||||||
|
<div class="emscripten" id="status">Downloading...</div>
|
||||||
|
<div class="emscripten">
|
||||||
|
<progress value="0" max="100" id="progress" hidden=1></progress>
|
||||||
|
</div>
|
||||||
|
<div class="emscripten_border">
|
||||||
|
<canvas class="emscripten" id="canvas" oncontextmenu="event.preventDefault()" tabindex=-1></canvas>
|
||||||
|
</div>
|
||||||
|
<hr/>
|
||||||
|
<div class="emscripten">
|
||||||
|
<input type="checkbox" id="resize">Resize canvas
|
||||||
|
<input type="checkbox" id="pointerLock" checked>Lock/hide mouse pointer
|
||||||
|
|
||||||
|
<input type="button" value="Fullscreen" onclick="Module.requestFullscreen(document.getElementById('pointerLock').checked,
|
||||||
|
document.getElementById('resize').checked)">
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<hr/>
|
||||||
|
<textarea class="emscripten" id="output" rows="8"></textarea>
|
||||||
|
<hr>
|
||||||
|
<script type='text/javascript'>
|
||||||
|
var statusElement = document.getElementById('status');
|
||||||
|
var progressElement = document.getElementById('progress');
|
||||||
|
var spinnerElement = document.getElementById('spinner');
|
||||||
|
var canvasElement = document.getElementById('canvas');
|
||||||
|
var outputElement = document.getElementById('output');
|
||||||
|
if (outputElement) outputElement.value = ''; // clear browser cache
|
||||||
|
|
||||||
|
// As a default initial behavior, pop up an alert when webgl context is lost. To make your
|
||||||
|
// application robust, you may want to override this behavior before shipping!
|
||||||
|
// See http://www.khronos.org/registry/webgl/specs/latest/1.0/#5.15.2
|
||||||
|
canvasElement.addEventListener("webglcontextlost", (e) => {
|
||||||
|
alert('WebGL context lost. You will need to reload the page.');
|
||||||
|
e.preventDefault();
|
||||||
|
}, false);
|
||||||
|
|
||||||
|
function setStatus(text) {
|
||||||
|
if (!setStatus.last) setStatus.last = { time: Date.now(), text: '' };
|
||||||
|
if (text === setStatus.last.text) return;
|
||||||
|
var m = text.match(/([^(]+)\((\d+(\.\d+)?)\/(\d+)\)/);
|
||||||
|
var now = Date.now();
|
||||||
|
if (m && now - setStatus.last.time < 30) return; // if this is a progress update, skip it if too soon
|
||||||
|
setStatus.last.time = now;
|
||||||
|
setStatus.last.text = text;
|
||||||
|
if (m) {
|
||||||
|
text = m[1];
|
||||||
|
progressElement.value = parseInt(m[2])*100;
|
||||||
|
progressElement.max = parseInt(m[4])*100;
|
||||||
|
progressElement.hidden = false;
|
||||||
|
spinnerElement.hidden = false;
|
||||||
|
} else {
|
||||||
|
progressElement.value = null;
|
||||||
|
progressElement.max = null;
|
||||||
|
progressElement.hidden = true;
|
||||||
|
if (!text) spinnerElement.hidden = true;
|
||||||
|
}
|
||||||
|
statusElement.innerHTML = text;
|
||||||
|
}
|
||||||
|
|
||||||
|
var Module = {
|
||||||
|
print(...args) {
|
||||||
|
// These replacements are necessary if you render to raw HTML
|
||||||
|
//text = text.replace(/&/g, "&");
|
||||||
|
//text = text.replace(/</g, "<");
|
||||||
|
//text = text.replace(/>/g, ">");
|
||||||
|
//text = text.replace('\n', '<br>', 'g');
|
||||||
|
console.log(...args);
|
||||||
|
if (outputElement) {
|
||||||
|
var text = args.join(' ');
|
||||||
|
outputElement.value += text + "\n";
|
||||||
|
outputElement.scrollTop = outputElement.scrollHeight; // focus on bottom
|
||||||
|
}
|
||||||
|
},
|
||||||
|
canvas: canvasElement,
|
||||||
|
setStatus: setStatus,
|
||||||
|
totalDependencies: 0,
|
||||||
|
monitorRunDependencies(left) {
|
||||||
|
this.totalDependencies = Math.max(this.totalDependencies, left);
|
||||||
|
setStatus(left ? 'Preparing... (' + (this.totalDependencies-left) + '/' + this.totalDependencies + ')' : 'All downloads complete.');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
setStatus('Downloading...');
|
||||||
|
window.onerror = () => {
|
||||||
|
setStatus('Exception thrown, see JavaScript console');
|
||||||
|
spinnerElement.style.display = 'none';
|
||||||
|
setStatus = (text) => {
|
||||||
|
if (text) console.error('[post-exception status] ' + text);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
<script src="MinecraftPE.js"></script>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
@@ -24,6 +24,7 @@ LOCAL_SRC_FILES := ../../../src/main.cpp \
|
|||||||
../../../src/client/Options.cpp \
|
../../../src/client/Options.cpp \
|
||||||
../../../src/client/OptionsFile.cpp \
|
../../../src/client/OptionsFile.cpp \
|
||||||
../../../src/client/OptionStrings.cpp \
|
../../../src/client/OptionStrings.cpp \
|
||||||
|
../../../src/client/Option.cpp \
|
||||||
../../../src/client/gamemode/GameMode.cpp \
|
../../../src/client/gamemode/GameMode.cpp \
|
||||||
../../../src/client/gamemode/CreativeMode.cpp \
|
../../../src/client/gamemode/CreativeMode.cpp \
|
||||||
../../../src/client/gamemode/SurvivalMode.cpp \
|
../../../src/client/gamemode/SurvivalMode.cpp \
|
||||||
@@ -37,14 +38,14 @@ LOCAL_SRC_FILES := ../../../src/main.cpp \
|
|||||||
../../../src/client/gui/components/NinePatch.cpp \
|
../../../src/client/gui/components/NinePatch.cpp \
|
||||||
../../../src/client/gui/components/OptionsGroup.cpp \
|
../../../src/client/gui/components/OptionsGroup.cpp \
|
||||||
../../../src/client/gui/components/OptionsItem.cpp \
|
../../../src/client/gui/components/OptionsItem.cpp \
|
||||||
../../../src/client/gui/components/OptionsPane.cpp \
|
../../../src/client/gui/components/KeyOption.cpp \
|
||||||
|
../../../src/client/gui/components/TextOption.cpp \
|
||||||
../../../src/client/gui/components/RolledSelectionListH.cpp \
|
../../../src/client/gui/components/RolledSelectionListH.cpp \
|
||||||
../../../src/client/gui/components/RolledSelectionListV.cpp \
|
../../../src/client/gui/components/RolledSelectionListV.cpp \
|
||||||
../../../src/client/gui/components/ScrolledSelectionList.cpp \
|
../../../src/client/gui/components/ScrolledSelectionList.cpp \
|
||||||
../../../src/client/gui/components/ScrollingPane.cpp \
|
../../../src/client/gui/components/ScrollingPane.cpp \
|
||||||
../../../src/client/gui/components/Slider.cpp \
|
../../../src/client/gui/components/Slider.cpp \
|
||||||
../../../src/client/gui/components/TextBox.cpp \
|
../../../src/client/gui/components/TextBox.cpp \
|
||||||
../../../src/client/gui/components/SmallButton.cpp \
|
|
||||||
../../../src/client/gui/Font.cpp \
|
../../../src/client/gui/Font.cpp \
|
||||||
../../../src/client/gui/Gui.cpp \
|
../../../src/client/gui/Gui.cpp \
|
||||||
../../../src/client/gui/GuiComponent.cpp \
|
../../../src/client/gui/GuiComponent.cpp \
|
||||||
@@ -256,7 +257,8 @@ LOCAL_SRC_FILES := ../../../src/main.cpp \
|
|||||||
../../../src/world/phys/HitResult.cpp
|
../../../src/world/phys/HitResult.cpp
|
||||||
|
|
||||||
LOCAL_CFLAGS := -DPLATFORM_ANDROID -DPRE_ANDROID23 -Wno-narrowing $(LOCAL_CFLAGS)
|
LOCAL_CFLAGS := -DPLATFORM_ANDROID -DPRE_ANDROID23 -Wno-narrowing $(LOCAL_CFLAGS)
|
||||||
LOCAL_CPPFLAGS := -std=c++11
|
LOCAL_CPPFLAGS := -std=c++14 -frtti
|
||||||
|
LOCAL_CPPFLAGS += -frtti
|
||||||
LOCAL_C_INCLUDES := $(LOCAL_PATH)/../../../src
|
LOCAL_C_INCLUDES := $(LOCAL_PATH)/../../../src
|
||||||
|
|
||||||
#LOCAL_CFLAGS := -DANDROID_PUBLISH -DDEMO_MODE $(LOCAL_CFLAGS)
|
#LOCAL_CFLAGS := -DANDROID_PUBLISH -DDEMO_MODE $(LOCAL_CFLAGS)
|
||||||
|
|||||||
@@ -3,4 +3,5 @@ APP_STL := gnustl_static
|
|||||||
APP_OPTIM := release
|
APP_OPTIM := release
|
||||||
APP_ABI := arm64-v8a
|
APP_ABI := arm64-v8a
|
||||||
APP_SHORT_COMMANDS := true
|
APP_SHORT_COMMANDS := true
|
||||||
|
APP_CPPFLAGS += -frtti -fexceptions
|
||||||
#APP_ABI := armeabi-v7a x86
|
#APP_ABI := armeabi-v7a x86
|
||||||
|
|||||||
@@ -1211,7 +1211,7 @@
|
|||||||
042A91A916B17517007ABBC6 /* OptionsPane.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = OptionsPane.cpp; sourceTree = "<group>"; };
|
042A91A916B17517007ABBC6 /* OptionsPane.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = OptionsPane.cpp; sourceTree = "<group>"; };
|
||||||
042A91AA16B17517007ABBC6 /* OptionsPane.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = OptionsPane.h; sourceTree = "<group>"; };
|
042A91AA16B17517007ABBC6 /* OptionsPane.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = OptionsPane.h; sourceTree = "<group>"; };
|
||||||
042A91AB16B17517007ABBC6 /* TextBox.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = TextBox.cpp; sourceTree = "<group>"; };
|
042A91AB16B17517007ABBC6 /* TextBox.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = TextBox.cpp; sourceTree = "<group>"; };
|
||||||
042A91AC16B17517007ABBC6 /* TextBox.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = TextBox.h; path = ../../src/client/gui/components/TextBox.h; sourceTree = SOURCE_ROOT; };
|
042A91AC16B17517007ABBC6 /* TextBox.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = TextBox.h; sourceTree = "<group>"; };
|
||||||
044129061682FF9600B70EE6 /* MouseHandler.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = MouseHandler.cpp; sourceTree = "<group>"; };
|
044129061682FF9600B70EE6 /* MouseHandler.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = MouseHandler.cpp; sourceTree = "<group>"; };
|
||||||
9D293CE616071C08000305C8 /* CreateNewWorld_iphone.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; name = CreateNewWorld_iphone.xib; path = minecraftpe/dialogs/CreateNewWorld_iphone.xib; sourceTree = "<group>"; };
|
9D293CE616071C08000305C8 /* CreateNewWorld_iphone.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; name = CreateNewWorld_iphone.xib; path = minecraftpe/dialogs/CreateNewWorld_iphone.xib; sourceTree = "<group>"; };
|
||||||
9D293CEA160720D6000305C8 /* worldname_iphone5_3.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = worldname_iphone5_3.png; sourceTree = "<group>"; };
|
9D293CEA160720D6000305C8 /* worldname_iphone5_3.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = worldname_iphone5_3.png; sourceTree = "<group>"; };
|
||||||
@@ -4527,16 +4527,10 @@
|
|||||||
isa = PBXProject;
|
isa = PBXProject;
|
||||||
attributes = {
|
attributes = {
|
||||||
LastUpgradeCheck = 0420;
|
LastUpgradeCheck = 0420;
|
||||||
TargetAttributes = {
|
|
||||||
D5CF9C41144C225000E4244F = {
|
|
||||||
DevelopmentTeam = PZUVNW8F2U;
|
|
||||||
ProvisioningStyle = Automatic;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
buildConfigurationList = D5CF9C3C144C225000E4244F /* Build configuration list for PBXProject "minecraftpe" */;
|
buildConfigurationList = D5CF9C3C144C225000E4244F /* Build configuration list for PBXProject "minecraftpe" */;
|
||||||
compatibilityVersion = "Xcode 3.2";
|
compatibilityVersion = "Xcode 3.2";
|
||||||
developmentRegion = en;
|
developmentRegion = English;
|
||||||
hasScannedForEncodings = 0;
|
hasScannedForEncodings = 0;
|
||||||
knownRegions = (
|
knownRegions = (
|
||||||
en,
|
en,
|
||||||
@@ -5742,27 +5736,24 @@
|
|||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
ALWAYS_SEARCH_USER_PATHS = NO;
|
ALWAYS_SEARCH_USER_PATHS = NO;
|
||||||
ARCHS = "$(ARCHS_STANDARD)";
|
ARCHS = "$(ARCHS_UNIVERSAL_IPHONE_OS)";
|
||||||
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Distribution: Mojang AB";
|
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Distribution: Mojang AB";
|
||||||
COPY_PHASE_STRIP = YES;
|
COPY_PHASE_STRIP = YES;
|
||||||
GCC_C_LANGUAGE_STANDARD = gnu99;
|
GCC_C_LANGUAGE_STANDARD = gnu99;
|
||||||
GCC_PREPROCESSOR_DEFINITIONS = PUBLISH;
|
GCC_PREPROCESSOR_DEFINITIONS = PUBLISH;
|
||||||
GCC_VERSION = "";
|
GCC_VERSION = com.apple.compilers.llvmgcc42;
|
||||||
GCC_WARN_ABOUT_MISSING_FIELD_INITIALIZERS = YES;
|
GCC_WARN_ABOUT_MISSING_FIELD_INITIALIZERS = YES;
|
||||||
GCC_WARN_ABOUT_MISSING_PROTOTYPES = YES;
|
GCC_WARN_ABOUT_MISSING_PROTOTYPES = YES;
|
||||||
GCC_WARN_ABOUT_RETURN_TYPE = YES;
|
GCC_WARN_ABOUT_RETURN_TYPE = YES;
|
||||||
GCC_WARN_HIDDEN_VIRTUAL_FUNCTIONS = NO;
|
GCC_WARN_HIDDEN_VIRTUAL_FUNCTIONS = NO;
|
||||||
GCC_WARN_NON_VIRTUAL_DESTRUCTOR = YES;
|
GCC_WARN_NON_VIRTUAL_DESTRUCTOR = YES;
|
||||||
GCC_WARN_UNUSED_VARIABLE = YES;
|
GCC_WARN_UNUSED_VARIABLE = YES;
|
||||||
HEADER_SEARCH_PATHS = "$(SRCROOT)\\src/**";
|
IPHONEOS_DEPLOYMENT_TARGET = 4.3;
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 14;
|
|
||||||
ONLY_ACTIVE_ARCH = YES;
|
|
||||||
OTHER_CFLAGS = "-DNS_BLOCK_ASSERTIONS=1";
|
OTHER_CFLAGS = "-DNS_BLOCK_ASSERTIONS=1";
|
||||||
"PROVISIONING_PROFILE[sdk=iphoneos*]" = "C93D3524-5C6F-466E-B12B-833663B7EAE0";
|
"PROVISIONING_PROFILE[sdk=iphoneos*]" = "C93D3524-5C6F-466E-B12B-833663B7EAE0";
|
||||||
RUN_CLANG_STATIC_ANALYZER = NO;
|
RUN_CLANG_STATIC_ANALYZER = NO;
|
||||||
SDKROOT = iphoneos;
|
SDKROOT = iphoneos6.0;
|
||||||
TARGETED_DEVICE_FAMILY = "1,2";
|
TARGETED_DEVICE_FAMILY = "1,2";
|
||||||
USER_HEADER_SEARCH_PATHS = "$(SRCROOT)\\src/**";
|
|
||||||
VALIDATE_PRODUCT = YES;
|
VALIDATE_PRODUCT = YES;
|
||||||
};
|
};
|
||||||
name = "Ad-Hoc";
|
name = "Ad-Hoc";
|
||||||
@@ -5774,17 +5765,15 @@
|
|||||||
GCC_PREFIX_HEADER = "minecraftpe/minecraftpe-Prefix.pch";
|
GCC_PREFIX_HEADER = "minecraftpe/minecraftpe-Prefix.pch";
|
||||||
GCC_PREPROCESSOR_DEFINITIONS = "";
|
GCC_PREPROCESSOR_DEFINITIONS = "";
|
||||||
"GCC_THUMB_SUPPORT[arch=armv7]" = NO;
|
"GCC_THUMB_SUPPORT[arch=armv7]" = NO;
|
||||||
GCC_VERSION = "";
|
GCC_VERSION = com.apple.compilers.llvmgcc42;
|
||||||
GCC_WARN_ABOUT_MISSING_PROTOTYPES = NO;
|
GCC_WARN_ABOUT_MISSING_PROTOTYPES = NO;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
INFOPLIST_FILE = "minecraftpe/minecraftpe-Info.plist";
|
INFOPLIST_FILE = "minecraftpe/minecraftpe-Info.plist";
|
||||||
INFOPLIST_KEY_LSApplicationCategoryType = "public.app-category.games";
|
IPHONEOS_DEPLOYMENT_TARGET = 4.3;
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 14;
|
|
||||||
ONLY_ACTIVE_ARCH = YES;
|
|
||||||
PRODUCT_BUNDLE_IDENTIFIER = "com.mojang.mcpe-arm64";
|
|
||||||
PRODUCT_NAME = "$(TARGET_NAME)";
|
PRODUCT_NAME = "$(TARGET_NAME)";
|
||||||
RUN_CLANG_STATIC_ANALYZER = NO;
|
RUN_CLANG_STATIC_ANALYZER = NO;
|
||||||
SDKROOT = iphoneos;
|
SDKROOT = iphoneos6.0;
|
||||||
|
VALID_ARCHS = "i386 armv6 armv7";
|
||||||
WRAPPER_EXTENSION = app;
|
WRAPPER_EXTENSION = app;
|
||||||
};
|
};
|
||||||
name = "Ad-Hoc";
|
name = "Ad-Hoc";
|
||||||
@@ -5858,26 +5847,23 @@
|
|||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
ALWAYS_SEARCH_USER_PATHS = NO;
|
ALWAYS_SEARCH_USER_PATHS = NO;
|
||||||
ARCHS = "$(ARCHS_STANDARD)";
|
ARCHS = "$(ARCHS_UNIVERSAL_IPHONE_OS)";
|
||||||
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Distribution: Mojang AB";
|
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Distribution: Mojang AB";
|
||||||
COPY_PHASE_STRIP = YES;
|
COPY_PHASE_STRIP = YES;
|
||||||
GCC_C_LANGUAGE_STANDARD = gnu99;
|
GCC_C_LANGUAGE_STANDARD = gnu99;
|
||||||
GCC_VERSION = "";
|
GCC_VERSION = com.apple.compilers.llvmgcc42;
|
||||||
GCC_WARN_ABOUT_MISSING_FIELD_INITIALIZERS = YES;
|
GCC_WARN_ABOUT_MISSING_FIELD_INITIALIZERS = YES;
|
||||||
GCC_WARN_ABOUT_MISSING_PROTOTYPES = YES;
|
GCC_WARN_ABOUT_MISSING_PROTOTYPES = YES;
|
||||||
GCC_WARN_ABOUT_RETURN_TYPE = YES;
|
GCC_WARN_ABOUT_RETURN_TYPE = YES;
|
||||||
GCC_WARN_HIDDEN_VIRTUAL_FUNCTIONS = NO;
|
GCC_WARN_HIDDEN_VIRTUAL_FUNCTIONS = NO;
|
||||||
GCC_WARN_NON_VIRTUAL_DESTRUCTOR = YES;
|
GCC_WARN_NON_VIRTUAL_DESTRUCTOR = YES;
|
||||||
GCC_WARN_UNUSED_VARIABLE = YES;
|
GCC_WARN_UNUSED_VARIABLE = YES;
|
||||||
HEADER_SEARCH_PATHS = "$(SRCROOT)\\src/**";
|
IPHONEOS_DEPLOYMENT_TARGET = 4.3;
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 14;
|
|
||||||
ONLY_ACTIVE_ARCH = YES;
|
|
||||||
OTHER_CFLAGS = "-DNS_BLOCK_ASSERTIONS=1";
|
OTHER_CFLAGS = "-DNS_BLOCK_ASSERTIONS=1";
|
||||||
"PROVISIONING_PROFILE[sdk=iphoneos*]" = "64BA8967-1A9A-4980-972C-42E75AD5E023";
|
"PROVISIONING_PROFILE[sdk=iphoneos*]" = "64BA8967-1A9A-4980-972C-42E75AD5E023";
|
||||||
RUN_CLANG_STATIC_ANALYZER = NO;
|
RUN_CLANG_STATIC_ANALYZER = NO;
|
||||||
SDKROOT = iphoneos;
|
SDKROOT = iphoneos6.0;
|
||||||
TARGETED_DEVICE_FAMILY = "1,2";
|
TARGETED_DEVICE_FAMILY = "1,2";
|
||||||
USER_HEADER_SEARCH_PATHS = "$(SRCROOT)\\src/**";
|
|
||||||
VALIDATE_PRODUCT = YES;
|
VALIDATE_PRODUCT = YES;
|
||||||
};
|
};
|
||||||
name = AppStore;
|
name = AppStore;
|
||||||
@@ -5890,13 +5876,11 @@
|
|||||||
GCC_PREFIX_HEADER = "minecraftpe/minecraftpe-Prefix.pch";
|
GCC_PREFIX_HEADER = "minecraftpe/minecraftpe-Prefix.pch";
|
||||||
GCC_PREPROCESSOR_DEFINITIONS = PUBLISH;
|
GCC_PREPROCESSOR_DEFINITIONS = PUBLISH;
|
||||||
"GCC_THUMB_SUPPORT[arch=armv7]" = NO;
|
"GCC_THUMB_SUPPORT[arch=armv7]" = NO;
|
||||||
GCC_VERSION = "";
|
GCC_VERSION = com.apple.compilers.llvmgcc42;
|
||||||
GCC_WARN_ABOUT_MISSING_PROTOTYPES = NO;
|
GCC_WARN_ABOUT_MISSING_PROTOTYPES = NO;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
INFOPLIST_FILE = "minecraftpe/minecraftpe-Info.plist";
|
INFOPLIST_FILE = "minecraftpe/minecraftpe-Info.plist";
|
||||||
INFOPLIST_KEY_LSApplicationCategoryType = "public.app-category.games";
|
IPHONEOS_DEPLOYMENT_TARGET = 4.3;
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 14;
|
|
||||||
ONLY_ACTIVE_ARCH = YES;
|
|
||||||
OTHER_CFLAGS = (
|
OTHER_CFLAGS = (
|
||||||
"-DNS_BLOCK_ASSERTIONS=1",
|
"-DNS_BLOCK_ASSERTIONS=1",
|
||||||
"-DANDROID_PUBLISH",
|
"-DANDROID_PUBLISH",
|
||||||
@@ -5904,7 +5888,8 @@
|
|||||||
PRODUCT_NAME = "$(TARGET_NAME)";
|
PRODUCT_NAME = "$(TARGET_NAME)";
|
||||||
"PROVISIONING_PROFILE[sdk=iphoneos*]" = "1B194957-98CF-49B7-A0E7-76692B4B722D";
|
"PROVISIONING_PROFILE[sdk=iphoneos*]" = "1B194957-98CF-49B7-A0E7-76692B4B722D";
|
||||||
RUN_CLANG_STATIC_ANALYZER = NO;
|
RUN_CLANG_STATIC_ANALYZER = NO;
|
||||||
SDKROOT = iphoneos;
|
SDKROOT = iphoneos6.0;
|
||||||
|
VALID_ARCHS = "i386 armv6 armv7";
|
||||||
WRAPPER_EXTENSION = app;
|
WRAPPER_EXTENSION = app;
|
||||||
};
|
};
|
||||||
name = AppStore;
|
name = AppStore;
|
||||||
@@ -5938,7 +5923,7 @@
|
|||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
ALWAYS_SEARCH_USER_PATHS = NO;
|
ALWAYS_SEARCH_USER_PATHS = NO;
|
||||||
ARCHS = "$(ARCHS_STANDARD)";
|
ARCHS = "$(ARCHS_UNIVERSAL_IPHONE_OS)";
|
||||||
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
|
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
|
||||||
COPY_PHASE_STRIP = NO;
|
COPY_PHASE_STRIP = NO;
|
||||||
GCC_C_LANGUAGE_STANDARD = gnu99;
|
GCC_C_LANGUAGE_STANDARD = gnu99;
|
||||||
@@ -5950,21 +5935,17 @@
|
|||||||
"$(inherited)",
|
"$(inherited)",
|
||||||
);
|
);
|
||||||
GCC_SYMBOLS_PRIVATE_EXTERN = NO;
|
GCC_SYMBOLS_PRIVATE_EXTERN = NO;
|
||||||
GCC_VERSION = "";
|
GCC_VERSION = com.apple.compilers.llvmgcc42;
|
||||||
GCC_WARN_ABOUT_MISSING_FIELD_INITIALIZERS = YES;
|
GCC_WARN_ABOUT_MISSING_FIELD_INITIALIZERS = YES;
|
||||||
GCC_WARN_ABOUT_MISSING_PROTOTYPES = YES;
|
GCC_WARN_ABOUT_MISSING_PROTOTYPES = YES;
|
||||||
GCC_WARN_ABOUT_RETURN_TYPE = YES;
|
GCC_WARN_ABOUT_RETURN_TYPE = YES;
|
||||||
GCC_WARN_HIDDEN_VIRTUAL_FUNCTIONS = NO;
|
GCC_WARN_HIDDEN_VIRTUAL_FUNCTIONS = NO;
|
||||||
GCC_WARN_NON_VIRTUAL_DESTRUCTOR = YES;
|
GCC_WARN_NON_VIRTUAL_DESTRUCTOR = YES;
|
||||||
GCC_WARN_UNUSED_VARIABLE = YES;
|
GCC_WARN_UNUSED_VARIABLE = YES;
|
||||||
HEADER_SEARCH_PATHS = "$(SRCROOT)\\src/**";
|
IPHONEOS_DEPLOYMENT_TARGET = 4.3;
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 14;
|
|
||||||
ONLY_ACTIVE_ARCH = YES;
|
|
||||||
RUN_CLANG_STATIC_ANALYZER = NO;
|
RUN_CLANG_STATIC_ANALYZER = NO;
|
||||||
SDKROOT = iphoneos;
|
SDKROOT = iphoneos6.0;
|
||||||
TARGETED_DEVICE_FAMILY = "1,2";
|
TARGETED_DEVICE_FAMILY = "1,2";
|
||||||
USER_HEADER_SEARCH_PATHS = "$(SRCROOT)\\src/**";
|
|
||||||
VALIDATE_PRODUCT = YES;
|
|
||||||
};
|
};
|
||||||
name = Debug;
|
name = Debug;
|
||||||
};
|
};
|
||||||
@@ -5972,26 +5953,23 @@
|
|||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
ALWAYS_SEARCH_USER_PATHS = NO;
|
ALWAYS_SEARCH_USER_PATHS = NO;
|
||||||
ARCHS = "$(ARCHS_STANDARD)";
|
ARCHS = "$(ARCHS_UNIVERSAL_IPHONE_OS)";
|
||||||
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
|
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
|
||||||
COPY_PHASE_STRIP = YES;
|
COPY_PHASE_STRIP = YES;
|
||||||
GCC_C_LANGUAGE_STANDARD = gnu99;
|
GCC_C_LANGUAGE_STANDARD = gnu99;
|
||||||
GCC_PREPROCESSOR_DEFINITIONS = PUBLISH;
|
GCC_PREPROCESSOR_DEFINITIONS = PUBLISH;
|
||||||
GCC_VERSION = "";
|
GCC_VERSION = com.apple.compilers.llvmgcc42;
|
||||||
GCC_WARN_ABOUT_MISSING_FIELD_INITIALIZERS = YES;
|
GCC_WARN_ABOUT_MISSING_FIELD_INITIALIZERS = YES;
|
||||||
GCC_WARN_ABOUT_MISSING_PROTOTYPES = YES;
|
GCC_WARN_ABOUT_MISSING_PROTOTYPES = YES;
|
||||||
GCC_WARN_ABOUT_RETURN_TYPE = YES;
|
GCC_WARN_ABOUT_RETURN_TYPE = YES;
|
||||||
GCC_WARN_HIDDEN_VIRTUAL_FUNCTIONS = NO;
|
GCC_WARN_HIDDEN_VIRTUAL_FUNCTIONS = NO;
|
||||||
GCC_WARN_NON_VIRTUAL_DESTRUCTOR = YES;
|
GCC_WARN_NON_VIRTUAL_DESTRUCTOR = YES;
|
||||||
GCC_WARN_UNUSED_VARIABLE = YES;
|
GCC_WARN_UNUSED_VARIABLE = YES;
|
||||||
HEADER_SEARCH_PATHS = "$(SRCROOT)\\src/**";
|
IPHONEOS_DEPLOYMENT_TARGET = 4.3;
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 14;
|
|
||||||
ONLY_ACTIVE_ARCH = YES;
|
|
||||||
OTHER_CFLAGS = "-DNS_BLOCK_ASSERTIONS=1";
|
OTHER_CFLAGS = "-DNS_BLOCK_ASSERTIONS=1";
|
||||||
RUN_CLANG_STATIC_ANALYZER = NO;
|
RUN_CLANG_STATIC_ANALYZER = NO;
|
||||||
SDKROOT = iphoneos;
|
SDKROOT = iphoneos6.0;
|
||||||
TARGETED_DEVICE_FAMILY = "1,2";
|
TARGETED_DEVICE_FAMILY = "1,2";
|
||||||
USER_HEADER_SEARCH_PATHS = "$(SRCROOT)\\src/**";
|
|
||||||
VALIDATE_PRODUCT = YES;
|
VALIDATE_PRODUCT = YES;
|
||||||
};
|
};
|
||||||
name = Release;
|
name = Release;
|
||||||
@@ -5999,25 +5977,19 @@
|
|||||||
D5CF9C6F144C225000E4244F /* Debug */ = {
|
D5CF9C6F144C225000E4244F /* Debug */ = {
|
||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
CODE_SIGN_IDENTITY = "Apple Development";
|
|
||||||
CODE_SIGN_STYLE = Automatic;
|
|
||||||
DEVELOPMENT_TEAM = PZUVNW8F2U;
|
|
||||||
GCC_PRECOMPILE_PREFIX_HEADER = YES;
|
GCC_PRECOMPILE_PREFIX_HEADER = YES;
|
||||||
GCC_PREFIX_HEADER = "minecraftpe/minecraftpe-Prefix.pch";
|
GCC_PREFIX_HEADER = "minecraftpe/minecraftpe-Prefix.pch";
|
||||||
GCC_PREPROCESSOR_DEFINITIONS = "DEBUG=1";
|
GCC_PREPROCESSOR_DEFINITIONS = "DEBUG=1";
|
||||||
"GCC_THUMB_SUPPORT[arch=armv7]" = NO;
|
"GCC_THUMB_SUPPORT[arch=armv7]" = NO;
|
||||||
GCC_VERSION = "";
|
GCC_VERSION = com.apple.compilers.llvmgcc42;
|
||||||
GCC_WARN_ABOUT_MISSING_PROTOTYPES = NO;
|
GCC_WARN_ABOUT_MISSING_PROTOTYPES = NO;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
INFOPLIST_FILE = "minecraftpe/minecraftpe-Info.plist";
|
INFOPLIST_FILE = "minecraftpe/minecraftpe-Info.plist";
|
||||||
INFOPLIST_KEY_LSApplicationCategoryType = "public.app-category.games";
|
IPHONEOS_DEPLOYMENT_TARGET = 4.3;
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 14;
|
|
||||||
ONLY_ACTIVE_ARCH = YES;
|
|
||||||
PRODUCT_BUNDLE_IDENTIFIER = "com.mojang.mcpe-arm64";
|
|
||||||
PRODUCT_NAME = "$(TARGET_NAME)";
|
PRODUCT_NAME = "$(TARGET_NAME)";
|
||||||
PROVISIONING_PROFILE_SPECIFIER = "";
|
|
||||||
RUN_CLANG_STATIC_ANALYZER = NO;
|
RUN_CLANG_STATIC_ANALYZER = NO;
|
||||||
SDKROOT = iphoneos;
|
SDKROOT = iphoneos6.0;
|
||||||
|
VALID_ARCHS = "i386 armv6 armv7";
|
||||||
WRAPPER_EXTENSION = app;
|
WRAPPER_EXTENSION = app;
|
||||||
};
|
};
|
||||||
name = Debug;
|
name = Debug;
|
||||||
@@ -6025,25 +5997,19 @@
|
|||||||
D5CF9C70144C225000E4244F /* Release */ = {
|
D5CF9C70144C225000E4244F /* Release */ = {
|
||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
CODE_SIGN_IDENTITY = "Apple Development";
|
|
||||||
CODE_SIGN_STYLE = Automatic;
|
|
||||||
DEVELOPMENT_TEAM = PZUVNW8F2U;
|
|
||||||
GCC_PRECOMPILE_PREFIX_HEADER = YES;
|
GCC_PRECOMPILE_PREFIX_HEADER = YES;
|
||||||
GCC_PREFIX_HEADER = "minecraftpe/minecraftpe-Prefix.pch";
|
GCC_PREFIX_HEADER = "minecraftpe/minecraftpe-Prefix.pch";
|
||||||
GCC_PREPROCESSOR_DEFINITIONS = "";
|
GCC_PREPROCESSOR_DEFINITIONS = "";
|
||||||
"GCC_THUMB_SUPPORT[arch=armv7]" = NO;
|
"GCC_THUMB_SUPPORT[arch=armv7]" = NO;
|
||||||
GCC_VERSION = "";
|
GCC_VERSION = com.apple.compilers.llvmgcc42;
|
||||||
GCC_WARN_ABOUT_MISSING_PROTOTYPES = NO;
|
GCC_WARN_ABOUT_MISSING_PROTOTYPES = NO;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
INFOPLIST_FILE = "minecraftpe/minecraftpe-Info.plist";
|
INFOPLIST_FILE = "minecraftpe/minecraftpe-Info.plist";
|
||||||
INFOPLIST_KEY_LSApplicationCategoryType = "public.app-category.games";
|
IPHONEOS_DEPLOYMENT_TARGET = 4.3;
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 14;
|
|
||||||
ONLY_ACTIVE_ARCH = YES;
|
|
||||||
PRODUCT_BUNDLE_IDENTIFIER = "com.mojang.mcpe-arm64";
|
|
||||||
PRODUCT_NAME = "$(TARGET_NAME)";
|
PRODUCT_NAME = "$(TARGET_NAME)";
|
||||||
PROVISIONING_PROFILE_SPECIFIER = "";
|
|
||||||
RUN_CLANG_STATIC_ANALYZER = NO;
|
RUN_CLANG_STATIC_ANALYZER = NO;
|
||||||
SDKROOT = iphoneos;
|
SDKROOT = iphoneos6.0;
|
||||||
|
VALID_ARCHS = "i386 armv6 armv7";
|
||||||
WRAPPER_EXTENSION = app;
|
WRAPPER_EXTENSION = app;
|
||||||
};
|
};
|
||||||
name = Release;
|
name = Release;
|
||||||
|
|||||||
@@ -37,7 +37,7 @@
|
|||||||
</dict>
|
</dict>
|
||||||
</dict>
|
</dict>
|
||||||
<key>CFBundleIdentifier</key>
|
<key>CFBundleIdentifier</key>
|
||||||
<string>$(PRODUCT_BUNDLE_IDENTIFIER)</string>
|
<string>com.mojang.${PRODUCT_NAME:rfc1034identifier}</string>
|
||||||
<key>CFBundleInfoDictionaryVersion</key>
|
<key>CFBundleInfoDictionaryVersion</key>
|
||||||
<string>6.0</string>
|
<string>6.0</string>
|
||||||
<key>CFBundleName</key>
|
<key>CFBundleName</key>
|
||||||
|
|||||||
@@ -4,10 +4,11 @@ include $(CLEAR_VARS)
|
|||||||
|
|
||||||
LOCAL_MODULE := RakNet
|
LOCAL_MODULE := RakNet
|
||||||
|
|
||||||
MY_PREFIX := $(LOCAL_PATH)/RakNetSources/
|
MY_PREFIX := $(LOCAL_PATH)/RaknetSources/
|
||||||
MY_SOURCES := $(wildcard $(MY_PREFIX)*.cpp)
|
MY_SOURCES := $(wildcard $(MY_PREFIX)*.cpp)
|
||||||
LOCAL_SRC_FILES += $(MY_SOURCES:$(MY_PREFIX)%=RakNetSources/%)
|
LOCAL_SRC_FILES += $(MY_SOURCES:$(MY_PREFIX)%=RaknetSources/%)
|
||||||
|
|
||||||
LOCAL_CFLAGS := -Wno-psabi $(LOCAL_CFLAGS)
|
LOCAL_CFLAGS := -Wno-psabi $(LOCAL_CFLAGS)
|
||||||
|
LOCAL_CPPFLAGS += -frtti
|
||||||
|
|
||||||
include $(BUILD_STATIC_LIBRARY)
|
include $(BUILD_STATIC_LIBRARY)
|
||||||
|
|||||||
@@ -31,7 +31,7 @@ public:
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
BinaryBlob readAssetFile(const std::string& filename) {
|
BinaryBlob readAssetFile(const std::string& filename) override {
|
||||||
FILE* fp = fopen(("data/" + filename).c_str(), "r");
|
FILE* fp = fopen(("data/" + filename).c_str(), "r");
|
||||||
if (!fp)
|
if (!fp)
|
||||||
return BinaryBlob();
|
return BinaryBlob();
|
||||||
@@ -48,7 +48,7 @@ public:
|
|||||||
return blob;
|
return blob;
|
||||||
}
|
}
|
||||||
|
|
||||||
void saveScreenshot(const std::string& filename, int glWidth, int glHeight) {
|
void saveScreenshot(const std::string& filename, int glWidth, int glHeight) override {
|
||||||
//@todo
|
//@todo
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -56,7 +56,7 @@ public:
|
|||||||
return (p & 0xff00ff00) | ((p >> 16) & 0xff) | ((p << 16) & 0xff0000);
|
return (p & 0xff00ff00) | ((p >> 16) & 0xff) | ((p << 16) & 0xff0000);
|
||||||
}
|
}
|
||||||
|
|
||||||
TextureData loadTexture(const std::string& filename_, bool textureFolder)
|
TextureData loadTexture(const std::string& filename_, bool textureFolder) override
|
||||||
{
|
{
|
||||||
// Support fetching PNG textures via HTTP/HTTPS (for skins, etc)
|
// Support fetching PNG textures via HTTP/HTTPS (for skins, etc)
|
||||||
if (Util::startsWith(filename_, "http://") || Util::startsWith(filename_, "https://")) {
|
if (Util::startsWith(filename_, "http://") || Util::startsWith(filename_, "https://")) {
|
||||||
@@ -132,10 +132,10 @@ public:
|
|||||||
return std::string(mbstr);
|
return std::string(mbstr);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual int getScreenWidth() { return 854; };
|
virtual int getScreenWidth() override { return 854; };
|
||||||
virtual int getScreenHeight() { return 480; };
|
virtual int getScreenHeight() override { return 480; };
|
||||||
|
|
||||||
virtual float getPixelsPerMillimeter();
|
virtual float getPixelsPerMillimeter() override;
|
||||||
|
|
||||||
virtual bool supportsTouchscreen() override { return true; }
|
virtual bool supportsTouchscreen() override { return true; }
|
||||||
|
|
||||||
@@ -148,6 +148,8 @@ public:
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GLFWwindow* window;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
};
|
};
|
||||||
#endif /*APPPLATFORM_GLFW_H__*/
|
#endif /*APPPLATFORM_GLFW_H__*/
|
||||||
|
|||||||
@@ -52,10 +52,11 @@ public:
|
|||||||
|
|
||||||
virtual StringVector getOptionStrings();
|
virtual StringVector getOptionStrings();
|
||||||
|
|
||||||
virtual bool isPowerVR();
|
virtual bool isPowerVR() { return false; }
|
||||||
virtual bool isSuperFast();
|
virtual bool isSuperFast();
|
||||||
virtual void showKeyboard();
|
virtual void showKeyboard();
|
||||||
virtual void hideKeyboard();
|
virtual void hideKeyboard();
|
||||||
|
virtual void isPowerVR();
|
||||||
private:
|
private:
|
||||||
|
|
||||||
std::string _basePath;
|
std::string _basePath;
|
||||||
|
|||||||
@@ -117,7 +117,6 @@ void NinecraftApp::init()
|
|||||||
setScreen(new UsernameScreen());
|
setScreen(new UsernameScreen());
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
user->name = "Server";
|
|
||||||
hostMultiplayer();
|
hostMultiplayer();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@@ -246,8 +245,9 @@ void NinecraftApp::initGLStates()
|
|||||||
glCullFace(GL_BACK);
|
glCullFace(GL_BACK);
|
||||||
|
|
||||||
glEnable2(GL_TEXTURE_2D);
|
glEnable2(GL_TEXTURE_2D);
|
||||||
|
#ifndef _EMSCRIPTEN_
|
||||||
glHint(GL_PERSPECTIVE_CORRECTION_HINT, GL_FASTEST);
|
glHint(GL_PERSPECTIVE_CORRECTION_HINT, GL_FASTEST);
|
||||||
|
#endif
|
||||||
// Both updates isPowerVR flag in java and returns if the graphics chip is PowerVR SGX or not
|
// Both updates isPowerVR flag in java and returns if the graphics chip is PowerVR SGX or not
|
||||||
_powerVr = platform()->isPowerVR();
|
_powerVr = platform()->isPowerVR();
|
||||||
#ifdef __APPLE__
|
#ifdef __APPLE__
|
||||||
|
|||||||
@@ -1,21 +0,0 @@
|
|||||||
#ifndef NET_MINECRAFT_CLIENT__KeyMapping_H__
|
|
||||||
#define NET_MINECRAFT_CLIENT__KeyMapping_H__
|
|
||||||
|
|
||||||
//package net.minecraft.client;
|
|
||||||
#include <string>
|
|
||||||
|
|
||||||
class KeyMapping
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
std::string name;
|
|
||||||
int key;
|
|
||||||
|
|
||||||
KeyMapping() {}
|
|
||||||
|
|
||||||
KeyMapping(const std::string& name_, int key_)
|
|
||||||
: name(name_),
|
|
||||||
key(key_)
|
|
||||||
{}
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif /*NET_MINECRAFT_CLIENT__KeyMapping_H__*/
|
|
||||||
@@ -23,6 +23,8 @@
|
|||||||
#include "../world/level/storage/LevelStorageSource.h"
|
#include "../world/level/storage/LevelStorageSource.h"
|
||||||
#include "../world/level/storage/LevelStorage.h"
|
#include "../world/level/storage/LevelStorage.h"
|
||||||
#include "player/input/KeyboardInput.h"
|
#include "player/input/KeyboardInput.h"
|
||||||
|
#include "player/input/ControllerTurnInput.h"
|
||||||
|
#include "player/input/XperiaPlayInput.h"
|
||||||
#include "world/level/chunk/ChunkSource.h"
|
#include "world/level/chunk/ChunkSource.h"
|
||||||
|
|
||||||
#ifndef STANDALONE_SERVER
|
#ifndef STANDALONE_SERVER
|
||||||
@@ -114,8 +116,7 @@ int Minecraft::customDebugId = Minecraft::CDI_NONE;
|
|||||||
|
|
||||||
bool Minecraft::useAmbientOcclusion = false;
|
bool Minecraft::useAmbientOcclusion = false;
|
||||||
|
|
||||||
Minecraft::Minecraft()
|
Minecraft::Minecraft() :
|
||||||
: user(NULL),
|
|
||||||
level(NULL),
|
level(NULL),
|
||||||
player(NULL),
|
player(NULL),
|
||||||
cameraTargetPlayer(NULL),
|
cameraTargetPlayer(NULL),
|
||||||
@@ -220,7 +221,6 @@ Minecraft::~Minecraft()
|
|||||||
}
|
}
|
||||||
|
|
||||||
//delete player;
|
//delete player;
|
||||||
delete user;
|
|
||||||
delete inputHolder;
|
delete inputHolder;
|
||||||
|
|
||||||
delete storageSource;
|
delete storageSource;
|
||||||
@@ -1143,10 +1143,8 @@ void Minecraft::init()
|
|||||||
checkGlError("Init complete");
|
checkGlError("Init complete");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
user = new User(options.getStringValue(OPTIONS_USERNAME), "");
|
|
||||||
setIsCreativeMode(false); // false means it's Survival Mode
|
setIsCreativeMode(false); // false means it's Survival Mode
|
||||||
reloadOptions();
|
reloadOptions();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Minecraft::setSize(int w, int h) {
|
void Minecraft::setSize(int w, int h) {
|
||||||
@@ -1332,9 +1330,9 @@ void Minecraft::hostMultiplayer(int port) {
|
|||||||
#if !defined(NO_NETWORK)
|
#if !defined(NO_NETWORK)
|
||||||
netCallback = new ServerSideNetworkHandler(this, raknetInstance);
|
netCallback = new ServerSideNetworkHandler(this, raknetInstance);
|
||||||
#ifdef STANDALONE_SERVER
|
#ifdef STANDALONE_SERVER
|
||||||
raknetInstance->host(user->name, port, 16);
|
raknetInstance->host("Server", port, 16);
|
||||||
#else
|
#else
|
||||||
raknetInstance->host(user->name, port);
|
raknetInstance->host(options.getStringValue(OPTIONS_USERNAME), port);
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@@ -1391,8 +1389,10 @@ void Minecraft::_levelGenerated()
|
|||||||
|
|
||||||
this->cameraTargetPlayer = player;
|
this->cameraTargetPlayer = player;
|
||||||
|
|
||||||
|
std::string serverName = options.getStringValue(OPTIONS_USERNAME) + " - " + level->getLevelData()->levelName;
|
||||||
|
|
||||||
if (raknetInstance->isServer())
|
if (raknetInstance->isServer())
|
||||||
raknetInstance->announceServer(user->name);
|
raknetInstance->announceServer(serverName);
|
||||||
|
|
||||||
if (netCallback) {
|
if (netCallback) {
|
||||||
netCallback->levelGenerated(level);
|
netCallback->levelGenerated(level);
|
||||||
|
|||||||
@@ -13,7 +13,6 @@
|
|||||||
//#include "../network/RakNetInstance.h"
|
//#include "../network/RakNetInstance.h"
|
||||||
#include "../world/phys/HitResult.h"
|
#include "../world/phys/HitResult.h"
|
||||||
|
|
||||||
class User;
|
|
||||||
class Level;
|
class Level;
|
||||||
class LocalPlayer;
|
class LocalPlayer;
|
||||||
class IInputHolder;
|
class IInputHolder;
|
||||||
@@ -165,7 +164,6 @@ public:
|
|||||||
int lastTickTime;
|
int lastTickTime;
|
||||||
float ticksSinceLastUpdate;
|
float ticksSinceLastUpdate;
|
||||||
|
|
||||||
User* user;
|
|
||||||
Level* level;
|
Level* level;
|
||||||
|
|
||||||
LocalPlayer* player;
|
LocalPlayer* player;
|
||||||
|
|||||||
@@ -1,5 +1,8 @@
|
|||||||
#include "Option.h"
|
#include "Option.h"
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
#include <cstdio>
|
||||||
|
|
||||||
|
Option::~Option() {}
|
||||||
|
|
||||||
bool Option::parse_bool_like(const std::string& value, bool& out) {
|
bool Option::parse_bool_like(const std::string& value, bool& out) {
|
||||||
if (value == "true" || value == "YES") {
|
if (value == "true" || value == "YES") {
|
||||||
@@ -23,7 +26,7 @@ bool OptionFloat::parse(const std::string& value) {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return std::sscanf(value.c_str(), "%f", &m_value) == 1;
|
return sscanf(value.c_str(), "%f", &m_value) == 1;
|
||||||
}
|
}
|
||||||
bool OptionInt::parse(const std::string& value) {
|
bool OptionInt::parse(const std::string& value) {
|
||||||
bool b;
|
bool b;
|
||||||
@@ -32,7 +35,7 @@ bool OptionInt::parse(const std::string& value) {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return std::sscanf(value.c_str(), "%d", &m_value) == 1;
|
return sscanf(value.c_str(), "%d", &m_value) == 1;
|
||||||
}
|
}
|
||||||
bool OptionBool::parse(const std::string& value) {
|
bool OptionBool::parse(const std::string& value) {
|
||||||
if (value == "0") {
|
if (value == "0") {
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
#include "Mth.h"
|
#include <util/Mth.h>
|
||||||
/*
|
/*
|
||||||
template<typename T>
|
template<typename T>
|
||||||
struct is_option_type : std::false_type {};
|
struct is_option_type : std::false_type {};
|
||||||
@@ -21,7 +21,7 @@ template<> struct is_min_max_option<float> : std::true_type {};
|
|||||||
class Option {
|
class Option {
|
||||||
public:
|
public:
|
||||||
Option(const std::string& key) : m_key("options." + key) {}
|
Option(const std::string& key) : m_key("options." + key) {}
|
||||||
virtual ~Option() = default;
|
virtual ~Option();
|
||||||
|
|
||||||
const std::string& getStringId() { return m_key; }
|
const std::string& getStringId() { return m_key; }
|
||||||
|
|
||||||
|
|||||||
@@ -168,9 +168,7 @@ void Options::set(OptionId key, const std::string& value) {
|
|||||||
|
|
||||||
if (option) {
|
if (option) {
|
||||||
option->set(value);
|
option->set(value);
|
||||||
|
|
||||||
notifyOptionUpdate(key, value);
|
notifyOptionUpdate(key, value);
|
||||||
save();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -179,9 +177,7 @@ void Options::set(OptionId key, float value) {
|
|||||||
|
|
||||||
if (option) {
|
if (option) {
|
||||||
option->set(value);
|
option->set(value);
|
||||||
|
|
||||||
notifyOptionUpdate(key, value);
|
notifyOptionUpdate(key, value);
|
||||||
save();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -190,9 +186,7 @@ void Options::set(OptionId key, int value) {
|
|||||||
|
|
||||||
if (option) {
|
if (option) {
|
||||||
option->set(value);
|
option->set(value);
|
||||||
|
|
||||||
notifyOptionUpdate(key, value);
|
notifyOptionUpdate(key, value);
|
||||||
save();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -201,9 +195,7 @@ void Options::toggle(OptionId key) {
|
|||||||
|
|
||||||
if (option) {
|
if (option) {
|
||||||
option->toggle();
|
option->toggle();
|
||||||
|
|
||||||
notifyOptionUpdate(key, option->get());
|
notifyOptionUpdate(key, option->get());
|
||||||
save();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,62 +0,0 @@
|
|||||||
#ifndef NET_MINECRAFT_CLIENT__User_H__
|
|
||||||
#define NET_MINECRAFT_CLIENT__User_H__
|
|
||||||
|
|
||||||
//package net.minecraft.client;
|
|
||||||
|
|
||||||
#include "../world/level/tile/Tile.h"
|
|
||||||
|
|
||||||
class User
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
//static List<Tile> allowedTiles = /*new*/ ArrayList<Tile>();
|
|
||||||
|
|
||||||
//static {
|
|
||||||
// allowedTiles.push_back(Tile::rock);
|
|
||||||
// allowedTiles.push_back(Tile::stoneBrick);
|
|
||||||
// allowedTiles.push_back(Tile::redBrick);
|
|
||||||
// allowedTiles.push_back(Tile::dirt);
|
|
||||||
// allowedTiles.push_back(Tile::wood);
|
|
||||||
// allowedTiles.push_back(Tile::treeTrunk);
|
|
||||||
// allowedTiles.push_back(Tile::leaves);
|
|
||||||
// allowedTiles.push_back(Tile::torch);
|
|
||||||
// allowedTiles.push_back(Tile::stoneSlabHalf);
|
|
||||||
|
|
||||||
// allowedTiles.push_back(Tile::glass);
|
|
||||||
// allowedTiles.push_back(Tile::mossStone);
|
|
||||||
// allowedTiles.push_back(Tile::sapling);
|
|
||||||
// allowedTiles.push_back(Tile::flower);
|
|
||||||
// allowedTiles.push_back(Tile::rose);
|
|
||||||
// allowedTiles.push_back(Tile::mushroom1);
|
|
||||||
// allowedTiles.push_back(Tile::mushroom2);
|
|
||||||
// allowedTiles.push_back(Tile::sand);
|
|
||||||
// allowedTiles.push_back(Tile::gravel);
|
|
||||||
// allowedTiles.push_back(Tile::sponge);
|
|
||||||
|
|
||||||
// allowedTiles.push_back(Tile::cloth);
|
|
||||||
// allowedTiles.push_back(Tile::coalOre);
|
|
||||||
// allowedTiles.push_back(Tile::ironOre);
|
|
||||||
// allowedTiles.push_back(Tile::goldOre);
|
|
||||||
// allowedTiles.push_back(Tile::ironBlock);
|
|
||||||
// allowedTiles.push_back(Tile::goldBlock);
|
|
||||||
// allowedTiles.push_back(Tile::bookshelf);
|
|
||||||
// allowedTiles.push_back(Tile::tnt);
|
|
||||||
// allowedTiles.push_back(Tile::obsidian);
|
|
||||||
|
|
||||||
// // System.out.println(allowedTiles.size());
|
|
||||||
//}
|
|
||||||
|
|
||||||
static bool isTileAllowed(const Tile& tile) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string name;
|
|
||||||
std::string sessionId;
|
|
||||||
//std::string mpPassword;
|
|
||||||
|
|
||||||
User(const std::string& name, const std::string& sessionId) {
|
|
||||||
this->name = name;
|
|
||||||
this->sessionId = sessionId;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif /*NET_MINECRAFT_CLIENT__User_H__*/
|
|
||||||
@@ -5,6 +5,7 @@
|
|||||||
#include "../../world/level/Level.h"
|
#include "../../world/level/Level.h"
|
||||||
#include "../../world/item/ItemInstance.h"
|
#include "../../world/item/ItemInstance.h"
|
||||||
#include "../player/LocalPlayer.h"
|
#include "../player/LocalPlayer.h"
|
||||||
|
#include "client/Options.h"
|
||||||
#ifndef STANDALONE_SERVER
|
#ifndef STANDALONE_SERVER
|
||||||
#include "../sound/SoundEngine.h"
|
#include "../sound/SoundEngine.h"
|
||||||
#include "../particle/ParticleEngine.h"
|
#include "../particle/ParticleEngine.h"
|
||||||
@@ -27,7 +28,7 @@ GameMode::GameMode( Minecraft* minecraft)
|
|||||||
|
|
||||||
/*virtual*/
|
/*virtual*/
|
||||||
Player* GameMode::createPlayer(Level* level) {
|
Player* GameMode::createPlayer(Level* level) {
|
||||||
return new LocalPlayer(minecraft, level, minecraft->user, level->dimension->id, isCreativeType());
|
return new LocalPlayer(minecraft, level, minecraft->options.getStringValue(OPTIONS_USERNAME), level->dimension->id, isCreativeType());
|
||||||
}
|
}
|
||||||
|
|
||||||
/*virtual*/
|
/*virtual*/
|
||||||
|
|||||||
@@ -27,6 +27,7 @@
|
|||||||
#include "../../platform/time.h"
|
#include "../../platform/time.h"
|
||||||
#include <cmath>
|
#include <cmath>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
#include <sstream>
|
||||||
|
|
||||||
float Gui::InvGuiScale = 1.0f / 3.0f;
|
float Gui::InvGuiScale = 1.0f / 3.0f;
|
||||||
float Gui::GuiScale = 1.0f / Gui::InvGuiScale;
|
float Gui::GuiScale = 1.0f / Gui::InvGuiScale;
|
||||||
@@ -841,7 +842,9 @@ void Gui::renderPlayerList(Font* font, int screenWidth, int screenHeight) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// player count title
|
// player count title
|
||||||
std::string titleText = "Players (" + std::to_string(playerNames.size()) + ")";
|
std::ostringstream titleStream;
|
||||||
|
titleStream << "Players (" << playerNames.size() << ")";
|
||||||
|
std::string titleText = titleStream.str();
|
||||||
float titleWidth = font->width(titleText);
|
float titleWidth = font->width(titleText);
|
||||||
|
|
||||||
if (titleWidth > maxNameWidth)
|
if (titleWidth > maxNameWidth)
|
||||||
|
|||||||
@@ -1,63 +0,0 @@
|
|||||||
#include "OptionsPane.h"
|
|
||||||
#include "OptionsGroup.h"
|
|
||||||
#include "OptionsItem.h"
|
|
||||||
#include "ImageButton.h"
|
|
||||||
#include "Slider.h"
|
|
||||||
#include "../../Minecraft.h"
|
|
||||||
|
|
||||||
OptionsPane::OptionsPane() {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void OptionsPane::setupPositions() {
|
|
||||||
int currentHeight = y + 1;
|
|
||||||
for(std::vector<GuiElement*>::iterator it = children.begin(); it != children.end(); ++it ) {
|
|
||||||
(*it)->width = width;
|
|
||||||
(*it)->y = currentHeight;
|
|
||||||
(*it)->x = x;
|
|
||||||
currentHeight += (*it)->height + 1;
|
|
||||||
}
|
|
||||||
height = currentHeight;
|
|
||||||
super::setupPositions();
|
|
||||||
}
|
|
||||||
|
|
||||||
OptionsGroup& OptionsPane::createOptionsGroup( std::string label ) {
|
|
||||||
OptionsGroup* newGroup = new OptionsGroup(label);
|
|
||||||
children.push_back(newGroup);
|
|
||||||
// create and return a new group index
|
|
||||||
return *newGroup;
|
|
||||||
}
|
|
||||||
|
|
||||||
void OptionsPane::createToggle( unsigned int group, std::string label, const Options::Option* option ) {
|
|
||||||
if(group > children.size()) return;
|
|
||||||
ImageDef def;
|
|
||||||
def.setSrc(IntRectangle(160, 206, 39, 20));
|
|
||||||
def.name = "gui/touchgui.png";
|
|
||||||
def.width = 39 * 0.7f;
|
|
||||||
def.height = 20 * 0.7f;
|
|
||||||
OptionButton* element = new OptionButton(option);
|
|
||||||
element->setImageDef(def, true);
|
|
||||||
OptionsItem* item = new OptionsItem(label, element);
|
|
||||||
((OptionsGroup*)children[group])->addChild(item);
|
|
||||||
setupPositions();
|
|
||||||
}
|
|
||||||
|
|
||||||
void OptionsPane::createProgressSlider( Minecraft* minecraft, unsigned int group, std::string label, const Options::Option* option, float progressMin/*=1.0f*/, float progressMax/*=1.0f */ ) {
|
|
||||||
if(group > children.size()) return;
|
|
||||||
Slider* element = new Slider(minecraft, option, progressMin, progressMax);
|
|
||||||
element->width = 100;
|
|
||||||
element->height = 20;
|
|
||||||
OptionsItem* item = new OptionsItem(label, element);
|
|
||||||
((OptionsGroup*)children[group])->addChild(item);
|
|
||||||
setupPositions();
|
|
||||||
}
|
|
||||||
|
|
||||||
void OptionsPane::createStepSlider( Minecraft* minecraft, unsigned int group, std::string label, const Options::Option* option, const std::vector<int>& stepVec ) {
|
|
||||||
if(group > children.size()) return;
|
|
||||||
Slider* element = new Slider(minecraft, option, stepVec);
|
|
||||||
element->width = 100;
|
|
||||||
element->height = 20;
|
|
||||||
OptionsItem* item = new OptionsItem(label, element);
|
|
||||||
((OptionsGroup*)children[group])->addChild(item);
|
|
||||||
setupPositions();
|
|
||||||
}
|
|
||||||
@@ -1,30 +0,0 @@
|
|||||||
#ifndef ITEMPANE_H__
|
|
||||||
#define ITEMPANE_H__
|
|
||||||
|
|
||||||
#include <string>
|
|
||||||
#include <vector>
|
|
||||||
#include "GuiElementContainer.h"
|
|
||||||
#include "../../../world/item/ItemInstance.h"
|
|
||||||
#include "../../../client/Options.h"
|
|
||||||
class Font;
|
|
||||||
class Textures;
|
|
||||||
class NinePatchLayer;
|
|
||||||
class ItemPane;
|
|
||||||
class OptionButton;
|
|
||||||
class Button;
|
|
||||||
class OptionsGroup;
|
|
||||||
class Slider;
|
|
||||||
class Minecraft;
|
|
||||||
class OptionsPane: public GuiElementContainer
|
|
||||||
{
|
|
||||||
typedef GuiElementContainer super;
|
|
||||||
public:
|
|
||||||
OptionsPane();
|
|
||||||
OptionsGroup& createOptionsGroup( std::string label );
|
|
||||||
void createToggle( unsigned int group, std::string label, const Options::Option* option );
|
|
||||||
void createProgressSlider(Minecraft* minecraft, unsigned int group, std::string label, const Options::Option* option, float progressMin=1.0f, float progressMax=1.0f );
|
|
||||||
void createStepSlider(Minecraft* minecraft, unsigned int group, std::string label, const Options::Option* option, const std::vector<int>& stepVec );
|
|
||||||
void setupPositions();
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif /*ITEMPANE_H__*/
|
|
||||||
@@ -1,24 +0,0 @@
|
|||||||
#include "SmallButton.h"
|
|
||||||
|
|
||||||
SmallButton::SmallButton( int id, int x, int y, const std::string& msg )
|
|
||||||
: super(id, x, y, 150, 20, msg),
|
|
||||||
option(NULL)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
SmallButton::SmallButton( int id, int x, int y, int width, int height, const std::string& msg )
|
|
||||||
: super(id, x, y, width, height, msg),
|
|
||||||
option(NULL)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
SmallButton::SmallButton( int id, int x, int y, Options::Option* item, const std::string& msg )
|
|
||||||
: super(id, x, y, 150, 20, msg),
|
|
||||||
option(item)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
Options::Option* SmallButton::getOption()
|
|
||||||
{
|
|
||||||
return option;
|
|
||||||
}
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
#ifndef NET_MINECRAFT_CLIENT_GUI_COMPONENTS__SmallButton_H__
|
|
||||||
#define NET_MINECRAFT_CLIENT_GUI_COMPONENTS__SmallButton_H__
|
|
||||||
|
|
||||||
//package net.minecraft.client.gui;
|
|
||||||
|
|
||||||
#include <string>
|
|
||||||
#include "Button.h"
|
|
||||||
#include "../../Options.h"
|
|
||||||
|
|
||||||
class SmallButton: public Button
|
|
||||||
{
|
|
||||||
typedef Button super;
|
|
||||||
public:
|
|
||||||
SmallButton(int id, int x, int y, const std::string& msg);
|
|
||||||
SmallButton(int id, int x, int y, int width, int height, const std::string& msg);
|
|
||||||
SmallButton(int id, int x, int y, Options::Option* item, const std::string& msg);
|
|
||||||
|
|
||||||
Options::Option* getOption();
|
|
||||||
private:
|
|
||||||
Options::Option* option;
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif /*NET_MINECRAFT_CLIENT_GUI_COMPONENTS__SmallButton_H__*/
|
|
||||||
@@ -1,26 +0,0 @@
|
|||||||
#ifndef NET_MINECRAFT_CLIENT_GUI_SCREENS__BuyGameScreen_H__
|
|
||||||
#define NET_MINECRAFT_CLIENT_GUI_SCREENS__BuyGameScreen_H__
|
|
||||||
|
|
||||||
#include "../Screen.h"
|
|
||||||
#include "../components/Button.h"
|
|
||||||
|
|
||||||
class BuyGameScreen: public Screen
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
BuyGameScreen() {}
|
|
||||||
virtual ~BuyGameScreen() {}
|
|
||||||
|
|
||||||
void init();
|
|
||||||
|
|
||||||
void render(int xm, int ym, float a);
|
|
||||||
|
|
||||||
void buttonClicked(Button* button) {
|
|
||||||
//if (button->id == bQuit.id)
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
//Button bQuit;
|
|
||||||
//Button bBuyGame;
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif /*NET_MINECRAFT_CLIENT_GUI_SCREENS__BuyGameScreen_H__*/
|
|
||||||
@@ -37,6 +37,8 @@ void CreditsScreen::init() {
|
|||||||
_lines.push_back("mschiller890");
|
_lines.push_back("mschiller890");
|
||||||
_lines.push_back("InviseDivine");
|
_lines.push_back("InviseDivine");
|
||||||
_lines.push_back("Kolyah35");
|
_lines.push_back("Kolyah35");
|
||||||
|
_lines.push_back("karson");
|
||||||
|
_lines.push_back("deepfriedwaffles");
|
||||||
_lines.push_back("");
|
_lines.push_back("");
|
||||||
// avoid color tags around the URL so it isn't mangled by the parser please
|
// avoid color tags around the URL so it isn't mangled by the parser please
|
||||||
_lines.push_back("Join our Discord server: https://discord.gg/c58YesBxve");
|
_lines.push_back("Join our Discord server: https://discord.gg/c58YesBxve");
|
||||||
|
|||||||
@@ -1,107 +0,0 @@
|
|||||||
#ifndef NET_MINECRAFT_CLIENT_GUI_SCREENS__InvalidLicenseScreen_H__
|
|
||||||
#define NET_MINECRAFT_CLIENT_GUI_SCREENS__InvalidLicenseScreen_H__
|
|
||||||
|
|
||||||
#include "../Screen.h"
|
|
||||||
#include "../components/Button.h"
|
|
||||||
#include "../../Minecraft.h"
|
|
||||||
#include "../../../LicenseCodes.h"
|
|
||||||
|
|
||||||
class InvalidLicenseScreen: public Screen
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
InvalidLicenseScreen(int id, bool hasBuyButton)
|
|
||||||
: _id(id),
|
|
||||||
_hasBuyButton(hasBuyButton),
|
|
||||||
_baseY(0),
|
|
||||||
bOk(0),
|
|
||||||
bBuy(0)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual ~InvalidLicenseScreen() {
|
|
||||||
delete bOk;
|
|
||||||
delete bBuy;
|
|
||||||
}
|
|
||||||
|
|
||||||
void init() {
|
|
||||||
if (minecraft->useTouchscreen()) {
|
|
||||||
bOk = new Touch::TButton(1, "Ok");
|
|
||||||
bBuy = new Touch::TButton(2, "Buy");
|
|
||||||
} else {
|
|
||||||
bOk = new Button(1, "Ok");
|
|
||||||
bBuy = new Button(2, "Buy");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (_hasBuyButton)
|
|
||||||
bOk->msg = "Quit";
|
|
||||||
|
|
||||||
if (!LicenseCodes::isOk(_id)) {
|
|
||||||
char buf[20] = {0};
|
|
||||||
sprintf(buf, "%d", _id);
|
|
||||||
|
|
||||||
desc1 = "License verification failed (error ";
|
|
||||||
desc1 += buf;
|
|
||||||
desc1 += ")";
|
|
||||||
desc2 = "Try again later.";
|
|
||||||
hint = "You need to be connected to the internet\n";
|
|
||||||
hint += "once while you start the game.";
|
|
||||||
}
|
|
||||||
|
|
||||||
buttons.push_back(bOk);
|
|
||||||
tabButtons.push_back(bOk);
|
|
||||||
|
|
||||||
if (_hasBuyButton) {
|
|
||||||
buttons.push_back(bBuy);
|
|
||||||
tabButtons.push_back(bBuy);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setupPositions() {
|
|
||||||
_baseY = height/5 + 6;
|
|
||||||
//if (_hasBuyButton)
|
|
||||||
_baseY -= 24;
|
|
||||||
|
|
||||||
bOk->width = bBuy->width = 200;
|
|
||||||
bOk->x = bBuy->x = (width - bOk->width) / 2;
|
|
||||||
bBuy->y = _baseY + 84;
|
|
||||||
bOk->y = bBuy->y + bBuy->height + 4;
|
|
||||||
|
|
||||||
if (!_hasBuyButton)
|
|
||||||
bOk->y -= 24;
|
|
||||||
}
|
|
||||||
|
|
||||||
void tick() {}
|
|
||||||
|
|
||||||
//void keyPressed(int eventKey) {}
|
|
||||||
|
|
||||||
void render(int xm, int ym, float a) {
|
|
||||||
renderDirtBackground(0);
|
|
||||||
drawCenteredString(minecraft->font, desc1, width/2, _baseY, 0xffffff);
|
|
||||||
drawCenteredString(minecraft->font, desc2, width/2, _baseY + 24, 0xffffff);
|
|
||||||
|
|
||||||
drawCenteredString(minecraft->font, hint, width/2, _baseY + 60, 0xffffff);
|
|
||||||
|
|
||||||
Screen::render(xm, ym, a);
|
|
||||||
}
|
|
||||||
|
|
||||||
void buttonClicked(Button* button) {
|
|
||||||
if (button->id == bOk->id) {
|
|
||||||
minecraft->quit();
|
|
||||||
}
|
|
||||||
if (button->id == bBuy->id) {
|
|
||||||
minecraft->platform()->buyGame();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
private:
|
|
||||||
int _id;
|
|
||||||
std::string desc1;
|
|
||||||
std::string desc2;
|
|
||||||
std::string hint;
|
|
||||||
|
|
||||||
Button* bOk;
|
|
||||||
Button* bBuy;
|
|
||||||
bool _hasBuyButton;
|
|
||||||
int _baseY;
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif /*NET_MINECRAFT_CLIENT_GUI_SCREENS__InvalidLicenseScreen_H__*/
|
|
||||||
@@ -9,6 +9,7 @@
|
|||||||
|
|
||||||
#include "../components/ImageButton.h"
|
#include "../components/ImageButton.h"
|
||||||
#include "../components/OptionsGroup.h"
|
#include "../components/OptionsGroup.h"
|
||||||
|
#include "platform/input/Keyboard.h"
|
||||||
|
|
||||||
OptionsScreen::OptionsScreen()
|
OptionsScreen::OptionsScreen()
|
||||||
: btnClose(NULL),
|
: btnClose(NULL),
|
||||||
@@ -153,18 +154,13 @@ void OptionsScreen::buttonClicked(Button* button) {
|
|||||||
if (button == btnClose) {
|
if (button == btnClose) {
|
||||||
minecraft->options.save();
|
minecraft->options.save();
|
||||||
minecraft->screenChooser.setScreen(SCREEN_STARTMENU);
|
minecraft->screenChooser.setScreen(SCREEN_STARTMENU);
|
||||||
|
|
||||||
}
|
}
|
||||||
else if (button->id > 1 && button->id < 7) {
|
else if (button->id > 1 && button->id < 7) {
|
||||||
|
|
||||||
int categoryButton = button->id - categoryButtons[0]->id;
|
int categoryButton = button->id - categoryButtons[0]->id;
|
||||||
selectCategory(categoryButton);
|
selectCategory(categoryButton);
|
||||||
|
|
||||||
}
|
}
|
||||||
else if (button == btnCredits) {
|
else if (button == btnCredits) {
|
||||||
|
|
||||||
minecraft->setScreen(new CreditsScreen());
|
minecraft->setScreen(new CreditsScreen());
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -221,9 +217,6 @@ void OptionsScreen::generateOptionScreens() {
|
|||||||
|
|
||||||
// // Graphics Pane
|
// // Graphics Pane
|
||||||
optionPanes[3]->addOptionItem(OPTIONS_FANCY_GRAPHICS, minecraft)
|
optionPanes[3]->addOptionItem(OPTIONS_FANCY_GRAPHICS, minecraft)
|
||||||
// .addOptionItem(&Options::Option::VIEW_BOBBING, minecraft)
|
|
||||||
// .addOptionItem(&Options::Option::AMBIENT_OCCLUSION, minecraft)
|
|
||||||
// .addOptionItem(&Options::Option::ANAGLYPH, minecraft)
|
|
||||||
.addOptionItem(OPTIONS_LIMIT_FRAMERATE, minecraft)
|
.addOptionItem(OPTIONS_LIMIT_FRAMERATE, minecraft)
|
||||||
.addOptionItem(OPTIONS_VSYNC, minecraft)
|
.addOptionItem(OPTIONS_VSYNC, minecraft)
|
||||||
.addOptionItem(OPTIONS_RENDER_DEBUG, minecraft)
|
.addOptionItem(OPTIONS_RENDER_DEBUG, minecraft)
|
||||||
@@ -254,6 +247,8 @@ void OptionsScreen::mouseReleased(int x, int y, int buttonNum) {
|
|||||||
void OptionsScreen::keyPressed(int eventKey) {
|
void OptionsScreen::keyPressed(int eventKey) {
|
||||||
if (currentOptionsGroup != NULL)
|
if (currentOptionsGroup != NULL)
|
||||||
currentOptionsGroup->keyPressed(minecraft, eventKey);
|
currentOptionsGroup->keyPressed(minecraft, eventKey);
|
||||||
|
if (eventKey == Keyboard::KEY_ESCAPE)
|
||||||
|
minecraft->options.save();
|
||||||
|
|
||||||
super::keyPressed(eventKey);
|
super::keyPressed(eventKey);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
#include "UsernameScreen.h"
|
#include "UsernameScreen.h"
|
||||||
#include "StartMenuScreen.h"
|
#include "StartMenuScreen.h"
|
||||||
#include "../../Minecraft.h"
|
#include "../../Minecraft.h"
|
||||||
#include "../../User.h"
|
|
||||||
#include "../Font.h"
|
#include "../Font.h"
|
||||||
#include "../components/Button.h"
|
#include "../components/Button.h"
|
||||||
#include "../../../platform/input/Keyboard.h"
|
#include "../../../platform/input/Keyboard.h"
|
||||||
@@ -75,7 +74,6 @@ void UsernameScreen::buttonClicked(Button* button)
|
|||||||
if (button == &_btnDone && !tUsername.text.empty()) {
|
if (button == &_btnDone && !tUsername.text.empty()) {
|
||||||
minecraft->options.set(OPTIONS_USERNAME, tUsername.text);
|
minecraft->options.set(OPTIONS_USERNAME, tUsername.text);
|
||||||
minecraft->options.save();
|
minecraft->options.save();
|
||||||
minecraft->user->name = tUsername.text;
|
|
||||||
minecraft->setScreen(NULL); // goes to StartMenuScreen
|
minecraft->setScreen(NULL); // goes to StartMenuScreen
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
#include "../Screen.h"
|
#include "../Screen.h"
|
||||||
#include "../components/Button.h"
|
#include "../components/Button.h"
|
||||||
#include "/client/gui/components/TextBox.h"
|
#include "client/gui/components/TextBox.h"
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
class UsernameScreen : public Screen
|
class UsernameScreen : public Screen
|
||||||
|
|||||||
@@ -86,21 +86,21 @@ public:
|
|||||||
SelectWorldScreen();
|
SelectWorldScreen();
|
||||||
virtual ~SelectWorldScreen();
|
virtual ~SelectWorldScreen();
|
||||||
|
|
||||||
virtual void init();
|
virtual void init() override;
|
||||||
virtual void setupPositions();
|
virtual void setupPositions() override;
|
||||||
|
|
||||||
virtual void tick();
|
virtual void tick() override;
|
||||||
virtual void render(int xm, int ym, float a);
|
virtual void render(int xm, int ym, float a) override;
|
||||||
|
|
||||||
virtual bool isIndexValid(int index);
|
virtual bool isIndexValid(int index);
|
||||||
virtual bool handleBackEvent(bool isDown);
|
virtual bool handleBackEvent(bool isDown) override;
|
||||||
virtual void buttonClicked(Button* button);
|
virtual void buttonClicked(Button* button) override;
|
||||||
virtual void keyPressed(int eventKey);
|
virtual void keyPressed(int eventKey) override;
|
||||||
|
|
||||||
// support for mouse wheel when desktop code uses touch variant
|
// support for mouse wheel when desktop code uses touch variant
|
||||||
virtual void mouseWheel(int dx, int dy, int xm, int ym) override;
|
virtual void mouseWheel(int dx, int dy, int xm, int ym) override;
|
||||||
|
|
||||||
bool isInGameScreen();
|
bool isInGameScreen() override;
|
||||||
private:
|
private:
|
||||||
void loadLevelSource();
|
void loadLevelSource();
|
||||||
std::string getUniqueLevelName(const std::string& level);
|
std::string getUniqueLevelName(const std::string& level);
|
||||||
|
|||||||
@@ -226,6 +226,7 @@ static void* fetchSkinForPlayer(void* param) {
|
|||||||
std::string skinUrl = getSkinUrlForUsername(player->name);
|
std::string skinUrl = getSkinUrlForUsername(player->name);
|
||||||
if (skinUrl.empty()) {
|
if (skinUrl.empty()) {
|
||||||
LOGW("[Skin] skin URL lookup failed for %s\n", player->name.c_str());
|
LOGW("[Skin] skin URL lookup failed for %s\n", player->name.c_str());
|
||||||
|
player->setTextureName("mob/char.png");
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -242,11 +243,13 @@ static void* fetchSkinForPlayer(void* param) {
|
|||||||
fwrite(skinData.data(), 1, skinData.size(), fp);
|
fwrite(skinData.data(), 1, skinData.size(), fp);
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
LOGI("[Skin] cached skin to %s\n", cacheFile.c_str());
|
LOGI("[Skin] cached skin to %s\n", cacheFile.c_str());
|
||||||
} else {
|
|
||||||
LOGW("[Skin] failed to write skin cache %s\n", cacheFile.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
player->setTextureName("skins/" + player->name + ".png");
|
player->setTextureName("skins/" + player->name + ".png");
|
||||||
|
} else {
|
||||||
|
LOGW("[Skin] failed to write skin cache %s\n", cacheFile.c_str());
|
||||||
|
player->setTextureName("mob/char.png");
|
||||||
|
}
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -287,11 +290,12 @@ static void* fetchCapeForPlayer(void* param) {
|
|||||||
fwrite(capeData.data(), 1, capeData.size(), fp);
|
fwrite(capeData.data(), 1, capeData.size(), fp);
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
LOGI("[Cape] cached cape to %s\n", cacheFile.c_str());
|
LOGI("[Cape] cached cape to %s\n", cacheFile.c_str());
|
||||||
|
|
||||||
|
player->setCapeTextureName("capes/" + player->name + ".png");
|
||||||
} else {
|
} else {
|
||||||
LOGW("[Cape] failed to write cape cache %s\n", cacheFile.c_str());
|
LOGW("[Cape] failed to write cape cache %s\n", cacheFile.c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
player->setCapeTextureName("capes/" + player->name + ".png");
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -310,7 +314,7 @@ static bool isJumpable(int tileId) {
|
|||||||
|
|
||||||
} // anonymous namespace
|
} // anonymous namespace
|
||||||
|
|
||||||
LocalPlayer::LocalPlayer(Minecraft* minecraft, Level* level, User* user, int dimension, bool isCreative)
|
LocalPlayer::LocalPlayer(Minecraft* minecraft, Level* level, const std::string& username, int dimension, bool isCreative)
|
||||||
: Player(level, isCreative),
|
: Player(level, isCreative),
|
||||||
minecraft(minecraft),
|
minecraft(minecraft),
|
||||||
input(NULL),
|
input(NULL),
|
||||||
@@ -326,9 +330,13 @@ LocalPlayer::LocalPlayer(Minecraft* minecraft, Level* level, User* user, int dim
|
|||||||
_init();
|
_init();
|
||||||
|
|
||||||
#ifndef STANDALONE_SERVER
|
#ifndef STANDALONE_SERVER
|
||||||
if (user != NULL && !user->name.empty()) {
|
printf("%s \n", name.c_str());
|
||||||
this->name = user->name;
|
|
||||||
|
if (!name.empty()) {
|
||||||
|
this->name = name;
|
||||||
|
printf("test \n");
|
||||||
// Fetch user skin and cape from Mojang servers in the background (avoids blocking the main thread)
|
// Fetch user skin and cape from Mojang servers in the background (avoids blocking the main thread)
|
||||||
|
// TODO: Fix this memory leak
|
||||||
new CThread(fetchSkinForPlayer, this);
|
new CThread(fetchSkinForPlayer, this);
|
||||||
new CThread(fetchCapeForPlayer, this);
|
new CThread(fetchCapeForPlayer, this);
|
||||||
}
|
}
|
||||||
@@ -350,8 +358,8 @@ void LocalPlayer::calculateFlight(float xa, float ya, float za) {
|
|||||||
za = za * flySpeed;
|
za = za * flySpeed;
|
||||||
|
|
||||||
#ifdef ANDROID
|
#ifdef ANDROID
|
||||||
if (Keyboard::isKeyDown(103)) ya = .2f * minecraft->options.flySpeed;
|
if (Keyboard::isKeyDown(103)) ya = .2f * flySpeed;
|
||||||
if (Keyboard::isKeyDown(102)) ya = -.2f * minecraft->options.flySpeed;
|
if (Keyboard::isKeyDown(102)) ya = -.2f * flySpeed;
|
||||||
#else
|
#else
|
||||||
if (Keyboard::isKeyDown(Keyboard::KEY_E)) ya = .2f * flySpeed;
|
if (Keyboard::isKeyDown(Keyboard::KEY_E)) ya = .2f * flySpeed;
|
||||||
if (Keyboard::isKeyDown(Keyboard::KEY_Q)) ya = -.2f * flySpeed;
|
if (Keyboard::isKeyDown(Keyboard::KEY_Q)) ya = -.2f * flySpeed;
|
||||||
|
|||||||
@@ -4,8 +4,6 @@
|
|||||||
//package net.minecraft.client.player;
|
//package net.minecraft.client.player;
|
||||||
|
|
||||||
#include "input/IMoveInput.h"
|
#include "input/IMoveInput.h"
|
||||||
#include "../User.h"
|
|
||||||
#include "../../platform/input/Keyboard.h"
|
|
||||||
#include "../../util/SmoothFloat.h"
|
#include "../../util/SmoothFloat.h"
|
||||||
#include "../../world/entity/player/Player.h"
|
#include "../../world/entity/player/Player.h"
|
||||||
|
|
||||||
@@ -17,7 +15,7 @@ class LocalPlayer: public Player
|
|||||||
{
|
{
|
||||||
typedef Player super;
|
typedef Player super;
|
||||||
public:
|
public:
|
||||||
LocalPlayer(Minecraft* minecraft, Level* level, User* user, int dimension, bool isCreative);
|
LocalPlayer(Minecraft* minecraft, Level* level, const std::string& username, int dimension, bool isCreative);
|
||||||
~LocalPlayer();
|
~LocalPlayer();
|
||||||
|
|
||||||
void _init();
|
void _init();
|
||||||
|
|||||||
@@ -4,6 +4,8 @@
|
|||||||
//package net.minecraft.client.player;
|
//package net.minecraft.client.player;
|
||||||
|
|
||||||
#include "KeyboardInput.h"
|
#include "KeyboardInput.h"
|
||||||
|
#include "platform/input/Controller.h"
|
||||||
|
#include "world/entity/player/Player.h"
|
||||||
|
|
||||||
// @note: This is just copy-pasted from KeyboardInput right now.
|
// @note: This is just copy-pasted from KeyboardInput right now.
|
||||||
class XperiaPlayInput: public KeyboardInput
|
class XperiaPlayInput: public KeyboardInput
|
||||||
|
|||||||
@@ -655,7 +655,7 @@ void GameRenderer::pick(float a) {
|
|||||||
float range = mc->gameMode->getPickRange();
|
float range = mc->gameMode->getPickRange();
|
||||||
bool isPicking = true;
|
bool isPicking = true;
|
||||||
#ifndef PLATFORM_DESKTOP
|
#ifndef PLATFORM_DESKTOP
|
||||||
bool freeform = mc->useTouchscreen() && !mc->options.isJoyTouchArea;
|
bool freeform = mc->useTouchscreen() && !mc->options.getBooleanValue(OPTIONS_IS_JOY_TOUCH_AREA);
|
||||||
#else
|
#else
|
||||||
bool freeform = false;
|
bool freeform = false;
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -79,6 +79,9 @@ RenderChunk Tesselator::end( bool useMine, int bufferId )
|
|||||||
const int o_vertices = vertices;
|
const int o_vertices = vertices;
|
||||||
|
|
||||||
if (vertices > 0) {
|
if (vertices > 0) {
|
||||||
|
if (p <= 0 || p > maxVertices) { clear(); return RenderChunk(); }
|
||||||
|
int bytes = p * sizeof(VERTEX);
|
||||||
|
if (bytes <= 0) return RenderChunk();
|
||||||
if (++vboId >= vboCounts)
|
if (++vboId >= vboCounts)
|
||||||
vboId = 0;
|
vboId = 0;
|
||||||
|
|
||||||
@@ -92,9 +95,9 @@ RenderChunk Tesselator::end( bool useMine, int bufferId )
|
|||||||
bufferId = vboIds[vboId];
|
bufferId = vboIds[vboId];
|
||||||
#endif
|
#endif
|
||||||
int access = GL_STATIC_DRAW;//(accessMode==ACCESS_DYNAMIC) ? GL_DYNAMIC_DRAW : GL_STATIC_DRAW;
|
int access = GL_STATIC_DRAW;//(accessMode==ACCESS_DYNAMIC) ? GL_DYNAMIC_DRAW : GL_STATIC_DRAW;
|
||||||
int bytes = p * sizeof(VERTEX);
|
|
||||||
glBindBuffer2(GL_ARRAY_BUFFER, bufferId);
|
glBindBuffer2(GL_ARRAY_BUFFER, bufferId);
|
||||||
glBufferData2(GL_ARRAY_BUFFER, bytes, _varray, access); // GL_STREAM_DRAW
|
glBufferData2(GL_ARRAY_BUFFER, bytes, _varray, access); // GL_STREAM_DRAW
|
||||||
|
|
||||||
totalSize += bytes;
|
totalSize += bytes;
|
||||||
|
|
||||||
#ifndef USE_VBO
|
#ifndef USE_VBO
|
||||||
@@ -264,6 +267,7 @@ void Tesselator::vertex( float x, float y, float z )
|
|||||||
for (int i = 0; i < 2; i++) {
|
for (int i = 0; i < 2; i++) {
|
||||||
|
|
||||||
const int offs = 3 - i;
|
const int offs = 3 - i;
|
||||||
|
if (p - offs < 0 || p >= maxVertices) { clear(); return; }
|
||||||
VERTEX& src = _varray[p - offs];
|
VERTEX& src = _varray[p - offs];
|
||||||
VERTEX& dst = _varray[p];
|
VERTEX& dst = _varray[p];
|
||||||
|
|
||||||
@@ -287,6 +291,7 @@ void Tesselator::vertex( float x, float y, float z )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (p < 0 || p >= maxVertices) { clear(); return; }
|
||||||
VERTEX& vertex = _varray[p];
|
VERTEX& vertex = _varray[p];
|
||||||
|
|
||||||
if (hasTexture) {
|
if (hasTexture) {
|
||||||
@@ -377,13 +382,15 @@ void Tesselator::draw()
|
|||||||
tesselating = false;
|
tesselating = false;
|
||||||
|
|
||||||
if (vertices > 0) {
|
if (vertices > 0) {
|
||||||
|
if (p <= 0 || p > maxVertices) { clear(); return; }
|
||||||
|
int bytes = p * sizeof(VERTEX);
|
||||||
|
if (bytes <= 0) { clear(); return; }
|
||||||
if (++vboId >= vboCounts)
|
if (++vboId >= vboCounts)
|
||||||
vboId = 0;
|
vboId = 0;
|
||||||
|
|
||||||
int bufferId = vboIds[vboId];
|
int bufferId = vboIds[vboId];
|
||||||
|
|
||||||
int access = GL_DYNAMIC_DRAW;//(accessMode==ACCESS_DYNAMIC) ? GL_DYNAMIC_DRAW : GL_STATIC_DRAW;
|
int access = GL_DYNAMIC_DRAW;//(accessMode==ACCESS_DYNAMIC) ? GL_DYNAMIC_DRAW : GL_STATIC_DRAW;
|
||||||
int bytes = p * sizeof(VERTEX);
|
|
||||||
glBindBuffer2(GL_ARRAY_BUFFER, bufferId);
|
glBindBuffer2(GL_ARRAY_BUFFER, bufferId);
|
||||||
glBufferData2(GL_ARRAY_BUFFER, bytes, _varray, access); // GL_STREAM_DRAW
|
glBufferData2(GL_ARRAY_BUFFER, bytes, _varray, access); // GL_STREAM_DRAW
|
||||||
|
|
||||||
|
|||||||
@@ -47,9 +47,13 @@ void glInit()
|
|||||||
}
|
}
|
||||||
|
|
||||||
void anGenBuffers(GLsizei n, GLuint* buffers) {
|
void anGenBuffers(GLsizei n, GLuint* buffers) {
|
||||||
|
#ifdef __EMSCRIPTEN__
|
||||||
|
glGenBuffers(n, buffers);
|
||||||
|
#else
|
||||||
static GLuint k = 1;
|
static GLuint k = 1;
|
||||||
for (int i = 0; i < n; ++i)
|
for (int i = 0; i < n; ++i)
|
||||||
buffers[i] = ++k;
|
buffers[i] = ++k;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef USE_VBO
|
#ifdef USE_VBO
|
||||||
|
|||||||
@@ -10,13 +10,13 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Other systems might run it, if they #define OPENGL_ES
|
// Other systems might run it, if they #define OPENGL_ES
|
||||||
#if defined(OPENGL_ES) // || defined(ANDROID)
|
// #if defined(OPENGL_ES) // || defined(ANDROID)
|
||||||
#define USE_VBO
|
#define USE_VBO
|
||||||
#define GL_QUADS 0x0007
|
#define GL_QUADS 0x0007
|
||||||
#if defined(__APPLE__)
|
#if defined(__APPLE__)
|
||||||
#import <OpenGLES/ES1/gl.h>
|
#import <OpenGLES/ES1/gl.height>
|
||||||
#import <OpenGLES/ES1/glext.h>
|
#import <OpenGLES/ES1/glext.height>
|
||||||
#elif defined(ANDROID)
|
#elif defined(ANDROID) || defined(__EMSCRIPTEN__)
|
||||||
#include <GLES/gl.h>
|
#include <GLES/gl.h>
|
||||||
#include <GLES/glext.h>
|
#include <GLES/glext.h>
|
||||||
#else
|
#else
|
||||||
@@ -28,18 +28,18 @@
|
|||||||
#define glClearDepthf(x) glClearDepth(x)
|
#define glClearDepthf(x) glClearDepth(x)
|
||||||
#define glDepthRangef(a,b) glDepthRange(a,b)
|
#define glDepthRangef(a,b) glDepthRange(a,b)
|
||||||
#endif
|
#endif
|
||||||
#else
|
// #else
|
||||||
// Uglyness to fix redeclaration issues
|
// // Uglyness to fix redeclaration issues
|
||||||
#ifdef WIN32
|
// #ifdef WIN32
|
||||||
#include <WinSock2.h>
|
// #include <WinSock2.h>
|
||||||
#include <Windows.h>
|
// #include <Windows.h>
|
||||||
#endif
|
// #endif
|
||||||
#include <gl/glew.h>
|
// #include <gl/glew.h>
|
||||||
#include <gl/GL.h>
|
// #include <gl/GL.h>
|
||||||
|
|
||||||
#define glFogx(a,b) glFogi(a,b)
|
// #define glFogx(a,b) glFogi(a,b)
|
||||||
#define glOrthof(a,b,c,d,e,f) glOrtho(a,b,c,d,e,f)
|
// #define glOrthof(a,b,c,d,e,f) glOrtho(a,b,c,d,e,f)
|
||||||
#endif
|
// #endif
|
||||||
|
|
||||||
|
|
||||||
#define GLERRDEBUG 1
|
#define GLERRDEBUG 1
|
||||||
|
|||||||
@@ -25,7 +25,7 @@
|
|||||||
#include "platform/input/Mouse.h"
|
#include "platform/input/Mouse.h"
|
||||||
#include "platform/input/Multitouch.h"
|
#include "platform/input/Multitouch.h"
|
||||||
|
|
||||||
#include "EGLConfigPrinter.h"
|
#include "EglConfigPrinter.h"
|
||||||
|
|
||||||
const int BroadcastPort = 9991;
|
const int BroadcastPort = 9991;
|
||||||
|
|
||||||
|
|||||||
@@ -23,7 +23,7 @@
|
|||||||
#include "platform/input/Mouse.h"
|
#include "platform/input/Mouse.h"
|
||||||
#include "platform/input/Controller.h"
|
#include "platform/input/Controller.h"
|
||||||
|
|
||||||
#include "EGLConfigPrinter.h"
|
#include "EglConfigPrinter.h"
|
||||||
|
|
||||||
const int BroadcastPort = 9991;
|
const int BroadcastPort = 9991;
|
||||||
|
|
||||||
|
|||||||
@@ -2,9 +2,9 @@
|
|||||||
#define MAIN_GLFW_H__
|
#define MAIN_GLFW_H__
|
||||||
|
|
||||||
#include "App.h"
|
#include "App.h"
|
||||||
#include "GLFW/glfw3.h"
|
#include "client/renderer/entity/PlayerRenderer.h"
|
||||||
#include "client/renderer/gles.h"
|
#include "client/renderer/gles.h"
|
||||||
#include "SharedConstants.h"
|
#include "GLFW/glfw3.h"
|
||||||
|
|
||||||
#include <cstdio>
|
#include <cstdio>
|
||||||
#include <chrono>
|
#include <chrono>
|
||||||
@@ -12,9 +12,10 @@
|
|||||||
#include "platform/input/Keyboard.h"
|
#include "platform/input/Keyboard.h"
|
||||||
#include "platform/input/Mouse.h"
|
#include "platform/input/Mouse.h"
|
||||||
#include "platform/input/Multitouch.h"
|
#include "platform/input/Multitouch.h"
|
||||||
#include "util/Mth.h"
|
|
||||||
#include "AppPlatform_glfw.h"
|
#include "AppPlatform_glfw.h"
|
||||||
|
#ifdef __EMSCRIPTEN__
|
||||||
|
#include <emscripten/emscripten.h>
|
||||||
|
#endif
|
||||||
static App* g_app = 0;
|
static App* g_app = 0;
|
||||||
|
|
||||||
int transformKey(int glfwkey) {
|
int transformKey(int glfwkey) {
|
||||||
@@ -112,12 +113,39 @@ void error_callback(int error, const char* desc) {
|
|||||||
printf("Error: %s\n", desc);
|
printf("Error: %s\n", desc);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
using clock = std::chrono::steady_clock;
|
||||||
|
auto frameStart = clock::now();
|
||||||
|
|
||||||
|
g_app->update();
|
||||||
|
|
||||||
|
glfwSwapBuffers(((AppPlatform_glfw*)g_app->platform())->window);
|
||||||
|
glfwPollEvents();
|
||||||
|
|
||||||
|
glfwSwapInterval(((MAIN_CLASS*)g_app)->options.getBooleanValue(OPTIONS_VSYNC) ? 1 : 0);
|
||||||
|
if(((MAIN_CLASS*)g_app)->options.getBooleanValue(OPTIONS_LIMIT_FRAMERATE)) {
|
||||||
|
auto frameEnd = clock::now();
|
||||||
|
auto elapsed = std::chrono::duration_cast<std::chrono::microseconds>(frameEnd - frameStart);
|
||||||
|
auto target = std::chrono::microseconds(33333); // ~30 fps
|
||||||
|
if(elapsed < target)
|
||||||
|
std::this_thread::sleep_for(target - elapsed);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int main(void) {
|
int main(void) {
|
||||||
AppContext appContext;
|
AppContext appContext;
|
||||||
|
|
||||||
#ifndef STANDALONE_SERVER
|
#ifndef STANDALONE_SERVER
|
||||||
// Platform init.
|
// Platform init.
|
||||||
appContext.platform = new AppPlatform_glfw();
|
appContext.platform = new AppPlatform_glfw();
|
||||||
|
#if defined(DEBUG) && defined(__EMSCRIPTEN__)
|
||||||
|
EM_ASM({
|
||||||
|
console.log(FS.readdir("/"));
|
||||||
|
console.log(FS.readdir("/data"));
|
||||||
|
console.log(FS.readdir("/data/images"));
|
||||||
|
});
|
||||||
|
#endif
|
||||||
|
|
||||||
glfwSetErrorCallback(error_callback);
|
glfwSetErrorCallback(error_callback);
|
||||||
|
|
||||||
@@ -126,26 +154,36 @@ int main(void) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
glfwWindowHint(GLFW_CONTEXT_CREATION_API, GLFW_NATIVE_CONTEXT_API);
|
glfwWindowHint(GLFW_CONTEXT_CREATION_API, GLFW_NATIVE_CONTEXT_API);
|
||||||
|
#ifndef __EMSCRIPTEN__
|
||||||
glfwWindowHint(GLFW_CLIENT_API, GLFW_OPENGL_API);
|
glfwWindowHint(GLFW_CLIENT_API, GLFW_OPENGL_API);
|
||||||
glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 2);
|
glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 2);
|
||||||
glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 1);
|
glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 1);
|
||||||
|
#else
|
||||||
|
glfwWindowHint(GLFW_CLIENT_API, GLFW_OPENGL_ES_API);
|
||||||
|
glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 1);
|
||||||
|
glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 0);
|
||||||
|
#endif
|
||||||
|
|
||||||
GLFWwindow* window = glfwCreateWindow(appContext.platform->getScreenWidth(), appContext.platform->getScreenHeight(), "main", NULL, NULL);
|
AppPlatform_glfw* platform = (AppPlatform_glfw*)appContext.platform;
|
||||||
|
|
||||||
if (window == NULL) {
|
platform->window = glfwCreateWindow(appContext.platform->getScreenWidth(), appContext.platform->getScreenHeight(), "main", NULL, NULL);
|
||||||
|
|
||||||
|
if (platform->window == NULL) {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
glfwSetKeyCallback(window, key_callback);
|
glfwSetKeyCallback(platform->window, key_callback);
|
||||||
glfwSetCharCallback(window, character_callback);
|
glfwSetCharCallback(platform->window, character_callback);
|
||||||
glfwSetCursorPosCallback(window, cursor_position_callback);
|
glfwSetCursorPosCallback(platform->window, cursor_position_callback);
|
||||||
glfwSetMouseButtonCallback(window, mouse_button_callback);
|
glfwSetMouseButtonCallback(platform->window, mouse_button_callback);
|
||||||
glfwSetScrollCallback(window, scroll_callback);
|
glfwSetScrollCallback(platform->window, scroll_callback);
|
||||||
glfwSetWindowSizeCallback(window, window_size_callback);
|
glfwSetWindowSizeCallback(platform->window, window_size_callback);
|
||||||
|
|
||||||
glfwMakeContextCurrent(window);
|
glfwMakeContextCurrent(platform->window);
|
||||||
|
#ifndef __EMSCRIPTEN__
|
||||||
gladLoadGLLoader((GLADloadproc)glfwGetProcAddress);
|
gladLoadGLLoader((GLADloadproc)glfwGetProcAddress);
|
||||||
glfwSwapInterval(0);
|
glfwSwapInterval(0);
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
App* app = new MAIN_CLASS();
|
App* app = new MAIN_CLASS();
|
||||||
@@ -156,25 +194,14 @@ int main(void) {
|
|||||||
g_app->init(appContext);
|
g_app->init(appContext);
|
||||||
g_app->setSize(appContext.platform->getScreenWidth(), appContext.platform->getScreenHeight());
|
g_app->setSize(appContext.platform->getScreenWidth(), appContext.platform->getScreenHeight());
|
||||||
|
|
||||||
|
#ifdef __EMSCRIPTEN__
|
||||||
|
emscripten_set_main_loop(loop, 0, 1);
|
||||||
|
#else
|
||||||
// Main event loop
|
// Main event loop
|
||||||
using clock = std::chrono::steady_clock;
|
while(!glfwWindowShouldClose(platform->window) && !app->wantToQuit()) {
|
||||||
while(!glfwWindowShouldClose(window) && !app->wantToQuit()) {
|
loop();
|
||||||
auto frameStart = clock::now();
|
|
||||||
|
|
||||||
app->update();
|
|
||||||
|
|
||||||
glfwSwapBuffers(window);
|
|
||||||
glfwPollEvents();
|
|
||||||
|
|
||||||
glfwSwapInterval(((MAIN_CLASS*)app)->options.getBooleanValue(OPTIONS_VSYNC) ? 1 : 0);
|
|
||||||
if(((MAIN_CLASS*)app)->options.getBooleanValue(OPTIONS_LIMIT_FRAMERATE)) {
|
|
||||||
auto frameEnd = clock::now();
|
|
||||||
auto elapsed = std::chrono::duration_cast<std::chrono::microseconds>(frameEnd - frameStart);
|
|
||||||
auto target = std::chrono::microseconds(33333); // ~30 fps
|
|
||||||
if(elapsed < target)
|
|
||||||
std::this_thread::sleep_for(target - elapsed);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
delete app;
|
delete app;
|
||||||
|
|
||||||
@@ -184,7 +211,7 @@ int main(void) {
|
|||||||
|
|
||||||
#ifndef STANDALONE_SERVER
|
#ifndef STANDALONE_SERVER
|
||||||
// Exit.
|
// Exit.
|
||||||
glfwDestroyWindow(window);
|
glfwDestroyWindow(platform->window);
|
||||||
glfwTerminate();
|
glfwTerminate();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
|
|
||||||
#include "ClientSideNetworkHandler.h"
|
#include "ClientSideNetworkHandler.h"
|
||||||
|
#include "client/Options.h"
|
||||||
#include "packet/PacketInclude.h"
|
#include "packet/PacketInclude.h"
|
||||||
#include "RakNetInstance.h"
|
#include "RakNetInstance.h"
|
||||||
#include "../world/level/chunk/ChunkSource.h"
|
#include "../world/level/chunk/ChunkSource.h"
|
||||||
@@ -85,7 +86,7 @@ void ClientSideNetworkHandler::onConnect(const RakNet::RakNetGUID& hostGuid)
|
|||||||
serverGuid = hostGuid;
|
serverGuid = hostGuid;
|
||||||
|
|
||||||
clearChunksLoaded();
|
clearChunksLoaded();
|
||||||
LoginPacket packet(minecraft->user->name.c_str(), SharedConstants::NetworkProtocolVersion);
|
LoginPacket packet(minecraft->options.getStringValue(OPTIONS_USERNAME).c_str(), SharedConstants::NetworkProtocolVersion);
|
||||||
raknetInstance->send(packet);
|
raknetInstance->send(packet);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -157,7 +158,7 @@ void ClientSideNetworkHandler::handle(const RakNet::RakNetGUID& source, StartGam
|
|||||||
level->isClientSide = true;
|
level->isClientSide = true;
|
||||||
|
|
||||||
bool isCreative = (packet->gameType == GameType::Creative);
|
bool isCreative = (packet->gameType == GameType::Creative);
|
||||||
LocalPlayer* player = new LocalPlayer(minecraft, level, minecraft->user, level->dimension->id, isCreative);
|
LocalPlayer* player = new LocalPlayer(minecraft, level, minecraft->options.getStringValue(OPTIONS_USERNAME), level->dimension->id, isCreative);
|
||||||
player->owner = rakPeer->GetMyGUID();
|
player->owner = rakPeer->GetMyGUID();
|
||||||
player->entityId = packet->entityId;
|
player->entityId = packet->entityId;
|
||||||
player->moveTo(packet->x, packet->y, packet->z, player->yRot, player->xRot);
|
player->moveTo(packet->x, packet->y, packet->z, player->yRot, player->xRot);
|
||||||
|
|||||||
@@ -66,7 +66,9 @@ public:
|
|||||||
|
|
||||||
void displayGameMessage(const std::string& message);
|
void displayGameMessage(const std::string& message);
|
||||||
private:
|
private:
|
||||||
|
/**
|
||||||
|
* @brief Send packet to all players
|
||||||
|
*/
|
||||||
void redistributePacket(Packet* packet, const RakNet::RakNetGUID& fromPlayer);
|
void redistributePacket(Packet* packet, const RakNet::RakNetGUID& fromPlayer);
|
||||||
Player* getPlayer(const RakNet::RakNetGUID& source);
|
Player* getPlayer(const RakNet::RakNetGUID& source);
|
||||||
|
|
||||||
|
|||||||
@@ -25,7 +25,7 @@
|
|||||||
&m_threadID // pointer to receive thread ID
|
&m_threadID // pointer to receive thread ID
|
||||||
);
|
);
|
||||||
#endif
|
#endif
|
||||||
#if defined(__linux__) || defined(ANDROID) || defined(__APPLE__) || defined(POSIX)
|
#if defined(__linux__) || defined(ANDROID) || defined(__APPLE__) || defined(POSIX) || defined(__EMSCRIPTEN__)
|
||||||
mp_threadFunc = (pthread_fn)threadFunc;
|
mp_threadFunc = (pthread_fn)threadFunc;
|
||||||
|
|
||||||
pthread_attr_init(&m_attributes);
|
pthread_attr_init(&m_attributes);
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
|
|
||||||
typedef void *( * pthread_fn )( void * );
|
typedef void *( * pthread_fn )( void * );
|
||||||
|
|
||||||
#if defined(__linux__) || defined(ANDROID) || defined(__APPLE__) || defined(POSIX)
|
#if defined(__linux__) || defined(ANDROID) || defined(__APPLE__) || defined(POSIX) || defined(__EMSCRIPTEN__)
|
||||||
#include <pthread.h>
|
#include <pthread.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
@@ -38,7 +38,7 @@ typedef void *( * pthread_fn )( void * );
|
|||||||
DWORD m_threadID;
|
DWORD m_threadID;
|
||||||
HANDLE m_threadHandle;
|
HANDLE m_threadHandle;
|
||||||
#endif
|
#endif
|
||||||
#if defined(__linux__) || defined(ANDROID) || defined(__APPLE__) || defined(POSIX)
|
#if defined(__linux__) || defined(ANDROID) || defined(__APPLE__) || defined(POSIX) || defined(__EMSCRIPTEN__)
|
||||||
pthread_fn mp_threadFunc;
|
pthread_fn mp_threadFunc;
|
||||||
pthread_t m_thread;
|
pthread_t m_thread;
|
||||||
pthread_attr_t m_attributes;
|
pthread_attr_t m_attributes;
|
||||||
|
|||||||
@@ -10,6 +10,7 @@ struct MemoryReader {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static void pngMemoryRead(png_structp pngPtr, png_bytep outBytes, png_size_t byteCountToRead) {
|
static void pngMemoryRead(png_structp pngPtr, png_bytep outBytes, png_size_t byteCountToRead) {
|
||||||
|
#ifndef STANDALONE_SERVER
|
||||||
MemoryReader* reader = (MemoryReader*)png_get_io_ptr(pngPtr);
|
MemoryReader* reader = (MemoryReader*)png_get_io_ptr(pngPtr);
|
||||||
if (!reader)
|
if (!reader)
|
||||||
return;
|
return;
|
||||||
@@ -21,10 +22,12 @@ static void pngMemoryRead(png_structp pngPtr, png_bytep outBytes, png_size_t byt
|
|||||||
|
|
||||||
memcpy(outBytes, reader->data + reader->pos, byteCountToRead);
|
memcpy(outBytes, reader->data + reader->pos, byteCountToRead);
|
||||||
reader->pos += byteCountToRead;
|
reader->pos += byteCountToRead;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
TextureData loadPngFromMemory(const unsigned char* data, size_t size) {
|
TextureData loadPngFromMemory(const unsigned char* data, size_t size) {
|
||||||
TextureData out;
|
TextureData out;
|
||||||
|
#ifndef STANDALONE_SERVER
|
||||||
if (!data || size == 0) return out;
|
if (!data || size == 0) return out;
|
||||||
|
|
||||||
png_structp pngPtr = png_create_read_struct(PNG_LIBPNG_VER_STRING, NULL, NULL, NULL);
|
png_structp pngPtr = png_create_read_struct(PNG_LIBPNG_VER_STRING, NULL, NULL, NULL);
|
||||||
@@ -89,6 +92,7 @@ TextureData loadPngFromMemory(const unsigned char* data, size_t size) {
|
|||||||
|
|
||||||
png_destroy_read_struct(&pngPtr, &infoPtr, NULL);
|
png_destroy_read_struct(&pngPtr, &infoPtr, NULL);
|
||||||
delete[] rowPtrs;
|
delete[] rowPtrs;
|
||||||
|
#endif
|
||||||
|
|
||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,14 +3,8 @@
|
|||||||
|
|
||||||
#include "SoundSystem.h"
|
#include "SoundSystem.h"
|
||||||
|
|
||||||
// If audio breaks for other platforms, this is probably why. Here, I'm just calling where Apple's OpenAL headers live (they arent in just "AL"
|
#include <AL/al.h>
|
||||||
#if defined(__APPLE__)
|
#include <AL/alc.h>
|
||||||
#include <OpenAL/al.h>
|
|
||||||
#include <OpenAL/alc.h>
|
|
||||||
#else
|
|
||||||
#include <AL/al.h>
|
|
||||||
#include <AL/alc.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <list>
|
#include <list>
|
||||||
|
|||||||
@@ -23,7 +23,7 @@
|
|||||||
ServerPlayer::ServerPlayer( Minecraft* minecraft, Level* level )
|
ServerPlayer::ServerPlayer( Minecraft* minecraft, Level* level )
|
||||||
: super(level, minecraft->isCreativeMode()),
|
: super(level, minecraft->isCreativeMode()),
|
||||||
_mc(minecraft),
|
_mc(minecraft),
|
||||||
_sentHealth(-999),
|
_prevHealth(-999),
|
||||||
_containerCounter(0)
|
_containerCounter(0)
|
||||||
{
|
{
|
||||||
hasFakeInventory = true;
|
hasFakeInventory = true;
|
||||||
@@ -58,8 +58,8 @@ void ServerPlayer::tick() {
|
|||||||
if (containerMenu)
|
if (containerMenu)
|
||||||
containerMenu->broadcastChanges();
|
containerMenu->broadcastChanges();
|
||||||
|
|
||||||
if (health != _sentHealth) {
|
if (health != _prevHealth) {
|
||||||
_sentHealth = health;
|
_prevHealth = health;
|
||||||
SetHealthPacket packet(health);
|
SetHealthPacket packet(health);
|
||||||
_mc->raknetInstance->send(owner, packet);
|
_mc->raknetInstance->send(owner, packet);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -48,7 +48,7 @@ private:
|
|||||||
void setContainerMenu( BaseContainerMenu* menu );
|
void setContainerMenu( BaseContainerMenu* menu );
|
||||||
|
|
||||||
Minecraft* _mc;
|
Minecraft* _mc;
|
||||||
int _sentHealth;
|
int _prevHealth;
|
||||||
int _containerCounter;
|
int _containerCounter;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -9,11 +9,6 @@ static Random _rand;
|
|||||||
|
|
||||||
namespace Mth
|
namespace Mth
|
||||||
{
|
{
|
||||||
const float PI = 3.1415926535897932384626433832795028841971f; // exactly!
|
|
||||||
const float TWO_PI = 2.0f * PI; // exactly!
|
|
||||||
const float DEGRAD = PI / 180.0f;
|
|
||||||
const float RADDEG = 180.0f / PI;
|
|
||||||
|
|
||||||
static float _sin[65536];
|
static float _sin[65536];
|
||||||
static const float _sinScale = 65536.0f / (2.0f * PI);
|
static const float _sinScale = 65536.0f / (2.0f * PI);
|
||||||
|
|
||||||
|
|||||||
@@ -6,11 +6,10 @@
|
|||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
|
||||||
namespace Mth {
|
namespace Mth {
|
||||||
|
constexpr float PI = 3.1415926535897932384626433832795028841971f; // exactly!
|
||||||
extern const float PI;
|
constexpr float TWO_PI = 2.0f * PI; // exactly!
|
||||||
extern const float TWO_PI;
|
constexpr float DEGRAD = PI / 180.0f;
|
||||||
extern const float RADDEG;
|
const float RADDEG = 180.0f / PI;
|
||||||
extern const float DEGRAD;
|
|
||||||
|
|
||||||
void initMth();
|
void initMth();
|
||||||
|
|
||||||
|
|||||||
@@ -25,38 +25,38 @@ public:
|
|||||||
static const int C_RIGHT_HINGE_MASK = 16;
|
static const int C_RIGHT_HINGE_MASK = 16;
|
||||||
|
|
||||||
DoorTile(int id, const Material* material);
|
DoorTile(int id, const Material* material);
|
||||||
int getTexture(LevelSource* level, int x, int y, int z, int face);
|
int getTexture(LevelSource* level, int x, int y, int z, int face) override;
|
||||||
|
|
||||||
bool blocksLight();
|
bool blocksLight();
|
||||||
bool isSolidRender();
|
bool isSolidRender() override;
|
||||||
bool isCubeShaped();
|
bool isCubeShaped() override;
|
||||||
int getRenderShape();
|
int getRenderShape() override;
|
||||||
int getRenderLayer();
|
int getRenderLayer() override;
|
||||||
|
|
||||||
AABB getTileAABB(Level* level, int x, int y, int z);
|
AABB getTileAABB(Level* level, int x, int y, int z) override;
|
||||||
AABB* getAABB(Level* level, int x, int y, int z);
|
AABB* getAABB(Level* level, int x, int y, int z) override;
|
||||||
|
|
||||||
void updateShape(LevelSource* level, int x, int y, int z);
|
void updateShape(LevelSource* level, int x, int y, int z) override;
|
||||||
void setShape(int compositeData);
|
void setShape(int compositeData);
|
||||||
|
|
||||||
void attack(Level* level, int x, int y, int z, Player* player);
|
void attack(Level* level, int x, int y, int z, Player* player) override;
|
||||||
bool use(Level* level, int x, int y, int z, Player* player);
|
bool use(Level* level, int x, int y, int z, Player* player) override;
|
||||||
|
|
||||||
void setOpen(Level* level, int x, int y, int z, bool shouldOpen);
|
void setOpen(Level* level, int x, int y, int z, bool shouldOpen);
|
||||||
static bool isOpen(LevelSource* level, int x, int y, int z);
|
static bool isOpen(LevelSource* level, int x, int y, int z);
|
||||||
|
|
||||||
void neighborChanged(Level* level, int x, int y, int z, int type);
|
void neighborChanged(Level* level, int x, int y, int z, int type) override;
|
||||||
|
|
||||||
int getResource(int data, Random* random);
|
int getResource(int data, Random* random) override;
|
||||||
|
|
||||||
// override to avoid duplicate drops when upper half is mined directly
|
// override to avoid duplicate drops when upper half is mined directly
|
||||||
void playerDestroy(Level* level, Player* player, int x, int y, int z, int data) override;
|
void playerDestroy(Level* level, Player* player, int x, int y, int z, int data) override;
|
||||||
|
|
||||||
HitResult clip(Level* level, int xt, int yt, int zt, const Vec3& a, const Vec3& b);
|
HitResult clip(Level* level, int xt, int yt, int zt, const Vec3& a, const Vec3& b) override;
|
||||||
|
|
||||||
int getDir(LevelSource* level, int x, int y, int z);
|
int getDir(LevelSource* level, int x, int y, int z);
|
||||||
|
|
||||||
bool mayPlace(Level* level, int x, int y, int z, unsigned char face);
|
bool mayPlace(Level* level, int x, int y, int z, unsigned char face) override;
|
||||||
|
|
||||||
static int getCompositeData(LevelSource* level, int x, int y, int z);
|
static int getCompositeData(LevelSource* level, int x, int y, int z);
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user