diff options
Diffstat (limited to 'platform/android/java/app')
| -rw-r--r-- | platform/android/java/app/AndroidManifest.xml | 10 | ||||
| -rw-r--r-- | platform/android/java/app/build.gradle | 4 | ||||
| -rw-r--r-- | platform/android/java/app/config.gradle | 64 | ||||
| -rw-r--r-- | platform/android/java/app/res/drawable/splash_drawable.xml | 2 | ||||
| -rw-r--r-- | platform/android/java/app/src/com/godot/game/GodotApp.java | 4 | 
5 files changed, 69 insertions, 15 deletions
| diff --git a/platform/android/java/app/AndroidManifest.xml b/platform/android/java/app/AndroidManifest.xml index e94681659c..948fa8c00b 100644 --- a/platform/android/java/app/AndroidManifest.xml +++ b/platform/android/java/app/AndroidManifest.xml @@ -22,6 +22,11 @@          tools:ignore="GoogleAppIndexingWarning"          android:icon="@mipmap/icon" > +        <!-- Records the version of the Godot editor used for building --> +        <meta-data +            android:name="org.godotengine.editor.version" +            android:value="${godotEditorVersion}" /> +          <!-- The following metadata values are replaced when Godot exports, modifying them here has no effect. -->          <!-- Do these changes in the export preset. Adding new ones is fine. --> @@ -30,11 +35,6 @@              android:name="xr_mode_metadata_name"              android:value="xr_mode_metadata_value" /> -        <!-- Metadata populated at export time and used by Godot to figure out which plugins must be enabled. --> -        <meta-data -            android:name="plugins" -            android:value="plugins_value"/> -          <activity              android:name=".GodotApp"              android:label="@string/godot_project_name_string" diff --git a/platform/android/java/app/build.gradle b/platform/android/java/app/build.gradle index 53d11fda5b..934c4bf441 100644 --- a/platform/android/java/app/build.gradle +++ b/platform/android/java/app/build.gradle @@ -85,6 +85,8 @@ android {              abiFilters export_abi_list          } +        manifestPlaceholders = [godotEditorVersion: getGodotEditorVersion()] +          // Feel free to modify the application id to your own.          applicationId getExportPackageName()          versionCode getExportVersionCode() @@ -98,6 +100,8 @@ android {          disable 'MissingTranslation', 'UnusedResources'      } +    ndkVersion versions.ndkVersion +      packagingOptions {          exclude 'META-INF/LICENSE'          exclude 'META-INF/NOTICE' diff --git a/platform/android/java/app/config.gradle b/platform/android/java/app/config.gradle index 80cf6f7ede..585e517631 100644 --- a/platform/android/java/app/config.gradle +++ b/platform/android/java/app/config.gradle @@ -1,5 +1,5 @@  ext.versions = [ -    androidGradlePlugin: '4.1.0', +    androidGradlePlugin: '4.0.1',      compileSdk         : 29,      minSdk             : 18,      targetSdk          : 29, @@ -7,7 +7,8 @@ ext.versions = [      supportCoreUtils   : '1.0.0',      kotlinVersion      : '1.4.10',      v4Support          : '1.0.0', -    javaVersion        : 1.8 +    javaVersion        : 1.8, +    ndkVersion         : '21.4.7075529' // Also update 'platform/android/detect.py#get_project_ndk_version()' when this is updated.  ] @@ -49,7 +50,56 @@ ext.getExportVersionName = { ->      return versionName  } -final String PLUGIN_VALUE_SEPARATOR_REGEX = "\\|" +ext.getGodotEditorVersion = { -> +    String editorVersion = project.hasProperty("godot_editor_version") ? project.property("godot_editor_version") : "" +    if (editorVersion == null || editorVersion.isEmpty()) { +        // Try the library version first +        editorVersion = getGodotLibraryVersion() + +        if (editorVersion.isEmpty()) { +            // Fallback value. +            editorVersion = "custom_build" +        } +    } +    return editorVersion +} + +ext.getGodotLibraryVersion = { -> +    // Attempt to read the version from the `version.py` file. +    String libraryVersion = "" + +    File versionFile = new File("../../../version.py") +    if (versionFile.isFile()) { +        List<String> requiredKeys = ["major", "minor", "patch", "status", "module_config"] +        def map = [:] + +        List<String> lines = versionFile.readLines() +        for (String line in lines) { +            String[] keyValue = line.split("=") +            String key = keyValue[0].trim() +            String value = keyValue[1].trim().replaceAll("\"", "") + +            if (requiredKeys.contains(key)) { +                if (!value.isEmpty()) { +                    map[key] = value +                } +                requiredKeys.remove(key) +            } +        } + +        if (requiredKeys.empty) { +            libraryVersion = map.values().join(".") +        } +    } + +    if (libraryVersion.isEmpty()) { +        // Fallback value in case we're unable to read the file. +        libraryVersion = "custom_build" +    } +    return libraryVersion +} + +final String VALUE_SEPARATOR_REGEX = "\\|"  // get the list of ABIs the project should be exported to  ext.getExportEnabledABIs = { -> @@ -58,7 +108,7 @@ ext.getExportEnabledABIs = { ->          enabledABIs = "armeabi-v7a|arm64-v8a|x86|x86_64|"      }      Set<String> exportAbiFilter = []; -    for (String abi_name : enabledABIs.split(PLUGIN_VALUE_SEPARATOR_REGEX)) { +    for (String abi_name : enabledABIs.split(VALUE_SEPARATOR_REGEX)) {          if (!abi_name.trim().isEmpty()){              exportAbiFilter.add(abi_name);          } @@ -93,7 +143,7 @@ ext.getGodotPluginsMavenRepos = { ->      if (project.hasProperty("plugins_maven_repos")) {          String mavenReposProperty = project.property("plugins_maven_repos")          if (mavenReposProperty != null && !mavenReposProperty.trim().isEmpty()) { -            for (String mavenRepoUrl : mavenReposProperty.split(PLUGIN_VALUE_SEPARATOR_REGEX)) { +            for (String mavenRepoUrl : mavenReposProperty.split(VALUE_SEPARATOR_REGEX)) {                  mavenRepos += mavenRepoUrl.trim()              }          } @@ -113,7 +163,7 @@ ext.getGodotPluginsRemoteBinaries = { ->      if (project.hasProperty("plugins_remote_binaries")) {          String remoteDepsList = project.property("plugins_remote_binaries")          if (remoteDepsList != null && !remoteDepsList.trim().isEmpty()) { -            for (String dep: remoteDepsList.split(PLUGIN_VALUE_SEPARATOR_REGEX)) { +            for (String dep: remoteDepsList.split(VALUE_SEPARATOR_REGEX)) {                  remoteDeps += dep.trim()              }          } @@ -132,7 +182,7 @@ ext.getGodotPluginsLocalBinaries = { ->      if (project.hasProperty("plugins_local_binaries")) {          String pluginsList = project.property("plugins_local_binaries")          if (pluginsList != null && !pluginsList.trim().isEmpty()) { -            for (String plugin : pluginsList.split(PLUGIN_VALUE_SEPARATOR_REGEX)) { +            for (String plugin : pluginsList.split(VALUE_SEPARATOR_REGEX)) {                  binDeps += plugin.trim()              }          } diff --git a/platform/android/java/app/res/drawable/splash_drawable.xml b/platform/android/java/app/res/drawable/splash_drawable.xml index 2794a40817..30627b998c 100644 --- a/platform/android/java/app/res/drawable/splash_drawable.xml +++ b/platform/android/java/app/res/drawable/splash_drawable.xml @@ -6,7 +6,7 @@  	<item>  		<bitmap  				android:gravity="center" +				android:filter="false"  				android:src="@drawable/splash" />  	</item> -  </layer-list> diff --git a/platform/android/java/app/src/com/godot/game/GodotApp.java b/platform/android/java/app/src/com/godot/game/GodotApp.java index 51df70969e..955446b0c2 100644 --- a/platform/android/java/app/src/com/godot/game/GodotApp.java +++ b/platform/android/java/app/src/com/godot/game/GodotApp.java @@ -5,8 +5,8 @@  /*                           GODOT ENGINE                                */  /*                      https://godotengine.org                          */  /*************************************************************************/ -/* Copyright (c) 2007-2020 Juan Linietsky, Ariel Manzur.                 */ -/* Copyright (c) 2014-2020 Godot Engine contributors (cf. AUTHORS.md).   */ +/* Copyright (c) 2007-2021 Juan Linietsky, Ariel Manzur.                 */ +/* Copyright (c) 2014-2021 Godot Engine contributors (cf. AUTHORS.md).   */  /*                                                                       */  /* Permission is hereby granted, free of charge, to any person obtaining */  /* a copy of this software and associated documentation files (the       */ |