1 /*
2 **
3 ** Copyright 2013, The Android Open Source Project
4 **
5 ** Licensed under the Apache License, Version 2.0 (the "License");
6 ** you may not use this file except in compliance with the License.
7 ** You may obtain a copy of the License at
8 **
9 **     http://www.apache.org/licenses/LICENSE-2.0
10 **
11 ** Unless required by applicable law or agreed to in writing, software
12 ** distributed under the License is distributed on an "AS IS" BASIS,
13 ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 ** See the License for the specific language governing permissions and
15 ** limitations under the License.
16 */
17 
18 package com.android.internal.os;
19 
20 import android.os.ShellCommand;
21 
22 import java.io.PrintStream;
23 
24 public abstract class BaseCommand {
25 
26     final protected ShellCommand mArgs = new ShellCommand() {
27         @Override public int onCommand(String cmd) {
28             return 0;
29         }
30         @Override public void onHelp() {
31         }
32     };
33 
34     // These are magic strings understood by the Eclipse plugin.
35     public static final String FATAL_ERROR_CODE = "Error type 1";
36     public static final String NO_SYSTEM_ERROR_CODE = "Error type 2";
37     public static final String NO_CLASS_ERROR_CODE = "Error type 3";
38 
39     private String[] mRawArgs;
40 
41     /**
42      * Call to run the command.
43      */
run(String[] args)44     public void run(String[] args) {
45         if (args.length < 1) {
46             onShowUsage(System.out);
47             return;
48         }
49 
50         mRawArgs = args;
51         mArgs.init(null, null, null, null, args, null, 0);
52 
53         try {
54             onRun();
55         } catch (IllegalArgumentException e) {
56             onShowUsage(System.err);
57             System.err.println();
58             System.err.println("Error: " + e.getMessage());
59         } catch (Exception e) {
60             e.printStackTrace(System.err);
61             System.exit(1);
62         }
63     }
64 
65     /**
66      * Convenience to show usage information to error output.
67      */
showUsage()68     public void showUsage() {
69         onShowUsage(System.err);
70     }
71 
72     /**
73      * Convenience to show usage information to error output along
74      * with an error message.
75      */
showError(String message)76     public void showError(String message) {
77         onShowUsage(System.err);
78         System.err.println();
79         System.err.println(message);
80     }
81 
82     /**
83      * Implement the command.
84      */
onRun()85     public abstract void onRun() throws Exception;
86 
87     /**
88      * Print help text for the command.
89      */
onShowUsage(PrintStream out)90     public abstract void onShowUsage(PrintStream out);
91 
92     /**
93      * Return the next option on the command line -- that is an argument that
94      * starts with '-'.  If the next argument is not an option, null is returned.
95      */
nextOption()96     public String nextOption() {
97         return mArgs.getNextOption();
98     }
99 
100     /**
101      * Return the next argument on the command line, whatever it is; if there are
102      * no arguments left, return null.
103      */
nextArg()104     public String nextArg() {
105         return mArgs.getNextArg();
106     }
107 
108     /**
109      * Peek the next argument on the command line, whatever it is; if there are
110      * no arguments left, return null.
111      */
peekNextArg()112     public String peekNextArg() {
113         return mArgs.peekNextArg();
114     }
115 
116     /**
117      * Return the next argument on the command line, whatever it is; if there are
118      * no arguments left, throws an IllegalArgumentException to report this to the user.
119      */
nextArgRequired()120     public String nextArgRequired() {
121         return mArgs.getNextArgRequired();
122     }
123 
124     /**
125      * Return the original raw argument list supplied to the command.
126      */
getRawArgs()127     public String[] getRawArgs() {
128         return mRawArgs;
129     }
130 }
131