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.

PDFEventProducer.java 2.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  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.pdf;
  19. import org.apache.fop.events.EventBroadcaster;
  20. import org.apache.fop.events.EventProducer;
  21. /**
  22. * Event producer interface for events generated by the PDF renderer.
  23. */
  24. public interface PDFEventProducer extends EventProducer {
  25. /** Provider class for the event producer. */
  26. final class Provider {
  27. /**
  28. * Utility classes should not have a public or default constructor.
  29. */
  30. private Provider() { }
  31. /**
  32. * Returns an event producer.
  33. * @param broadcaster the event broadcaster to use
  34. * @return the event producer
  35. */
  36. public static PDFEventProducer get(EventBroadcaster broadcaster) {
  37. return (PDFEventProducer)broadcaster.getEventProducerFor(
  38. PDFEventProducer.class);
  39. }
  40. }
  41. /**
  42. * Some link targets haven't been fully resolved.
  43. * @param source the event source
  44. * @param count the number of unresolved links
  45. * @event.severity WARN
  46. */
  47. void nonFullyResolvedLinkTargets(Object source, int count);
  48. /**
  49. * Custom structure type is not standard as per the PDF reference.
  50. *
  51. * @param source the event source
  52. * @param fo the local name of the formatting object having the custom type
  53. * @param type custom structure type
  54. * @param fallback default structure type used as a fallback
  55. * @event.severity WARN
  56. */
  57. void nonStandardStructureType(Object source, String fo, String type, String fallback);
  58. /**
  59. * The encryption length must be a multiple of 8 between 40 and 128.
  60. *
  61. * @param source the event source
  62. * @param originalValue requested encryption length
  63. * @param correctedValue corrected encryption length
  64. * @event.severity WARN
  65. */
  66. void incorrectEncryptionLength(Object source, int originalValue, int correctedValue);
  67. }