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.

PDFReference.java 2.5KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /*
  2. * Licensed to the Apache Software Foundation (ASF) under one or more
  3. * contributor license agreements. See the NOTICE file distributed with
  4. * this work for additional information regarding copyright ownership.
  5. * The ASF licenses this file to You under the Apache License, Version 2.0
  6. * (the "License"); you may not use this file except in compliance with
  7. * the License. You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. */
  17. /* $Id$ */
  18. package org.apache.fop.pdf;
  19. import java.io.IOException;
  20. import java.io.OutputStream;
  21. import java.io.Writer;
  22. import java.lang.ref.Reference;
  23. import java.lang.ref.SoftReference;
  24. /**
  25. * Class representing a PDF object reference. The object holds a soft reference to the actual
  26. * PDF object so the garbage collector can free the object if it's not referenced elsewhere. The
  27. * important thing about the class is the reference information to the actual PDF object in the
  28. * PDF file.
  29. */
  30. public class PDFReference implements PDFWritable {
  31. private String indirectReference;
  32. private Reference objReference;
  33. /**
  34. * Creates a new PDF reference.
  35. * @param obj the object to be referenced
  36. */
  37. public PDFReference(PDFObject obj) {
  38. this.indirectReference = obj.referencePDF();
  39. this.objReference = new SoftReference(obj);
  40. }
  41. /**
  42. * Creates a new PDF reference, but without a reference to the original object.
  43. * @param ref an object reference
  44. */
  45. public PDFReference(String ref) {
  46. this.indirectReference = ref;
  47. }
  48. /**
  49. * Returns the PDF object
  50. * @return the PDF object, or null if it has been released
  51. */
  52. public PDFObject getObject() {
  53. if (this.objReference != null) {
  54. PDFObject obj = (PDFObject)this.objReference.get();
  55. if (obj == null) {
  56. this.objReference = null;
  57. }
  58. return obj;
  59. } else {
  60. return null;
  61. }
  62. }
  63. /** {@inheritDoc} */
  64. public String toString() {
  65. return this.indirectReference;
  66. }
  67. /** {@inheritDoc} */
  68. public void outputInline(OutputStream out, Writer writer) throws IOException {
  69. writer.write(toString());
  70. }
  71. }