You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@karaf.apache.org by io...@apache.org on 2012/02/22 15:19:47 UTC
svn commit: r1292305 - in /karaf/branches/karaf-2.2.x/shell:
commands/src/main/java/org/apache/karaf/shell/shell/
commands/src/main/resources/OSGI-INF/blueprint/
console/src/main/java/org/apache/karaf/shell/console/completer/
Author: iocanel
Date: Wed Feb 22 14:19:47 2012
New Revision: 1292305
URL: http://svn.apache.org/viewvc?rev=1292305&view=rev
Log:
[KARAF-1196] Implemented command-watch command which watches and refreshes the output of a command at a given interval. Modified CommandsCompleter to be usable as argument/option completer.
Conflicts:
shell/console/src/main/java/org/apache/karaf/shell/console/completer/CommandsCompleter.java
Added:
karaf/branches/karaf-2.2.x/shell/commands/src/main/java/org/apache/karaf/shell/shell/
karaf/branches/karaf-2.2.x/shell/commands/src/main/java/org/apache/karaf/shell/shell/WatchAction.java
Modified:
karaf/branches/karaf-2.2.x/shell/commands/src/main/resources/OSGI-INF/blueprint/shell-commands.xml
karaf/branches/karaf-2.2.x/shell/console/src/main/java/org/apache/karaf/shell/console/completer/ArgumentCompleter.java
karaf/branches/karaf-2.2.x/shell/console/src/main/java/org/apache/karaf/shell/console/completer/CommandsCompleter.java
Added: karaf/branches/karaf-2.2.x/shell/commands/src/main/java/org/apache/karaf/shell/shell/WatchAction.java
URL: http://svn.apache.org/viewvc/karaf/branches/karaf-2.2.x/shell/commands/src/main/java/org/apache/karaf/shell/shell/WatchAction.java?rev=1292305&view=auto
==============================================================================
--- karaf/branches/karaf-2.2.x/shell/commands/src/main/java/org/apache/karaf/shell/shell/WatchAction.java (added)
+++ karaf/branches/karaf-2.2.x/shell/commands/src/main/java/org/apache/karaf/shell/shell/WatchAction.java Wed Feb 22 14:19:47 2012
@@ -0,0 +1,124 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you 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 org.apache.karaf.shell.shell;
+
+import java.io.ByteArrayOutputStream;
+import java.io.IOException;
+import java.io.PrintStream;
+import java.util.concurrent.Executors;
+import java.util.concurrent.ScheduledExecutorService;
+import java.util.concurrent.TimeUnit;
+import org.apache.felix.service.command.CommandProcessor;
+import org.apache.felix.service.command.CommandSession;
+import org.apache.karaf.shell.commands.Argument;
+import org.apache.karaf.shell.commands.Command;
+import org.apache.karaf.shell.commands.Option;
+import org.apache.karaf.shell.console.AbstractAction;
+
+@Command(scope = "shell", name = "command-watch", description = "Watches & refreshes the output of a command")
+public class WatchAction extends AbstractAction {
+
+ @Option(name = "-n", aliases = {"--interval"}, description = "The interval between executions of the command in seconds", required = false, multiValued = false)
+ private long interval = 1;
+
+ @Argument(index = 0, name = "command", description = "The command to watch / refresh", required = true, multiValued = true)
+ private String[] arguments;
+
+ CommandProcessor commandProcessor;
+ private ScheduledExecutorService executorService = Executors.newSingleThreadScheduledExecutor();
+
+ @Override
+ protected Object doExecute() throws Exception {
+ if (arguments == null || arguments.length == 0) {
+ System.err.println("Argument expected");
+ return null;
+ } else {
+ StringBuilder command = new StringBuilder();
+ for (String arg:arguments) {
+ command.append(arg).append(" ");
+ }
+ WatchTask watchTask = new WatchTask(commandProcessor, command.toString().trim());
+ executorService.scheduleAtFixedRate(watchTask, 0, interval, TimeUnit.SECONDS);
+ try {
+ int c = ' ';
+ while (c != 'q' && c != 'Q') {
+ c = System.in.read();
+ }
+ } finally {
+ executorService.shutdownNow();
+ watchTask.close();
+ return null;
+ }
+ }
+ }
+
+ public class WatchTask implements Runnable {
+
+ private final CommandProcessor processor;
+ private final String command;
+
+ CommandSession session;
+ ByteArrayOutputStream byteArrayOutputStream = null;
+ PrintStream printStream = null;
+
+ public WatchTask(CommandProcessor processor, String command) {
+ this.processor = processor;
+ this.command = command;
+ }
+
+ public void run() {
+ try {
+ byteArrayOutputStream = new ByteArrayOutputStream();
+ printStream = new PrintStream(byteArrayOutputStream);
+ session = commandProcessor.createSession(null, printStream, printStream);
+ String output = "";
+ session.execute(command);
+ output = byteArrayOutputStream.toString();
+ System.out.print("\33[2J");
+ System.out.print("\33[1;1H");
+ System.out.print(output);
+ System.out.flush();
+ byteArrayOutputStream.close();
+ session.close();
+ } catch (Exception e) {
+ //Ingore
+ }
+ }
+
+ public void close() throws IOException {
+ if (this.session != null) {
+ this.session.close();
+ }
+ if (this.byteArrayOutputStream != null) {
+ this.byteArrayOutputStream.close();
+ }
+ if (this.printStream != null) {
+ printStream.close();
+ }
+ }
+ }
+
+ public CommandProcessor getCommandProcessor() {
+ return commandProcessor;
+ }
+
+ public void setCommandProcessor(CommandProcessor commandProcessor) {
+ this.commandProcessor = commandProcessor;
+ }
+}
Modified: karaf/branches/karaf-2.2.x/shell/commands/src/main/resources/OSGI-INF/blueprint/shell-commands.xml
URL: http://svn.apache.org/viewvc/karaf/branches/karaf-2.2.x/shell/commands/src/main/resources/OSGI-INF/blueprint/shell-commands.xml?rev=1292305&r1=1292304&r2=1292305&view=diff
==============================================================================
--- karaf/branches/karaf-2.2.x/shell/commands/src/main/resources/OSGI-INF/blueprint/shell-commands.xml (original)
+++ karaf/branches/karaf-2.2.x/shell/commands/src/main/resources/OSGI-INF/blueprint/shell-commands.xml Wed Feb 22 14:19:47 2012
@@ -82,8 +82,19 @@
<command name="shell/tail">
<action class="org.apache.karaf.shell.commands.TailAction"/>
</command>
+ <command name="shell/command-watch">
+ <action class="org.apache.karaf.shell.shell.WatchAction">
+ <property name="commandProcessor" ref="commandProcessor"/>
+ </action>
+ <completers>
+ <ref component-id="commandCompleter" />
+ <null/>
+ </completers>
+ </command>
</command-bundle>
+ <bean id="commandCompleter" class="org.apache.karaf.shell.console.completer.CommandsCompleter"/>
+
<bean class="org.osgi.util.tracker.BundleTracker" init-method="open"
destroy-method="close">
<argument ref="blueprintBundleContext" />
@@ -98,5 +109,7 @@
<reference-list id="infoProviders" interface="org.apache.karaf.shell.commands.info.InfoProvider"
availability="optional">
</reference-list>
+
+ <reference id="commandProcessor" interface="org.apache.felix.service.command.CommandProcessor"/>
</blueprint>
Modified: karaf/branches/karaf-2.2.x/shell/console/src/main/java/org/apache/karaf/shell/console/completer/ArgumentCompleter.java
URL: http://svn.apache.org/viewvc/karaf/branches/karaf-2.2.x/shell/console/src/main/java/org/apache/karaf/shell/console/completer/ArgumentCompleter.java?rev=1292305&r1=1292304&r2=1292305&view=diff
==============================================================================
--- karaf/branches/karaf-2.2.x/shell/console/src/main/java/org/apache/karaf/shell/console/completer/ArgumentCompleter.java (original)
+++ karaf/branches/karaf-2.2.x/shell/console/src/main/java/org/apache/karaf/shell/console/completer/ArgumentCompleter.java Wed Feb 22 14:19:47 2012
@@ -325,7 +325,8 @@ public class ArgumentCompleter implement
* enter "f bar" into the buffer, and move to after the "f"
* and hit TAB, we want "foo bar" instead of "foo bar".
*/
- if ((cursor != buffer.length()) && isDelimiter(buffer, cursor)) {
+
+ if ((buffer != null) && (cursor != buffer.length()) && isDelimiter(buffer, cursor)) {
for (int i = 0; i < candidates.size(); i++) {
String val = candidates.get(i);
Modified: karaf/branches/karaf-2.2.x/shell/console/src/main/java/org/apache/karaf/shell/console/completer/CommandsCompleter.java
URL: http://svn.apache.org/viewvc/karaf/branches/karaf-2.2.x/shell/console/src/main/java/org/apache/karaf/shell/console/completer/CommandsCompleter.java?rev=1292305&r1=1292304&r2=1292305&view=diff
==============================================================================
--- karaf/branches/karaf-2.2.x/shell/console/src/main/java/org/apache/karaf/shell/console/completer/CommandsCompleter.java (original)
+++ karaf/branches/karaf-2.2.x/shell/console/src/main/java/org/apache/karaf/shell/console/completer/CommandsCompleter.java Wed Feb 22 14:19:47 2012
@@ -35,6 +35,7 @@ import org.apache.karaf.shell.console.Co
import org.apache.karaf.shell.console.Completer;
import org.osgi.framework.BundleContext;
import org.osgi.framework.ServiceReference;
+import org.apache.karaf.shell.console.jline.CommandSessionHolder;
/**
* Like the {@link org.apache.karaf.shell.console.completer.CommandsCompleter} but does not use OSGi but is
@@ -46,12 +47,19 @@ public class CommandsCompleter implement
private final List<Completer> completers = new ArrayList<Completer>();
private final Set<String> commands = new HashSet<String>();
+ public CommandsCompleter() {
+ this(CommandSessionHolder.getSession());
+ }
+
public CommandsCompleter(CommandSession session) {
this.session = session;
}
public int complete(String buffer, int cursor, List<String> candidates) {
+ if (session == null) {
+ session = CommandSessionHolder.getSession();
+ }
checkData();
int res = new AggregateCompleter(completers).complete(buffer, cursor, candidates);
Collections.sort(candidates);