setActiveHigh(getSavedActiveHigh());
}
- public boolean loadModule() {
+ public boolean loadModule() throws NotRootedException,ShellException {
if (!_loadModule())
return false;
return true;
}
- protected void runAsRoot(String command) throws java.io.IOException,java.lang.InterruptedException {
- Process rootcmd = Runtime.getRuntime().exec(new String[]{"su","-c","sh"});
- DataOutputStream sh = new DataOutputStream(rootcmd.getOutputStream());
- sh.writeBytes(command + "\n");
- sh.writeBytes("exit\n");
- sh.flush();
- sh.close();
+ protected void runAsRoot(String command) throws NotRootedException,ShellException {
+ Process rootcmd;
- rootcmd.waitFor();
+ try {
+ rootcmd = Runtime.getRuntime().exec(new String[]{"su","-c","sh"});
+ } catch (java.io.IOException e) {
+ throw new NotRootedException();
+ }
+
+ try {
+ DataOutputStream sh = new DataOutputStream(rootcmd.getOutputStream());
+ sh.writeBytes(command + "\n");
+ sh.writeBytes("exit\n");
+ sh.flush();
+ sh.close();
+ } catch (java.io.IOException e) {
+ throw new ShellException();
+ }
+
+ try {
+ if (rootcmd.waitFor() != 0)
+ throw new ShellException();
+ } catch (java.lang.InterruptedException e) {
+ throw new ShellException();
+ }
}
- public synchronized boolean _loadModule() {
- File debounce_ko = new File(ctx.getFilesDir() + "/debounce.ko");
+ public synchronized boolean _loadModule() throws NotRootedException,ShellException {
+ File insmod = new File("/system/bin/insmod");
+ if (!insmod.exists()) {
+ insmod = new File("/system/xbin/insmod");
+ if (!insmod.exists()) {
+ return false;
+ }
+ }
+
+ File debounce_ko = new File("/system/lib/modules/debounce.ko");
+ if (!debounce_ko.exists()) {
+ debounce_ko = new File(ctx.getFilesDir() + "/debounce.ko");
- extractModule();
+ extractModule();
+ }
SharedPreferences settings = ctx.getSharedPreferences(PREFS_NAME, Context.MODE_PRIVATE);
SharedPreferences.Editor editor = settings.edit();
editor.commit();
}
- try {
- runAsRoot("/system/bin/insmod " + debounce_ko + " || /system/xbin/insmod " + debounce_ko);
- } catch (Exception e) {
- return false;
- }
+ runAsRoot(insmod + " " + debounce_ko);
if (!isLoaded()) {
return false;
return true;
}
- public synchronized boolean unloadModule() {
- try {
- runAsRoot("/system/bin/rmmod debounce || /system/xbin/rmmod debounce");
- } catch (Exception e) {
- return false;
+ public synchronized void unloadModule() throws NotRootedException,ShellException {
+ File rmmod = new File("/system/bin/rmmod");
+
+ if (!rmmod.exists()) {
+ rmmod = new File("/system/xbin/rmmod");
+ if (!rmmod.exists()) {
+ return;
+ }
}
- return true;
+ runAsRoot(rmmod + " debounce");
}
public synchronized boolean isLoaded() {
fbuf.write((new Integer(value)).toString());
fbuf.close();
- } catch (Exception e) {
- }
+ } catch (Exception e) {}
}
public synchronized int getDelay() {