shape-output.hh 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. /*
  2. * Copyright © 2010 Behdad Esfahbod
  3. * Copyright © 2011,2012 Google, Inc.
  4. *
  5. * This is part of HarfBuzz, a text shaping library.
  6. *
  7. * Permission is hereby granted, without written agreement and without
  8. * license or royalty fees, to use, copy, modify, and distribute this
  9. * software and its documentation for any purpose, provided that the
  10. * above copyright notice and the following two paragraphs appear in
  11. * all copies of this software.
  12. *
  13. * IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
  14. * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
  15. * ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
  16. * IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
  17. * DAMAGE.
  18. *
  19. * THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
  20. * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  21. * FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
  22. * ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
  23. * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
  24. *
  25. * Google Author(s): Behdad Esfahbod
  26. */
  27. #ifndef HB_SHAPE_OUTPUT_HH
  28. #define HB_SHAPE_OUTPUT_HH
  29. #include "shape-format.hh"
  30. #include "output-options.hh"
  31. struct shape_output_t : output_options_t<>
  32. {
  33. void add_options (option_parser_t *parser)
  34. {
  35. parser->set_summary ("Shape text with given font.");
  36. output_options_t::add_options (parser, hb_buffer_serialize_list_formats ());
  37. format.add_options (parser);
  38. }
  39. void init (hb_buffer_t *buffer, const font_options_t *font_opts)
  40. {
  41. gs = g_string_new (nullptr);
  42. line_no = 0;
  43. font = hb_font_reference (font_opts->font);
  44. if (!output_format)
  45. serialize_format = HB_BUFFER_SERIALIZE_FORMAT_TEXT;
  46. else
  47. serialize_format = hb_buffer_serialize_format_from_string (output_format, -1);
  48. /* An empty "output_format" parameter basically skips output generating.
  49. * Useful for benchmarking. */
  50. if ((!output_format || *output_format) &&
  51. !hb_buffer_serialize_format_to_string (serialize_format))
  52. {
  53. if (explicit_output_format)
  54. fail (false, "Unknown output format `%s'; supported formats are: %s",
  55. output_format,
  56. g_strjoinv ("/", const_cast<char**> (hb_buffer_serialize_list_formats ())));
  57. else
  58. /* Just default to TEXT if not explicitly requested and the
  59. * file extension is not recognized. */
  60. serialize_format = HB_BUFFER_SERIALIZE_FORMAT_TEXT;
  61. }
  62. unsigned int flags = HB_BUFFER_SERIALIZE_FLAG_DEFAULT;
  63. if (!format.show_glyph_names)
  64. flags |= HB_BUFFER_SERIALIZE_FLAG_NO_GLYPH_NAMES;
  65. if (!format.show_clusters)
  66. flags |= HB_BUFFER_SERIALIZE_FLAG_NO_CLUSTERS;
  67. if (!format.show_positions)
  68. flags |= HB_BUFFER_SERIALIZE_FLAG_NO_POSITIONS;
  69. if (!format.show_advances)
  70. flags |= HB_BUFFER_SERIALIZE_FLAG_NO_ADVANCES;
  71. if (format.show_extents)
  72. flags |= HB_BUFFER_SERIALIZE_FLAG_GLYPH_EXTENTS;
  73. if (format.show_flags)
  74. flags |= HB_BUFFER_SERIALIZE_FLAG_GLYPH_FLAGS;
  75. serialize_flags = (hb_buffer_serialize_flags_t) flags;
  76. if (format.trace)
  77. hb_buffer_set_message_func (buffer, message_func, this, nullptr);
  78. }
  79. void new_line () { line_no++; }
  80. void consume_text (hb_buffer_t *buffer,
  81. const char *text,
  82. unsigned int text_len,
  83. hb_bool_t utf8_clusters)
  84. {
  85. g_string_set_size (gs, 0);
  86. format.serialize_buffer_of_text (buffer, line_no, text, text_len, font, gs);
  87. fprintf (out_fp, "%s", gs->str);
  88. }
  89. void error (const char *message)
  90. {
  91. g_string_set_size (gs, 0);
  92. format.serialize_message (line_no, "error", message, gs);
  93. fprintf (out_fp, "%s", gs->str);
  94. }
  95. void consume_glyphs (hb_buffer_t *buffer,
  96. const char *text,
  97. unsigned int text_len,
  98. hb_bool_t utf8_clusters)
  99. {
  100. g_string_set_size (gs, 0);
  101. format.serialize_buffer_of_glyphs (buffer, line_no, text, text_len, font,
  102. serialize_format, serialize_flags, gs);
  103. fprintf (out_fp, "%s", gs->str);
  104. }
  105. void finish (hb_buffer_t *buffer, const font_options_t *font_opts)
  106. {
  107. hb_buffer_set_message_func (buffer, nullptr, nullptr, nullptr);
  108. hb_font_destroy (font);
  109. g_string_free (gs, true);
  110. gs = nullptr;
  111. font = nullptr;
  112. }
  113. static hb_bool_t
  114. message_func (hb_buffer_t *buffer,
  115. hb_font_t *font,
  116. const char *message,
  117. void *user_data)
  118. {
  119. shape_output_t *that = (shape_output_t *) user_data;
  120. that->trace (buffer, font, message);
  121. return true;
  122. }
  123. void
  124. trace (hb_buffer_t *buffer,
  125. hb_font_t *font,
  126. const char *message)
  127. {
  128. g_string_set_size (gs, 0);
  129. format.serialize_line_no (line_no, gs);
  130. g_string_append_printf (gs, "trace: %s buffer: ", message);
  131. format.serialize (buffer, font, serialize_format, serialize_flags, gs);
  132. g_string_append_c (gs, '\n');
  133. fprintf (out_fp, "%s", gs->str);
  134. }
  135. protected:
  136. shape_format_options_t format;
  137. GString *gs = nullptr;
  138. unsigned int line_no = 0;
  139. hb_font_t *font = nullptr;
  140. hb_buffer_serialize_format_t serialize_format = HB_BUFFER_SERIALIZE_FORMAT_INVALID;
  141. hb_buffer_serialize_flags_t serialize_flags = HB_BUFFER_SERIALIZE_FLAG_DEFAULT;
  142. };
  143. #endif