You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

SourceFileAttribute.java 2.2KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. /*
  2. * Javassist, a Java-bytecode translator toolkit.
  3. * Copyright (C) 1999- Shigeru Chiba. All Rights Reserved.
  4. *
  5. * The contents of this file are subject to the Mozilla Public License Version
  6. * 1.1 (the "License"); you may not use this file except in compliance with
  7. * the License. Alternatively, the contents of this file may be used under
  8. * the terms of the GNU Lesser General Public License Version 2.1 or later,
  9. * or the Apache License Version 2.0.
  10. *
  11. * Software distributed under the License is distributed on an "AS IS" basis,
  12. * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
  13. * for the specific language governing rights and limitations under the
  14. * License.
  15. */
  16. package javassist.bytecode;
  17. import java.io.DataInputStream;
  18. import java.io.IOException;
  19. import java.util.Map;
  20. /**
  21. * <code>SourceFile_attribute</code>.
  22. */
  23. public class SourceFileAttribute extends AttributeInfo {
  24. /**
  25. * The name of this attribute <code>"SourceFile"</code>.
  26. */
  27. public static final String tag = "SourceFile";
  28. SourceFileAttribute(ConstPool cp, int n, DataInputStream in)
  29. throws IOException
  30. {
  31. super(cp, n, in);
  32. }
  33. /**
  34. * Constructs a SourceFile attribute.
  35. *
  36. * @param cp a constant pool table.
  37. * @param filename the name of the source file.
  38. */
  39. public SourceFileAttribute(ConstPool cp, String filename) {
  40. super(cp, tag);
  41. int index = cp.addUtf8Info(filename);
  42. byte[] bvalue = new byte[2];
  43. bvalue[0] = (byte)(index >>> 8);
  44. bvalue[1] = (byte)index;
  45. set(bvalue);
  46. }
  47. /**
  48. * Returns the file name indicated by <code>sourcefile_index</code>.
  49. */
  50. public String getFileName() {
  51. return getConstPool().getUtf8Info(ByteArray.readU16bit(get(), 0));
  52. }
  53. /**
  54. * Makes a copy. Class names are replaced according to the
  55. * given <code>Map</code> object.
  56. *
  57. * @param newCp the constant pool table used by the new copy.
  58. * @param classnames pairs of replaced and substituted
  59. * class names.
  60. */
  61. public AttributeInfo copy(ConstPool newCp, Map classnames) {
  62. return new SourceFileAttribute(newCp, getFileName());
  63. }
  64. }