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.

LoggingElementListObserver.java 2.8KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  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.logging;
  19. import java.util.List;
  20. import java.util.ListIterator;
  21. import org.apache.commons.logging.Log;
  22. import org.apache.commons.logging.LogFactory;
  23. import org.apache.fop.layoutmgr.ElementListObserver.Observer;
  24. import org.apache.fop.layoutmgr.ElementListUtils;
  25. import org.apache.fop.layoutmgr.ListElement;
  26. /**
  27. * <p>Logs all observed element lists.
  28. * </p>
  29. * <p>You can enable/disabled individual categories separately, for example for JDK 1.4 logging:
  30. * </p>
  31. * <p>org.apache.fop.logging.LoggingElementListObserver.level = INFO</p>
  32. * <p>org.apache.fop.logging.LoggingElementListObserver.table-cell.level = FINE</p>
  33. */
  34. public class LoggingElementListObserver implements Observer {
  35. /** @see org.apache.fop.layoutmgr.ElementListObserver.Observer */
  36. public void observe(List elementList, String category, String id) {
  37. Log log = LogFactory.getLog(LoggingElementListObserver.class.getName() + "." + category);
  38. if (!log.isDebugEnabled()) {
  39. return;
  40. }
  41. log.debug(" ");
  42. int len = (elementList != null ? ElementListUtils.calcContentLength(elementList) : 0);
  43. log.debug("ElementList: category=" + category + ", id=" + id + ", len=" + len + "mpt");
  44. if (elementList == null) {
  45. log.debug("<<empty list>>");
  46. return;
  47. }
  48. ListIterator tempIter = elementList.listIterator();
  49. ListElement temp;
  50. while (tempIter.hasNext()) {
  51. temp = (ListElement) tempIter.next();
  52. if (temp.isBox()) {
  53. log.debug(tempIter.previousIndex()
  54. + ") " + temp);
  55. } else if (temp.isGlue()) {
  56. log.debug(tempIter.previousIndex()
  57. + ") " + temp);
  58. } else {
  59. log.debug(tempIter.previousIndex()
  60. + ") " + temp);
  61. }
  62. if (temp.getPosition() != null) {
  63. log.debug(" " + temp.getPosition());
  64. }
  65. }
  66. log.debug(" ");
  67. }
  68. }