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.

AbstractRendererConfigurator.java 3.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  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.render;
  19. import org.apache.avalon.framework.configuration.Configuration;
  20. import org.apache.avalon.framework.configuration.ConfigurationException;
  21. import org.apache.commons.logging.Log;
  22. import org.apache.commons.logging.LogFactory;
  23. import org.apache.fop.apps.FOUserAgent;
  24. /**
  25. * Abstract base classes for renderer-related configurator classes. This class basically just
  26. * provides an accessor to the specific renderer configuration object.
  27. */
  28. public abstract class AbstractRendererConfigurator {
  29. /** logger instance */
  30. protected static Log log = LogFactory.getLog(AbstractRendererConfigurator.class);
  31. /** fop factory configuration */
  32. protected FOUserAgent userAgent = null;
  33. /**
  34. * Default constructor
  35. * @param userAgent user agent
  36. */
  37. public AbstractRendererConfigurator(FOUserAgent userAgent) {
  38. super();
  39. this.userAgent = userAgent;
  40. }
  41. /**
  42. * Returns the configuration subtree for a specific renderer.
  43. * @param renderer the renderer
  44. * @return the requested configuration subtree, null if there's no configuration
  45. */
  46. protected Configuration getRendererConfig(Renderer renderer) {
  47. String mimeType = renderer.getMimeType();
  48. if (mimeType == null) {
  49. if (log.isInfoEnabled()) {
  50. log.info("renderer mimeType is null");
  51. }
  52. return null;
  53. }
  54. return getRendererConfig(mimeType);
  55. }
  56. /**
  57. * Returns the configuration subtree for a specific renderer.
  58. * @param mimeType the MIME type of the renderer
  59. * @return the requested configuration subtree, null if there's no configuration
  60. */
  61. private Configuration getRendererConfig(String mimeType) {
  62. Configuration cfg = userAgent.getFactory().getUserConfig();
  63. if (cfg == null) {
  64. if (log.isDebugEnabled()) {
  65. log.debug("userconfig is null");
  66. }
  67. return null;
  68. }
  69. Configuration userRendererConfig = null;
  70. Configuration[] cfgs
  71. = cfg.getChild("renderers").getChildren("renderer");
  72. for (int i = 0; i < cfgs.length; ++i) {
  73. Configuration child = cfgs[i];
  74. try {
  75. if (child.getAttribute("mime").equals(mimeType)) {
  76. userRendererConfig = child;
  77. break;
  78. }
  79. } catch (ConfigurationException e) {
  80. // silently pass over configurations without mime type
  81. }
  82. }
  83. log.debug((userRendererConfig == null ? "No u" : "U")
  84. + "ser configuration found for MIME type " + mimeType);
  85. return userRendererConfig;
  86. }
  87. }