mathematical 0.1.0 → 0.1.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/ext/mathematical/extconf.rb +14 -0
- data/ext/mathematical/itex2MML.h +63 -0
- data/ext/mathematical/lasemrender.c +257 -0
- data/ext/mathematical/lex.yy.c +6548 -0
- data/ext/mathematical/lsm.c +31 -0
- data/ext/mathematical/lsm.h +39 -0
- data/ext/mathematical/lsmattributes.c +279 -0
- data/ext/mathematical/lsmattributes.h +75 -0
- data/ext/mathematical/lsmcairo.c +598 -0
- data/ext/mathematical/lsmcairo.h +51 -0
- data/ext/mathematical/lsmdebug.c +183 -0
- data/ext/mathematical/lsmdebug.h +73 -0
- data/ext/mathematical/lsmdom.h +43 -0
- data/ext/mathematical/lsmdomcharacterdata.c +114 -0
- data/ext/mathematical/lsmdomcharacterdata.h +59 -0
- data/ext/mathematical/lsmdomdocument.c +255 -0
- data/ext/mathematical/lsmdomdocument.h +75 -0
- data/ext/mathematical/lsmdomdocumentfragment.c +81 -0
- data/ext/mathematical/lsmdomdocumentfragment.h +55 -0
- data/ext/mathematical/lsmdomelement.c +148 -0
- data/ext/mathematical/lsmdomelement.h +62 -0
- data/ext/mathematical/lsmdomentities.c +2166 -0
- data/ext/mathematical/lsmdomentities.h +35 -0
- data/ext/mathematical/lsmdomenumtypes.c +99 -0
- data/ext/mathematical/lsmdomenumtypes.h +26 -0
- data/ext/mathematical/lsmdomimplementation.c +82 -0
- data/ext/mathematical/lsmdomimplementation.h +41 -0
- data/ext/mathematical/lsmdomnamednodemap.c +118 -0
- data/ext/mathematical/lsmdomnamednodemap.h +64 -0
- data/ext/mathematical/lsmdomnode.c +737 -0
- data/ext/mathematical/lsmdomnode.h +122 -0
- data/ext/mathematical/lsmdomnodelist.c +70 -0
- data/ext/mathematical/lsmdomnodelist.h +58 -0
- data/ext/mathematical/lsmdomparser.c +461 -0
- data/ext/mathematical/lsmdomparser.h +54 -0
- data/ext/mathematical/lsmdomtext.c +82 -0
- data/ext/mathematical/lsmdomtext.h +55 -0
- data/ext/mathematical/lsmdomtypes.h +44 -0
- data/ext/mathematical/lsmdomview.c +422 -0
- data/ext/mathematical/lsmdomview.h +94 -0
- data/ext/mathematical/lsmitex.c +76 -0
- data/ext/mathematical/lsmitex.h +36 -0
- data/ext/mathematical/lsmmathml.h +66 -0
- data/ext/mathematical/lsmmathmlactionelement.c +93 -0
- data/ext/mathematical/lsmmathmlactionelement.h +57 -0
- data/ext/mathematical/lsmmathmlaligngroupelement.c +102 -0
- data/ext/mathematical/lsmmathmlaligngroupelement.h +56 -0
- data/ext/mathematical/lsmmathmlalignmarkelement.c +102 -0
- data/ext/mathematical/lsmmathmlalignmarkelement.h +56 -0
- data/ext/mathematical/lsmmathmlattributes.c +197 -0
- data/ext/mathematical/lsmmathmlattributes.h +126 -0
- data/ext/mathematical/lsmmathmldocument.c +304 -0
- data/ext/mathematical/lsmmathmldocument.h +61 -0
- data/ext/mathematical/lsmmathmlelement.c +491 -0
- data/ext/mathematical/lsmmathmlelement.h +107 -0
- data/ext/mathematical/lsmmathmlenums.c +429 -0
- data/ext/mathematical/lsmmathmlenums.h +182 -0
- data/ext/mathematical/lsmmathmlenumtypes.c +666 -0
- data/ext/mathematical/lsmmathmlenumtypes.h +90 -0
- data/ext/mathematical/lsmmathmlerrorelement.c +58 -0
- data/ext/mathematical/lsmmathmlerrorelement.h +56 -0
- data/ext/mathematical/lsmmathmlfencedelement.c +178 -0
- data/ext/mathematical/lsmmathmlfencedelement.h +65 -0
- data/ext/mathematical/lsmmathmlfractionelement.c +253 -0
- data/ext/mathematical/lsmmathmlfractionelement.h +62 -0
- data/ext/mathematical/lsmmathmlglyphtableams.c +597 -0
- data/ext/mathematical/lsmmathmlglyphtableams.h +45 -0
- data/ext/mathematical/lsmmathmlitexelement.c +187 -0
- data/ext/mathematical/lsmmathmlitexelement.h +60 -0
- data/ext/mathematical/lsmmathmllayoututils.c +191 -0
- data/ext/mathematical/lsmmathmllayoututils.h +58 -0
- data/ext/mathematical/lsmmathmlmathelement.c +204 -0
- data/ext/mathematical/lsmmathmlmathelement.h +81 -0
- data/ext/mathematical/lsmmathmloperatordictionary.c +3332 -0
- data/ext/mathematical/lsmmathmloperatordictionary.h +54 -0
- data/ext/mathematical/lsmmathmloperatorelement.c +307 -0
- data/ext/mathematical/lsmmathmloperatorelement.h +73 -0
- data/ext/mathematical/lsmmathmlpaddedelement.c +58 -0
- data/ext/mathematical/lsmmathmlpaddedelement.h +56 -0
- data/ext/mathematical/lsmmathmlphantomelement.c +71 -0
- data/ext/mathematical/lsmmathmlphantomelement.h +56 -0
- data/ext/mathematical/lsmmathmlpresentationcontainer.c +43 -0
- data/ext/mathematical/lsmmathmlpresentationcontainer.h +54 -0
- data/ext/mathematical/lsmmathmlpresentationtoken.c +303 -0
- data/ext/mathematical/lsmmathmlpresentationtoken.h +83 -0
- data/ext/mathematical/lsmmathmlradicalelement.c +266 -0
- data/ext/mathematical/lsmmathmlradicalelement.h +71 -0
- data/ext/mathematical/lsmmathmlrowelement.c +58 -0
- data/ext/mathematical/lsmmathmlrowelement.h +56 -0
- data/ext/mathematical/lsmmathmlscriptelement.c +282 -0
- data/ext/mathematical/lsmmathmlscriptelement.h +78 -0
- data/ext/mathematical/lsmmathmlsemanticselement.c +84 -0
- data/ext/mathematical/lsmmathmlsemanticselement.h +56 -0
- data/ext/mathematical/lsmmathmlspaceelement.c +142 -0
- data/ext/mathematical/lsmmathmlspaceelement.h +60 -0
- data/ext/mathematical/lsmmathmlstringelement.c +123 -0
- data/ext/mathematical/lsmmathmlstringelement.h +58 -0
- data/ext/mathematical/lsmmathmlstyle.c +130 -0
- data/ext/mathematical/lsmmathmlstyle.h +81 -0
- data/ext/mathematical/lsmmathmlstyleelement.c +307 -0
- data/ext/mathematical/lsmmathmlstyleelement.h +87 -0
- data/ext/mathematical/lsmmathmltablecellelement.c +122 -0
- data/ext/mathematical/lsmmathmltablecellelement.h +62 -0
- data/ext/mathematical/lsmmathmltableelement.c +545 -0
- data/ext/mathematical/lsmmathmltableelement.h +78 -0
- data/ext/mathematical/lsmmathmltablerowelement.c +120 -0
- data/ext/mathematical/lsmmathmltablerowelement.h +64 -0
- data/ext/mathematical/lsmmathmltraits.c +819 -0
- data/ext/mathematical/lsmmathmltraits.h +119 -0
- data/ext/mathematical/lsmmathmltypes.h +66 -0
- data/ext/mathematical/lsmmathmlunderoverelement.c +485 -0
- data/ext/mathematical/lsmmathmlunderoverelement.h +82 -0
- data/ext/mathematical/lsmmathmlutils.c +170 -0
- data/ext/mathematical/lsmmathmlutils.h +50 -0
- data/ext/mathematical/lsmmathmlview.c +1048 -0
- data/ext/mathematical/lsmmathmlview.h +164 -0
- data/ext/mathematical/lsmproperties.c +418 -0
- data/ext/mathematical/lsmproperties.h +85 -0
- data/ext/mathematical/lsmstr.c +231 -0
- data/ext/mathematical/lsmstr.h +114 -0
- data/ext/mathematical/lsmsvg.h +67 -0
- data/ext/mathematical/lsmsvgaelement.c +73 -0
- data/ext/mathematical/lsmsvgaelement.h +55 -0
- data/ext/mathematical/lsmsvgattributes.h +118 -0
- data/ext/mathematical/lsmsvgcircleelement.c +153 -0
- data/ext/mathematical/lsmsvgcircleelement.h +59 -0
- data/ext/mathematical/lsmsvgclippathelement.c +134 -0
- data/ext/mathematical/lsmsvgclippathelement.h +59 -0
- data/ext/mathematical/lsmsvgcolors.c +212 -0
- data/ext/mathematical/lsmsvgcolors.h +39 -0
- data/ext/mathematical/lsmsvgdefselement.c +74 -0
- data/ext/mathematical/lsmsvgdefselement.h +55 -0
- data/ext/mathematical/lsmsvgdocument.c +288 -0
- data/ext/mathematical/lsmsvgdocument.h +64 -0
- data/ext/mathematical/lsmsvgelement.c +373 -0
- data/ext/mathematical/lsmsvgelement.h +81 -0
- data/ext/mathematical/lsmsvgellipseelement.c +158 -0
- data/ext/mathematical/lsmsvgellipseelement.h +60 -0
- data/ext/mathematical/lsmsvgenums.c +544 -0
- data/ext/mathematical/lsmsvgenums.h +357 -0
- data/ext/mathematical/lsmsvgenumtypes.c +1083 -0
- data/ext/mathematical/lsmsvgenumtypes.h +111 -0
- data/ext/mathematical/lsmsvgfilterblend.c +105 -0
- data/ext/mathematical/lsmsvgfilterblend.h +58 -0
- data/ext/mathematical/lsmsvgfiltercomposite.c +109 -0
- data/ext/mathematical/lsmsvgfiltercomposite.h +58 -0
- data/ext/mathematical/lsmsvgfilterelement.c +266 -0
- data/ext/mathematical/lsmsvgfilterelement.h +66 -0
- data/ext/mathematical/lsmsvgfilterflood.c +86 -0
- data/ext/mathematical/lsmsvgfilterflood.h +55 -0
- data/ext/mathematical/lsmsvgfiltergaussianblur.c +114 -0
- data/ext/mathematical/lsmsvgfiltergaussianblur.h +57 -0
- data/ext/mathematical/lsmsvgfiltermerge.c +98 -0
- data/ext/mathematical/lsmsvgfiltermerge.h +55 -0
- data/ext/mathematical/lsmsvgfiltermergenode.c +87 -0
- data/ext/mathematical/lsmsvgfiltermergenode.h +57 -0
- data/ext/mathematical/lsmsvgfilteroffset.c +112 -0
- data/ext/mathematical/lsmsvgfilteroffset.h +58 -0
- data/ext/mathematical/lsmsvgfilterprimitive.c +168 -0
- data/ext/mathematical/lsmsvgfilterprimitive.h +66 -0
- data/ext/mathematical/lsmsvgfilterspecularlighting.c +127 -0
- data/ext/mathematical/lsmsvgfilterspecularlighting.h +60 -0
- data/ext/mathematical/lsmsvgfiltersurface.c +455 -0
- data/ext/mathematical/lsmsvgfiltersurface.h +66 -0
- data/ext/mathematical/lsmsvgfiltertile.c +102 -0
- data/ext/mathematical/lsmsvgfiltertile.h +57 -0
- data/ext/mathematical/lsmsvggelement.c +73 -0
- data/ext/mathematical/lsmsvggelement.h +55 -0
- data/ext/mathematical/lsmsvggradientelement.c +151 -0
- data/ext/mathematical/lsmsvggradientelement.h +68 -0
- data/ext/mathematical/lsmsvgimageelement.c +261 -0
- data/ext/mathematical/lsmsvgimageelement.h +67 -0
- data/ext/mathematical/lsmsvglength.c +152 -0
- data/ext/mathematical/lsmsvglength.h +65 -0
- data/ext/mathematical/lsmsvglineargradientelement.c +271 -0
- data/ext/mathematical/lsmsvglineargradientelement.h +60 -0
- data/ext/mathematical/lsmsvglineelement.c +153 -0
- data/ext/mathematical/lsmsvglineelement.h +60 -0
- data/ext/mathematical/lsmsvgmarkerelement.c +266 -0
- data/ext/mathematical/lsmsvgmarkerelement.h +74 -0
- data/ext/mathematical/lsmsvgmaskelement.c +232 -0
- data/ext/mathematical/lsmsvgmaskelement.h +64 -0
- data/ext/mathematical/lsmsvgmatrix.c +205 -0
- data/ext/mathematical/lsmsvgmatrix.h +59 -0
- data/ext/mathematical/lsmsvgpathelement.c +115 -0
- data/ext/mathematical/lsmsvgpathelement.h +59 -0
- data/ext/mathematical/lsmsvgpatternelement.c +398 -0
- data/ext/mathematical/lsmsvgpatternelement.h +69 -0
- data/ext/mathematical/lsmsvgpolygonelement.c +106 -0
- data/ext/mathematical/lsmsvgpolygonelement.h +57 -0
- data/ext/mathematical/lsmsvgpolylineelement.c +106 -0
- data/ext/mathematical/lsmsvgpolylineelement.h +57 -0
- data/ext/mathematical/lsmsvgradialgradientelement.c +323 -0
- data/ext/mathematical/lsmsvgradialgradientelement.h +61 -0
- data/ext/mathematical/lsmsvgrectelement.c +184 -0
- data/ext/mathematical/lsmsvgrectelement.h +62 -0
- data/ext/mathematical/lsmsvgstopelement.c +106 -0
- data/ext/mathematical/lsmsvgstopelement.h +57 -0
- data/ext/mathematical/lsmsvgstyle.c +560 -0
- data/ext/mathematical/lsmsvgstyle.h +217 -0
- data/ext/mathematical/lsmsvgsvgelement.c +260 -0
- data/ext/mathematical/lsmsvgsvgelement.h +71 -0
- data/ext/mathematical/lsmsvgswitchelement.c +103 -0
- data/ext/mathematical/lsmsvgswitchelement.h +55 -0
- data/ext/mathematical/lsmsvgsymbolelement.c +74 -0
- data/ext/mathematical/lsmsvgsymbolelement.h +55 -0
- data/ext/mathematical/lsmsvgtextelement.c +203 -0
- data/ext/mathematical/lsmsvgtextelement.h +60 -0
- data/ext/mathematical/lsmsvgtraits.c +1232 -0
- data/ext/mathematical/lsmsvgtraits.h +104 -0
- data/ext/mathematical/lsmsvgtransformable.c +106 -0
- data/ext/mathematical/lsmsvgtransformable.h +54 -0
- data/ext/mathematical/lsmsvgtspanelement.c +174 -0
- data/ext/mathematical/lsmsvgtspanelement.h +60 -0
- data/ext/mathematical/lsmsvgtypes.h +77 -0
- data/ext/mathematical/lsmsvguseelement.c +237 -0
- data/ext/mathematical/lsmsvguseelement.h +69 -0
- data/ext/mathematical/lsmsvgview.c +2583 -0
- data/ext/mathematical/lsmsvgview.h +179 -0
- data/ext/mathematical/lsmtraits.c +119 -0
- data/ext/mathematical/lsmtraits.h +49 -0
- data/ext/mathematical/lsmtypes.h +36 -0
- data/ext/mathematical/lsmutils.c +54 -0
- data/ext/mathematical/lsmutils.h +56 -0
- data/ext/mathematical/mathematical.c +145 -0
- data/ext/mathematical/y.tab.c +6179 -0
- data/ext/mathematical/y.tab.h +389 -0
- data/lib/mathematical/version.rb +1 -1
- data/mathematical.gemspec +8 -6
- data/test/mathematical/basic_test.rb +9 -0
- data/test/mathematical/fixtures/after/brackets_display.html +1 -0
- data/test/mathematical/fixtures/after/compliance_accents.html +17 -0
- data/test/mathematical/fixtures/after/compliance_arrows.html +71 -0
- data/test/mathematical/fixtures/after/compliance_colors.html +4 -0
- data/test/mathematical/fixtures/after/compliance_greek_letters.html +42 -0
- data/test/mathematical/fixtures/after/compliance_large_math.html +19 -0
- data/test/mathematical/fixtures/after/compliance_log_symbols.html +34 -0
- data/test/mathematical/fixtures/after/compliance_operators.html +262 -0
- data/test/mathematical/fixtures/after/dollar_sign_inline.html +1 -0
- data/test/mathematical/fixtures/after/equation_display.html +1 -0
- data/test/mathematical/fixtures/after/multiple_dollar_inline.html +1 -0
- data/test/mathematical/fixtures/after/parens_inline.html +1 -0
- data/test/mathematical/fixtures/before/brackets_display.text +1 -0
- data/test/mathematical/fixtures/before/compliance_accents.text +17 -0
- data/test/mathematical/fixtures/before/compliance_arrows.text +71 -0
- data/test/mathematical/fixtures/before/compliance_colors.text +4 -0
- data/test/mathematical/fixtures/before/compliance_greek_letters.text +42 -0
- data/test/mathematical/fixtures/before/compliance_large_math.text +19 -0
- data/test/mathematical/fixtures/before/compliance_log_symbols.text +34 -0
- data/test/mathematical/fixtures/before/compliance_operators.text +262 -0
- data/test/mathematical/fixtures/before/dollar_sign_inline.text +1 -0
- data/test/mathematical/fixtures/before/equation_display.text +1 -0
- data/test/mathematical/fixtures/before/multiple_dollar_inline.text +1 -0
- data/test/mathematical/fixtures/before/parens_inline.text +1 -0
- data/test/mathematical/fixtures/performance/big_file.text +1767 -0
- data/test/mathematical/fixtures_test.rb +45 -0
- data/test/mathematical/maliciousness_test.rb +45 -0
- data/test/mathematical/performance_test.rb +15 -0
- data/test/test_helper.rb +5 -0
- metadata +301 -14
- data/lib/mathematical.bundle +0 -0
- data/lib/mathematical/mathematical.bundle +0 -0
@@ -0,0 +1,304 @@
|
|
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 <lsmmathmldocument.h>
|
25
|
+
#include <lsmmathmlsemanticselement.h>
|
26
|
+
#include <lsmmathmlphantomelement.h>
|
27
|
+
#include <lsmmathmlmathelement.h>
|
28
|
+
#include <lsmmathmltableelement.h>
|
29
|
+
#include <lsmmathmltablerowelement.h>
|
30
|
+
#include <lsmmathmltablecellelement.h>
|
31
|
+
#include <lsmmathmlspaceelement.h>
|
32
|
+
#include <lsmmathmlradicalelement.h>
|
33
|
+
#include <lsmmathmlscriptelement.h>
|
34
|
+
#include <lsmmathmlfractionelement.h>
|
35
|
+
#include <lsmmathmlunderoverelement.h>
|
36
|
+
#include <lsmmathmloperatorelement.h>
|
37
|
+
#include <lsmmathmlstringelement.h>
|
38
|
+
#include <lsmmathmlrowelement.h>
|
39
|
+
#include <lsmmathmlpaddedelement.h>
|
40
|
+
#include <lsmmathmlfencedelement.h>
|
41
|
+
#include <lsmmathmlerrorelement.h>
|
42
|
+
#include <lsmmathmlactionelement.h>
|
43
|
+
#include <lsmmathmlstyleelement.h>
|
44
|
+
#include <lsmmathmlalignmarkelement.h>
|
45
|
+
#include <lsmmathmlaligngroupelement.h>
|
46
|
+
#include <lsmmathmlitexelement.h>
|
47
|
+
#include <lsmmathmlview.h>
|
48
|
+
#include <lsmdebug.h>
|
49
|
+
#include <gio/gio.h>
|
50
|
+
#include <string.h>
|
51
|
+
|
52
|
+
#include <lsmdomparser.h>
|
53
|
+
|
54
|
+
#include "itex2MML.h"
|
55
|
+
|
56
|
+
/* LsmDomNode implementation */
|
57
|
+
|
58
|
+
static gboolean
|
59
|
+
lsm_mathml_document_can_append_child (LsmDomNode *self, LsmDomNode *child)
|
60
|
+
{
|
61
|
+
return (LSM_IS_MATHML_MATH_ELEMENT (child));
|
62
|
+
}
|
63
|
+
|
64
|
+
/* LsmDomDocument implementation */
|
65
|
+
|
66
|
+
static LsmDomElement *
|
67
|
+
_create_element (LsmDomDocument *document, const char *tag_name)
|
68
|
+
{
|
69
|
+
LsmDomNode *node = NULL;
|
70
|
+
|
71
|
+
if (strcmp (tag_name, "math") == 0)
|
72
|
+
node = lsm_mathml_math_element_new ();
|
73
|
+
else if (strcmp (tag_name, "mtable") == 0)
|
74
|
+
node = lsm_mathml_table_element_new ();
|
75
|
+
else if (strcmp (tag_name, "mtr") == 0)
|
76
|
+
node = lsm_mathml_table_row_element_new ();
|
77
|
+
else if (strcmp (tag_name, "mlabeledtr") == 0)
|
78
|
+
node = lsm_mathml_labeled_table_row_element_new ();
|
79
|
+
else if (strcmp (tag_name, "mtd") == 0)
|
80
|
+
node = lsm_mathml_table_cell_element_new ();
|
81
|
+
else if (strcmp (tag_name, "mspace") == 0)
|
82
|
+
node = lsm_mathml_space_element_new ();
|
83
|
+
else if (strcmp (tag_name, "msqrt") == 0)
|
84
|
+
node = lsm_mathml_sqrt_element_new ();
|
85
|
+
else if (strcmp (tag_name, "mroot") == 0)
|
86
|
+
node = lsm_mathml_root_element_new ();
|
87
|
+
else if (strcmp (tag_name, "msub") == 0)
|
88
|
+
node = lsm_mathml_sub_element_new ();
|
89
|
+
else if (strcmp (tag_name, "msup") == 0)
|
90
|
+
node = lsm_mathml_sup_element_new ();
|
91
|
+
else if (strcmp (tag_name, "msubsup") == 0)
|
92
|
+
node = lsm_mathml_sub_sup_element_new ();
|
93
|
+
else if (strcmp (tag_name, "mfrac") == 0)
|
94
|
+
node = lsm_mathml_fraction_element_new ();
|
95
|
+
else if (strcmp (tag_name, "munder") == 0)
|
96
|
+
node = lsm_mathml_under_element_new ();
|
97
|
+
else if (strcmp (tag_name, "mover") == 0)
|
98
|
+
node = lsm_mathml_over_element_new ();
|
99
|
+
else if (strcmp (tag_name, "munderover") == 0)
|
100
|
+
node = lsm_mathml_under_over_element_new ();
|
101
|
+
else if (strcmp (tag_name, "mo") == 0)
|
102
|
+
node = lsm_mathml_operator_element_new ();
|
103
|
+
else if (strcmp (tag_name, "mrow") == 0)
|
104
|
+
node = lsm_mathml_row_element_new ();
|
105
|
+
else if (strcmp (tag_name, "mn") == 0)
|
106
|
+
node = lsm_mathml_number_element_new ();
|
107
|
+
else if (strcmp (tag_name, "mi") == 0)
|
108
|
+
node = lsm_mathml_identifier_element_new ();
|
109
|
+
else if (strcmp (tag_name, "mtext") == 0)
|
110
|
+
node = lsm_mathml_text_element_new ();
|
111
|
+
else if (strcmp (tag_name, "ms") == 0)
|
112
|
+
node = lsm_mathml_string_element_new ();
|
113
|
+
else if (strcmp (tag_name, "mstyle") == 0)
|
114
|
+
node = lsm_mathml_style_element_new ();
|
115
|
+
else if (strcmp (tag_name, "mphantom") == 0)
|
116
|
+
node = lsm_mathml_phantom_element_new ();
|
117
|
+
else if (strcmp (tag_name, "mpadded") == 0)
|
118
|
+
node = lsm_mathml_padded_element_new ();
|
119
|
+
else if (strcmp (tag_name, "mfenced") == 0)
|
120
|
+
node = lsm_mathml_fenced_element_new ();
|
121
|
+
else if (strcmp (tag_name, "merror") == 0)
|
122
|
+
node = lsm_mathml_error_element_new ();
|
123
|
+
else if (strcmp (tag_name, "maction") == 0)
|
124
|
+
node = lsm_mathml_action_element_new ();
|
125
|
+
else if (strcmp (tag_name, "malignmark") == 0)
|
126
|
+
node = lsm_mathml_align_mark_element_new ();
|
127
|
+
else if (strcmp (tag_name, "maligngroup") == 0)
|
128
|
+
node = lsm_mathml_align_group_element_new ();
|
129
|
+
else if (strcmp (tag_name, "semantics") == 0)
|
130
|
+
node = lsm_mathml_semantics_element_new ();
|
131
|
+
else if (strcmp (tag_name, "lasem:itex") == 0)
|
132
|
+
node = lsm_mathml_itex_element_new ();
|
133
|
+
else
|
134
|
+
lsm_debug_dom ("[MathmlDocument::create_element] Unknown tag (%s)", tag_name);
|
135
|
+
|
136
|
+
return LSM_DOM_ELEMENT (node);
|
137
|
+
}
|
138
|
+
|
139
|
+
static LsmDomElement *
|
140
|
+
lsm_mathml_document_create_element (LsmDomDocument *document, const char *tag_name)
|
141
|
+
{
|
142
|
+
LsmDomElement *element;
|
143
|
+
|
144
|
+
element = _create_element (document, tag_name);
|
145
|
+
if (element != NULL)
|
146
|
+
return element;
|
147
|
+
|
148
|
+
if (g_str_has_prefix (tag_name, "math:"))
|
149
|
+
return _create_element (document, &tag_name[4]);
|
150
|
+
|
151
|
+
return NULL;
|
152
|
+
}
|
153
|
+
|
154
|
+
static LsmDomView *
|
155
|
+
lsm_mathml_document_create_view (LsmDomDocument *document)
|
156
|
+
{
|
157
|
+
return LSM_DOM_VIEW (lsm_mathml_view_new (LSM_MATHML_DOCUMENT (document)));
|
158
|
+
}
|
159
|
+
|
160
|
+
/* LsmMathmlDocument implementation */
|
161
|
+
|
162
|
+
LsmDomDocument *
|
163
|
+
lsm_mathml_document_new (void)
|
164
|
+
{
|
165
|
+
return g_object_new (LSM_TYPE_MATHML_DOCUMENT, NULL);
|
166
|
+
}
|
167
|
+
|
168
|
+
static void
|
169
|
+
lsm_mathml_document_init (LsmMathmlDocument *document)
|
170
|
+
{
|
171
|
+
}
|
172
|
+
|
173
|
+
/* Additional methods */
|
174
|
+
|
175
|
+
LsmMathmlMathElement *
|
176
|
+
lsm_mathml_document_get_root_element (const LsmMathmlDocument *document)
|
177
|
+
{
|
178
|
+
return LSM_MATHML_MATH_ELEMENT (lsm_dom_document_get_document_element (LSM_DOM_DOCUMENT (document)));
|
179
|
+
}
|
180
|
+
|
181
|
+
/* LsmMathmlDocument class */
|
182
|
+
|
183
|
+
static void
|
184
|
+
lsm_mathml_document_class_init (LsmMathmlDocumentClass *m_document_class)
|
185
|
+
{
|
186
|
+
LsmDomNodeClass *d_node_class = LSM_DOM_NODE_CLASS (m_document_class);
|
187
|
+
LsmDomDocumentClass *d_document_class = LSM_DOM_DOCUMENT_CLASS (m_document_class);
|
188
|
+
|
189
|
+
d_node_class->can_append_child = lsm_mathml_document_can_append_child;
|
190
|
+
|
191
|
+
d_document_class->create_element = lsm_mathml_document_create_element;
|
192
|
+
d_document_class->create_view = lsm_mathml_document_create_view;
|
193
|
+
}
|
194
|
+
|
195
|
+
G_DEFINE_TYPE (LsmMathmlDocument, lsm_mathml_document, LSM_TYPE_DOM_DOCUMENT)
|
196
|
+
|
197
|
+
static GQuark
|
198
|
+
lsm_mathml_document_error_quark (void)
|
199
|
+
{
|
200
|
+
static GQuark q = 0;
|
201
|
+
|
202
|
+
if (q == 0) {
|
203
|
+
q = g_quark_from_static_string ("lsm-mathml-error-quark");
|
204
|
+
}
|
205
|
+
|
206
|
+
return q;
|
207
|
+
}
|
208
|
+
|
209
|
+
#define LSM_MATHML_DOCUMENT_ERROR lsm_mathml_document_error_quark ()
|
210
|
+
|
211
|
+
typedef enum {
|
212
|
+
LSM_MATHML_DOCUMENT_ERROR_INVALID_ITEX
|
213
|
+
} LsmMathmlDocumentError;
|
214
|
+
|
215
|
+
LsmMathmlDocument *
|
216
|
+
lsm_mathml_document_new_from_itex (const char *itex, int size, GError **error)
|
217
|
+
{
|
218
|
+
LsmDomDocument *document;
|
219
|
+
char *mathml;
|
220
|
+
|
221
|
+
mathml = lsm_itex_to_mathml (itex, size);
|
222
|
+
|
223
|
+
if (mathml == NULL) {
|
224
|
+
lsm_debug_dom ("[LsmMathmlDocument::new_from_itex] Invalid document");
|
225
|
+
|
226
|
+
g_set_error (error,
|
227
|
+
LSM_MATHML_DOCUMENT_ERROR,
|
228
|
+
LSM_MATHML_DOCUMENT_ERROR_INVALID_ITEX,
|
229
|
+
"Invalid itex document.");
|
230
|
+
|
231
|
+
return NULL;
|
232
|
+
}
|
233
|
+
|
234
|
+
document = lsm_dom_document_new_from_memory (mathml, -1, error);
|
235
|
+
|
236
|
+
lsm_itex_free_mathml_buffer (mathml);
|
237
|
+
|
238
|
+
if (document == NULL)
|
239
|
+
return NULL;
|
240
|
+
|
241
|
+
if (!LSM_IS_MATHML_DOCUMENT (document)) {
|
242
|
+
g_object_unref (document);
|
243
|
+
return NULL;
|
244
|
+
}
|
245
|
+
|
246
|
+
return LSM_MATHML_DOCUMENT (document);
|
247
|
+
}
|
248
|
+
|
249
|
+
static LsmMathmlDocument *
|
250
|
+
lsm_mathml_document_new_from_itex_file (GFile *file, GError **error)
|
251
|
+
{
|
252
|
+
LsmMathmlDocument *document;
|
253
|
+
gsize size = 0;
|
254
|
+
char *contents = NULL;
|
255
|
+
|
256
|
+
if (!g_file_load_contents (file, NULL, &contents, &size, NULL, error))
|
257
|
+
return NULL;
|
258
|
+
|
259
|
+
document = lsm_mathml_document_new_from_itex (contents, size, error);
|
260
|
+
|
261
|
+
g_free (contents);
|
262
|
+
|
263
|
+
return document;
|
264
|
+
}
|
265
|
+
|
266
|
+
LsmMathmlDocument *
|
267
|
+
lsm_mathml_document_new_from_itex_path (const char *path, GError **error)
|
268
|
+
{
|
269
|
+
LsmMathmlDocument *document;
|
270
|
+
GFile *file;
|
271
|
+
|
272
|
+
g_return_val_if_fail (path != NULL, NULL);
|
273
|
+
|
274
|
+
file = g_file_new_for_path (path);
|
275
|
+
|
276
|
+
document = lsm_mathml_document_new_from_itex_file (file, error);
|
277
|
+
|
278
|
+
g_object_unref (file);
|
279
|
+
|
280
|
+
if (document != NULL)
|
281
|
+
lsm_dom_document_set_path (LSM_DOM_DOCUMENT (document), path);
|
282
|
+
|
283
|
+
return document;
|
284
|
+
}
|
285
|
+
|
286
|
+
LsmMathmlDocument *
|
287
|
+
lsm_mathml_document_new_from_itex_url (const char *url, GError **error)
|
288
|
+
{
|
289
|
+
LsmMathmlDocument *document;
|
290
|
+
GFile *file;
|
291
|
+
|
292
|
+
g_return_val_if_fail (url != NULL, NULL);
|
293
|
+
|
294
|
+
file = g_file_new_for_uri (url);
|
295
|
+
|
296
|
+
document = lsm_mathml_document_new_from_itex_file (file, error);
|
297
|
+
|
298
|
+
g_object_unref (file);
|
299
|
+
|
300
|
+
if (document != NULL)
|
301
|
+
lsm_dom_document_set_url (LSM_DOM_DOCUMENT (document), url);
|
302
|
+
|
303
|
+
return document;
|
304
|
+
}
|
@@ -0,0 +1,61 @@
|
|
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_DOCUMENT_H
|
25
|
+
#define LSM_MATHML_DOCUMENT_H
|
26
|
+
|
27
|
+
#include <lsmmathmltypes.h>
|
28
|
+
#include <lsmdomdocument.h>
|
29
|
+
|
30
|
+
G_BEGIN_DECLS
|
31
|
+
|
32
|
+
#define LSM_TYPE_MATHML_DOCUMENT (lsm_mathml_document_get_type ())
|
33
|
+
#define LSM_MATHML_DOCUMENT(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), LSM_TYPE_MATHML_DOCUMENT, LsmMathmlDocument))
|
34
|
+
#define LSM_MATHML_DOCUMENT_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), LSM_TYPE_MATHML_DOCUMENT, LsmMathmlDocumentClass))
|
35
|
+
#define LSM_IS_MATHML_DOCUMENT(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), LSM_TYPE_MATHML_DOCUMENT))
|
36
|
+
#define LSM_IS_MATHML_DOCUMENT_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), LSM_TYPE_MATHML_DOCUMENT))
|
37
|
+
#define LSM_MATHML_DOCUMENT_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), LSM_TYPE_MATHML_DOCUMENT, LsmMathmlDocumentClass))
|
38
|
+
|
39
|
+
typedef struct _LsmMathmlDocumentClass LsmMathmlDocumentClass;
|
40
|
+
|
41
|
+
struct _LsmMathmlDocument {
|
42
|
+
LsmDomDocument document;
|
43
|
+
};
|
44
|
+
|
45
|
+
struct _LsmMathmlDocumentClass {
|
46
|
+
LsmDomDocumentClass parent_class;
|
47
|
+
};
|
48
|
+
|
49
|
+
GType lsm_mathml_document_get_type (void);
|
50
|
+
|
51
|
+
LsmDomDocument * lsm_mathml_document_new (void);
|
52
|
+
LsmMathmlMathElement * lsm_mathml_document_get_root_element (const LsmMathmlDocument *document);
|
53
|
+
|
54
|
+
LsmMathmlDocument * lsm_mathml_document_new_from_itex (const char *itex, int size, GError **error);
|
55
|
+
LsmMathmlDocument * lsm_mathml_document_new_from_itex_path (const char *url, GError **error);
|
56
|
+
LsmMathmlDocument * lsm_mathml_document_new_from_itex_url (const char *url, GError **error);
|
57
|
+
|
58
|
+
G_END_DECLS
|
59
|
+
|
60
|
+
#endif
|
61
|
+
|
@@ -0,0 +1,491 @@
|
|
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 <lsmmathmlelement.h>
|
25
|
+
#include <lsmmathmlspaceelement.h>
|
26
|
+
#include <lsmmathmloperatorelement.h>
|
27
|
+
#include <lsmmathmlview.h>
|
28
|
+
#include <lsmdebug.h>
|
29
|
+
|
30
|
+
static GObjectClass *parent_class;
|
31
|
+
|
32
|
+
static const LsmMathmlBbox null_bbox = {0.0,0.0,0.0, FALSE};
|
33
|
+
|
34
|
+
/* LsmDomNode implementation */
|
35
|
+
|
36
|
+
static gboolean
|
37
|
+
lsm_mathml_element_can_append_child (LsmDomNode *self, LsmDomNode *child)
|
38
|
+
{
|
39
|
+
return (LSM_IS_MATHML_ELEMENT (child));
|
40
|
+
}
|
41
|
+
|
42
|
+
static void
|
43
|
+
lsm_mathml_element_changed (LsmDomNode *self)
|
44
|
+
{
|
45
|
+
LsmMathmlElement *element = LSM_MATHML_ELEMENT (self);
|
46
|
+
|
47
|
+
element->need_update = TRUE;
|
48
|
+
element->need_measure = TRUE;
|
49
|
+
}
|
50
|
+
|
51
|
+
static gboolean
|
52
|
+
lsm_mathml_element_child_changed (LsmDomNode *parent, LsmDomNode *child)
|
53
|
+
{
|
54
|
+
LsmMathmlElement *element = LSM_MATHML_ELEMENT (parent);
|
55
|
+
|
56
|
+
if (element->need_children_update)
|
57
|
+
return FALSE;
|
58
|
+
|
59
|
+
element->need_children_update = TRUE;
|
60
|
+
element->need_measure = TRUE;
|
61
|
+
|
62
|
+
return TRUE;
|
63
|
+
}
|
64
|
+
|
65
|
+
/* LsmDomElement implementation */
|
66
|
+
|
67
|
+
static void
|
68
|
+
lsm_mathml_element_set_attribute (LsmDomElement *self, const char* name, const char *value)
|
69
|
+
{
|
70
|
+
LsmMathmlElementClass *m_element_class = LSM_MATHML_ELEMENT_GET_CLASS(self);
|
71
|
+
|
72
|
+
lsm_attribute_manager_set_attribute (m_element_class->attribute_manager,
|
73
|
+
self, name, value);
|
74
|
+
}
|
75
|
+
|
76
|
+
static const char *
|
77
|
+
lsm_mathml_element_get_attribute (LsmDomElement *self, const char *name)
|
78
|
+
{
|
79
|
+
LsmMathmlElementClass *m_element_class = LSM_MATHML_ELEMENT_GET_CLASS(self);
|
80
|
+
|
81
|
+
return lsm_attribute_manager_get_attribute (m_element_class->attribute_manager,
|
82
|
+
self, name);
|
83
|
+
}
|
84
|
+
|
85
|
+
static char *
|
86
|
+
lsm_mathml_element_get_serialized_attributes (LsmDomElement *self)
|
87
|
+
{
|
88
|
+
LsmMathmlElementClass *m_element_class = LSM_MATHML_ELEMENT_GET_CLASS(self);
|
89
|
+
|
90
|
+
return lsm_attribute_manager_serialize (m_element_class->attribute_manager, self);
|
91
|
+
}
|
92
|
+
|
93
|
+
/* LsmMathmlElement implementation */
|
94
|
+
|
95
|
+
static gboolean
|
96
|
+
_update_children (LsmMathmlElement *self, LsmMathmlStyle *style)
|
97
|
+
{
|
98
|
+
LsmDomNode *node;
|
99
|
+
gboolean need_measure = FALSE;
|
100
|
+
|
101
|
+
for (node = LSM_DOM_NODE (self)->first_child; node != NULL; node = node->next_sibling)
|
102
|
+
if (LSM_IS_MATHML_ELEMENT (node))
|
103
|
+
if (lsm_mathml_element_update (LSM_MATHML_ELEMENT (node), style))
|
104
|
+
need_measure = TRUE;
|
105
|
+
|
106
|
+
return need_measure;
|
107
|
+
}
|
108
|
+
|
109
|
+
/**
|
110
|
+
* lsm_mathml_element_update:
|
111
|
+
* @self: a #LsmMathmlElement
|
112
|
+
* @parent_style: self parent style
|
113
|
+
*
|
114
|
+
* Update the actual property of an element and it's children. This function parses the element attributes and also make elements inherit style from their parents.
|
115
|
+
*
|
116
|
+
* Returns: TRUE if the size of the element has changed and needs to be recalculated.
|
117
|
+
*/
|
118
|
+
|
119
|
+
gboolean
|
120
|
+
lsm_mathml_element_update (LsmMathmlElement *self, const LsmMathmlStyle *parent_style)
|
121
|
+
{
|
122
|
+
LsmMathmlElementClass *element_class;
|
123
|
+
LsmMathmlStyle *style;
|
124
|
+
gboolean need_measure;
|
125
|
+
|
126
|
+
g_return_val_if_fail (LSM_IS_MATHML_ELEMENT (self), FALSE);
|
127
|
+
g_return_val_if_fail (parent_style != NULL, FALSE);
|
128
|
+
|
129
|
+
if (!self->need_update && !self->need_children_update) {
|
130
|
+
lsm_debug_update ("[Element::update] %s already up to date",
|
131
|
+
lsm_dom_node_get_node_name (LSM_DOM_NODE (self)));
|
132
|
+
return FALSE;
|
133
|
+
}
|
134
|
+
|
135
|
+
element_class = LSM_MATHML_ELEMENT_GET_CLASS (self);
|
136
|
+
|
137
|
+
style = lsm_mathml_style_duplicate (parent_style);
|
138
|
+
g_return_val_if_fail (style != NULL, FALSE);
|
139
|
+
|
140
|
+
if (element_class->update != NULL)
|
141
|
+
element_class->update (self, style);
|
142
|
+
|
143
|
+
lsm_debug_update ("[Element::update] update %s (%s-%g)",
|
144
|
+
lsm_dom_node_get_node_name (LSM_DOM_NODE (self)),
|
145
|
+
style->math_family != NULL ? style->math_family : "undefined" ,
|
146
|
+
style->math_size);
|
147
|
+
|
148
|
+
g_free (self->style.math_family);
|
149
|
+
self->style.math_family = g_strdup (style->math_family);
|
150
|
+
self->style.math_variant = style->math_variant;
|
151
|
+
self->style.math_size = style->math_size;
|
152
|
+
self->style.math_color = style->math_color;
|
153
|
+
self->style.math_background = style->math_background;
|
154
|
+
|
155
|
+
if (self->need_update) {
|
156
|
+
LsmDomNode *node;
|
157
|
+
|
158
|
+
for (node = LSM_DOM_NODE (self)->first_child; node != NULL; node = node->next_sibling)
|
159
|
+
if (LSM_IS_MATHML_ELEMENT (node))
|
160
|
+
LSM_MATHML_ELEMENT (node)->need_update = TRUE;
|
161
|
+
}
|
162
|
+
|
163
|
+
if (element_class->update_children != NULL)
|
164
|
+
need_measure = element_class->update_children (self, style);
|
165
|
+
else
|
166
|
+
need_measure = FALSE;
|
167
|
+
|
168
|
+
lsm_mathml_style_free (style);
|
169
|
+
|
170
|
+
self->need_measure = need_measure || self->need_update;
|
171
|
+
|
172
|
+
self->need_update = FALSE;
|
173
|
+
self->need_children_update = FALSE;
|
174
|
+
|
175
|
+
return self->need_measure;
|
176
|
+
}
|
177
|
+
|
178
|
+
/* Inferred mrow implementation */
|
179
|
+
|
180
|
+
static const LsmMathmlBbox *
|
181
|
+
_measure (LsmMathmlElement *self, LsmMathmlView *view, const LsmMathmlBbox *bbox)
|
182
|
+
{
|
183
|
+
const LsmMathmlOperatorElement *operator;
|
184
|
+
LsmDomNode *node;
|
185
|
+
LsmMathmlBbox child_bbox;
|
186
|
+
LsmMathmlBbox stretch_bbox;
|
187
|
+
gboolean stretchy_found = FALSE;
|
188
|
+
unsigned int n_elements = 0;
|
189
|
+
|
190
|
+
self->bbox = lsm_mathml_bbox_null;
|
191
|
+
|
192
|
+
stretch_bbox = *bbox;
|
193
|
+
|
194
|
+
for (node = LSM_DOM_NODE (self)->first_child; node != NULL; node = node->next_sibling) {
|
195
|
+
if (LSM_IS_MATHML_ELEMENT (node)) {
|
196
|
+
operator = lsm_mathml_element_get_embellished_core (LSM_MATHML_ELEMENT (node));
|
197
|
+
if (operator != NULL && operator->stretchy.value) {
|
198
|
+
stretchy_found = TRUE;
|
199
|
+
child_bbox = *lsm_mathml_element_measure (LSM_MATHML_ELEMENT (operator), view,
|
200
|
+
&lsm_mathml_bbox_null);
|
201
|
+
lsm_mathml_bbox_stretch_vertically (&stretch_bbox, &child_bbox);
|
202
|
+
} else {
|
203
|
+
child_bbox = *lsm_mathml_element_measure (LSM_MATHML_ELEMENT (node), view,
|
204
|
+
&lsm_mathml_bbox_null);
|
205
|
+
if (operator != NULL)
|
206
|
+
child_bbox.width += operator->left_space.value + operator->right_space.value;
|
207
|
+
lsm_mathml_bbox_add_horizontally (&self->bbox, &child_bbox);
|
208
|
+
lsm_mathml_bbox_stretch_vertically (&stretch_bbox, &child_bbox);
|
209
|
+
}
|
210
|
+
n_elements++;
|
211
|
+
}
|
212
|
+
}
|
213
|
+
|
214
|
+
if (stretchy_found) {
|
215
|
+
lsm_debug_measure ("[Element::_measure] Stretchy found (width = %g, height = %g, depth = %g)",
|
216
|
+
stretch_bbox.width, stretch_bbox.height, stretch_bbox.depth);
|
217
|
+
|
218
|
+
for (node = LSM_DOM_NODE (self)->first_child; node != NULL; node = node->next_sibling) {
|
219
|
+
if (LSM_IS_MATHML_ELEMENT (node)) {
|
220
|
+
operator = lsm_mathml_element_get_embellished_core (LSM_MATHML_ELEMENT (node));
|
221
|
+
if (operator != NULL && operator->stretchy.value) {
|
222
|
+
child_bbox = *lsm_mathml_element_measure (LSM_MATHML_ELEMENT (node), view,
|
223
|
+
&stretch_bbox);
|
224
|
+
child_bbox.width += operator->left_space.value + operator->right_space.value;
|
225
|
+
lsm_mathml_bbox_add_horizontally (&self->bbox, &child_bbox);
|
226
|
+
}
|
227
|
+
}
|
228
|
+
}
|
229
|
+
}
|
230
|
+
|
231
|
+
return &self->bbox;
|
232
|
+
}
|
233
|
+
|
234
|
+
const LsmMathmlBbox *
|
235
|
+
lsm_mathml_element_measure (LsmMathmlElement *element, LsmMathmlView *view, const LsmMathmlBbox *stretch_bbox)
|
236
|
+
{
|
237
|
+
LsmMathmlElementClass *element_class;
|
238
|
+
|
239
|
+
g_return_val_if_fail (LSM_IS_MATHML_ELEMENT (element), &null_bbox);
|
240
|
+
|
241
|
+
element_class = LSM_MATHML_ELEMENT_GET_CLASS (element);
|
242
|
+
|
243
|
+
g_return_val_if_fail (element_class != NULL, &null_bbox);
|
244
|
+
|
245
|
+
if (stretch_bbox == NULL)
|
246
|
+
stretch_bbox = &lsm_mathml_bbox_null;
|
247
|
+
|
248
|
+
if (element->need_measure || stretch_bbox->is_defined) {
|
249
|
+
if (element_class->measure) {
|
250
|
+
element->bbox = *(element_class->measure (element, view, stretch_bbox));
|
251
|
+
|
252
|
+
lsm_debug_measure ("[Element::measure] Bbox (%s) %g, %g, %g",
|
253
|
+
lsm_dom_node_get_node_name (LSM_DOM_NODE (element)),
|
254
|
+
element->bbox.width, element->bbox.height, element->bbox.depth);
|
255
|
+
} else {
|
256
|
+
|
257
|
+
lsm_debug_measure ("[Element::measure] method not defined");
|
258
|
+
element->bbox.width = 0.0;
|
259
|
+
element->bbox.height = 0.0;
|
260
|
+
element->bbox.depth = 0.0;
|
261
|
+
}
|
262
|
+
|
263
|
+
element->need_measure = FALSE;
|
264
|
+
element->need_layout = TRUE;
|
265
|
+
} else
|
266
|
+
lsm_debug_measure ("[Element::measure] %s already up to date",
|
267
|
+
lsm_dom_node_get_node_name (LSM_DOM_NODE (element)));
|
268
|
+
|
269
|
+
return &element->bbox;
|
270
|
+
}
|
271
|
+
|
272
|
+
/* Inferred mrow implementation */
|
273
|
+
|
274
|
+
static void
|
275
|
+
_layout (LsmMathmlElement *self, LsmMathmlView *view,
|
276
|
+
double x, double y, const LsmMathmlBbox *bbox)
|
277
|
+
{
|
278
|
+
const LsmMathmlOperatorElement *operator;
|
279
|
+
LsmDomNode *node;
|
280
|
+
LsmMathmlBbox child_bbox;
|
281
|
+
double offset;
|
282
|
+
|
283
|
+
for (node = LSM_DOM_NODE (self)->first_child; node != NULL; node = node->next_sibling)
|
284
|
+
if (LSM_IS_MATHML_ELEMENT (node)) {
|
285
|
+
child_bbox = *lsm_mathml_element_get_bbox (LSM_MATHML_ELEMENT (node));
|
286
|
+
operator = lsm_mathml_element_get_embellished_core (LSM_MATHML_ELEMENT (node));
|
287
|
+
if (operator != NULL)
|
288
|
+
offset = operator->left_space.value;
|
289
|
+
else
|
290
|
+
offset = 0.0;
|
291
|
+
lsm_mathml_element_layout (LSM_MATHML_ELEMENT (node), view, x + offset, y, &child_bbox);
|
292
|
+
if (operator != NULL)
|
293
|
+
child_bbox.width += offset + operator->right_space.value;
|
294
|
+
x += child_bbox.width;
|
295
|
+
}
|
296
|
+
}
|
297
|
+
|
298
|
+
void
|
299
|
+
lsm_mathml_element_layout (LsmMathmlElement *self, LsmMathmlView *view,
|
300
|
+
double x, double y, const LsmMathmlBbox *bbox)
|
301
|
+
{
|
302
|
+
LsmMathmlElementClass *element_class;
|
303
|
+
|
304
|
+
g_return_if_fail (LSM_IS_MATHML_ELEMENT (self));
|
305
|
+
|
306
|
+
element_class = LSM_MATHML_ELEMENT_GET_CLASS (self);
|
307
|
+
|
308
|
+
g_return_if_fail (element_class != NULL);
|
309
|
+
|
310
|
+
lsm_debug_measure ("[Element::layout] assigned bbox for %s = %g, %g, %g at %g, %g",
|
311
|
+
lsm_dom_node_get_node_name (LSM_DOM_NODE (self)), bbox->width, bbox->height, bbox->depth, x , y);
|
312
|
+
|
313
|
+
self->x = x;
|
314
|
+
self->y = y;
|
315
|
+
|
316
|
+
if (element_class->layout)
|
317
|
+
element_class->layout (self, view, x, y, bbox);
|
318
|
+
|
319
|
+
self->need_layout = FALSE;
|
320
|
+
}
|
321
|
+
|
322
|
+
/* Inferred mrow implementation */
|
323
|
+
|
324
|
+
static void
|
325
|
+
_render (LsmMathmlElement *element, LsmMathmlView *view)
|
326
|
+
{
|
327
|
+
LsmDomNode *node;
|
328
|
+
|
329
|
+
for (node = LSM_DOM_NODE (element)->first_child; node != NULL; node = node->next_sibling)
|
330
|
+
if (LSM_IS_MATHML_ELEMENT (node))
|
331
|
+
lsm_mathml_element_render (LSM_MATHML_ELEMENT (node), view);
|
332
|
+
}
|
333
|
+
|
334
|
+
void
|
335
|
+
lsm_mathml_element_render (LsmMathmlElement *element, LsmMathmlView *view)
|
336
|
+
{
|
337
|
+
LsmMathmlElementClass *element_class;
|
338
|
+
|
339
|
+
g_return_if_fail (LSM_IS_MATHML_ELEMENT (element));
|
340
|
+
element_class = LSM_MATHML_ELEMENT_GET_CLASS (element);
|
341
|
+
g_return_if_fail (element_class != NULL);
|
342
|
+
|
343
|
+
if (element_class->render) {
|
344
|
+
lsm_mathml_view_show_bbox (view, element->x, element->y, &element->bbox);
|
345
|
+
lsm_mathml_view_show_background (view, &element->style,
|
346
|
+
element->x, element->y,
|
347
|
+
&element->bbox);
|
348
|
+
element_class->render (element, view);
|
349
|
+
}
|
350
|
+
}
|
351
|
+
|
352
|
+
/* Inferred mrow implementation */
|
353
|
+
|
354
|
+
static LsmMathmlOperatorElement *
|
355
|
+
_get_embellished_core (const LsmMathmlElement *self)
|
356
|
+
{
|
357
|
+
LsmDomNode *node;
|
358
|
+
LsmMathmlOperatorElement *core = NULL;
|
359
|
+
|
360
|
+
g_assert (LSM_IS_MATHML_ELEMENT (self));
|
361
|
+
|
362
|
+
for (node = LSM_DOM_NODE (self)->first_child; node != NULL; node = node->next_sibling) {
|
363
|
+
if (LSM_IS_MATHML_ELEMENT (node)) {
|
364
|
+
if (!LSM_IS_MATHML_SPACE_ELEMENT (node)) {
|
365
|
+
if (core != NULL)
|
366
|
+
return NULL;
|
367
|
+
core = lsm_mathml_element_get_embellished_core (LSM_MATHML_ELEMENT (node));
|
368
|
+
}
|
369
|
+
} else
|
370
|
+
if (core != NULL)
|
371
|
+
return NULL;
|
372
|
+
}
|
373
|
+
|
374
|
+
return core;
|
375
|
+
}
|
376
|
+
|
377
|
+
LsmMathmlOperatorElement *
|
378
|
+
lsm_mathml_element_get_embellished_core (const LsmMathmlElement *self)
|
379
|
+
{
|
380
|
+
LsmMathmlElementClass *element_class;
|
381
|
+
|
382
|
+
g_return_val_if_fail (LSM_IS_MATHML_ELEMENT (self), NULL);
|
383
|
+
|
384
|
+
element_class = LSM_MATHML_ELEMENT_GET_CLASS (self);
|
385
|
+
|
386
|
+
if (element_class->get_embellished_core != NULL)
|
387
|
+
return element_class->get_embellished_core (self);
|
388
|
+
|
389
|
+
return NULL;
|
390
|
+
}
|
391
|
+
|
392
|
+
const LsmMathmlBbox *
|
393
|
+
lsm_mathml_element_get_bbox (const LsmMathmlElement *self)
|
394
|
+
{
|
395
|
+
g_return_val_if_fail (LSM_IS_MATHML_ELEMENT (self), &lsm_mathml_bbox_null);
|
396
|
+
|
397
|
+
return &self->bbox;
|
398
|
+
}
|
399
|
+
|
400
|
+
static gboolean
|
401
|
+
_is_inferred_row (const LsmMathmlElement *self)
|
402
|
+
{
|
403
|
+
return TRUE;
|
404
|
+
}
|
405
|
+
|
406
|
+
gboolean
|
407
|
+
lsm_mathml_element_is_inferred_row (const LsmMathmlElement *self)
|
408
|
+
{
|
409
|
+
LsmMathmlElementClass *element_class;
|
410
|
+
|
411
|
+
g_return_val_if_fail (LSM_IS_MATHML_ELEMENT (self), FALSE);
|
412
|
+
|
413
|
+
element_class = LSM_MATHML_ELEMENT_GET_CLASS (self);
|
414
|
+
|
415
|
+
if (element_class->is_inferred_row != NULL)
|
416
|
+
return element_class->is_inferred_row (self);
|
417
|
+
|
418
|
+
return FALSE;
|
419
|
+
}
|
420
|
+
|
421
|
+
static void
|
422
|
+
lsm_mathml_element_init (LsmMathmlElement *element)
|
423
|
+
{
|
424
|
+
element->need_update = TRUE;
|
425
|
+
element->need_measure = TRUE;
|
426
|
+
}
|
427
|
+
|
428
|
+
static void
|
429
|
+
lsm_mathml_element_finalize (GObject *object)
|
430
|
+
{
|
431
|
+
LsmMathmlElementClass *m_element_class = LSM_MATHML_ELEMENT_GET_CLASS (object);
|
432
|
+
LsmMathmlElement *m_element = LSM_MATHML_ELEMENT (object);
|
433
|
+
|
434
|
+
g_free (m_element->style.math_family);
|
435
|
+
|
436
|
+
lsm_attribute_manager_clean_attributes (m_element_class->attribute_manager, m_element);
|
437
|
+
|
438
|
+
parent_class->finalize (object);
|
439
|
+
}
|
440
|
+
|
441
|
+
/* LsmMathmlElement class */
|
442
|
+
|
443
|
+
static const LsmAttributeInfos lsm_svg_attribute_infos[] = {
|
444
|
+
{
|
445
|
+
.name = "id",
|
446
|
+
.trait_class = &lsm_null_trait_class,
|
447
|
+
.attribute_offset = offsetof (LsmMathmlElement, id)
|
448
|
+
},
|
449
|
+
{
|
450
|
+
.name = "class",
|
451
|
+
.trait_class = &lsm_null_trait_class,
|
452
|
+
.attribute_offset = offsetof (LsmMathmlElement, class_name)
|
453
|
+
},
|
454
|
+
{
|
455
|
+
.name = "href",
|
456
|
+
.trait_class = &lsm_null_trait_class,
|
457
|
+
.attribute_offset = offsetof (LsmMathmlElement, href)
|
458
|
+
}
|
459
|
+
};
|
460
|
+
|
461
|
+
static void
|
462
|
+
lsm_mathml_element_class_init (LsmMathmlElementClass *m_element_class)
|
463
|
+
{
|
464
|
+
GObjectClass *object_class = G_OBJECT_CLASS (m_element_class);
|
465
|
+
LsmDomNodeClass *d_node_class = LSM_DOM_NODE_CLASS (m_element_class);
|
466
|
+
LsmDomElementClass *d_element_class = LSM_DOM_ELEMENT_CLASS (m_element_class);
|
467
|
+
|
468
|
+
parent_class = g_type_class_peek_parent (m_element_class);
|
469
|
+
|
470
|
+
object_class->finalize = lsm_mathml_element_finalize;
|
471
|
+
|
472
|
+
d_node_class->can_append_child = lsm_mathml_element_can_append_child;
|
473
|
+
d_node_class->changed = lsm_mathml_element_changed;
|
474
|
+
d_node_class->child_changed = lsm_mathml_element_child_changed;
|
475
|
+
|
476
|
+
d_element_class->get_attribute = lsm_mathml_element_get_attribute;
|
477
|
+
d_element_class->set_attribute = lsm_mathml_element_set_attribute;
|
478
|
+
d_element_class->get_serialized_attributes = lsm_mathml_element_get_serialized_attributes;
|
479
|
+
|
480
|
+
m_element_class->update = NULL;
|
481
|
+
m_element_class->update_children = _update_children;
|
482
|
+
m_element_class->measure = _measure;
|
483
|
+
m_element_class->layout = _layout;
|
484
|
+
m_element_class->render = _render;
|
485
|
+
m_element_class->get_embellished_core = _get_embellished_core;
|
486
|
+
m_element_class->is_inferred_row = _is_inferred_row;
|
487
|
+
m_element_class->attribute_manager = lsm_attribute_manager_new (G_N_ELEMENTS (lsm_svg_attribute_infos),
|
488
|
+
lsm_svg_attribute_infos);
|
489
|
+
}
|
490
|
+
|
491
|
+
G_DEFINE_ABSTRACT_TYPE (LsmMathmlElement, lsm_mathml_element, LSM_TYPE_DOM_ELEMENT)
|