Package gw.lang.reflect
Class MethodInfoBuilder.BuiltMethodInfo
java.lang.Object
gw.lang.reflect.MethodInfoBuilder.BuiltMethodInfo
- All Implemented Interfaces:
IAnnotatedFeatureInfo,IAttributedFeatureInfo,IFeatureInfo,IHasParameterInfos,IMethodInfo,IOptionalParamCapable
- Enclosing class:
- MethodInfoBuilder
private static class MethodInfoBuilder.BuiltMethodInfo
extends Object
implements IMethodInfo, IOptionalParamCapable
-
Nested Class Summary
Nested classes/interfaces inherited from interface gw.lang.reflect.IAnnotatedFeatureInfo
IAnnotatedFeatureInfo.IAnnotationInfoHelperNested classes/interfaces inherited from interface gw.lang.reflect.IAttributedFeatureInfo
IAttributedFeatureInfo.MODIFIER -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final IMethodCallHandlerprivate final IFeatureInfoprivate final Stringprivate final Stringprivate final List<IExceptionInfo>private final booleanprivate final booleanprivate final ILocationInfoprivate final Stringprivate final IParameterInfo[]private final Stringprivate final ITypeprivate final StringFields inherited from interface gw.lang.reflect.IAnnotatedFeatureInfo
ANNOTATION_HELPER -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptiongetAnnotation(IType type) getAnnotationsOfType(IType type) Get this feature's containing feature.A full description of this feature.Gets the display name of this feature.getName()Gets the programmatic name or identifier of this feature.Get this feature's owner's type.String[]booleanhasAnnotation(IType type) booleanhasDeclaredAnnotation(IType type) booleanbooleanbooleanbooleanisFinal()booleanisHidden()True if this feature is hidden.booleanTrue if this feature is internal.booleanTrue if this feature is private.booleanTrue if this feature is protected.booleanisPublic()True if this feature is public.booleanbooleanTrue if this feature is exposed for scripting.booleanisStatic()True if this feature is static, meaning the feature is not specific to a particular instance of the feature's containing type.booleanisVisible(IScriptabilityModifier constraint) Determine if this feature is visible given a visibility constraint.private StringtoString()
-
Field Details
-
_container
-
_name
-
_signature
-
_parameters
-
_returnType
-
_callHandler
-
_exceptions
-
_deprecated
-
_isStatic
private final boolean _isStatic -
_description
-
_returnDescription
-
_locationInfo
-
-
Constructor Details
-
BuiltMethodInfo
-
-
Method Details
-
getParameters
- Specified by:
getParametersin interfaceIHasParameterInfos- Specified by:
getParametersin interfaceIMethodInfo
-
getDefaultValueExpressions
- Specified by:
getDefaultValueExpressionsin interfaceIOptionalParamCapable- Returns:
- An array of objects representing the default values for a function's parameters. Returns an empty array if there are no default values, otherwise returns an array corresponding with default parameter values. If a parameter does not have a default value, it's default value is null in the array.
-
getParameterNames
- Specified by:
getParameterNamesin interfaceIOptionalParamCapable
-
getReturnType
- Specified by:
getReturnTypein interfaceIMethodInfo
-
getCallHandler
- Specified by:
getCallHandlerin interfaceIMethodInfo
-
getReturnDescription
- Specified by:
getReturnDescriptionin interfaceIMethodInfo
-
getExceptions
- Specified by:
getExceptionsin interfaceIMethodInfo
-
isScriptable
public boolean isScriptable()Description copied from interface:IAttributedFeatureInfoTrue if this feature is exposed for scripting.- Specified by:
isScriptablein interfaceIAttributedFeatureInfo
-
isDeprecated
public boolean isDeprecated()- Specified by:
isDeprecatedin interfaceIAnnotatedFeatureInfo- Returns:
- True if this feature is deprecated.
-
getDeprecatedReason
- Specified by:
getDeprecatedReasonin interfaceIAnnotatedFeatureInfo- Returns:
- The deprecation message, or null if the feature is not deprecated.
-
isDefaultImpl
public boolean isDefaultImpl()- Specified by:
isDefaultImplin interfaceIAnnotatedFeatureInfo- Returns:
- True if this feature is the default implementation e.g., default interface method
-
isVisible
Description copied from interface:IAttributedFeatureInfoDetermine if this feature is visible given a visibility constraint.
NOTE: implementers of this method are responsible for handling the null case, taken to mean that there are not scriptability constraints.- Specified by:
isVisiblein interfaceIAttributedFeatureInfo
-
isHidden
public boolean isHidden()Description copied from interface:IAttributedFeatureInfoTrue if this feature is hidden. Hidden feature should not to be exposed to earthlings.- Specified by:
isHiddenin interfaceIAttributedFeatureInfo
-
isStatic
public boolean isStatic()Description copied from interface:IAttributedFeatureInfoTrue if this feature is static, meaning the feature is not specific to a particular instance of the feature's containing type.- Specified by:
isStaticin interfaceIAttributedFeatureInfo
-
isPrivate
public boolean isPrivate()Description copied from interface:IAttributedFeatureInfoTrue if this feature is private. Private features are only accessible from within the type that owns them.- Specified by:
isPrivatein interfaceIAttributedFeatureInfo
-
isInternal
public boolean isInternal()Description copied from interface:IAttributedFeatureInfoTrue if this feature is internal. Internal features are accessible from within the type that owns them and from other types in the same namespace.- Specified by:
isInternalin interfaceIAttributedFeatureInfo
-
isProtected
public boolean isProtected()Description copied from interface:IAttributedFeatureInfoTrue if this feature is protected. Protected features are accessible from within the type that owns them and from derived containers.- Specified by:
isProtectedin interfaceIAttributedFeatureInfo
-
isPublic
public boolean isPublic()Description copied from interface:IAttributedFeatureInfoTrue if this feature is public. Public features are not restricted.- Specified by:
isPublicin interfaceIAttributedFeatureInfo
-
isAbstract
public boolean isAbstract()- Specified by:
isAbstractin interfaceIAttributedFeatureInfo
-
isFinal
public boolean isFinal()- Specified by:
isFinalin interfaceIAttributedFeatureInfo
-
isReified
public boolean isReified()- Specified by:
isReifiedin interfaceIAttributedFeatureInfo
-
getAnnotations
- Specified by:
getAnnotationsin interfaceIAnnotatedFeatureInfo- Returns:
- A map of AnnotationInfo objects by type representing all the annotations associated with this feature and all the features in its ancestry, or an empty map if there are no annotations.
-
getDeclaredAnnotations
- Specified by:
getDeclaredAnnotationsin interfaceIAnnotatedFeatureInfo- Returns:
- A map of AnnotationInfo objects by type representing all the annotations associated with this feature, or an empty map if there are no annotations.
-
getAnnotationsOfType
- Specified by:
getAnnotationsOfTypein interfaceIAnnotatedFeatureInfo- Returns:
- A list of AnnotationInfo objects having the specified type.
-
getAnnotation
- Specified by:
getAnnotationin interfaceIAnnotatedFeatureInfo- Returns:
- An AnnotationInfo object having the specified type, or null if no such AnnotationInfo exists.
-
hasDeclaredAnnotation
- Specified by:
hasDeclaredAnnotationin interfaceIAnnotatedFeatureInfo- Parameters:
type- The type of the annotation to test for existence.- Returns:
- true If this feature has a declared annotation of the given type, false otherwise
-
hasAnnotation
- Specified by:
hasAnnotationin interfaceIAnnotatedFeatureInfo- Parameters:
type- The type of the annotation to test for existence.- Returns:
- true If this feature has an annotation with of the given type, false otherwise
-
getContainer
Description copied from interface:IFeatureInfoGet this feature's containing feature. May be null.- Specified by:
getContainerin interfaceIFeatureInfo
-
getOwnersType
Description copied from interface:IFeatureInfoGet this feature's owner's type. If this feature has no owner, this is the type of the feature itself. Typically, the only kind of feature w/o an owner is an ITypeInfo, so properties, methods, params, etc. s/b considered owned. Hence, ultimately an ITypeInfo's type will be the owner's type for any given feature.- Specified by:
getOwnersTypein interfaceIFeatureInfo
-
getName
Description copied from interface:IFeatureInfoGets the programmatic name or identifier of this feature. Note this name should follow Java identifier naming conventions (alpha-num and underscores, but can't start with a digit).- Specified by:
getNamein interfaceIFeatureInfo- Specified by:
getNamein interfaceIMethodInfo
-
makeSignature
-
getDisplayName
Description copied from interface:IFeatureInfoGets the display name of this feature. There is no guarantee this display name is localized.- Specified by:
getDisplayNamein interfaceIFeatureInfo
-
getDescription
Description copied from interface:IFeatureInfoA full description of this feature.- Specified by:
getDescriptionin interfaceIFeatureInfo
-
getLocationInfo
- Specified by:
getLocationInfoin interfaceIFeatureInfo
-
toString
-