jline 在Eclipse下的运行问题

最近用到karaf,而karaf的控制台使用了jline处理控制台输入。

在Eclipse下运行时,控制台无法接受输入,输入命令、回车,系统没反应。

 

原因是在通过JNI调用本地WindowsAPI时,本地的private static final native int ReadConsoleInputW()方法返回了非预期的值。导致控制台读取部分实际上处于死循环状态。

 

解决方法:设置系统属性jline.WindowsTerminal.directConsole为false。

(绕过本地库Windows API调用,直接使用Java IO流读取输入)

主要参考了:http://whitesock.iteye.com/blog/692816

 

打开jline的日志:设置系统属性jline.internal.Log.debug为true

另外,要调试jline的话,几个依赖库:

<dependency>

<groupId>org.fusesource.hawtjni</groupId>

<artifactId>hawtjni-runtime</artifactId>

<version>1.11</version>

</dependency>

<dependency>

<groupId>org.fusesource.jansi</groupId>

<artifactId>jansi-native</artifactId>

<version>1.5</version>

</dependency>

<dependency>

<groupId>jline</groupId>

<artifactId>jline</artifactId>

<version>2.13</version>

</dependency>

 

调试代码:

public static void main(String[] args) throws Exception {

System.setProperty("jline.internal.Log.debug", "true");

//System.setProperty("jline.WindowsTerminal.directConsole", "false");

 

ConsoleReader console = new ConsoleReader();

String line = console.readLine();

System.out.println("----" + line);

}

 

 对于karaf shell中包含 more输出方式的命令,more的执行效果仍然有问题。

比如,对于help命令。(按每一个字母都分别输出了---more----)

可以修改etc\shell.init.script文件,修改其:

help = { *:help $args | more } ;  改为:

help = { *:help $args } ;

猜你喜欢

转载自sswh.iteye.com/blog/2256621