/* * Copyright (C) 2012 The CyanogenMod 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.cyanogenmod.filemanager.commands.shell; import com.cyanogenmod.filemanager.commands.AsyncResultListener; import com.cyanogenmod.filemanager.commands.SIGNAL; import com.cyanogenmod.filemanager.commands.WriteExecutable; import com.cyanogenmod.filemanager.console.CommandNotFoundException; import com.cyanogenmod.filemanager.console.ExecutionException; import com.cyanogenmod.filemanager.console.InsufficientPermissionsException; import java.io.IOException; import java.io.OutputStream; /** * A class for write data to disk.<br/> * <br/> * User MUST call the {@link #createOutputStream()} to get the output stream where * write the data.<br/>. When no more exist then user MUST call the onEnd method * of the asynchronous listener.<br/> * * {@link "http://unixhelp.ed.ac.uk/CGI/man-cgi?dd"} */ public class WriteCommand extends AsyncResultProgram implements WriteExecutable { private static final String ID = "write"; //$NON-NLS-1$ private static final long TIMEOUT = 1000L; /** * @hide */ final Object mSync = new Object(); private boolean mReady; /** * @hide */ boolean mError; /** * Constructor of <code>WriteCommand</code>. * * @param file The file where to write the data * @param asyncResultListener The partial result listener * @throws InvalidCommandDefinitionException If the command has an invalid definition */ public WriteCommand( String file, AsyncResultListener asyncResultListener) throws InvalidCommandDefinitionException { super(ID, asyncResultListener, file); this.mReady = false; this.mError = false; } /** * {@inheritDoc} */ @Override public boolean isExpectEnd() { return false; } /** * {@inheritDoc} */ @Override public OutputStream createOutputStream() throws IOException { // Wait until command is ready synchronized (this.mSync) { if (!this.mReady) { try { this.mSync.wait(TIMEOUT); } catch (Exception e) {/**NON BLOCK**/} } } return getProgramListener().getOutputStream(); } /** * {@inheritDoc} */ @Override public void onStartParsePartialResult() { synchronized (this.mSync) { this.mReady = true; this.mSync.notify(); } } /** * {@inheritDoc} */ @Override public void onEndParsePartialResult(boolean cancelled) {/**NON BLOCK**/} /** * {@inheritDoc} */ @Override public SIGNAL onRequestEnd() { try { if (this.getProgramListener().getOutputStream() != null) { this.getProgramListener().getOutputStream().flush(); } } catch (Exception ex) {/**NON BLOCK**/} try { Thread.yield(); } catch (Exception ex) {/**NON BLOCK**/} return null; } /** * {@inheritDoc} */ @Override public void onParsePartialResult(final String partialIn) {/**NON BLOCK**/} /** * {@inheritDoc} */ @Override public void onParseErrorPartialResult(String partialErr) {/**NON BLOCK**/} /** * {@inheritDoc} */ @Override public boolean isIgnoreShellStdErrCheck() { return true; } /** * {@inheritDoc} */ @Override public void checkExitCode(int exitCode) throws InsufficientPermissionsException, CommandNotFoundException, ExecutionException { //Ignore exit code 143 (cancelled) //Ignore exit code 137 (kill -9) if (exitCode != 0 && exitCode != 143 && exitCode != 137) { throw new ExecutionException( "exitcode != 0 && != 143 && != 137"); //$NON-NLS-1$ } } }