diff options
| author | 2018-02-09 10:36:33 +0000 | |
|---|---|---|
| committer | 2018-02-09 10:36:33 +0000 | |
| commit | c8b76fe1f4d48aadf07c479dc9412d6b344bab1a (patch) | |
| tree | ae4b79de63c2405bbcf9f963a6b7f8211266c762 /native/android/configuration.cpp | |
| parent | 49cdc08b4ba0d9ed2e3227083721e48f007c9f96 (diff) | |
| parent | 93811532096a2d0d822f64d6271dca4f1147841d (diff) | |
Merge "AssetManager2: Fix issue with native cast"
Diffstat (limited to 'native/android/configuration.cpp')
| -rw-r--r-- | native/android/configuration.cpp | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/native/android/configuration.cpp b/native/android/configuration.cpp index 77237ae97ff5..87fe9edb49c5 100644 --- a/native/android/configuration.cpp +++ b/native/android/configuration.cpp @@ -17,9 +17,10 @@ #define LOG_TAG "Configuration" #include <utils/Log.h> -#include <androidfw/AssetManager.h> +#include <androidfw/AssetManager2.h> #include <android_runtime/android_content_res_Configuration.h> +#include <android_runtime/android_util_AssetManager.h> using namespace android; @@ -34,7 +35,11 @@ void AConfiguration_delete(AConfiguration* config) { } void AConfiguration_fromAssetManager(AConfiguration* out, AAssetManager* am) { - ((AssetManager*)am)->getConfiguration(out); + ScopedLock<AssetManager2> locked_mgr(*AssetManagerForNdkAssetManager(am)); + ResTable_config config = locked_mgr->GetConfiguration(); + + // AConfiguration is not a virtual subclass, so we can memcpy. + memcpy(out, &config, sizeof(config)); } void AConfiguration_copy(AConfiguration* dest, AConfiguration* src) { |