mathematical 0.1.0 → 0.1.1

Sign up to get free protection for your applications and to get access to all the features.
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
+ }