mathematical 0.1.0 → 0.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (263) hide show
  1. checksums.yaml +4 -4
  2. data/ext/mathematical/extconf.rb +14 -0
  3. data/ext/mathematical/itex2MML.h +63 -0
  4. data/ext/mathematical/lasemrender.c +257 -0
  5. data/ext/mathematical/lex.yy.c +6548 -0
  6. data/ext/mathematical/lsm.c +31 -0
  7. data/ext/mathematical/lsm.h +39 -0
  8. data/ext/mathematical/lsmattributes.c +279 -0
  9. data/ext/mathematical/lsmattributes.h +75 -0
  10. data/ext/mathematical/lsmcairo.c +598 -0
  11. data/ext/mathematical/lsmcairo.h +51 -0
  12. data/ext/mathematical/lsmdebug.c +183 -0
  13. data/ext/mathematical/lsmdebug.h +73 -0
  14. data/ext/mathematical/lsmdom.h +43 -0
  15. data/ext/mathematical/lsmdomcharacterdata.c +114 -0
  16. data/ext/mathematical/lsmdomcharacterdata.h +59 -0
  17. data/ext/mathematical/lsmdomdocument.c +255 -0
  18. data/ext/mathematical/lsmdomdocument.h +75 -0
  19. data/ext/mathematical/lsmdomdocumentfragment.c +81 -0
  20. data/ext/mathematical/lsmdomdocumentfragment.h +55 -0
  21. data/ext/mathematical/lsmdomelement.c +148 -0
  22. data/ext/mathematical/lsmdomelement.h +62 -0
  23. data/ext/mathematical/lsmdomentities.c +2166 -0
  24. data/ext/mathematical/lsmdomentities.h +35 -0
  25. data/ext/mathematical/lsmdomenumtypes.c +99 -0
  26. data/ext/mathematical/lsmdomenumtypes.h +26 -0
  27. data/ext/mathematical/lsmdomimplementation.c +82 -0
  28. data/ext/mathematical/lsmdomimplementation.h +41 -0
  29. data/ext/mathematical/lsmdomnamednodemap.c +118 -0
  30. data/ext/mathematical/lsmdomnamednodemap.h +64 -0
  31. data/ext/mathematical/lsmdomnode.c +737 -0
  32. data/ext/mathematical/lsmdomnode.h +122 -0
  33. data/ext/mathematical/lsmdomnodelist.c +70 -0
  34. data/ext/mathematical/lsmdomnodelist.h +58 -0
  35. data/ext/mathematical/lsmdomparser.c +461 -0
  36. data/ext/mathematical/lsmdomparser.h +54 -0
  37. data/ext/mathematical/lsmdomtext.c +82 -0
  38. data/ext/mathematical/lsmdomtext.h +55 -0
  39. data/ext/mathematical/lsmdomtypes.h +44 -0
  40. data/ext/mathematical/lsmdomview.c +422 -0
  41. data/ext/mathematical/lsmdomview.h +94 -0
  42. data/ext/mathematical/lsmitex.c +76 -0
  43. data/ext/mathematical/lsmitex.h +36 -0
  44. data/ext/mathematical/lsmmathml.h +66 -0
  45. data/ext/mathematical/lsmmathmlactionelement.c +93 -0
  46. data/ext/mathematical/lsmmathmlactionelement.h +57 -0
  47. data/ext/mathematical/lsmmathmlaligngroupelement.c +102 -0
  48. data/ext/mathematical/lsmmathmlaligngroupelement.h +56 -0
  49. data/ext/mathematical/lsmmathmlalignmarkelement.c +102 -0
  50. data/ext/mathematical/lsmmathmlalignmarkelement.h +56 -0
  51. data/ext/mathematical/lsmmathmlattributes.c +197 -0
  52. data/ext/mathematical/lsmmathmlattributes.h +126 -0
  53. data/ext/mathematical/lsmmathmldocument.c +304 -0
  54. data/ext/mathematical/lsmmathmldocument.h +61 -0
  55. data/ext/mathematical/lsmmathmlelement.c +491 -0
  56. data/ext/mathematical/lsmmathmlelement.h +107 -0
  57. data/ext/mathematical/lsmmathmlenums.c +429 -0
  58. data/ext/mathematical/lsmmathmlenums.h +182 -0
  59. data/ext/mathematical/lsmmathmlenumtypes.c +666 -0
  60. data/ext/mathematical/lsmmathmlenumtypes.h +90 -0
  61. data/ext/mathematical/lsmmathmlerrorelement.c +58 -0
  62. data/ext/mathematical/lsmmathmlerrorelement.h +56 -0
  63. data/ext/mathematical/lsmmathmlfencedelement.c +178 -0
  64. data/ext/mathematical/lsmmathmlfencedelement.h +65 -0
  65. data/ext/mathematical/lsmmathmlfractionelement.c +253 -0
  66. data/ext/mathematical/lsmmathmlfractionelement.h +62 -0
  67. data/ext/mathematical/lsmmathmlglyphtableams.c +597 -0
  68. data/ext/mathematical/lsmmathmlglyphtableams.h +45 -0
  69. data/ext/mathematical/lsmmathmlitexelement.c +187 -0
  70. data/ext/mathematical/lsmmathmlitexelement.h +60 -0
  71. data/ext/mathematical/lsmmathmllayoututils.c +191 -0
  72. data/ext/mathematical/lsmmathmllayoututils.h +58 -0
  73. data/ext/mathematical/lsmmathmlmathelement.c +204 -0
  74. data/ext/mathematical/lsmmathmlmathelement.h +81 -0
  75. data/ext/mathematical/lsmmathmloperatordictionary.c +3332 -0
  76. data/ext/mathematical/lsmmathmloperatordictionary.h +54 -0
  77. data/ext/mathematical/lsmmathmloperatorelement.c +307 -0
  78. data/ext/mathematical/lsmmathmloperatorelement.h +73 -0
  79. data/ext/mathematical/lsmmathmlpaddedelement.c +58 -0
  80. data/ext/mathematical/lsmmathmlpaddedelement.h +56 -0
  81. data/ext/mathematical/lsmmathmlphantomelement.c +71 -0
  82. data/ext/mathematical/lsmmathmlphantomelement.h +56 -0
  83. data/ext/mathematical/lsmmathmlpresentationcontainer.c +43 -0
  84. data/ext/mathematical/lsmmathmlpresentationcontainer.h +54 -0
  85. data/ext/mathematical/lsmmathmlpresentationtoken.c +303 -0
  86. data/ext/mathematical/lsmmathmlpresentationtoken.h +83 -0
  87. data/ext/mathematical/lsmmathmlradicalelement.c +266 -0
  88. data/ext/mathematical/lsmmathmlradicalelement.h +71 -0
  89. data/ext/mathematical/lsmmathmlrowelement.c +58 -0
  90. data/ext/mathematical/lsmmathmlrowelement.h +56 -0
  91. data/ext/mathematical/lsmmathmlscriptelement.c +282 -0
  92. data/ext/mathematical/lsmmathmlscriptelement.h +78 -0
  93. data/ext/mathematical/lsmmathmlsemanticselement.c +84 -0
  94. data/ext/mathematical/lsmmathmlsemanticselement.h +56 -0
  95. data/ext/mathematical/lsmmathmlspaceelement.c +142 -0
  96. data/ext/mathematical/lsmmathmlspaceelement.h +60 -0
  97. data/ext/mathematical/lsmmathmlstringelement.c +123 -0
  98. data/ext/mathematical/lsmmathmlstringelement.h +58 -0
  99. data/ext/mathematical/lsmmathmlstyle.c +130 -0
  100. data/ext/mathematical/lsmmathmlstyle.h +81 -0
  101. data/ext/mathematical/lsmmathmlstyleelement.c +307 -0
  102. data/ext/mathematical/lsmmathmlstyleelement.h +87 -0
  103. data/ext/mathematical/lsmmathmltablecellelement.c +122 -0
  104. data/ext/mathematical/lsmmathmltablecellelement.h +62 -0
  105. data/ext/mathematical/lsmmathmltableelement.c +545 -0
  106. data/ext/mathematical/lsmmathmltableelement.h +78 -0
  107. data/ext/mathematical/lsmmathmltablerowelement.c +120 -0
  108. data/ext/mathematical/lsmmathmltablerowelement.h +64 -0
  109. data/ext/mathematical/lsmmathmltraits.c +819 -0
  110. data/ext/mathematical/lsmmathmltraits.h +119 -0
  111. data/ext/mathematical/lsmmathmltypes.h +66 -0
  112. data/ext/mathematical/lsmmathmlunderoverelement.c +485 -0
  113. data/ext/mathematical/lsmmathmlunderoverelement.h +82 -0
  114. data/ext/mathematical/lsmmathmlutils.c +170 -0
  115. data/ext/mathematical/lsmmathmlutils.h +50 -0
  116. data/ext/mathematical/lsmmathmlview.c +1048 -0
  117. data/ext/mathematical/lsmmathmlview.h +164 -0
  118. data/ext/mathematical/lsmproperties.c +418 -0
  119. data/ext/mathematical/lsmproperties.h +85 -0
  120. data/ext/mathematical/lsmstr.c +231 -0
  121. data/ext/mathematical/lsmstr.h +114 -0
  122. data/ext/mathematical/lsmsvg.h +67 -0
  123. data/ext/mathematical/lsmsvgaelement.c +73 -0
  124. data/ext/mathematical/lsmsvgaelement.h +55 -0
  125. data/ext/mathematical/lsmsvgattributes.h +118 -0
  126. data/ext/mathematical/lsmsvgcircleelement.c +153 -0
  127. data/ext/mathematical/lsmsvgcircleelement.h +59 -0
  128. data/ext/mathematical/lsmsvgclippathelement.c +134 -0
  129. data/ext/mathematical/lsmsvgclippathelement.h +59 -0
  130. data/ext/mathematical/lsmsvgcolors.c +212 -0
  131. data/ext/mathematical/lsmsvgcolors.h +39 -0
  132. data/ext/mathematical/lsmsvgdefselement.c +74 -0
  133. data/ext/mathematical/lsmsvgdefselement.h +55 -0
  134. data/ext/mathematical/lsmsvgdocument.c +288 -0
  135. data/ext/mathematical/lsmsvgdocument.h +64 -0
  136. data/ext/mathematical/lsmsvgelement.c +373 -0
  137. data/ext/mathematical/lsmsvgelement.h +81 -0
  138. data/ext/mathematical/lsmsvgellipseelement.c +158 -0
  139. data/ext/mathematical/lsmsvgellipseelement.h +60 -0
  140. data/ext/mathematical/lsmsvgenums.c +544 -0
  141. data/ext/mathematical/lsmsvgenums.h +357 -0
  142. data/ext/mathematical/lsmsvgenumtypes.c +1083 -0
  143. data/ext/mathematical/lsmsvgenumtypes.h +111 -0
  144. data/ext/mathematical/lsmsvgfilterblend.c +105 -0
  145. data/ext/mathematical/lsmsvgfilterblend.h +58 -0
  146. data/ext/mathematical/lsmsvgfiltercomposite.c +109 -0
  147. data/ext/mathematical/lsmsvgfiltercomposite.h +58 -0
  148. data/ext/mathematical/lsmsvgfilterelement.c +266 -0
  149. data/ext/mathematical/lsmsvgfilterelement.h +66 -0
  150. data/ext/mathematical/lsmsvgfilterflood.c +86 -0
  151. data/ext/mathematical/lsmsvgfilterflood.h +55 -0
  152. data/ext/mathematical/lsmsvgfiltergaussianblur.c +114 -0
  153. data/ext/mathematical/lsmsvgfiltergaussianblur.h +57 -0
  154. data/ext/mathematical/lsmsvgfiltermerge.c +98 -0
  155. data/ext/mathematical/lsmsvgfiltermerge.h +55 -0
  156. data/ext/mathematical/lsmsvgfiltermergenode.c +87 -0
  157. data/ext/mathematical/lsmsvgfiltermergenode.h +57 -0
  158. data/ext/mathematical/lsmsvgfilteroffset.c +112 -0
  159. data/ext/mathematical/lsmsvgfilteroffset.h +58 -0
  160. data/ext/mathematical/lsmsvgfilterprimitive.c +168 -0
  161. data/ext/mathematical/lsmsvgfilterprimitive.h +66 -0
  162. data/ext/mathematical/lsmsvgfilterspecularlighting.c +127 -0
  163. data/ext/mathematical/lsmsvgfilterspecularlighting.h +60 -0
  164. data/ext/mathematical/lsmsvgfiltersurface.c +455 -0
  165. data/ext/mathematical/lsmsvgfiltersurface.h +66 -0
  166. data/ext/mathematical/lsmsvgfiltertile.c +102 -0
  167. data/ext/mathematical/lsmsvgfiltertile.h +57 -0
  168. data/ext/mathematical/lsmsvggelement.c +73 -0
  169. data/ext/mathematical/lsmsvggelement.h +55 -0
  170. data/ext/mathematical/lsmsvggradientelement.c +151 -0
  171. data/ext/mathematical/lsmsvggradientelement.h +68 -0
  172. data/ext/mathematical/lsmsvgimageelement.c +261 -0
  173. data/ext/mathematical/lsmsvgimageelement.h +67 -0
  174. data/ext/mathematical/lsmsvglength.c +152 -0
  175. data/ext/mathematical/lsmsvglength.h +65 -0
  176. data/ext/mathematical/lsmsvglineargradientelement.c +271 -0
  177. data/ext/mathematical/lsmsvglineargradientelement.h +60 -0
  178. data/ext/mathematical/lsmsvglineelement.c +153 -0
  179. data/ext/mathematical/lsmsvglineelement.h +60 -0
  180. data/ext/mathematical/lsmsvgmarkerelement.c +266 -0
  181. data/ext/mathematical/lsmsvgmarkerelement.h +74 -0
  182. data/ext/mathematical/lsmsvgmaskelement.c +232 -0
  183. data/ext/mathematical/lsmsvgmaskelement.h +64 -0
  184. data/ext/mathematical/lsmsvgmatrix.c +205 -0
  185. data/ext/mathematical/lsmsvgmatrix.h +59 -0
  186. data/ext/mathematical/lsmsvgpathelement.c +115 -0
  187. data/ext/mathematical/lsmsvgpathelement.h +59 -0
  188. data/ext/mathematical/lsmsvgpatternelement.c +398 -0
  189. data/ext/mathematical/lsmsvgpatternelement.h +69 -0
  190. data/ext/mathematical/lsmsvgpolygonelement.c +106 -0
  191. data/ext/mathematical/lsmsvgpolygonelement.h +57 -0
  192. data/ext/mathematical/lsmsvgpolylineelement.c +106 -0
  193. data/ext/mathematical/lsmsvgpolylineelement.h +57 -0
  194. data/ext/mathematical/lsmsvgradialgradientelement.c +323 -0
  195. data/ext/mathematical/lsmsvgradialgradientelement.h +61 -0
  196. data/ext/mathematical/lsmsvgrectelement.c +184 -0
  197. data/ext/mathematical/lsmsvgrectelement.h +62 -0
  198. data/ext/mathematical/lsmsvgstopelement.c +106 -0
  199. data/ext/mathematical/lsmsvgstopelement.h +57 -0
  200. data/ext/mathematical/lsmsvgstyle.c +560 -0
  201. data/ext/mathematical/lsmsvgstyle.h +217 -0
  202. data/ext/mathematical/lsmsvgsvgelement.c +260 -0
  203. data/ext/mathematical/lsmsvgsvgelement.h +71 -0
  204. data/ext/mathematical/lsmsvgswitchelement.c +103 -0
  205. data/ext/mathematical/lsmsvgswitchelement.h +55 -0
  206. data/ext/mathematical/lsmsvgsymbolelement.c +74 -0
  207. data/ext/mathematical/lsmsvgsymbolelement.h +55 -0
  208. data/ext/mathematical/lsmsvgtextelement.c +203 -0
  209. data/ext/mathematical/lsmsvgtextelement.h +60 -0
  210. data/ext/mathematical/lsmsvgtraits.c +1232 -0
  211. data/ext/mathematical/lsmsvgtraits.h +104 -0
  212. data/ext/mathematical/lsmsvgtransformable.c +106 -0
  213. data/ext/mathematical/lsmsvgtransformable.h +54 -0
  214. data/ext/mathematical/lsmsvgtspanelement.c +174 -0
  215. data/ext/mathematical/lsmsvgtspanelement.h +60 -0
  216. data/ext/mathematical/lsmsvgtypes.h +77 -0
  217. data/ext/mathematical/lsmsvguseelement.c +237 -0
  218. data/ext/mathematical/lsmsvguseelement.h +69 -0
  219. data/ext/mathematical/lsmsvgview.c +2583 -0
  220. data/ext/mathematical/lsmsvgview.h +179 -0
  221. data/ext/mathematical/lsmtraits.c +119 -0
  222. data/ext/mathematical/lsmtraits.h +49 -0
  223. data/ext/mathematical/lsmtypes.h +36 -0
  224. data/ext/mathematical/lsmutils.c +54 -0
  225. data/ext/mathematical/lsmutils.h +56 -0
  226. data/ext/mathematical/mathematical.c +145 -0
  227. data/ext/mathematical/y.tab.c +6179 -0
  228. data/ext/mathematical/y.tab.h +389 -0
  229. data/lib/mathematical/version.rb +1 -1
  230. data/mathematical.gemspec +8 -6
  231. data/test/mathematical/basic_test.rb +9 -0
  232. data/test/mathematical/fixtures/after/brackets_display.html +1 -0
  233. data/test/mathematical/fixtures/after/compliance_accents.html +17 -0
  234. data/test/mathematical/fixtures/after/compliance_arrows.html +71 -0
  235. data/test/mathematical/fixtures/after/compliance_colors.html +4 -0
  236. data/test/mathematical/fixtures/after/compliance_greek_letters.html +42 -0
  237. data/test/mathematical/fixtures/after/compliance_large_math.html +19 -0
  238. data/test/mathematical/fixtures/after/compliance_log_symbols.html +34 -0
  239. data/test/mathematical/fixtures/after/compliance_operators.html +262 -0
  240. data/test/mathematical/fixtures/after/dollar_sign_inline.html +1 -0
  241. data/test/mathematical/fixtures/after/equation_display.html +1 -0
  242. data/test/mathematical/fixtures/after/multiple_dollar_inline.html +1 -0
  243. data/test/mathematical/fixtures/after/parens_inline.html +1 -0
  244. data/test/mathematical/fixtures/before/brackets_display.text +1 -0
  245. data/test/mathematical/fixtures/before/compliance_accents.text +17 -0
  246. data/test/mathematical/fixtures/before/compliance_arrows.text +71 -0
  247. data/test/mathematical/fixtures/before/compliance_colors.text +4 -0
  248. data/test/mathematical/fixtures/before/compliance_greek_letters.text +42 -0
  249. data/test/mathematical/fixtures/before/compliance_large_math.text +19 -0
  250. data/test/mathematical/fixtures/before/compliance_log_symbols.text +34 -0
  251. data/test/mathematical/fixtures/before/compliance_operators.text +262 -0
  252. data/test/mathematical/fixtures/before/dollar_sign_inline.text +1 -0
  253. data/test/mathematical/fixtures/before/equation_display.text +1 -0
  254. data/test/mathematical/fixtures/before/multiple_dollar_inline.text +1 -0
  255. data/test/mathematical/fixtures/before/parens_inline.text +1 -0
  256. data/test/mathematical/fixtures/performance/big_file.text +1767 -0
  257. data/test/mathematical/fixtures_test.rb +45 -0
  258. data/test/mathematical/maliciousness_test.rb +45 -0
  259. data/test/mathematical/performance_test.rb +15 -0
  260. data/test/test_helper.rb +5 -0
  261. metadata +301 -14
  262. data/lib/mathematical.bundle +0 -0
  263. data/lib/mathematical/mathematical.bundle +0 -0
