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

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  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(userAgent, mimeType);
  55. }
  56. /**
  57. * Returns the configuration subtree for a specific renderer.
  58. * @param userAgent the user agent containing the user configuration
  59. * @param mimeType the MIME type of the renderer
  60. * @return the requested configuration subtree, null if there's no configuration
  61. */
  62. public static Configuration getRendererConfig(FOUserAgent userAgent, String mimeType) {
  63. Configuration cfg = userAgent.getFactory().getUserConfig();
  64. if (cfg == null) {
  65. if (log.isDebugEnabled()) {
  66. log.debug("userconfig is null");
  67. }
  68. return null;
  69. }
  70. Configuration userRendererConfig = null;
  71. Configuration[] cfgs
  72. = cfg.getChild("renderers").getChildren("renderer");
  73. for (int i = 0; i < cfgs.length; ++i) {
  74. Configuration child = cfgs[i];
  75. try {
  76. if (child.getAttribute("mime").equals(mimeType)) {
  77. userRendererConfig = child;
  78. break;
  79. }
  80. } catch (ConfigurationException e) {
  81. // silently pass over configurations without mime type
  82. }
  83. }
  84. log.debug((userRendererConfig == null ? "No u" : "U")
  85. + "ser configuration found for MIME type " + mimeType);
  86. return userRendererConfig;
  87. }
  88. }