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.6KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  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. if (ref == null) {
  47. throw new NullPointerException("ref must not be null");
  48. }
  49. this.indirectReference = ref;
  50. }
  51. /**
  52. * Returns the PDF object
  53. * @return the PDF object, or null if it has been released
  54. */
  55. public PDFObject getObject() {
  56. if (this.objReference != null) {
  57. PDFObject obj = (PDFObject)this.objReference.get();
  58. if (obj == null) {
  59. this.objReference = null;
  60. }
  61. return obj;
  62. } else {
  63. return null;
  64. }
  65. }
  66. /** {@inheritDoc} */
  67. public String toString() {
  68. return this.indirectReference;
  69. }
  70. /** {@inheritDoc} */
  71. public void outputInline(OutputStream out, Writer writer) throws IOException {
  72. writer.write(toString());
  73. }
  74. }