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.

AbstractConfigurator.java 2.9KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  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. * An abstract configurator
  26. */
  27. public abstract class AbstractConfigurator {
  28. /** logger instance */
  29. protected static Log log = LogFactory.getLog(AbstractConfigurator.class);
  30. private static final String MIME = "mime";
  31. /** fop factory configuration */
  32. protected FOUserAgent userAgent = null;
  33. /**
  34. * Default constructor
  35. * @param userAgent user agent
  36. */
  37. public AbstractConfigurator(FOUserAgent userAgent) {
  38. super();
  39. this.userAgent = userAgent;
  40. }
  41. /**
  42. * Returns the configuration subtree for a specific renderer.
  43. * @param mimeType the MIME type of the renderer
  44. * @return the requested configuration subtree, null if there's no configuration
  45. */
  46. protected Configuration getConfig(String mimeType) {
  47. Configuration cfg = userAgent.getFactory().getUserConfig();
  48. if (cfg == null) {
  49. if (log.isDebugEnabled()) {
  50. log.debug("userconfig is null");
  51. }
  52. return null;
  53. }
  54. Configuration userConfig = null;
  55. String type = getType();
  56. Configuration[] cfgs
  57. = cfg.getChild(type + "s").getChildren(type);
  58. for (int i = 0; i < cfgs.length; ++i) {
  59. Configuration child = cfgs[i];
  60. try {
  61. if (child.getAttribute(MIME).equals(mimeType)) {
  62. userConfig = child;
  63. break;
  64. }
  65. } catch (ConfigurationException e) {
  66. // silently pass over configurations without mime type
  67. }
  68. }
  69. log.debug((userConfig == null ? "No u" : "U")
  70. + "ser configuration found for MIME type " + mimeType);
  71. return userConfig;
  72. }
  73. /**
  74. * Returns the configurator type
  75. * @return the configurator type
  76. */
  77. public abstract String getType();
  78. }