LibreOffice Module starmath (master) 1
ooxmlimport.cxx
Go to the documentation of this file.
1/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2/*
3 * This file is part of the LibreOffice project.
4 *
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8 */
9
10#include <sal/config.h>
11
12#include <string_view>
13
14#include "ooxmlimport.hxx"
15#include <types.hxx>
16
18#include <oox/token/namespaces.hxx>
19#include <rtl/ustring.hxx>
20#include <rtl/ustrbuf.hxx>
21#include <sal/log.hxx>
22#include <o3tl/string_view.hxx>
23
24using namespace oox::formulaimport;
25
26/*
27The primary internal data structure for the formula is the text representation
28(the SmNode tree is built from it), so read data must be converted into this format.
29*/
30
31#define OPENING( token ) XML_STREAM_OPENING( token )
32#define CLOSING( token ) XML_STREAM_CLOSING( token )
33
34// TODO create IS_OPENING(), IS_CLOSING() instead of doing 'next == OPENING( next )' ?
35
37 : m_rStream( s )
38{
39}
40
42{
43 return handleStream();
44}
45
46// "toplevel" of reading, there will be oMath (if there was oMathPara, that was
47// up to the parent component to handle)
48
49// NOT complete
51{
52 m_rStream.ensureOpeningTag( M_TOKEN( oMath ));
53 OUStringBuffer ret;
54 while( !m_rStream.atEnd() && m_rStream.currentToken() != CLOSING( M_TOKEN( oMath )))
55 {
56 // strictly speaking, it is not OMathArg here, but currently supported
57 // functionality is the same like OMathArg, in the future this may need improving
58 OUString item = readOMathArg( M_TOKEN( oMath ));
59 if( item.isEmpty())
60 continue;
61 if( !ret.isEmpty())
62 ret.append(" ");
63 ret.append(item);
64 }
65 m_rStream.ensureClosingTag( M_TOKEN( oMath ));
66 // Placeholders are written out as nothing (i.e. nothing inside e.g. the <e> element),
67 // which will result in "{}" in the formula text. Fix this up.
68 OUString ret2 = ret.makeStringAndClear().replaceAll( "{}", "<?>" );
69 // And as a result, empty parts of the formula that are not placeholders are written out
70 // as a single space, so fix that up too.
71 ret2 = ret2.replaceAll( "{ }", "{}" );
72 SAL_INFO( "starmath.ooxml", "Formula: " << ret2 );
73 return ret2;
74}
75
76OUString SmOoxmlImport::readOMathArg( int stoptoken )
77{
78 OUStringBuffer ret;
79 while( !m_rStream.atEnd() && m_rStream.currentToken() != CLOSING( stoptoken ))
80 {
81 if( !ret.isEmpty())
82 ret.append(" ");
83 switch( m_rStream.currentToken())
84 {
85 case OPENING( M_TOKEN( acc )):
86 ret.append(handleAcc());
87 break;
88 case OPENING( M_TOKEN( bar )):
89 ret.append(handleBar());
90 break;
91 case OPENING( M_TOKEN( box )):
92 ret.append(handleBox());
93 break;
94 case OPENING( M_TOKEN( borderBox )):
95 ret.append(handleBorderBox());
96 break;
97 case OPENING( M_TOKEN( d )):
98 ret.append(handleD());
99 break;
100 case OPENING( M_TOKEN( eqArr )):
101 ret.append(handleEqArr());
102 break;
103 case OPENING( M_TOKEN( f )):
104 ret.append(handleF());
105 break;
106 case OPENING( M_TOKEN( func )):
107 ret.append(handleFunc());
108 break;
109 case OPENING( M_TOKEN( limLow )):
110 ret.append(handleLimLowUpp( LimLow ));
111 break;
112 case OPENING( M_TOKEN( limUpp )):
113 ret.append(handleLimLowUpp( LimUpp ));
114 break;
115 case OPENING( M_TOKEN( groupChr )):
116 ret.append(handleGroupChr());
117 break;
118 case OPENING( M_TOKEN( m )):
119 ret.append(handleM());
120 break;
121 case OPENING( M_TOKEN( nary )):
122 ret.append(handleNary());
123 break;
124 case OPENING( M_TOKEN( r )):
125 ret.append(handleR());
126 break;
127 case OPENING( M_TOKEN( rad )):
128 ret.append(handleRad());
129 break;
130 case OPENING( M_TOKEN( sPre )):
131 ret.append(handleSpre());
132 break;
133 case OPENING( M_TOKEN( sSub )):
134 ret.append(handleSsub());
135 break;
136 case OPENING( M_TOKEN( sSubSup )):
137 ret.append(handleSsubsup());
138 break;
139 case OPENING( M_TOKEN( sSup )):
140 ret.append(handleSsup());
141 break;
142 default:
144 break;
145 }
146 }
147 return ret.makeStringAndClear();
148}
149
151{
153 OUString ret = readOMathArg( token );
155 return ret;
156}
157
159{
160 m_rStream.ensureOpeningTag( M_TOKEN( acc ));
161 sal_Unicode accChr = 0x302;
162 if( XmlStream::Tag accPr = m_rStream.checkOpeningTag( M_TOKEN( accPr )))
163 {
164 if( XmlStream::Tag chr = m_rStream.checkOpeningTag( M_TOKEN( chr )))
165 {
166 accChr = chr.attribute( M_TOKEN( val ), accChr );
167 m_rStream.ensureClosingTag( M_TOKEN( chr ));
168 }
169 m_rStream.ensureClosingTag( M_TOKEN( accPr ));
170 }
171 // see aTokenTable in parse.cxx
172 OUString acc;
173 switch( accChr )
174 {
175 case MS_BAR:
176 case MS_COMBBAR:
177 acc = "bar";
178 break;
179 case MS_CHECK:
180 case MS_COMBCHECK:
181 acc = "check";
182 break;
183 case MS_ACUTE:
184 case MS_COMBACUTE:
185 acc = "acute";
186 break;
187 case MS_COMBOVERLINE:
188 acc = "overline";
189 break;
190 case MS_GRAVE:
191 case MS_COMBGRAVE:
192 acc = "grave";
193 break;
194 case MS_BREVE:
195 case MS_COMBBREVE:
196 acc = "breve";
197 break;
198 case MS_CIRCLE:
199 case MS_COMBCIRCLE:
200 acc = "circle";
201 break;
202 case MS_RIGHTARROW:
203 case MS_VEC:
204 // prefer wide variants for these 3, .docx can't seem to differentiate
205 // between e.g. 'vec' and 'widevec', if whatever the accent is above is short, this
206 // shouldn't matter, but short above a longer expression doesn't look right
207 acc = "widevec";
208 break;
209 case MS_HARPOON:
210 acc = "wideharpoon";
211 break;
212 case MS_TILDE:
213 case MS_COMBTILDE:
214 acc = "widetilde";
215 break;
216 case MS_HAT:
217 case MS_COMBHAT:
218 acc = "widehat";
219 break;
220 case MS_DOT:
221 case MS_COMBDOT:
222 acc = "dot";
223 break;
224 case MS_DDOT:
225 case MS_COMBDDOT:
226 acc = "ddot";
227 break;
228 case MS_DDDOT:
229 acc = "dddot";
230 break;
231 default:
232 acc = "acute";
233 SAL_WARN( "starmath.ooxml", "Unknown m:chr in m:acc \'" << OUString(accChr) << "\'" );
234 break;
235 }
236 OUString e = readOMathArgInElement( M_TOKEN( e ));
237 m_rStream.ensureClosingTag( M_TOKEN( acc ));
238 return acc + " {" + e + "}";
239}
240
242{
243 m_rStream.ensureOpeningTag( M_TOKEN( bar ));
244 enum pos_t { top, bot } topbot = bot;
245 if( m_rStream.checkOpeningTag( M_TOKEN( barPr )))
246 {
248 {
249 if( pos.attribute( M_TOKEN( val )) == "top" )
250 topbot = top;
251 else if( pos.attribute( M_TOKEN( val )) == "bot" )
252 topbot = bot;
253 m_rStream.ensureClosingTag( M_TOKEN( pos ));
254 }
255 m_rStream.ensureClosingTag( M_TOKEN( barPr ));
256 }
257 OUString e = readOMathArgInElement( M_TOKEN( e ));
258 m_rStream.ensureClosingTag( M_TOKEN( bar ));
259 if( topbot == top )
260 return "overline {" + e + "}";
261 else
262 return "underline {" + e + "}";
263}
264
266{
267 // there does not seem to be functionality in LO to actually implement this
268 // (or is there), but at least read in the contents instead of ignoring them
269 m_rStream.ensureOpeningTag( M_TOKEN( box ));
270 OUString e = readOMathArgInElement( M_TOKEN( e ));
271 m_rStream.ensureClosingTag( M_TOKEN( box ));
272 return e;
273}
274
275
277{
278 m_rStream.ensureOpeningTag( M_TOKEN( borderBox ));
279 bool isStrikeH = false;
280 if( m_rStream.checkOpeningTag( M_TOKEN( borderBoxPr )))
281 {
282 if( XmlStream::Tag strikeH = m_rStream.checkOpeningTag( M_TOKEN( strikeH )))
283 {
284 if( strikeH.attribute( M_TOKEN( val ), false ))
285 isStrikeH = true;
286 m_rStream.ensureClosingTag( M_TOKEN( strikeH ));
287 }
288 m_rStream.ensureClosingTag( M_TOKEN( borderBoxPr ));
289 }
290 OUString e = readOMathArgInElement( M_TOKEN( e ));
291 m_rStream.ensureClosingTag( M_TOKEN( borderBox ));
292 if( isStrikeH )
293 return "overstrike {" + e + "}";
294 // LO does not seem to implement anything for handling the other cases
295 return e;
296}
297
299{
300 m_rStream.ensureOpeningTag( M_TOKEN( d ));
301 OUString opening = "(";
302 OUString closing = ")";
303 OUString separator = "|";
304 if( XmlStream::Tag dPr = m_rStream.checkOpeningTag( M_TOKEN( dPr )))
305 {
306 if( XmlStream::Tag begChr = m_rStream.checkOpeningTag( M_TOKEN( begChr )))
307 {
308 opening = begChr.attribute( M_TOKEN( val ), opening );
309 m_rStream.ensureClosingTag( M_TOKEN( begChr ));
310 }
311 if( XmlStream::Tag sepChr = m_rStream.checkOpeningTag( M_TOKEN( sepChr )))
312 {
313 separator = sepChr.attribute( M_TOKEN( val ), separator );
314 m_rStream.ensureClosingTag( M_TOKEN( sepChr ));
315 }
316 if( XmlStream::Tag endChr = m_rStream.checkOpeningTag( M_TOKEN( endChr )))
317 {
318 closing = endChr.attribute( M_TOKEN( val ), closing );
319 m_rStream.ensureClosingTag( M_TOKEN( endChr ));
320 }
321 m_rStream.ensureClosingTag( M_TOKEN( dPr ));
322 }
323 if( opening == "{" )
324 opening = "left lbrace ";
325 if( closing == "}" )
326 closing = " right rbrace";
327 if( opening == u"\u27e6" )
328 opening = "left ldbracket ";
329 if( closing == u"\u27e7" )
330 closing = " right rdbracket";
331 if( opening == "|" )
332 opening = "left lline ";
333 if( closing == "|" )
334 closing = " right rline";
335 if (opening == OUStringChar(MS_DLINE)
336 || opening == OUStringChar(MS_DVERTLINE))
337 opening = "left ldline ";
338 if (closing == OUStringChar(MS_DLINE)
339 || closing == OUStringChar(MS_DVERTLINE))
340 closing = " right rdline";
341 if (opening == OUStringChar(MS_LANGLE)
342 || opening == OUStringChar(MS_LMATHANGLE))
343 opening = "left langle ";
344 if (closing == OUStringChar(MS_RANGLE)
345 || closing == OUStringChar(MS_RMATHANGLE))
346 closing = " right rangle";
347 // use scalable brackets (the explicit "left" or "right")
348 if( opening == "(" || opening == "[" )
349 opening = "left " + opening;
350 if( closing == ")" || closing == "]" )
351 closing = " right " + closing;
352 if( separator == "|" ) // plain "|" would be actually "V" (logical or)
353 separator = " mline ";
354 if( opening.isEmpty())
355 opening = "left none ";
356 if( closing.isEmpty())
357 closing = " right none";
358 OUStringBuffer ret( opening );
359 bool first = true;
360 while( m_rStream.findTag( OPENING( M_TOKEN( e ))))
361 {
362 if( !first )
363 ret.append( separator );
364 first = false;
365 ret.append( readOMathArgInElement( M_TOKEN( e )));
366 }
367 ret.append( closing );
368 m_rStream.ensureClosingTag( M_TOKEN( d ));
369 return ret.makeStringAndClear();
370}
371
373{
374 m_rStream.ensureOpeningTag( M_TOKEN( eqArr ));
375 OUStringBuffer ret;
376 do
377 { // there must be at least one m:e
378 if( !ret.isEmpty())
379 ret.append("#");
380 ret.append(" "
381 + readOMathArgInElement( M_TOKEN( e ))
382 + " ");
383 } while( !m_rStream.atEnd() && m_rStream.findTag( OPENING( M_TOKEN( e ))));
384 m_rStream.ensureClosingTag( M_TOKEN( eqArr ));
385 return "stack {" + ret + "}";
386}
387
389{
390 m_rStream.ensureOpeningTag( M_TOKEN( f ));
391 enum operation_t { bar, lin, noBar } operation = bar;
392 if( m_rStream.checkOpeningTag( M_TOKEN( fPr )))
393 {
395 {
396 if( type.attribute( M_TOKEN( val )) == "bar" )
397 operation = bar;
398 else if( type.attribute( M_TOKEN( val )) == "lin" )
399 operation = lin;
400 else if( type.attribute( M_TOKEN( val )) == "noBar" )
401 operation = noBar;
402 m_rStream.ensureClosingTag( M_TOKEN( type ));
403 }
404 m_rStream.ensureClosingTag( M_TOKEN( fPr ));
405 }
406 OUString num = readOMathArgInElement( M_TOKEN( num ));
407 OUString den = readOMathArgInElement( M_TOKEN( den ));
408 m_rStream.ensureClosingTag( M_TOKEN( f ));
409 if( operation == bar )
410 return "{" + num + "} over {" + den + "}";
411 else if( operation == lin )
412 return "{" + num + "} / {" + den + "}";
413 else // noBar
414 {
415 return "binom {" + num + "} {" + den + "}";
416 }
417}
418
420{
421//lim from{x rightarrow 1} x
422 m_rStream.ensureOpeningTag( M_TOKEN( func ));
423 OUString fname = readOMathArgInElement( M_TOKEN( fName ));
424 // fix the various functions
425 if( fname.startsWith( "lim csub {" ))
426 fname = OUString::Concat("lim from {") + fname.subView( 10 );
427 OUString ret = fname + " {" + readOMathArgInElement( M_TOKEN( e )) + "}";
428 m_rStream.ensureClosingTag( M_TOKEN( func ));
429 return ret;
430}
431
433{
434 int token = limlowupp == LimLow ? M_TOKEN( limLow ) : M_TOKEN( limUpp );
436 OUString e = readOMathArgInElement( M_TOKEN( e ));
437 OUString lim = readOMathArgInElement( M_TOKEN( lim ));
439 // fix up overbrace/underbrace (use { }, as {} will be converted to a placeholder)
440 if( limlowupp == LimUpp && e.endsWith( " overbrace { }" ))
441 return e.subView( 0, e.getLength() - 2 ) + lim + "}";
442 if( limlowupp == LimLow && e.endsWith( " underbrace { }" ))
443 return e.subView( 0, e.getLength() - 2 ) + lim + "}";
444 return e
445 + ( limlowupp == LimLow
446 ? std::u16string_view( u" csub {" ) : std::u16string_view( u" csup {" ))
447 + lim + "}";
448}
449
451{
452 m_rStream.ensureOpeningTag( M_TOKEN( groupChr ));
453 sal_Unicode chr = 0x23df;
454 enum pos_t { top, bot } pos = bot;
455 if( m_rStream.checkOpeningTag( M_TOKEN( groupChrPr )))
456 {
457 if( XmlStream::Tag chrTag = m_rStream.checkOpeningTag( M_TOKEN( chr )))
458 {
459 chr = chrTag.attribute( M_TOKEN( val ), chr );
460 m_rStream.ensureClosingTag( M_TOKEN( chr ));
461 }
462 if( XmlStream::Tag posTag = m_rStream.checkOpeningTag( M_TOKEN( pos )))
463 {
464 if( posTag.attribute( M_TOKEN( val ), OUString( "bot" )) == "top" )
465 pos = top;
466 m_rStream.ensureClosingTag( M_TOKEN( pos ));
467 }
468 m_rStream.ensureClosingTag( M_TOKEN( groupChrPr ));
469 }
470 OUString e = readOMathArgInElement( M_TOKEN( e ));
471 m_rStream.ensureClosingTag( M_TOKEN( groupChr ));
472 if( pos == top && chr == u'\x23de')
473 return "{" + e + "} overbrace { }";
474 if( pos == bot && chr == u'\x23df')
475 return "{" + e + "} underbrace { }";
476 if( pos == top )
477 return "{" + e + "} csup {" + OUStringChar( chr ) + "}";
478 else
479 return "{" + e + "} csub {" + OUStringChar( chr ) + "}";
480}
481
483{
484 m_rStream.ensureOpeningTag( M_TOKEN( m ));
485 OUStringBuffer allrows;
486 do // there must be at least one m:mr
487 {
488 m_rStream.ensureOpeningTag( M_TOKEN( mr ));
489 OUStringBuffer row;
490 do // there must be at least one m:e
491 {
492 if( !row.isEmpty())
493 row.append(" # ");
494 row.append(readOMathArgInElement( M_TOKEN( e )));
495 } while( !m_rStream.atEnd() && m_rStream.findTag( OPENING( M_TOKEN( e ))));
496 if( !allrows.isEmpty())
497 allrows.append(" ## ");
498 allrows.append(row);
499 m_rStream.ensureClosingTag( M_TOKEN( mr ));
500 } while( !m_rStream.atEnd() && m_rStream.findTag( OPENING( M_TOKEN( mr ))));
501 m_rStream.ensureClosingTag( M_TOKEN( m ));
502 return "matrix {" + allrows + "}";
503}
504
506{
507 m_rStream.ensureOpeningTag( M_TOKEN( nary ));
508 sal_Unicode chr = 0x222b;
509 bool subHide = false;
510 bool supHide = false;
511 if( m_rStream.checkOpeningTag( M_TOKEN( naryPr )))
512 {
513 if( XmlStream::Tag chrTag = m_rStream.checkOpeningTag( M_TOKEN( chr )))
514 {
515 chr = chrTag.attribute( M_TOKEN( val ), chr );
516 m_rStream.ensureClosingTag( M_TOKEN( chr ));
517 }
518 if( XmlStream::Tag subHideTag = m_rStream.checkOpeningTag( M_TOKEN( subHide )))
519 {
520 subHide = subHideTag.attribute( M_TOKEN( val ), subHide );
521 m_rStream.ensureClosingTag( M_TOKEN( subHide ));
522 }
523 if( XmlStream::Tag supHideTag = m_rStream.checkOpeningTag( M_TOKEN( supHide )))
524 {
525 supHide = supHideTag.attribute( M_TOKEN( val ), supHide );
526 m_rStream.ensureClosingTag( M_TOKEN( supHide ));
527 }
528 m_rStream.ensureClosingTag( M_TOKEN( naryPr ));
529 }
530 OUString sub = readOMathArgInElement( M_TOKEN( sub ));
531 OUString sup = readOMathArgInElement( M_TOKEN( sup ));
532 OUString e = readOMathArgInElement( M_TOKEN( e ));
533 OUString ret;
534 switch( chr )
535 {
536 case MS_INT:
537 ret = "int";
538 break;
539 case MS_IINT:
540 ret = "iint";
541 break;
542 case MS_IIINT:
543 ret = "iiint";
544 break;
545 case MS_LINT:
546 ret = "lint";
547 break;
548 case MS_LLINT:
549 ret = "llint";
550 break;
551 case MS_LLLINT:
552 ret = "lllint";
553 break;
554 case MS_PROD:
555 ret = "prod";
556 break;
557 case MS_COPROD:
558 ret = "coprod";
559 break;
560 case MS_SUM:
561 ret = "sum";
562 break;
563 default:
564 SAL_WARN( "starmath.ooxml", "Unknown m:nary chr \'" << OUString(chr) << "\'" );
565 break;
566 }
567 if( !subHide )
568 ret += " from {" + sub + "}";
569 if( !supHide )
570 ret += " to {" + sup + "}";
571 ret += " {" + e + "}";
572 m_rStream.ensureClosingTag( M_TOKEN( nary ));
573 return ret;
574}
575
576// NOT complete
578{
579 m_rStream.ensureOpeningTag( M_TOKEN( r ));
580 bool normal = false;
581 bool literal = false;
582 if( XmlStream::Tag rPr = m_rStream.checkOpeningTag( M_TOKEN( rPr )))
583 {
584 if( XmlStream::Tag litTag = m_rStream.checkOpeningTag( M_TOKEN( lit )))
585 {
586 literal = litTag.attribute( M_TOKEN( val ), true );
587 m_rStream.ensureClosingTag( M_TOKEN( lit ));
588 }
589 if( XmlStream::Tag norTag = m_rStream.checkOpeningTag( M_TOKEN( nor )))
590 {
591 normal = norTag.attribute( M_TOKEN( val ), true );
592 m_rStream.ensureClosingTag( M_TOKEN( nor ));
593 }
594 m_rStream.ensureClosingTag( M_TOKEN( rPr ));
595 }
596 OUStringBuffer text;
598 {
599 switch( m_rStream.currentToken())
600 {
601 case OPENING( M_TOKEN( t )):
602 {
603 XmlStream::Tag rtag = m_rStream.ensureOpeningTag( M_TOKEN( t ));
604 if( rtag.attribute( OOX_TOKEN( xml, space )) != "preserve" )
605 text.append(o3tl::trim(rtag.text));
606 else
607 text.append(rtag.text);
608 m_rStream.ensureClosingTag( M_TOKEN( t ));
609 break;
610 }
611 default:
613 break;
614 }
615 }
616 m_rStream.ensureClosingTag( M_TOKEN( r ));
617 if( normal || literal )
618 {
619 text.insert(0, "\"");
620 text.append("\"");
621 }
622 return text.makeStringAndClear().replaceAll("{", "\\{").replaceAll("}", "\\}");
623}
624
626{
627 m_rStream.ensureOpeningTag( M_TOKEN( rad ));
628 bool degHide = false;
629 if( m_rStream.checkOpeningTag( M_TOKEN( radPr )))
630 {
631 if( XmlStream::Tag degHideTag = m_rStream.checkOpeningTag( M_TOKEN( degHide )))
632 {
633 degHide = degHideTag.attribute( M_TOKEN( val ), degHide );
634 m_rStream.ensureClosingTag( M_TOKEN( degHide ));
635 }
636 m_rStream.ensureClosingTag( M_TOKEN( radPr ));
637 }
638 OUString deg = readOMathArgInElement( M_TOKEN( deg ));
639 OUString e = readOMathArgInElement( M_TOKEN( e ));
640 m_rStream.ensureClosingTag( M_TOKEN( rad ));
641 if( degHide )
642 return "sqrt {" + e + "}";
643 else
644 return "nroot {" + deg + "} {" + e + "}";
645}
646
648{
649 m_rStream.ensureOpeningTag( M_TOKEN( sPre ));
650 OUString sub = readOMathArgInElement( M_TOKEN( sub ));
651 OUString sup = readOMathArgInElement( M_TOKEN( sup ));
652 OUString e = readOMathArgInElement( M_TOKEN( e ));
653 m_rStream.ensureClosingTag( M_TOKEN( sPre ));
654 return "{" + e + "} lsub {" + sub + "} lsup {" + sup + "}";
655}
656
658{
659 m_rStream.ensureOpeningTag( M_TOKEN( sSub ));
660 OUString e = readOMathArgInElement( M_TOKEN( e ));
661 OUString sub = readOMathArgInElement( M_TOKEN( sub ));
662 m_rStream.ensureClosingTag( M_TOKEN( sSub ));
663 return "{" + e + "} rsub {" + sub + "}";
664}
665
667{
668 m_rStream.ensureOpeningTag( M_TOKEN( sSubSup ));
669 OUString e = readOMathArgInElement( M_TOKEN( e ));
670 OUString sub = readOMathArgInElement( M_TOKEN( sub ));
671 OUString sup = readOMathArgInElement( M_TOKEN( sup ));
672 m_rStream.ensureClosingTag( M_TOKEN( sSubSup ));
673 return "{" + e + "} rsub {" + sub + "} rsup {" + sup + "}";
674}
675
677{
678 m_rStream.ensureOpeningTag( M_TOKEN( sSup ));
679 OUString e = readOMathArgInElement( M_TOKEN( e ));
680 OUString sup = readOMathArgInElement( M_TOKEN( sup ));
681 m_rStream.ensureClosingTag( M_TOKEN( sSup ));
682 return "{" + e + "} ^ {" + sup + "}";
683}
684
685/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
XPropertyListType t
double d
OUString ConvertToStarMath()
Definition: ooxmlimport.cxx:41
OUString handleRad()
OUString handleBar()
OUString handleD()
OUString readOMathArgInElement(int token)
OUString handleM()
OUString handleSsub()
OUString handleGroupChr()
OUString handleFunc()
SmOoxmlImport(oox::formulaimport::XmlStream &stream)
Definition: ooxmlimport.cxx:36
OUString handleSsup()
OUString handleSsubsup()
OUString handleSpre()
OUString readOMathArg(int stoptoken)
Definition: ooxmlimport.cxx:76
OUString handleF()
OUString handleR()
OUString handleStream()
Definition: ooxmlimport.cxx:50
oox::formulaimport::XmlStream & m_rStream
Definition: ooxmlimport.hxx:48
OUString handleEqArr()
OUString handleBox()
OUString handleNary()
OUString handleAcc()
OUString handleLimLowUpp(LimLowUpp_t limlowupp)
OUString handleBorderBox()
void ensureClosingTag(int token)
OString top
float u
#define SAL_WARN(area, stream)
#define SAL_INFO(area, stream)
def text(shape, orig_st)
constexpr OUStringLiteral first
m
std::basic_string_view< charT, traits > trim(std::basic_string_view< charT, traits > str)
#define OPENING(token)
Definition: ooxmlimport.cxx:31
#define CLOSING(token)
Definition: ooxmlimport.cxx:32
OUString attribute(int token, const OUString &def=OUString()) const
sal_uInt16 sal_Unicode
sal_Unicode const MS_SUM
Definition: types.hxx:127
sal_Unicode const MS_DVERTLINE
Definition: types.hxx:111
sal_Unicode const MS_COMBOVERLINE
Definition: types.hxx:146
sal_Unicode const MS_TILDE
Definition: types.hxx:142
sal_Unicode const MS_RIGHTARROW
Definition: types.hxx:188
sal_Unicode const MS_LANGLE
Definition: types.hxx:175
sal_Unicode const MS_HAT
Definition: types.hxx:140
sal_Unicode const MS_COMBBREVE
Definition: types.hxx:148
sal_Unicode const MS_COMBGRAVE
Definition: types.hxx:137
sal_Unicode const MS_IIINT
Definition: types.hxx:131
sal_Unicode const MS_LLINT
Definition: types.hxx:133
sal_Unicode const MS_COMBACUTE
Definition: types.hxx:139
sal_Unicode const MS_GRAVE
Definition: types.hxx:136
sal_Unicode const MS_RMATHANGLE
Definition: types.hxx:180
sal_Unicode const MS_DDOT
Definition: types.hxx:156
sal_Unicode const MS_VEC
Definition: types.hxx:154
sal_Unicode const MS_DLINE
Definition: types.hxx:110
sal_Unicode const MS_DDDOT
Definition: types.hxx:159
sal_Unicode const MS_COMBDDOT
Definition: types.hxx:158
sal_Unicode const MS_CHECK
Definition: types.hxx:151
sal_Unicode const MS_BAR
Definition: types.hxx:144
sal_Unicode const MS_ACUTE
Definition: types.hxx:138
sal_Unicode const MS_INT
Definition: types.hxx:129
sal_Unicode const MS_RANGLE
Definition: types.hxx:176
sal_Unicode const MS_LLLINT
Definition: types.hxx:134
sal_Unicode const MS_CIRCLE
Definition: types.hxx:149
sal_Unicode const MS_COMBBAR
Definition: types.hxx:145
sal_Unicode const MS_COMBCIRCLE
Definition: types.hxx:150
sal_Unicode const MS_DOT
Definition: types.hxx:155
sal_Unicode const MS_COMBTILDE
Definition: types.hxx:143
sal_Unicode const MS_HARPOON
Definition: types.hxx:153
sal_Unicode const MS_COPROD
Definition: types.hxx:126
sal_Unicode const MS_COMBCHECK
Definition: types.hxx:152
sal_Unicode const MS_LMATHANGLE
Definition: types.hxx:179
sal_Unicode const MS_IINT
Definition: types.hxx:130
sal_Unicode const MS_PROD
Definition: types.hxx:125
sal_Unicode const MS_COMBDOT
Definition: types.hxx:157
sal_Unicode const MS_COMBHAT
Definition: types.hxx:141
sal_Unicode const MS_LINT
Definition: types.hxx:132
sal_Unicode const MS_BREVE
Definition: types.hxx:147
ResultType type
size_t pos