blob: 5fc3c662c8b85a84679b5238107efe13a7503462 [file] [log] [blame]
/***** BEGIN LICENSE BLOCK *****
* Version: CPL 1.0/GPL 2.0/LGPL 2.1
*
* The contents of this file are subject to the Common Public
* License Version 1.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.eclipse.org/legal/cpl-v10.html
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Copyright (C) 2002 Jan Arne Petersen <jpetersen@uni-bonn.de>
* Copyright (C) 2002-2004 Anders Bengtsson <ndrsbngtssn@yahoo.se>
* Copyright (C) 2004 Thomas E Enebo <enebo@acm.org>
*
* Alternatively, the contents of this file may be used under the terms of
* either of the GNU General Public License Version 2 or later (the "GPL"),
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the CPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the CPL, the GPL or the LGPL.
***** END LICENSE BLOCK *****/
package org.jruby.runtime;
import java.io.Serializable;
/**
* This class represents two concepts: method visibility and a mask for
* determining a set of valid method visibilities. The first concept can only
* be a single value: PUBLIC, PRIVATE, PROTECTED, and MODULE_FUNCTION (see
* RubyModule#module_function). It is used to adorn a method with a _SINGLE_
* visibility. Some functions (see RubyModule#instance_methods) want to be
* able to see methods of multiple visibilities. The second concept allows
* making a vibility which is basically a mask (see
* Visibility.PUBLIC_PROTECTED). The method 'is' can then be used to see if a
* method visibility is in the mask.
*
* @author jpetersen
*/
public final class Visibility implements Serializable {
private static final short PUBLIC_VALUE = (short) 1;
private static final short PROTECTED_VALUE = (short) 2;
private static final short PRIVATE_VALUE = (short) 4;
private static final short MODULE_FUNCTION_VALUE = (short) 8;
public static final Visibility PUBLIC = new Visibility(PUBLIC_VALUE);
public static final Visibility PROTECTED = new Visibility(PROTECTED_VALUE);
public static final Visibility PRIVATE = new Visibility(PRIVATE_VALUE);
public static final Visibility MODULE_FUNCTION = new Visibility(MODULE_FUNCTION_VALUE);
public static final Visibility PUBLIC_PROTECTED =
new Visibility((short) (PUBLIC_VALUE | PROTECTED_VALUE));
private final short restore;
static final long serialVersionUID = 2002102900L;
/**
* Constructor for MethodScope.
*/
private Visibility(short restore) {
this.restore = restore;
}
public boolean isPublic() {
return (restore & PUBLIC_VALUE) != 0;
}
public boolean isProtected() {
return (restore & PROTECTED_VALUE) != 0;
}
public boolean isPrivate() {
return (restore & PRIVATE_VALUE) != 0;
}
public boolean isModuleFunction() {
return (restore & MODULE_FUNCTION_VALUE) != 0;
}
public boolean is(Visibility other) {
return (restore & other.restore) != 0;
}
public String toString() {
// XXXEnebo: will only print out actual visibilities
// and not masks
switch (restore) {
case 1:
return "public";
case 2:
return "protected";
case 4:
return "private";
case 8:
return "module_function";
default:
return "mixed mask: " + restore;
}
}
// public String errorMessageFormat(CallType callType, String name) {
// String format = "undefined method `%s' for %s%s%s";
// if (callType == CallType.VARIABLE) {
// if (IdUtil.isLocal(name)) {
// format = "undefined local variable or method '%s' for %s%s%s";
// }
// } else if (this == Visibility.PRIVATE && callType == CallType.NORMAL) {
// format = "private method '%s' called for %s%s%s";
// } else if (this == Visibility.PROTECTED) {
// format = "protected method '%s' called for %s%s%s";
// } else {
// }
//
// return format;
// }
}