blob: 91ad3b8f3e3505b0863a096ae7a871b0a801dfc6 [file] [log] [blame]
/* Copyright (C) 2003 Vladimir Roubtsov. All rights reserved.
*
* This program and the accompanying materials are made available under
* the terms of the Common Public License v1.0 which accompanies this distribution,
* and is available at http://www.eclipse.org/legal/cpl-v10.html
*
* $Id: IMethodCollection.java,v 1.1.1.1 2004/05/09 16:57:46 vlad_r Exp $
*/
package com.vladium.jcd.cls;
import com.vladium.jcd.compiler.IClassFormatOutput;
// ----------------------------------------------------------------------------
/**
* An abstraction of the 'methods' component of .class format. The contents
* are {@link Method_info} structures corresponding to all methods directly
* declared by this class/interface. The order in which they appear is
* unspecified.
*
* @author (C) 2001, Vlad Roubtsov
*/
public
interface IMethodCollection extends Cloneable, IClassFormatOutput
{
// public: ................................................................
// ACCESSORS:
/**
* Returns {@link Method_info} descriptor at a given offset.
*
* @param offset method offset [must be in [0, size()) range; input not checked]
* @return Method_info descriptor [never null]
*
* @throws IndexOutOfBoundsException if 'offset' is outside of valid range
*/
Method_info get (int offset);
/**
* Returns an array of offsets for methods named 'name' (empty array if no
* matching fields found).
*
* @param cls class definition providing the constant pool against which to
* resolve names [may not be null]
* @param name method name [null or empty will result in no matches]
* @return array of method offsets in no particular order [never null; could be empty]
*
* @throws IllegalArgumentException if 'cls' is null
*/
int [] get (ClassDef cls, String name);
/**
* Returns the number of methods in this collection [can be 0].
*/
int size ();
// Cloneable: adjust the access level of Object.clone():
Object clone ();
// Visitor:
void accept (IClassDefVisitor visitor, Object ctx);
// MUTATORS:
/**
* Adds a new Method_info descriptor to this collection. No duplicate
* checks are made. It is the responsibility of the caller to ensure
* that all data referenced in 'method' will eventually appear in the
* constant pool.
*
* @param method new method descriptor [may not be null]
*/
int add (Method_info method);
/**
* Replaces the Method_info descriptor at a given offset. No duplicate
* checks are made. No method type compatibility checks are made. It is
* the responsibility of the caller to ensure that all data referenced
* in 'method' will eventually appear in the constant pool.
*
* @param offset method offset [must be in [0, size()) range; input not checked]
* @param method new method descriptor [may not be null]
* @return previous method descriptor at this offset [never null]
*
* @throws IndexOutOfBoundsException if 'offset' is outside of valid range
*/
Method_info set (int offset, Method_info method);
// TODO: support this via iterators instead
/**
* Removes the Method_info descriptor at a given offset. It is
* the responsibility of the caller to ensure that the class definition
* remains consistent after this change.
*
* @param offset method offset [must be in [0, size()) range; input not checked]
* @return method descriptor at this offset [never null]
*
* @throws IndexOutOfBoundsException if 'offset' is outside of valid range
*/
Method_info remove (int offset);
} // end of interface
// ----------------------------------------------------------------------------