/* * Copyright (c) 2006, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package com.sun.tools.javac.main; import com.sun.tools.javac.util.Log; import com.sun.tools.javac.util.Options; import java.io.PrintWriter; /** * TODO: describe com.sun.tools.javac.main.JavacOption * * <p><b>This is NOT part of any supported API. * If you write code that depends on this, you do so at your own * risk. This code and its internal interfaces are subject to change * or deletion without notice.</b></p> */ public interface JavacOption { OptionKind getKind(); /** Does this option take a (separate) operand? */ boolean hasArg(); /** Does argument string match option pattern? * @param arg The command line argument string. */ boolean matches(String arg); /** Process the option (with arg). Return true if error detected. */ boolean process(Options options, String option, String arg); /** Process the option (without arg). Return true if error detected. */ boolean process(Options options, String option); OptionName getName(); enum OptionKind { NORMAL, EXTENDED, HIDDEN, } /** This class represents an option recognized by the main program */ static class Option implements JavacOption { /** Option string. */ OptionName name; /** Documentation key for arguments. */ String argsNameKey; /** Documentation key for description. */ String descrKey; /** Suffix option (-foo=bar or -foo:bar) */ boolean hasSuffix; Option(OptionName name, String argsNameKey, String descrKey) { this.name = name; this.argsNameKey = argsNameKey; this.descrKey = descrKey; char lastChar = name.optionName.charAt(name.optionName.length()-1); hasSuffix = lastChar == ':' || lastChar == '='; } Option(OptionName name, String descrKey) { this(name, null, descrKey); } public String toString() { return name.optionName; } /** Does this option take a (separate) operand? */ public boolean hasArg() { return argsNameKey != null && !hasSuffix; } /** Does argument string match option pattern? * @param arg The command line argument string. */ public boolean matches(String arg) { return hasSuffix ? arg.startsWith(name.optionName) : arg.equals(name.optionName); } /** Print a line of documentation describing this option, if standard. */ void help(PrintWriter out) { String s = " " + helpSynopsis(); out.print(s); for (int j = s.length(); j < 29; j++) out.print(" "); Log.printLines(out, Main.getLocalizedString(descrKey)); } String helpSynopsis() { return name + (argsNameKey == null ? "" : ((hasSuffix ? "" : " ") + Main.getLocalizedString(argsNameKey))); } /** Print a line of documentation describing this option, if non-standard. */ void xhelp(PrintWriter out) {} /** Process the option (with arg). Return true if error detected. */ public boolean process(Options options, String option, String arg) { if (options != null) options.put(option, arg); return false; } /** Process the option (without arg). Return true if error detected. */ public boolean process(Options options, String option) { if (hasSuffix) return process(options, name.optionName, option.substring(name.optionName.length())); else return process(options, option, option); } public OptionKind getKind() { return OptionKind.NORMAL; } public OptionName getName() { return name; } }; /** A nonstandard or extended (-X) option */ static class XOption extends Option { XOption(OptionName name, String argsNameKey, String descrKey) { super(name, argsNameKey, descrKey); } XOption(OptionName name, String descrKey) { this(name, null, descrKey); } void help(PrintWriter out) {} void xhelp(PrintWriter out) { super.help(out); } public OptionKind getKind() { return OptionKind.EXTENDED; } }; /** A hidden (implementor) option */ static class HiddenOption extends Option { HiddenOption(OptionName name) { super(name, null, null); } HiddenOption(OptionName name, String argsNameKey) { super(name, argsNameKey, null); } void help(PrintWriter out) {} void xhelp(PrintWriter out) {} public OptionKind getKind() { return OptionKind.HIDDEN; } }; }