X-Git-Url: http://cvs.zerfleddert.de/cgi-bin/gitweb.cgi/ms2-fixes/blobdiff_plain/7edd7d4014c0744be072e76f07ea51710a2ff8a7..131fed255e5772093e2f41cba76bca2bbafd33d1:/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java?ds=sidebyside diff --git a/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java b/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java index 25c2262..e26379f 100644 --- a/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java +++ b/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java @@ -4,7 +4,9 @@ import java.io.InputStream; import java.io.OutputStream; import java.io.File; import java.io.FileReader; +import java.io.FileWriter; import java.io.BufferedReader; +import java.io.BufferedWriter; import java.io.DataOutputStream; import android.content.Context; @@ -20,8 +22,15 @@ public class DebounceModuleHelper ctx = context; } + public void setAllValues() { + setDelay(getSavedDelay()); + setSettle(getSavedSettle()); + setPoll(getSavedPoll()); + } + public void loadModule() { - loadModule(getSavedDelay()); + _loadModule(); + setAllValues(); } protected void runAsRoot(String command) throws java.io.IOException,java.lang.InterruptedException { @@ -35,7 +44,7 @@ public class DebounceModuleHelper rootcmd.waitFor(); } - public synchronized void loadModule(int delay) { + public synchronized void _loadModule() { File debounce_ko = new File(ctx.getFilesDir() + "/debounce.ko"); extractModule(); @@ -48,7 +57,7 @@ public class DebounceModuleHelper } try { - runAsRoot("/system/bin/insmod " + debounce_ko + " debounce_delay=" + delay); + runAsRoot("/system/bin/insmod " + debounce_ko); } catch (Exception e) { return; } @@ -57,7 +66,7 @@ public class DebounceModuleHelper return; } - if (getDelay() <= 0) { + if (getDelay() < 0) { return; } @@ -93,34 +102,63 @@ public class DebounceModuleHelper return loaded; } - public synchronized int getDelay() { - int debounce_delay = -1; + private synchronized int getValue(String parameter) { + int value = -1; try { String read; - FileReader delay = new FileReader("/sys/module/debounce/parameters/debounce_delay"); - BufferedReader delay_buf = new BufferedReader(delay); + FileReader fr = new FileReader("/sys/devices/debounce/" + parameter); + BufferedReader fbuf = new BufferedReader(fr); - read = delay_buf.readLine(); + read = fbuf.readLine(); if (read != null) { - debounce_delay = Integer.parseInt(read.trim()); + value = Integer.parseInt(read.trim()); } + + fbuf.close(); } catch (Exception e) {} - return debounce_delay; + return value; } - public synchronized void setDelay(int delay) { - if (isLoaded()) { - if (getDelay() == delay) { - return; - } - - unloadModule(); + private synchronized void setValue(String parameter, int value) { + if (!isLoaded()) { + return; } - loadModule(delay); + try { + FileWriter fw = new FileWriter("/sys/devices/debounce/" + parameter); + BufferedWriter fbuf = new BufferedWriter(fw); + + fbuf.write((new Integer(value)).toString()); + + fbuf.close(); + } catch (Exception e) {} + } + + public synchronized int getDelay() { + return getValue("debounce_delay"); + } + + public synchronized void setDelay(int debounce_delay) { + setValue("debounce_delay", debounce_delay); + } + + public synchronized int getSettle() { + return getValue("settle_time"); + } + + public synchronized void setSettle(int settle_time) { + setValue("settle_time", settle_time); + } + + public synchronized int getPoll() { + return getValue("poll_time"); + } + + public synchronized void setPoll(int poll_time) { + setValue("poll_time", poll_time); } public synchronized int getSavedDelay() { @@ -137,6 +175,34 @@ public class DebounceModuleHelper editor.commit(); } + public synchronized int getSavedSettle() { + SharedPreferences settings = ctx.getSharedPreferences(PREFS_NAME, Context.MODE_PRIVATE); + + return settings.getInt("settle_time", 150); + } + + public synchronized void setSavedSettle(int settle) { + SharedPreferences settings = ctx.getSharedPreferences(PREFS_NAME, Context.MODE_PRIVATE); + SharedPreferences.Editor editor = settings.edit(); + + editor.putInt("settle_time", settle); + editor.commit(); + } + + public synchronized int getSavedPoll() { + SharedPreferences settings = ctx.getSharedPreferences(PREFS_NAME, Context.MODE_PRIVATE); + + return settings.getInt("poll_time", 2); + } + + public synchronized void setSavedPoll(int poll) { + SharedPreferences settings = ctx.getSharedPreferences(PREFS_NAME, Context.MODE_PRIVATE); + SharedPreferences.Editor editor = settings.edit(); + + editor.putInt("poll_time", poll); + editor.commit(); + } + public synchronized boolean is_safe_to_load() { SharedPreferences settings = ctx.getSharedPreferences(PREFS_NAME, Context.MODE_PRIVATE); return settings.getBoolean("safe_to_load", false);