diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/com/google/ase/Exec.java | 69 | ||||
-rw-r--r-- | src/org/connectbot/transport/Local.java | 38 |
2 files changed, 75 insertions, 32 deletions
diff --git a/src/com/google/ase/Exec.java b/src/com/google/ase/Exec.java new file mode 100644 index 0000000..016fdf3 --- /dev/null +++ b/src/com/google/ase/Exec.java @@ -0,0 +1,69 @@ +/* + * Copyright (C) 2007 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package com.google.ase; + +import java.io.FileDescriptor; + +/** + * Tools for executing commands. + */ +public class Exec { + /** + * @param cmd + * The command to execute + * @param arg0 + * The first argument to the command, may be null + * @param arg1 + * the second argument to the command, may be null + * @return the file descriptor of the started process. + * + */ + public static FileDescriptor createSubprocess(String cmd, String arg0, String arg1) { + return createSubprocess(cmd, arg0, arg1, null); + } + + /** + * @param cmd + * The command to execute + * @param arg0 + * The first argument to the command, may be null + * @param arg1 + * the second argument to the command, may be null + * @param processId + * A one-element array to which the process ID of the started process will be written. + * @return the file descriptor of the started process. + * + */ + public static native FileDescriptor createSubprocess(String cmd, String arg0, String arg1, + int[] processId); + + public static native void setPtyWindowSize(FileDescriptor fd, int row, int col, int xpixel, + int ypixel); + + /** + * Causes the calling thread to wait for the process associated with the receiver to finish + * executing. + * + * @return The exit value of the Process being waited on + * + */ + public static native int waitFor(int processId); + + static { + System.loadLibrary("com_google_ase_Exec"); + } +} diff --git a/src/org/connectbot/transport/Local.java b/src/org/connectbot/transport/Local.java index 23c16b2..915e471 100644 --- a/src/org/connectbot/transport/Local.java +++ b/src/org/connectbot/transport/Local.java @@ -22,7 +22,6 @@ import java.io.FileDescriptor; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; -import java.lang.reflect.Method; import java.util.Map; import org.connectbot.R; @@ -35,6 +34,8 @@ import android.content.Context; import android.net.Uri; import android.util.Log; +import com.google.ase.Exec; + /** * @author Kenny Root * @@ -45,34 +46,11 @@ public class Local extends AbsTransport { private static final String DEFAULT_URI = "local:#Local"; - private static Method mExec_openSubprocess; - private static Method mExec_waitFor; - private static Method mExec_setPtyWindowSize; - private FileDescriptor shellFd; private FileInputStream is; private FileOutputStream os; - static { - initPrivateAPI(); - } - - private static void initPrivateAPI() { - try { - Class<?> mExec = Class.forName("android.os.Exec"); - mExec_openSubprocess = mExec.getMethod("createSubprocess", - String.class, String.class, String.class, int[].class); - mExec_waitFor = mExec.getMethod("waitFor", int.class); - mExec_setPtyWindowSize = mExec.getMethod("setPtyWindowSize", - FileDescriptor.class, int.class, int.class, int.class, int.class); - } catch (NoSuchMethodException e) { - // Give up - } catch (ClassNotFoundException e) { - // Give up - } - } - /** * */ @@ -113,21 +91,17 @@ public class Local extends AbsTransport { int[] pids = new int[1]; try { - shellFd = (FileDescriptor) mExec_openSubprocess.invoke(null, - "/system/bin/sh", "-", null, pids); + shellFd = Exec.createSubprocess("/system/bin/sh", "-", null, pids); } catch (Exception e) { bridge.outputLine(manager.res.getString(R.string.local_shell_unavailable)); + Log.e(TAG, "Cannot start local shell", e); return; } final int shellPid = pids[0]; Runnable exitWatcher = new Runnable() { public void run() { - try { - mExec_waitFor.invoke(null, shellPid); - } catch (Exception e) { - Log.e(TAG, "Couldn't wait for shell exit", e); - } + Exec.waitFor(shellPid); bridge.dispatchDisconnect(false); } @@ -181,7 +155,7 @@ public class Local extends AbsTransport { @Override public void setDimensions(int columns, int rows, int width, int height) { try { - mExec_setPtyWindowSize.invoke(null, shellFd, rows, columns, width, height); + Exec.setPtyWindowSize(shellFd, rows, columns, width, height); } catch (Exception e) { Log.e(TAG, "Couldn't resize pty", e); } |