summaryrefslogtreecommitdiffstats
path: root/src/main/java/com/beust/jcommander/internal/JDK6Console.java
diff options
context:
space:
mode:
authorIgor Murashkin <iam@google.com>2016-03-24 14:21:34 -0700
committerIgor Murashkin <iam@google.com>2016-03-24 14:21:57 -0700
commit7f95581d269e0815eab16115f0e36c0ee325dc88 (patch)
treef1aa3cbaef213c6d2693df6d0ae4d449cc3e6815 /src/main/java/com/beust/jcommander/internal/JDK6Console.java
parentb3994367e22d0ce3670ff9fb693a4f2939ef5d58 (diff)
parent5321f6ff3251784760f79982b1a720e3607c5003 (diff)
downloadplatform_external_jcommander-7f95581d269e0815eab16115f0e36c0ee325dc88.tar.gz
platform_external_jcommander-7f95581d269e0815eab16115f0e36c0ee325dc88.tar.bz2
platform_external_jcommander-7f95581d269e0815eab16115f0e36c0ee325dc88.zip
Merge remote-tracking branch 'goog/master' into nyc-dev
Bug: 27552463 Change-Id: Icaacbb9acf1454b39974d319d30023aea6fea5f6
Diffstat (limited to 'src/main/java/com/beust/jcommander/internal/JDK6Console.java')
-rw-r--r--src/main/java/com/beust/jcommander/internal/JDK6Console.java45
1 files changed, 45 insertions, 0 deletions
diff --git a/src/main/java/com/beust/jcommander/internal/JDK6Console.java b/src/main/java/com/beust/jcommander/internal/JDK6Console.java
new file mode 100644
index 0000000..70cb186
--- /dev/null
+++ b/src/main/java/com/beust/jcommander/internal/JDK6Console.java
@@ -0,0 +1,45 @@
+package com.beust.jcommander.internal;
+
+import com.beust.jcommander.ParameterException;
+
+import java.io.PrintWriter;
+import java.lang.reflect.Method;
+
+public class JDK6Console implements Console {
+
+ private Object console;
+
+ private PrintWriter writer;
+
+ public JDK6Console(Object console) throws Exception {
+ this.console = console;
+ Method writerMethod = console.getClass().getDeclaredMethod("writer", new Class<?>[0]);
+ writer = (PrintWriter) writerMethod.invoke(console, new Object[0]);
+ }
+
+ public void print(String msg) {
+ writer.print(msg);
+ }
+
+ public void println(String msg) {
+ writer.println(msg);
+ }
+
+ public char[] readPassword(boolean echoInput) {
+ try {
+ writer.flush();
+ Method method;
+ if (echoInput) {
+ method = console.getClass().getDeclaredMethod("readLine", new Class<?>[0]);
+ return ((String) method.invoke(console, new Object[0])).toCharArray();
+ } else {
+ method = console.getClass().getDeclaredMethod("readPassword", new Class<?>[0]);
+ return (char[]) method.invoke(console, new Object[0]);
+ }
+ }
+ catch (Exception e) {
+ throw new ParameterException(e);
+ }
+ }
+
+} \ No newline at end of file