Class GosuFragmentTypeInfo

java.lang.Object
gw.internal.gosu.parser.fragments.GosuFragmentTypeInfo
All Implemented Interfaces:
IAnnotatedFeatureInfo, IFeatureInfo, IRelativeTypeInfo, ITypeInfo

public class GosuFragmentTypeInfo extends Object implements IRelativeTypeInfo
  • Field Details

  • Constructor Details

    • GosuFragmentTypeInfo

      public GosuFragmentTypeInfo(GosuFragment fragment)
  • Method Details

    • getAnnotations

      public List<IAnnotationInfo> getAnnotations()
      Specified by:
      getAnnotations in interface IAnnotatedFeatureInfo
      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

      public List<IAnnotationInfo> getDeclaredAnnotations()
      Specified by:
      getDeclaredAnnotations in interface IAnnotatedFeatureInfo
      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

      public List<IAnnotationInfo> getAnnotationsOfType(IType type)
      Specified by:
      getAnnotationsOfType in interface IAnnotatedFeatureInfo
      Returns:
      A list of AnnotationInfo objects having the specified type.
    • hasAnnotation

      public boolean hasAnnotation(IType type)
      Specified by:
      hasAnnotation in interface IAnnotatedFeatureInfo
      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
    • isDeprecated

      public boolean isDeprecated()
      Specified by:
      isDeprecated in interface IAnnotatedFeatureInfo
      Returns:
      True if this feature is deprecated.
    • getDeprecatedReason

      public String getDeprecatedReason()
      Specified by:
      getDeprecatedReason in interface IAnnotatedFeatureInfo
      Returns:
      The deprecation message, or null if the feature is not deprecated.
    • isDefaultImpl

      public boolean isDefaultImpl()
      Specified by:
      isDefaultImpl in interface IAnnotatedFeatureInfo
      Returns:
      True if this feature is the default implementation e.g., default interface method
    • getContainer

      public IFeatureInfo getContainer()
      Description copied from interface: IFeatureInfo
      Get this feature's containing feature. May be null.
      Specified by:
      getContainer in interface IFeatureInfo
    • getOwnersType

      public IType getOwnersType()
      Description copied from interface: IFeatureInfo
      Get 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:
      getOwnersType in interface IFeatureInfo
    • getName

      public String getName()
      Description copied from interface: IFeatureInfo
      Gets 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:
      getName in interface IFeatureInfo
    • getDisplayName

      public String getDisplayName()
      Description copied from interface: IFeatureInfo
      Gets the display name of this feature. There is no guarantee this display name is localized.
      Specified by:
      getDisplayName in interface IFeatureInfo
    • getDescription

      public String getDescription()
      Description copied from interface: IFeatureInfo
      A full description of this feature.
      Specified by:
      getDescription in interface IFeatureInfo
    • getProperties

      public List<? extends IPropertyInfo> getProperties()
      Specified by:
      getProperties in interface ITypeInfo
      Returns:
      An unmodifiable random access list of IPropertyInfo instances. The list is sorted ascending by name. Returns an empty list if there are no properties.
    • getProperty

      public IPropertyInfo getProperty(CharSequence propName)
      Description copied from interface: ITypeInfo
      Get a property mapped to the specified name.
      Specified by:
      getProperty in interface ITypeInfo
      Parameters:
      propName - The property name.
      Returns:
      An IPropertyInfo corresponding to the property name.
    • getMethods

      public MethodList getMethods()
      Specified by:
      getMethods in interface ITypeInfo
      Returns:
      An unmodifiable random access list of IMethodInfo instances. The list is sorted ascending by name. Returns an empty list if there are no methods.
    • getMethod

      public IMethodInfo getMethod(CharSequence methodName, IType... params)
      Description copied from interface: ITypeInfo
      Returns a IMethodInfo matching the specified name and parameter types or null if no match is found.

      Note params must exactly match those of the target method in number, order, and type. If null, params is treated as an empty array.

      Specified by:
      getMethod in interface ITypeInfo
      Parameters:
      methodName - The name of the method to find.
      params - Represents the exact number, order, and type of parameters in the method. A null value here is treated as an empty array.
      Returns:
      A IMethodInfo matching the name and parameter types.
    • getCallableMethod

      public IMethodInfo getCallableMethod(CharSequence method, IType... params)
      Description copied from interface: ITypeInfo
      Returns a IMethodInfo matching the specified name and has parameter types that produce the best match.

      If there is a tie with method names then this will throw an illegal argument exception.

      Specified by:
      getCallableMethod in interface ITypeInfo
      Parameters:
      method - The name of the method to find.
      params - Represents the exact number, order, and type of parameters in the method. A null value here is treated as an empty array.
      Returns:
      A IMethodInfo matching the name and parameter types.
    • getConstructors

      public List<? extends IConstructorInfo> getConstructors()
      Specified by:
      getConstructors in interface ITypeInfo
      Returns:
      An unmodifiable random access list of IConstructorInfo instances. The list is sorted ascending by name. Returns an empty list if there are no constructors.
    • getConstructor

      public IConstructorInfo getConstructor(IType... params)
      Description copied from interface: ITypeInfo
      Returns a IConstructorInfo that has parameter types that produce the best match.

      If there is a tie with method names then this will throw an illegal argument exception.

      Specified by:
      getConstructor in interface ITypeInfo
      Parameters:
      params - Represents the exact number, order, and type of parameters in the constructor. A null value here is treated as an empty array.
      Returns:
      A IConstructorInfo matching the parameter types.
    • getCallableConstructor

      public IConstructorInfo getCallableConstructor(IType... params)
      Description copied from interface: ITypeInfo
      Returns a IConstructorInfo matching the specified parameter types or null if no match is found.
      Specified by:
      getCallableConstructor in interface ITypeInfo
      Parameters:
      params - Represents the exact number, order, and type of parameters in the constructor. A null value here is treated as an empty array.
      Returns:
      A IConstructorInfo matching the parameter types.
    • getEvents

      public List<? extends IEventInfo> getEvents()
      Specified by:
      getEvents in interface ITypeInfo
      Returns:
      An unmodifiable random access list of IEventInfo instances. The list is sorted ascending by name. Returns an empty list if ther are no events.
    • getEvent

      public IEventInfo getEvent(CharSequence event)
      Description copied from interface: ITypeInfo
      Get an event mapped to the specified name.
      Specified by:
      getEvent in interface ITypeInfo
      Parameters:
      event - The event name.
      Returns:
      An IEventInfo corresponding to the event name.
    • getAccessibilityForType

      public IRelativeTypeInfo.Accessibility getAccessibilityForType(IType whosaskin)
      Specified by:
      getAccessibilityForType in interface IRelativeTypeInfo
    • getProperties

      public List<? extends IPropertyInfo> getProperties(IType whosaskin)
      Specified by:
      getProperties in interface IRelativeTypeInfo
    • getProperty

      public IPropertyInfo getProperty(IType whosaskin, CharSequence propName)
      Specified by:
      getProperty in interface IRelativeTypeInfo
    • getMethods

      public MethodList getMethods(IType whosaskin)
      Specified by:
      getMethods in interface IRelativeTypeInfo
    • getMethod

      public IMethodInfo getMethod(IType whosaskin, CharSequence methodName, IType... params)
      Specified by:
      getMethod in interface IRelativeTypeInfo
    • getConstructors

      public List<? extends IConstructorInfo> getConstructors(IType whosaskin)
      Specified by:
      getConstructors in interface IRelativeTypeInfo
    • getConstructor

      public IConstructorInfo getConstructor(IType whosAskin, IType[] params)
      Specified by:
      getConstructor in interface IRelativeTypeInfo
    • getAnnotation

      public IAnnotationInfo getAnnotation(IType type)
      Specified by:
      getAnnotation in interface IAnnotatedFeatureInfo
      Returns:
      An AnnotationInfo object having the specified type, or null if no such AnnotationInfo exists.
    • hasDeclaredAnnotation

      public boolean hasDeclaredAnnotation(IType type)
      Specified by:
      hasDeclaredAnnotation in interface IAnnotatedFeatureInfo
      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
    • getDeclaredProperties

      public List<? extends IPropertyInfo> getDeclaredProperties()
      Description copied from interface: IRelativeTypeInfo
      Returns a list of IPropertyInfo objects reflecting all the properties declared by the class or interface represented by this IType object. This includes public, protected, internal access, and private properties, but excludes inherited properties. The elements in the list are ordered by declaration order in the file. This method returns an empty list if the type does not contain any properties
      Specified by:
      getDeclaredProperties in interface IRelativeTypeInfo
      Returns:
      the list of IPropertyInfo objects representing all the declared properties of this class
    • getDeclaredMethods

      public List<? extends IMethodInfo> getDeclaredMethods()
      Description copied from interface: IRelativeTypeInfo
      Returns a list of IMethodInfo objects reflecting all the methods declared by the class or interface represented by this IType object. This includes public, protected, internal access, and private methods, but excludes inherited methods. The elements in the list are ordered by declaration order in the file. This method returns an empty list if the type does not contain any methods
      Specified by:
      getDeclaredMethods in interface IRelativeTypeInfo
      Returns:
      the list of IMethodInfo objects representing all the declared methods of this class
    • getDeclaredConstructors

      public List<? extends IConstructorInfo> getDeclaredConstructors()
      Description copied from interface: IRelativeTypeInfo
      Returns a list of IConstructorInfo objects reflecting all the constructors declared by the class represented by this IType object. This includes public, protected, internal access, and private constructors. Interfaces and arrays always return an empty list. The elements in the list are ordered by declaration order in the file. This method returns an empty list if the type does not contain any methods
      Specified by:
      getDeclaredConstructors in interface IRelativeTypeInfo
      Returns:
      the list of IConstructorInfo objects representing all the declared methods of this class