diff --git a/server/src/main/java/com/genymobile/scrcpy/FakeContext.java b/server/src/main/java/com/genymobile/scrcpy/FakeContext.java index 6501d4cf26..d9bcaf9eb3 100644 --- a/server/src/main/java/com/genymobile/scrcpy/FakeContext.java +++ b/server/src/main/java/com/genymobile/scrcpy/FakeContext.java @@ -18,7 +18,7 @@ public static FakeContext get() { } private FakeContext() { - super(null); + super(Workarounds.retrieveSystemContext()); } @Override diff --git a/server/src/main/java/com/genymobile/scrcpy/Workarounds.java b/server/src/main/java/com/genymobile/scrcpy/Workarounds.java index b8ee68ca58..37240246e5 100644 --- a/server/src/main/java/com/genymobile/scrcpy/Workarounds.java +++ b/server/src/main/java/com/genymobile/scrcpy/Workarounds.java @@ -7,6 +7,7 @@ import android.content.Context; import android.content.ContextWrapper; import android.content.pm.ApplicationInfo; +import android.content.pm.PackageManager; import android.media.AudioAttributes; import android.media.AudioManager; import android.media.AudioRecord; @@ -30,6 +31,11 @@ private Workarounds() { public static void apply(boolean audio, boolean camera) { Workarounds.prepareMainLooper(); + try { + fillActivityThread(); + } catch (Exception e) { + throw new AssertionError(e); + } boolean mustFillAppInfo = false; boolean mustFillBaseContext = false; @@ -123,6 +129,17 @@ private static void fillAppInfo() { ApplicationInfo applicationInfo = new ApplicationInfo(); applicationInfo.packageName = FakeContext.PACKAGE_NAME; + Application application = new Application() { + @Override + public String getOpPackageName() { + return FakeContext.PACKAGE_NAME; + } + }; + + Field initialApplicationField = activityThreadClass.getDeclaredField("mInitialApplication"); + initialApplicationField.setAccessible(true); + initialApplicationField.set(activityThread, application); + // appBindData.appInfo = applicationInfo; Field appInfoField = appBindDataClass.getDeclaredField("appInfo"); appInfoField.setAccessible(true); @@ -306,4 +323,14 @@ public static AudioRecord createAudioRecord(int source, int sampleRate, int chan throw new RuntimeException("Cannot create AudioRecord"); } } + + static Context retrieveSystemContext() { + try { + Method getSystemContextMethod = activityThreadClass.getDeclaredMethod("getSystemContext"); + return (Context) getSystemContextMethod.invoke(activityThread); + } catch (Exception e) { + Ln.e("Cannot retrieve system context", e); + return null; + } + } }