X-Git-Url: https://git.zerfleddert.de/cgi-bin/gitweb.cgi/ms2-fixes/blobdiff_plain/0ae502f627e216e71b179a37079c9d43c7feeed3..5738a32fed2d7c93bfbcfcb8e1ccdffdc5dceb6a:/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java diff --git a/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java b/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java index f4569a5..2f9804c 100644 --- a/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java +++ b/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java @@ -1,15 +1,45 @@ package de.rmdir.ms2debounce; +import java.io.InputStream; +import java.io.OutputStream; +import java.io.File; + +import android.content.Context; + public class DebounceModuleHelper { - static public void loadModule() { + private Context ctx; + + public DebounceModuleHelper(Context context) { + ctx = context; + } + + public void loadModule() { + extractModule(); + try { Process insmod = Runtime.getRuntime().exec(new String[]{"su","-c","/system/bin/insmod /system/lib/modules/debounce.ko"}); insmod.waitFor(); } catch (Exception e) {} } - static public boolean isLoaded() { + public boolean isLoaded() { return false; } + + private synchronized void extractModule() { + File debounce_ko = new File(ctx.getFilesDir() + "/debounce.ko"); + + if (debounce_ko.exists()) { + return; + } + + try { + InputStream apk = ctx.getAssets().open("debounce.ko"); + OutputStream mod = ctx.openFileOutput("debounce.ko", 0); + + apk.close(); + mod.close(); + } catch (Exception e) {} + } }