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.

PatternConsumer.java 2.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  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.hyphenation;
  19. import java.util.ArrayList;
  20. /**
  21. * <p>This interface is used to connect the XML pattern file parser to
  22. * the hyphenation tree.</p>
  23. *
  24. * <p>This work was authored by Carlos Villegas (cav@uniscope.co.jp).</p>
  25. */
  26. public interface PatternConsumer {
  27. /**
  28. * Add a character class.
  29. * A character class defines characters that are considered
  30. * equivalent for the purpose of hyphenation (e.g. "aA"). It
  31. * usually means to ignore case.
  32. * @param chargroup character group
  33. */
  34. void addClass(String chargroup);
  35. /**
  36. * Add a hyphenation exception. An exception replaces the
  37. * result obtained by the algorithm for cases for which this
  38. * fails or the user wants to provide his own hyphenation.
  39. * A hyphenatedword is a vector of alternating String's and
  40. * {@link Hyphen Hyphen} instances
  41. * @param word word to add as an exception
  42. * @param hyphenatedword pre-hyphenated word
  43. */
  44. void addException(String word, ArrayList hyphenatedword);
  45. /**
  46. * Add hyphenation patterns.
  47. * @param pattern the pattern
  48. * @param values interletter values expressed as a string of
  49. * digit characters.
  50. */
  51. void addPattern(String pattern, String values);
  52. }