- when running a remote command on a remote target, the 
TerminalServiceHostShell implementation is used for the HostShell(instead of 
the LocalHostShell)
        - in this case, the shell does not have two readers (input, error), and 
instead it only offers one reader for both of the streams
        - in the current implementation, the error stream is parsed first 
because it makes more sense to check for errors before trying to parse the 
output of the command
                - in the remote case, since all output(error and output) will 
be sent to the same reader, the needed output of the command will be parsed as 
error and the output will be empty
                - in order to fix this, we should look at the error lines 
resulted after running a remote command if we are using a remote target

Signed-off-by: Ioana Grigoropol <ioanax.grigoro...@intel.com>
---
 plugins/org.yocto.bc.ui/META-INF/MANIFEST.MF       |    1 +
 .../yocto/bc/remote/utils/ProcessStreamBuffer.java |   13 ++++++++++---
 .../org/yocto/bc/remote/utils/RemoteHelper.java    |    7 ++-----
 .../org/yocto/bc/remote/utils/RemoteMachine.java   |    6 ------
 .../org/yocto/bc/remote/utils/YoctoCommand.java    |    2 +-
 5 files changed, 14 insertions(+), 15 deletions(-)

diff --git a/plugins/org.yocto.bc.ui/META-INF/MANIFEST.MF 
b/plugins/org.yocto.bc.ui/META-INF/MANIFEST.MF
index 4e57f33..68fc49e 100644
--- a/plugins/org.yocto.bc.ui/META-INF/MANIFEST.MF
+++ b/plugins/org.yocto.bc.ui/META-INF/MANIFEST.MF
@@ -30,6 +30,7 @@ Import-Package: org.eclipse.cdt.managedbuilder.core,
  org.eclipse.rse.core.model,
  org.eclipse.rse.core.subsystems,
  org.eclipse.rse.internal.services.local.shells,
+ org.eclipse.rse.internal.services.shells,
  org.eclipse.rse.services,
  org.eclipse.rse.services.clientserver.messages,
  org.eclipse.rse.services.files,
diff --git 
a/plugins/org.yocto.bc.ui/src/org/yocto/bc/remote/utils/ProcessStreamBuffer.java
 
b/plugins/org.yocto.bc.ui/src/org/yocto/bc/remote/utils/ProcessStreamBuffer.java
index e0d502c..73d0805 100644
--- 
a/plugins/org.yocto.bc.ui/src/org/yocto/bc/remote/utils/ProcessStreamBuffer.java
+++ 
b/plugins/org.yocto.bc.ui/src/org/yocto/bc/remote/utils/ProcessStreamBuffer.java
@@ -8,8 +8,10 @@ public class ProcessStreamBuffer {
        private static final String WHITESPACES = "\\s+";
        List<String> errorLines;
        List<String> outputLines;
+       boolean isTerminal;
 
-       ProcessStreamBuffer(){
+       ProcessStreamBuffer(boolean isTerminal){
+               this.isTerminal = isTerminal;
                errorLines = new ArrayList<String>();
                outputLines = new ArrayList<String>();
        }
@@ -56,8 +58,13 @@ public class ProcessStreamBuffer {
        }
 
        public String getOutputLineContaining(String arg, String pattern) {
-               for (int i = outputLines.size() - 1; i >= 0; i--){
-                       String line = outputLines.get(i);
+               List<String> lines = null;
+               if (isTerminal)
+                       lines = errorLines;
+               else
+                       lines = outputLines;
+               for (int i = lines.size() - 1; i >= 0; i--){
+                       String line = lines.get(i);
                        if (line.contains(arg)) {
                                String[] tokens = line.split("\\s+");
                                if (Pattern.matches(pattern,  tokens[0])) {
diff --git 
a/plugins/org.yocto.bc.ui/src/org/yocto/bc/remote/utils/RemoteHelper.java 
b/plugins/org.yocto.bc.ui/src/org/yocto/bc/remote/utils/RemoteHelper.java
index 87c8637..5b82e13 100644
--- a/plugins/org.yocto.bc.ui/src/org/yocto/bc/remote/utils/RemoteHelper.java
+++ b/plugins/org.yocto.bc.ui/src/org/yocto/bc/remote/utils/RemoteHelper.java
@@ -36,6 +36,7 @@ import org.eclipse.rse.core.model.IHost;
 import org.eclipse.rse.core.model.ISystemRegistry;
 import org.eclipse.rse.core.subsystems.ISubSystem;
 import org.eclipse.rse.internal.services.local.shells.LocalHostShell;
+import org.eclipse.rse.internal.services.shells.TerminalServiceHostShell;
 import org.eclipse.rse.services.IService;
 import org.eclipse.rse.services.clientserver.messages.SystemMessageException;
 import org.eclipse.rse.services.files.IFileService;
@@ -76,10 +77,6 @@ public class RemoteHelper {
                return getRemoteMachine(connection).getCmdHandler();
        }
 
-       public static ProcessStreamBuffer getProcessBuffer(IHost connection) {
-               return getRemoteMachine(connection).getProcessBuffer();
-       }
-
        public static IHostShell getHostShell(IHost connection) {
                return getRemoteMachine(connection).getHostShell();
        }
@@ -93,7 +90,7 @@ public class RemoteHelper {
                        lock = ((LocalHostShell)hostShell).getLock();
                        lock.lock();
                }
-               ProcessStreamBuffer processBuffer = new ProcessStreamBuffer();
+               ProcessStreamBuffer processBuffer = new 
ProcessStreamBuffer(hostShell instanceof TerminalServiceHostShell);
                
                BufferedReader inbr = null;
                BufferedReader errbr = null;
diff --git 
a/plugins/org.yocto.bc.ui/src/org/yocto/bc/remote/utils/RemoteMachine.java 
b/plugins/org.yocto.bc.ui/src/org/yocto/bc/remote/utils/RemoteMachine.java
index 52bc011..14501e4 100644
--- a/plugins/org.yocto.bc.ui/src/org/yocto/bc/remote/utils/RemoteMachine.java
+++ b/plugins/org.yocto.bc.ui/src/org/yocto/bc/remote/utils/RemoteMachine.java
@@ -165,12 +165,6 @@ public class RemoteMachine {
                return null;
        }
 
-       public ProcessStreamBuffer getProcessBuffer() {
-               if (processBuffer == null)
-                       processBuffer = new ProcessStreamBuffer();
-               return processBuffer;
-       }
-
        public IHost getConnection() {
                return connection;
        }
diff --git 
a/plugins/org.yocto.bc.ui/src/org/yocto/bc/remote/utils/YoctoCommand.java 
b/plugins/org.yocto.bc.ui/src/org/yocto/bc/remote/utils/YoctoCommand.java
index 0fd4f32..9375806 100644
--- a/plugins/org.yocto.bc.ui/src/org/yocto/bc/remote/utils/YoctoCommand.java
+++ b/plugins/org.yocto.bc.ui/src/org/yocto/bc/remote/utils/YoctoCommand.java
@@ -11,7 +11,7 @@ public class YoctoCommand {
                this.setCommand(command);
                this.setInitialDirectory(initialDirectory);
                this.setArguments(arguments);
-               this.setProcessBuffer(new ProcessStreamBuffer());
+               this.setProcessBuffer(new ProcessStreamBuffer(false));
        }
 
        public String getCommand() {
-- 
1.7.9.5

_______________________________________________
yocto mailing list
yocto@yoctoproject.org
https://lists.yoctoproject.org/listinfo/yocto

Reply via email to