Tue, 16 Sep 2008 18:35:18 -0700
6574134: Allow for alternative implementation of Name Table with garbage collection of name bytes
Reviewed-by: darcy, mcimadamore
1 /*
2 * Copyright 2007-2008 Sun Microsystems, Inc. All Rights Reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation. Sun designates this
8 * particular file as subject to the "Classpath" exception as provided
9 * by Sun in the LICENSE file that accompanied this code.
10 *
11 * This code is distributed in the hope that it will be useful, but WITHOUT
12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14 * version 2 for more details (a copy is included in the LICENSE file that
15 * accompanied this code).
16 *
17 * You should have received a copy of the GNU General Public License version
18 * 2 along with this work; if not, write to the Free Software Foundation,
19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
20 *
21 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
22 * CA 95054 USA or visit www.sun.com if you need additional information or
23 * have any questions.
24 */
26 package com.sun.tools.javap;
28 import java.util.HashSet;
29 import java.util.Set;
30 import com.sun.tools.classfile.AccessFlags;
32 /*
33 * Provides access to javap's options, set via the command line
34 * or JSR 199 API.
35 * <p><b>This is NOT part of any API supported by Sun Microsystems. If
36 * you write code that depends on this, you do so at your own risk.
37 * This code and its internal interfaces are subject to change or
38 * deletion without notice.</b>
39 */
40 public class Options {
41 public static Options instance(Context context) {
42 Options instance = context.get(Options.class);
43 if (instance == null)
44 instance = new Options(context);
45 return instance;
46 }
48 protected Options(Context context) {
49 context.put(Options.class, this);
50 }
52 /**
53 * Checks access of class, field or method.
54 */
55 public boolean checkAccess(AccessFlags flags){
57 boolean isPublic = flags.is(AccessFlags.ACC_PUBLIC);
58 boolean isProtected = flags.is(AccessFlags.ACC_PROTECTED);
59 boolean isPrivate = flags.is(AccessFlags.ACC_PRIVATE);
60 boolean isPackage = !(isPublic || isProtected || isPrivate);
62 if ((showAccess == AccessFlags.ACC_PUBLIC) && (isProtected || isPrivate || isPackage))
63 return false;
64 else if ((showAccess == AccessFlags.ACC_PROTECTED) && (isPrivate || isPackage))
65 return false;
66 else if ((showAccess == 0) && (isPrivate))
67 return false;
68 else
69 return true;
70 }
72 public boolean help;
73 public boolean verbose;
74 public boolean version;
75 public boolean fullVersion;
76 public boolean showFlags;
77 public boolean showLineAndLocalVariableTables;
78 public int showAccess;
79 public Set<String> accessOptions = new HashSet<String>();
80 public boolean showDisassembled;
81 public boolean showInternalSignatures;
82 public boolean showAllAttrs;
83 public boolean showConstants;
84 public boolean sysInfo;
86 public boolean compat; // bug-for-bug compatibility mode with old javap
87 public boolean jsr277;
88 public boolean ignoreSymbolFile; // file manager should ignore ct.sym
89 }