jline.UnsupportedTerminal Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hadoop-ranger-client-for-impala Show documentation
Show all versions of hadoop-ranger-client-for-impala Show documentation
Tencent Qcloud chdfs hadoop ranger client.
The newest version!
/*
* Copyright (c) 2002-2007, Marc Prud'hommeaux. All rights reserved.
*
* This software is distributable under the BSD license. See the terms of the
* BSD license in the documentation provided with this software.
*/
package jline;
import java.io.IOException;
/**
* A no-op unsupported terminal.
*
* @author Marc Prud'hommeaux
*/
public class UnsupportedTerminal extends Terminal {
private Thread maskThread = null;
public void initializeTerminal() {
// nothing we need to do (or can do) for windows.
}
public boolean getEcho() {
return true;
}
public boolean isEchoEnabled() {
return true;
}
public void enableEcho() {
}
public void disableEcho() {
}
/**
* Always returng 80, since we can't access this info on Windows.
*/
public int getTerminalWidth() {
return 80;
}
/**
* Always returng 24, since we can't access this info on Windows.
*/
public int getTerminalHeight() {
return 80;
}
public boolean isSupported() {
return false;
}
public void beforeReadLine(final ConsoleReader reader, final String prompt,
final Character mask) {
if ((mask != null) && (maskThread == null)) {
final String fullPrompt = "\r" + prompt
+ " "
+ " "
+ " "
+ "\r" + prompt;
maskThread = new Thread("JLine Mask Thread") {
public void run() {
while (!interrupted()) {
try {
reader.out.write(fullPrompt);
reader.out.flush();
sleep(3);
} catch (IOException ioe) {
return;
} catch (InterruptedException ie) {
return;
}
}
}
};
maskThread.setPriority(Thread.MAX_PRIORITY);
maskThread.setDaemon(true);
maskThread.start();
}
}
public void afterReadLine(final ConsoleReader reader, final String prompt,
final Character mask) {
if ((maskThread != null) && maskThread.isAlive()) {
maskThread.interrupt();
}
maskThread = null;
}
}