Class WrapIdentifier<T extends JobParameters>

All Implemented Interfaces:
LifecycleUser<T>

public class WrapIdentifier<T extends JobParameters> extends Transformation<T>
The wrap identifier transformation wraps the usage of a certain identifier with new code by replacing its usage with a new expression and inserting code that takes care of handling the conversion from the new to the old value. It also checks that the wrapped value isn't already present in the code.
  • Constructor Details

    • WrapIdentifier

      public WrapIdentifier(TransformationPhase<T> wrapResultDetector, TransformationPhase<T> wrappingReplacer, TransformationPhase<T> wrappingInjector)
      Creates a new wrap identifier transformation.
      Parameters:
      wrapResultDetector - A phase that makes sure the wrap result doesn't already exist in the tree
      wrappingReplacer - The replacer phase that should replace a target identifier with a replacement expression or identifier
      wrappingInjector - A transformation phase that does the additional code injection, usually providing a definition for the newly inserted identifier in the form of an external declaration of some sort
    • WrapIdentifier

      public WrapIdentifier(String wrapResult, TransformationPhase<T> wrappingReplacer, TransformationPhase<T> wrappingInjector)
      Creates a new wrap identifier transformation with a fixed result identifier.
      Parameters:
      wrapResult - The identifier that's inserted for the wrapping
      wrappingReplacer - The replacer phase that replaces a target identifier with a replacement expression or identifier
      wrappingInjector - A transformation phase that does the additional code injection, usually providing a definition for the newly inserted identifier in the form of an external declaration of some sort
      See Also:
    • WrapIdentifier

      public WrapIdentifier(String wrapResult, HandlerTarget<T> wrappingTarget, TransformationPhase<T> wrappingInjector)
      Creates a new wrap identifier transformation with a fixed result identifier and a fixed replacement phase for which only the target is given.
      Parameters:
      wrapResult - The identifier that's inserted for the wrapping
      wrappingTarget - A replacement target to be used in a search terminal's phase
      wrappingInjector - A transformation phase that does the additional code injection, usually providing a definition for the newly inserted identifier in the form of an external declaration of some sort
  • Method Details

    • fromTerminal

      public static <T extends JobParameters> WrapIdentifier<T> fromTerminal(String wrapTarget, String wrapResult, RunPhase<T> wrappingInjector)
      Creates a new wrap identifier transformation that uses an unparsed terminal replace target. It uses the wrap result as the identifier to disallow as well as the terminal to insert as a replacement. This is a commonly used operation when the inserted replacement is just a different identifier.
      Type Parameters:
      T - The job parameter type
      Parameters:
      wrapTarget - The identifier to replace
      wrapResult - The identifier that will be used to replace it
      wrappingInjector - A transformation phase that does the additional code injection
      Returns:
      The wrap identifier transformation with the given parameters
    • fromExpression

      public static <T extends JobParameters> WrapIdentifier<T> fromExpression(String wrapTarget, String wrapResult, String wrapExpression, RunPhase<T> wrappingInjector)
      Creates a new wrap identifier transformation that uses a parsed replace target that replaces identifiers with an expression. (which may also just be an identifier)
      Type Parameters:
      T - The job parameter type
      Parameters:
      wrapTarget - The identifier to replace
      wrapResult - The identifier that will be used to replace it
      wrapExpression - The expression to insert instead of the wrapTarget
      wrappingInjector - A transformation phase that does the additional code injection
      Returns:
      The wrap identifier transformation with the given parameters
    • withExternalDeclaration

      public static <T extends JobParameters> WrapIdentifier<T> withExternalDeclaration(String wrapTarget, String wrapResult, String wrapExpression, TransformationPhase.InjectionPoint location, String injectedCode)
      Creates a new wrap identifier transformation that inserts a parsed expression as a replacement and inserts a new external declaration.
      Type Parameters:
      T - The job parameter type
      Parameters:
      wrapTarget - The identifier to replace
      wrapResult - The identifier that will be used to replace it
      wrapExpression - The expression to insert instead of the wrapTarget
      location - The injection location for the new code
      injectedCode - The code to parse and inject as an external declaration at the given location
      Returns:
      The wrap identifier transformation with the given parameters
      See Also: