001    package edu.rice.cs.cunit.classFile.attributes;
002    
003    import edu.rice.cs.cunit.classFile.attributes.visitors.IAttributeVisitor;
004    import edu.rice.cs.cunit.classFile.code.instructions.LineNumberTable;
005    import edu.rice.cs.cunit.classFile.constantPool.APoolInfo;
006    import edu.rice.cs.cunit.classFile.constantPool.AUTFPoolInfo;
007    import edu.rice.cs.cunit.classFile.constantPool.ConstantPool;
008    import edu.rice.cs.cunit.classFile.constantPool.visitors.CheckUTFVisitor;
009    import edu.rice.cs.cunit.classFile.ClassFile;
010    import edu.rice.cs.cunit.util.Types;
011    
012    import java.util.ArrayList;
013    
014    /**
015     * Represents the Synthetic attribute in a class file.
016     *
017     * @author Mathias Ricken
018     */
019    public class SyntheticAttributeInfo extends AAttributeInfo {
020        /**
021         * Constructor.
022         *
023         * @param name attribute name
024         * @param data attribute data
025         * @param cp   constant pool
026         *
027         * @throws ClassFormatError
028         */
029        public SyntheticAttributeInfo(AUTFPoolInfo name, byte[] data, ConstantPool cp) throws ClassFormatError {
030            super(name, data, cp);
031        }
032    
033        /**
034         * Execute a visitor on this attribute.
035         *
036         * @param visitor visitor
037         * @param param   visitor-specific parameter
038         *
039         * @return visitor-specific return value
040         */
041        public <R, D> R execute(IAttributeVisitor<R, D> visitor, D param) {
042            return visitor.syntheticCase(this, param);
043        }
044    
045        /**
046         * Adjust program counter values contained in this attribute, starting at startPC, by adding deltaPC to them.
047         *
048         * @param startPC program counter to start at
049         * @param deltaPC change in program counter values
050         */
051        public void adjustPC(int startPC, int deltaPC) {
052            // nothing to do
053        }
054    
055        /**
056         * Translate the program counter values contained in this attribute from an old line number table to a new one.
057         *
058         * @param index      critical point (insertion or deletion point)
059         * @param deltaIndex delta value to add to all old line numbers greater than the critical point
060         * @param oldLnt     old line number table
061         * @param newLnt     new line number table
062         */
063        public void translatePC(int index, int deltaIndex, LineNumberTable oldLnt, LineNumberTable newLnt) {
064            // nothing to do
065        }
066    
067        /**
068         * Creates and returns a copy of this object.
069         */
070        public Object clone() throws CloneNotSupportedException {
071            return super.clone();
072        }
073    
074        /**
075         * Return a human-readable version of this attribute.
076         *
077         * @return string
078         */
079        public String toString() {
080            return "Synthatic";
081        }
082    
083        /**
084         * Returns the name of the attribute as it appears in the class file.
085         *
086         * @return name of the attribute.
087         */
088        public static String getAttributeName() {
089            return "Synthetic";
090        }
091    }