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.

Footnote.java 4.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  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.fo.flow;
  19. import org.xml.sax.Locator;
  20. import org.apache.fop.apps.FOPException;
  21. import org.apache.fop.fo.FONode;
  22. import org.apache.fop.fo.FObj;
  23. import org.apache.fop.fo.PropertyList;
  24. import org.apache.fop.fo.ValidationException;
  25. /**
  26. * Class modelling the <a href="http://www.w3.org/TR/xsl/#fo_footnote">
  27. * <code>fo:footnote</code></a> object.
  28. */
  29. public class Footnote extends FObj {
  30. // The value of properties relevant for fo:footnote (commented out for performance).
  31. // private CommonAccessibility commonAccessibility;
  32. // End of property values
  33. private Inline footnoteCitation = null;
  34. private FootnoteBody footnoteBody;
  35. /**
  36. * Create a Footnote instance that is a child of the
  37. * given {@link FONode}
  38. *
  39. * @param parent {@link FONode} that is the parent of this object
  40. */
  41. public Footnote(FONode parent) {
  42. super(parent);
  43. }
  44. /** {@inheritDoc} */
  45. public void bind(PropertyList pList) throws FOPException {
  46. // No active properties -> do nothing.
  47. }
  48. /** {@inheritDoc} */
  49. protected void startOfNode() throws FOPException {
  50. getFOEventHandler().startFootnote(this);
  51. }
  52. /**
  53. * Make sure content model satisfied, if so then tell the
  54. * {@link org.apache.fop.fo.FOEventHandler} that we are at the end of the footnote.
  55. *
  56. * {@inheritDoc}
  57. */
  58. protected void endOfNode() throws FOPException {
  59. super.endOfNode();
  60. if (footnoteCitation == null || footnoteBody == null) {
  61. missingChildElementError("(inline,footnote-body)");
  62. }
  63. getFOEventHandler().endFootnote(this);
  64. }
  65. /**
  66. * {@inheritDoc}
  67. * <br>XSL Content Model: (inline,footnote-body)
  68. * @asf.todo implement additional constraint: A fo:footnote is not permitted
  69. * to have a fo:float, fo:footnote, or fo:marker as a descendant.
  70. * @asf.todo implement additional constraint: A fo:footnote is not
  71. * permitted to have as a descendant a fo:block-container that
  72. * generates an absolutely positioned area.
  73. */
  74. protected void validateChildNode(Locator loc, String nsURI, String localName)
  75. throws ValidationException {
  76. if (FO_URI.equals(nsURI)) {
  77. if (localName.equals("inline")) {
  78. if (footnoteCitation != null) {
  79. tooManyNodesError(loc, "fo:inline");
  80. }
  81. } else if (localName.equals("footnote-body")) {
  82. if (footnoteCitation == null) {
  83. nodesOutOfOrderError(loc, "fo:inline", "fo:footnote-body");
  84. } else if (footnoteBody != null) {
  85. tooManyNodesError(loc, "fo:footnote-body");
  86. }
  87. } else {
  88. invalidChildError(loc, nsURI, localName);
  89. }
  90. }
  91. }
  92. /** {@inheritDoc} */
  93. public void addChildNode(FONode child) {
  94. if (child.getNameId() == FO_INLINE) {
  95. footnoteCitation = (Inline) child;
  96. } else if (child.getNameId() == FO_FOOTNOTE_BODY) {
  97. footnoteBody = (FootnoteBody) child;
  98. }
  99. }
  100. /**
  101. * Public accessor for inline FO
  102. *
  103. * @return the {@link Inline} child
  104. */
  105. public Inline getFootnoteCitation() {
  106. return footnoteCitation;
  107. }
  108. /**
  109. * Public accessor for footnote-body FO
  110. *
  111. * @return the {@link FootnoteBody} child
  112. */
  113. public FootnoteBody getFootnoteBody() {
  114. return footnoteBody;
  115. }
  116. /** {@inheritDoc} */
  117. public String getLocalName() {
  118. return "footnote";
  119. }
  120. /**
  121. * {@inheritDoc}
  122. * @return {@link org.apache.fop.fo.Constants#FO_FOOTNOTE}
  123. */
  124. public int getNameId() {
  125. return FO_FOOTNOTE;
  126. }
  127. }