@@ -0,0 +1,45 @@
1
+ /* Lasem
2
+ *
3
+ * Copyright © 2007-2008 Emmanuel Pacaud
4
+ *
5
+ * This library is free software; you can redistribute it and/or
6
+ * modify it under the terms of the GNU Lesser General Public
7
+ * License as published by the Free Software Foundation; either
8
+ * version 2 of the License, or (at your option) any later version.
9
+ *
10
+ * This library is distributed in the hope that it will be useful,
11
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13
+ * Lesser General Public License for more details.
14
+ *
15
+ * You should have received a copy of the GNU Lesser General
16
+ * Public License along with this library; if not, write to the
17
+ * Free Software Foundation, Inc., 59 Temple Place, Suite 330,
18
+ * Boston, MA 02111-1307, USA.
19
+ *
20
+ * Author:
21
+ * Emmanuel Pacaud <emmanuel@gnome.org>
22
+ */
23
+
24
+ #ifndef LSM_MATHML_GLYPH_TABLE_AMS_H
25
+ #define LSM_MATHML_GLYPH_TABLE_AMS_H
26
+
27
+ #include <lsmmathmltypes.h>
28
+ #include <lsmmathmlview.h>
29
+
30
+ G_BEGIN_DECLS
31
+
32
+ #define LSM_MATHML_RADICAL_UTF8 "\xe2\x88\x9a"
33
+
34
+ #define LSM_MATHML_RADICAL_ORDER_X_OFFSET 0.5
35
+ #define LSM_MATHML_RADICAL_ORDER_Y_OFFSET 0.5
36
+ #define LSM_MATHML_RADICAL_TOP_LINE_WIDTH 0.05
37
+
38
+ extern const LsmMathmlOperatorGlyph AMS_table[];
39
+
40
+ const LsmMathmlOperatorGlyph * lsm_mathml_glyph_table_find_operator_glyph (const char *text);
41
+ double lsm_mathml_glyph_table_get_operator_slant (const char *text);
42
+
43
+ G_END_DECLS
44
+
45
+ #endif
@@ -0,0 +1,187 @@
1
+ /* Lasem
2
+ *
3
+ * Copyright © 2010 Emmanuel Pacaud
4
+ *
5
+ * This library is free software; you can redistribute it and/or
6
+ * modify it under the terms of the GNU Lesser General Public
7
+ * License as published by the Free Software Foundation; either
8
+ * version 2 of the License, or (at your option) any later version.
9
+ *
10
+ * This library is distributed in the hope that it will be useful,
11
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13
+ * Lesser General Public License for more details.
14
+ *
15
+ * You should have received a copy of the GNU Lesser General
16
+ * Public License along with this library; if not, write to the
17
+ * Free Software Foundation, Inc., 59 Temple Place, Suite 330,
18
+ * Boston, MA 02111-1307, USA.
19
+ *
20
+ * Author:
21
+ * Emmanuel Pacaud <emmanuel@gnome.org>
22
+ */
23
+
24
+ #include <lsmmathmlitexelement.h>
25
+ #include <lsmmathmlview.h>
26
+ #include <lsmdomtext.h>
27
+ #include <lsmdebug.h>
28
+
29
+ static GObjectClass *parent_class;
30
+
31
+ /* GdomNode implementation */
32
+
33
+ static const char *
34
+ lsm_mathml_itex_element_get_node_name (LsmDomNode *node)
35
+ {
36
+ return "lasem:itex";
37
+ }
38
+
39
+ static gboolean
40
+ lsm_mathml_itex_can_append_child (LsmDomNode *self, LsmDomNode *child)
41
+ {
42
+ return (LSM_IS_DOM_TEXT (child));
43
+ }
44
+
45
+ /* LsmMathmlElement implementation */
46
+
47
+ static void
48
+ _update (LsmMathmlElement *self, LsmMathmlStyle *style)
49
+ {
50
+ LsmMathmlItexElement *itex_element = LSM_MATHML_ITEX_ELEMENT (self);
51
+ LsmDomNode *node;
52
+ GString *string;
53
+ gboolean need_conversion;
54
+
55
+ if (style->display == LSM_MATHML_DISPLAY_INLINE)
56
+ string = g_string_new ("$");
57
+ else
58
+ string = g_string_new ("$$");
59
+
60
+ for (node = LSM_DOM_NODE (self)->first_child; node != NULL; node = node->next_sibling) {
61
+ if (LSM_IS_DOM_TEXT (node)) {
62
+ g_string_append (string, lsm_dom_node_get_node_value (node));
63
+ }
64
+ }
65
+
66
+ if (style->display == LSM_MATHML_DISPLAY_INLINE)
67
+ g_string_append (string, "$");
68
+ else
69
+ g_string_append (string, "$$");
70
+
71
+ need_conversion = g_strcmp0 (itex_element->itex, string->str) != 0;
72
+
73
+ lsm_debug_update ("[MathmlItex::update] itex = '%s'", itex_element->itex);
74
+
75
+ if (need_conversion) {
76
+ LsmMathmlDocument *document;
77
+
78
+ g_free (itex_element->itex);
79
+ itex_element->itex = string->str;
80
+
81
+ lsm_debug_update ("[MathmlItex::update] need conversion");
82
+
83
+ document = lsm_mathml_document_new_from_itex (itex_element->itex,
84
+ string->len, NULL);
85
+ if (document != NULL) {
86
+ if (itex_element->math != NULL)
87
+ g_object_unref (lsm_dom_node_get_owner_document (LSM_DOM_NODE (itex_element->math)));
88
+
89
+ itex_element->math = LSM_MATHML_ELEMENT (lsm_mathml_document_get_root_element (document));
90
+ }
91
+ }
92
+
93
+ g_string_free (string, FALSE);
94
+
95
+ if (itex_element->math != NULL) {
96
+ lsm_dom_node_changed (LSM_DOM_NODE (itex_element->math));
97
+ self->need_measure = lsm_mathml_element_update (itex_element->math, style);
98
+ }
99
+ }
100
+
101
+ static const LsmMathmlBbox *
102
+ _measure (LsmMathmlElement *self, LsmMathmlView *view, const LsmMathmlBbox *bbox)
103
+ {
104
+ LsmMathmlItexElement *itex_element = LSM_MATHML_ITEX_ELEMENT (self);
105
+
106
+ if (itex_element->math != NULL)
107
+ return lsm_mathml_element_measure (itex_element->math, view, bbox);
108
+
109
+ self->bbox.width = 0.0;
110
+ self->bbox.height = 0.0;
111
+ self->bbox.depth = 0.0;
112
+
113
+ return &self->bbox;
114
+ }
115
+
116
+ static void
117
+ _layout (LsmMathmlElement *self, LsmMathmlView *view,
118
+ double x, double y, const LsmMathmlBbox *bbox)
119
+ {
120
+ LsmMathmlItexElement *itex_element = LSM_MATHML_ITEX_ELEMENT (self);
121
+
122
+ if (itex_element->math != NULL)
123
+ lsm_mathml_element_layout (itex_element->math, view, x, y, bbox);
124
+ }
125
+
126
+ static void
127
+ _render (LsmMathmlElement *self, LsmMathmlView *view)
128
+ {
129
+ LsmMathmlItexElement *itex_element = LSM_MATHML_ITEX_ELEMENT (self);
130
+
131
+ if (itex_element->math != NULL)
132
+ lsm_mathml_element_render (itex_element->math, view);
133
+ }
134
+
135
+ /* LsmMathmlItexElement implementation */
136
+
137
+ LsmDomNode *
138
+ lsm_mathml_itex_element_new (void)
139
+ {
140
+ return g_object_new (LSM_TYPE_MATHML_ITEX_ELEMENT, NULL);
141
+ }
142
+
143
+ static void
144
+ lsm_mathml_itex_element_init (LsmMathmlItexElement *self)
145
+ {
146
+ self->itex = NULL;
147
+ self->math = NULL;
148
+ }
149
+
150
+ static void
151
+ lsm_mathml_itex_element_finalize (GObject *object)
152
+ {
153
+ LsmMathmlItexElement *itex_element = LSM_MATHML_ITEX_ELEMENT (object);
154
+
155
+ g_free (itex_element->itex);
156
+ itex_element->itex = NULL;
157
+
158
+ if (itex_element->math != NULL)
159
+ g_object_unref (lsm_dom_node_get_owner_document (LSM_DOM_NODE (itex_element->math)));
160
+ itex_element->math = NULL;
161
+
162
+ parent_class->finalize (object);
163
+ }
164
+
165
+ /* LsmMathmlItexElement class */
166
+
167
+ static void
168
+ lsm_mathml_itex_element_class_init (LsmMathmlItexElementClass *itex_class)
169
+ {
170
+ GObjectClass *object_class = G_OBJECT_CLASS (itex_class);
171
+ LsmDomNodeClass *d_node_class = LSM_DOM_NODE_CLASS (itex_class);
172
+ LsmMathmlElementClass *m_element_class = LSM_MATHML_ELEMENT_CLASS (itex_class);
173
+
174
+ parent_class = g_type_class_peek_parent (itex_class);
175
+
176
+ object_class->finalize = lsm_mathml_itex_element_finalize;
177
+
178
+ d_node_class->get_node_name = lsm_mathml_itex_element_get_node_name;
179
+ d_node_class->can_append_child = lsm_mathml_itex_can_append_child;
180
+
181
+ m_element_class->update = _update;
182
+ m_element_class->measure = _measure;
183
+ m_element_class->layout = _layout;
184
+ m_element_class->render = _render;
185
+ }
186
+
187
+ G_DEFINE_TYPE (LsmMathmlItexElement, lsm_mathml_itex_element, LSM_TYPE_MATHML_ELEMENT)
@@ -0,0 +1,60 @@
1
+ /* Lasem
2
+ *
3
+ * Copyright © 2010 Emmanuel Pacaud
4
+ *
5
+ * This library is free software; you can redistribute it and/or
6
+ * modify it under the terms of the GNU Lesser General Public
7
+ * License as published by the Free Software Foundation; either
8
+ * version 2 of the License, or (at your option) any later version.
9
+ *
10
+ * This library is distributed in the hope that it will be useful,
11
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13
+ * Lesser General Public License for more details.
14
+ *
15
+ * You should have received a copy of the GNU Lesser General
16
+ * Public License along with this library; if not, write to the
17
+ * Free Software Foundation, Inc., 59 Temple Place, Suite 330,
18
+ * Boston, MA 02111-1307, USA.
19
+ *
20
+ * Author:
21
+ * Emmanuel Pacaud <emmanuel@gnome.org>
22
+ */
23
+
24
+ #ifndef LSM_MATHML_ITEX_ELEMENT_H
25
+ #define LSM_MATHML_ITEX_ELEMENT_H
26
+
27
+ #include <lsmmathmltypes.h>
28
+ #include <lsmmathmlelement.h>
29
+ #include <lsmmathmldocument.h>
30
+
31
+ G_BEGIN_DECLS
32
+
33
+ #define LSM_TYPE_MATHML_ITEX_ELEMENT (lsm_mathml_itex_element_get_type ())
34
+ #define LSM_MATHML_ITEX_ELEMENT(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), LSM_TYPE_MATHML_ITEX_ELEMENT, LsmMathmlItexElement))
35
+ #define LSM_MATHML_ITEX_ELEMENT_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), LSM_TYPE_MATHML_ITEX_ELEMENT, LsmMathmlItexElementClass))
36
+ #define LSM_IS_MATHML_ITEX_ELEMENT(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), LSM_TYPE_MATHML_ITEX_ELEMENT))
37
+ #define LSM_IS_MATHML_ITEX_ELEMENT_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), LSM_TYPE_MATHML_ITEX_ELEMENT))
38
+ #define LSM_MATHML_ITEX_ELEMENT_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), LSM_TYPE_MATHML_ITEX_ELEMENT, LsmMathmlItexElementClass))
39
+
40
+ typedef struct _LsmMathmlItexElementClass LsmMathmlItexElementClass;
41
+
42
+ struct _LsmMathmlItexElement {
43
+ LsmMathmlElement element;
44
+
45
+ char *itex;
46
+
47
+ LsmMathmlElement *math;
48
+ };
49
+
50
+ struct _LsmMathmlItexElementClass {
51
+ LsmMathmlElementClass parent_class;
52
+ };
53
+
54
+ GType lsm_mathml_itex_element_get_type (void);
55
+
56
+ LsmDomNode * lsm_mathml_itex_element_new (void);
57
+
58
+ G_END_DECLS
59
+
60
+ #endif
@@ -0,0 +1,191 @@
1
+ /* Lasem
2
+ *
3
+ * Copyright © 2007-2008 Emmanuel Pacaud
4
+ *
5
+ * This library is free software; you can redistribute it and/or
6
+ * modify it under the terms of the GNU Lesser General Public
7
+ * License as published by the Free Software Foundation; either
8
+ * version 2 of the License, or (at your option) any later version.
9
+ *
10
+ * This library is distributed in the hope that it will be useful,
11
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13
+ * Lesser General Public License for more details.
14
+ *
15
+ * You should have received a copy of the GNU Lesser General
16
+ * Public License along with this library; if not, write to the
17
+ * Free Software Foundation, Inc., 59 Temple Place, Suite 330,
18
+ * Boston, MA 02111-1307, USA.
19
+ *
20
+ * Author:
21
+ * Emmanuel Pacaud <emmanuel@gnome.org>
22
+ */
23
+
24
+ #include <lsmmathmllayoututils.h>
25
+ #include <lsmmathmloperatorelement.h>
26
+ #include <math.h>
27
+
28
+ void
29
+ lsm_mathml_measure_sub_sup (LsmMathmlElement *parent,
30
+ LsmMathmlView *view,
31
+ LsmMathmlElement *base,
32
+ LsmMathmlElement *subscript,
33
+ LsmMathmlElement *superscript,
34
+ double subscript_offset_min,
35
+ double superscript_offset_min,
36
+ LsmMathmlDisplay display,
37
+ const LsmMathmlBbox *stretch_bbox,
38
+ LsmMathmlBbox *bbox,
39
+ double *subscript_offset,
40
+ double *superscript_offset)
41
+ {
42
+ LsmMathmlBbox const *base_bbox = NULL;
43
+ LsmMathmlBbox const *subscript_bbox = NULL;
44
+ LsmMathmlBbox const *superscript_bbox = NULL;
45
+ LsmMathmlBbox children_bbox = lsm_mathml_bbox_null;
46
+ LsmMathmlOperatorElement *embellished_core;
47
+ double axis_offset, ascent, descent;
48
+ double v_space;
49
+ gboolean is_operator;
50
+
51
+ *bbox = lsm_mathml_bbox_null;
52
+
53
+ if (base == NULL)
54
+ return;
55
+
56
+ embellished_core = lsm_mathml_element_get_embellished_core (base);
57
+ is_operator = embellished_core != NULL;
58
+
59
+ /* TODO
60
+ double slant;
61
+ slant = is_operator ? lsm_mathml_operator_element_get_slant (embellished_core, view) : 0.0;
62
+ */
63
+
64
+ axis_offset = lsm_mathml_view_measure_axis_offset (view, parent->style.math_size);
65
+ v_space = parent->style.math_size * LSM_MATHML_SPACE_EM_THIN;
66
+ lsm_mathml_view_get_font_metrics (view, &parent->style, &ascent, &descent);
67
+
68
+ if (display == LSM_MATHML_DISPLAY_INLINE)
69
+ descent /= 2.0;
70
+
71
+ base_bbox = lsm_mathml_element_measure (LSM_MATHML_ELEMENT (base), view, stretch_bbox);
72
+
73
+ *bbox = *base_bbox;
74
+
75
+ subscript_bbox = subscript != NULL ? lsm_mathml_element_measure (subscript, view, NULL) : NULL;
76
+ superscript_bbox = superscript != NULL ? lsm_mathml_element_measure (superscript, view, NULL) : NULL;
77
+
78
+ if (subscript_bbox != NULL) {
79
+ if (is_operator) {
80
+ *subscript_offset = base_bbox->depth +
81
+ 0.5 * lsm_mathml_view_measure_axis_offset (view, subscript->style.math_size);
82
+ } else {
83
+ *subscript_offset = descent;
84
+
85
+ if (base_bbox->depth > descent)
86
+ *subscript_offset += base_bbox->depth - descent;
87
+ if (subscript_bbox->height - *subscript_offset > axis_offset)
88
+ *subscript_offset = subscript_bbox->height - axis_offset;
89
+ }
90
+ } else
91
+ *subscript_offset = 0.0;
92
+
93
+ if (superscript_bbox != NULL) {
94
+ if (is_operator) {
95
+ *superscript_offset = base_bbox->height -
96
+ 1.5 * lsm_mathml_view_measure_axis_offset (view, superscript->style.math_size);
97
+ } else {
98
+ if (display == LSM_MATHML_DISPLAY_INLINE)
99
+ *superscript_offset = axis_offset;
100
+ else {
101
+ double superscript_descent;
102
+
103
+ lsm_mathml_view_get_font_metrics (view, &superscript->style,
104
+ NULL, &superscript_descent);
105
+ *superscript_offset = axis_offset + superscript_descent;
106
+ }
107
+
108
+ if (base_bbox->height > ascent)
109
+ *superscript_offset += base_bbox->height - ascent;
110
+ if (*superscript_offset - superscript_bbox->depth < axis_offset)
111
+ *superscript_offset = axis_offset + superscript_bbox->depth;
112
+ }
113
+ } else
114
+ *superscript_offset = 0.0;
115
+
116
+ if (superscript_bbox != NULL && subscript_bbox != NULL) {
117
+ double delta = (*superscript_offset + *subscript_offset) -
118
+ (superscript_bbox->depth + subscript_bbox->height);
119
+ if (delta < v_space) {
120
+ *superscript_offset += fabs (delta - v_space) * 0.5;
121
+ *subscript_offset += fabs (delta - v_space) * 0.5;
122
+ }
123
+ }
124
+
125
+ *superscript_offset = MAX (*superscript_offset, superscript_offset_min);
126
+ *subscript_offset = MAX (*subscript_offset, subscript_offset_min);
127
+
128
+ if (subscript_bbox != NULL)
129
+ lsm_mathml_bbox_merge_vertically (&children_bbox, subscript_bbox, -*subscript_offset);
130
+ if (superscript_bbox != NULL)
131
+ lsm_mathml_bbox_merge_vertically (&children_bbox, superscript_bbox, *superscript_offset);
132
+
133
+ lsm_mathml_bbox_add_horizontally (bbox, &children_bbox);
134
+ }
135
+
136
+ void
137
+ lsm_mathml_layout_sub_sup (LsmMathmlElement *parent,
138
+ LsmMathmlView *view,
139
+ double x,
140
+ double y,
141
+ LsmMathmlElement *base,
142
+ LsmMathmlElement *subscript,
143
+ LsmMathmlElement *superscript,
144
+ double subscript_offset,
145
+ double superscript_offset)
146
+ {
147
+ const LsmMathmlBbox *base_bbox;
148
+ const LsmMathmlOperatorElement *embellished_core;
149
+ double slant;
150
+ double slant_offset;
151
+ gboolean is_operator;
152
+
153
+ if (base == NULL)
154
+ return;
155
+
156
+ embellished_core = lsm_mathml_element_get_embellished_core (base);
157
+ is_operator = embellished_core != NULL;
158
+
159
+ slant = is_operator ? lsm_mathml_operator_element_get_slant (embellished_core, view) : 0.0;
160
+
161
+ base_bbox = lsm_mathml_element_get_bbox (base);
162
+
163
+ lsm_mathml_element_layout (base, view, x, y, base_bbox);
164
+
165
+ if (subscript) {
166
+ const LsmMathmlBbox *subscript_bbox;
167
+
168
+ subscript_bbox = lsm_mathml_element_get_bbox (subscript);
169
+
170
+ slant_offset = slant < 0.0 ? (base_bbox->height + subscript_offset -
171
+ subscript_bbox->height) * sin (slant) : 0.0;
172
+
173
+ lsm_mathml_element_layout (subscript, view,
174
+ x + base_bbox->width + slant_offset,
175
+ y + subscript_offset,
176
+ lsm_mathml_element_get_bbox (subscript));
177
+ }
178
+ if (superscript) {
179
+ const LsmMathmlBbox *superscript_bbox;
180
+
181
+ superscript_bbox = lsm_mathml_element_get_bbox (superscript);
182
+
183
+ slant_offset = slant > 0.0 ? (base_bbox->depth + superscript_offset -
184
+ superscript_bbox->depth) * sin (-slant) : 0.0;
185
+
186
+ lsm_mathml_element_layout (superscript, view,
187
+ x + base_bbox->width,
188
+ y - superscript_offset,
189
+ lsm_mathml_element_get_bbox (superscript));
190
+ }
191
+ }