]> git.lyx.org Git - lyx.git/blob - src/mathed/MathStream.cpp
ffc91c4f42667cd611d2fc749cda76f4b9af7630
[lyx.git] / src / mathed / MathStream.cpp
1 /**
2  * \file MathStream.cpp
3  * This file is part of LyX, the document processor.
4  * Licence details can be found in the file COPYING.
5  *
6  * \author André Pönitz
7  *
8  * Full author contact details are available in file CREDITS.
9  */
10
11 #include <config.h>
12
13 #include "MathStream.h"
14
15 #include "MathData.h"
16 #include "MathExtern.h"
17
18 #include "support/textutils.h"
19 #include "support/docstring.h"
20
21 #include <algorithm>
22 #include <cstring>
23 #include <ostream>
24
25 using namespace std;
26
27 namespace lyx {
28
29
30 //////////////////////////////////////////////////////////////////////
31
32
33 NormalStream & operator<<(NormalStream & ns, MathAtom const & at)
34 {
35         at->normalize(ns);
36         return ns;
37 }
38
39
40 NormalStream & operator<<(NormalStream & ns, MathData const & ar)
41 {
42         normalize(ar, ns);
43         return ns;
44 }
45
46
47 NormalStream & operator<<(NormalStream & ns, docstring const & s)
48 {
49         ns.os() << s;
50         return ns;
51 }
52
53
54 NormalStream & operator<<(NormalStream & ns, const string & s)
55 {
56         ns.os() << from_utf8(s);
57         return ns;
58 }
59
60
61 NormalStream & operator<<(NormalStream & ns, char const * s)
62 {
63         ns.os() << s;
64         return ns;
65 }
66
67
68 NormalStream & operator<<(NormalStream & ns, char c)
69 {
70         ns.os() << c;
71         return ns;
72 }
73
74
75 NormalStream & operator<<(NormalStream & ns, int i)
76 {
77         ns.os() << i;
78         return ns;
79 }
80
81
82
83 /////////////////////////////////////////////////////////////////
84
85
86 WriteStream & operator<<(WriteStream & ws, docstring const & s)
87 {
88         if (ws.pendingBrace()) {
89                 ws.os() << '}';
90                 ws.pendingBrace(false);
91                 ws.pendingSpace(false);
92                 ws.textMode(true);
93         } else if (ws.pendingSpace() && s.length() > 0) {
94                 if (isAlphaASCII(s[0]))
95                         ws.os() << ' ';
96                 else if (s[0] == ' ' && ws.textMode())
97                         ws.os() << '\\';
98                 ws.pendingSpace(false);
99         }
100         ws.os() << s;
101         int lf = 0;
102         docstring::const_iterator dit = s.begin();
103         docstring::const_iterator end = s.end();
104         for (; dit != end; ++dit)
105                 if ((*dit) == '\n')
106                         ++lf;
107         ws.addlines(lf);
108         return ws;
109 }
110
111
112 WriteStream::WriteStream(odocstream & os, bool fragile, bool latex, OutputType output,
113                         Encoding const * encoding)
114         : os_(os), fragile_(fragile), firstitem_(false), latex_(latex),
115           output_(output), pendingspace_(false), pendingbrace_(false),
116           textmode_(false), locked_(0), line_(0), encoding_(encoding)
117 {}
118
119
120 WriteStream::WriteStream(odocstream & os)
121         : os_(os), fragile_(false), firstitem_(false), latex_(false),
122           output_(wsDefault), pendingspace_(false), pendingbrace_(false),
123           textmode_(false), locked_(0), line_(0), encoding_(0)
124 {}
125
126
127 WriteStream::~WriteStream()
128 {
129         if (pendingbrace_)
130                 os_ << '}';
131         else if (pendingspace_)
132                 os_ << ' ';
133 }
134
135
136 void WriteStream::addlines(unsigned int n)
137 {
138         line_ += n;
139 }
140
141
142 void WriteStream::pendingSpace(bool how)
143 {
144         pendingspace_ = how;
145 }
146
147
148 void WriteStream::pendingBrace(bool brace)
149 {
150         pendingbrace_ = brace;
151 }
152
153
154 void WriteStream::textMode(bool textmode)
155 {
156         textmode_ = textmode;
157 }
158
159
160 void WriteStream::lockedMode(bool locked)
161 {
162         locked_ = locked;
163 }
164
165
166 WriteStream & operator<<(WriteStream & ws, MathAtom const & at)
167 {
168         at->write(ws);
169         return ws;
170 }
171
172
173 WriteStream & operator<<(WriteStream & ws, MathData const & ar)
174 {
175         write(ar, ws);
176         return ws;
177 }
178
179
180 WriteStream & operator<<(WriteStream & ws, char const * s)
181 {
182         if (ws.pendingBrace()) {
183                 ws.os() << '}';
184                 ws.pendingBrace(false);
185                 ws.pendingSpace(false);
186                 ws.textMode(true);
187         } else if (ws.pendingSpace() && strlen(s) > 0) {
188                 if (isAlphaASCII(s[0]))
189                         ws.os() << ' ';
190                 else if (s[0] == ' ' && ws.textMode())
191                         ws.os() << '\\';
192                 ws.pendingSpace(false);
193         }
194         ws.os() << s;
195         ws.addlines(int(count(s, s + strlen(s), '\n')));
196         return ws;
197 }
198
199
200 WriteStream & operator<<(WriteStream & ws, char c)
201 {
202         if (ws.pendingBrace()) {
203                 ws.os() << '}';
204                 ws.pendingBrace(false);
205                 ws.pendingSpace(false);
206                 ws.textMode(true);
207         } else if (ws.pendingSpace()) {
208                 if (isAlphaASCII(c))
209                         ws.os() << ' ';
210                 else if (c == ' ' && ws.textMode())
211                         ws.os() << '\\';
212                 ws.pendingSpace(false);
213         }
214         ws.os() << c;
215         if (c == '\n')
216                 ws.addlines(1);
217         return ws;
218 }
219
220
221 WriteStream & operator<<(WriteStream & ws, int i)
222 {
223         if (ws.pendingBrace()) {
224                 ws.os() << '}';
225                 ws.pendingBrace(false);
226                 ws.textMode(true);
227         }
228         ws.os() << i;
229         return ws;
230 }
231
232
233 WriteStream & operator<<(WriteStream & ws, unsigned int i)
234 {
235         if (ws.pendingBrace()) {
236                 ws.os() << '}';
237                 ws.pendingBrace(false);
238                 ws.textMode(true);
239         }
240         ws.os() << i;
241         return ws;
242 }
243
244
245 //////////////////////////////////////////////////////////////////////
246
247
248 MathStream::MathStream(odocstream & os)
249         : os_(os), tab_(0), line_(0), lastchar_(0), in_text_(false)
250 {}
251
252
253 void MathStream::cr()
254 {
255         os() << '\n';
256         for (int i = 0; i < tab(); ++i)
257                 os() << ' ';
258 }
259
260
261 void MathStream::defer(docstring const & s)
262 {
263         deferred_ << s;
264 }
265
266
267 void MathStream::defer(string const & s)
268 {
269         deferred_ << from_utf8(s);
270 }
271
272
273 docstring MathStream::deferred() const
274
275         return deferred_.str();
276 }
277
278
279 MathStream & operator<<(MathStream & ms, MathAtom const & at)
280 {
281         at->mathmlize(ms);
282         return ms;
283 }
284
285
286 MathStream & operator<<(MathStream & ms, MathData const & ar)
287 {
288         mathmlize(ar, ms);
289         return ms;
290 }
291
292
293 MathStream & operator<<(MathStream & ms, char const * s)
294 {
295         ms.os() << s;
296         return ms;
297 }
298
299
300 MathStream & operator<<(MathStream & ms, char c)
301 {
302         ms.os() << c;
303         return ms;
304 }
305
306
307 MathStream & operator<<(MathStream & ms, char_type c)
308 {
309         ms.os() << c;
310         return ms;
311 }
312
313
314 MathStream & operator<<(MathStream & ms, MTag const & t)
315 {
316         ++ms.tab();
317         ms.cr();
318         ms.os() << '<' << from_ascii(t.tag_) << '>';
319         return ms;
320 }
321
322
323 MathStream & operator<<(MathStream & ms, ETag const & t)
324 {
325         ms.cr();
326         if (ms.tab() > 0)
327                 --ms.tab();
328         ms.os() << "</" << from_ascii(t.tag_) << '>';
329         return ms;
330 }
331
332
333 MathStream & operator<<(MathStream & ms, docstring const & s)
334 {
335         ms.os() << s;
336         return ms;
337 }
338
339
340 SetMode::SetMode(MathStream & os, bool text)
341         : os_(os)
342 {
343         init(text, from_ascii(""));
344 }
345
346
347 SetMode::SetMode(MathStream & os, bool text, docstring attrs)
348         : os_(os)
349 {
350         init(text, attrs);
351 }
352
353
354 void SetMode::init(bool text, docstring attrs)
355 {
356         was_text_ = os_.inText();
357         if (was_text_)
358                 os_ << "</mtext>";
359         if (text) {
360                 os_.setTextMode();
361                 os_ << "<mtext";
362                 if (!attrs.empty())
363                         os_ << " " << attrs;
364                 os_ << ">";
365         } else {
366                 if (!attrs.empty())
367                         os_ << "<mstyle " << attrs << ">";
368                 os_.setMathMode();
369         }
370 }
371
372
373 SetMode::~SetMode()
374 {
375         if (os_.inText())
376                 os_ << "</mtext>";
377         if (was_text_) {
378                 os_.setTextMode();
379                 os_ << "<mtext>";
380         } else {
381                 os_.setMathMode();
382         }
383 }
384
385
386 //////////////////////////////////////////////////////////////////////
387
388
389 MapleStream & operator<<(MapleStream & ms, MathAtom const & at)
390 {
391         at->maple(ms);
392         return ms;
393 }
394
395
396 MapleStream & operator<<(MapleStream & ms, MathData const & ar)
397 {
398         maple(ar, ms);
399         return ms;
400 }
401
402
403 MapleStream & operator<<(MapleStream & ms, char const * s)
404 {
405         ms.os() << s;
406         return ms;
407 }
408
409
410 MapleStream & operator<<(MapleStream & ms, char c)
411 {
412         ms.os() << c;
413         return ms;
414 }
415
416
417 MapleStream & operator<<(MapleStream & ms, int i)
418 {
419         ms.os() << i;
420         return ms;
421 }
422
423
424 MapleStream & operator<<(MapleStream & ms, char_type c)
425 {
426         ms.os().put(c);
427         return ms;
428 }
429
430
431 MapleStream & operator<<(MapleStream & ms, docstring const & s)
432 {
433         ms.os() << s;
434         return ms;
435 }
436
437
438 //////////////////////////////////////////////////////////////////////
439
440
441 MaximaStream & operator<<(MaximaStream & ms, MathAtom const & at)
442 {
443         at->maxima(ms);
444         return ms;
445 }
446
447
448 MaximaStream & operator<<(MaximaStream & ms, MathData const & ar)
449 {
450         maxima(ar, ms);
451         return ms;
452 }
453
454
455 MaximaStream & operator<<(MaximaStream & ms, char const * s)
456 {
457         ms.os() << s;
458         return ms;
459 }
460
461
462 MaximaStream & operator<<(MaximaStream & ms, char c)
463 {
464         ms.os() << c;
465         return ms;
466 }
467
468
469 MaximaStream & operator<<(MaximaStream & ms, int i)
470 {
471         ms.os() << i;
472         return ms;
473 }
474
475
476 MaximaStream & operator<<(MaximaStream & ms, docstring const & s)
477 {
478         ms.os() << s;
479         return ms;
480 }
481
482
483 MaximaStream & operator<<(MaximaStream & ms, char_type c)
484 {
485         ms.os().put(c);
486         return ms;
487 }
488
489
490 //////////////////////////////////////////////////////////////////////
491
492
493 MathematicaStream & operator<<(MathematicaStream & ms, MathAtom const & at)
494 {
495         at->mathematica(ms);
496         return ms;
497 }
498
499
500 MathematicaStream & operator<<(MathematicaStream & ms, MathData const & ar)
501 {
502         mathematica(ar, ms);
503         return ms;
504 }
505
506
507 MathematicaStream & operator<<(MathematicaStream & ms, char const * s)
508 {
509         ms.os() << s;
510         return ms;
511 }
512
513
514 MathematicaStream & operator<<(MathematicaStream & ms, char c)
515 {
516         ms.os() << c;
517         return ms;
518 }
519
520
521 MathematicaStream & operator<<(MathematicaStream & ms, int i)
522 {
523         ms.os() << i;
524         return ms;
525 }
526
527
528 MathematicaStream & operator<<(MathematicaStream & ms, docstring const & s)
529 {
530         ms.os() << s;
531         return ms;
532 }
533
534
535 MathematicaStream & operator<<(MathematicaStream & ms, char_type c)
536 {
537         ms.os().put(c);
538         return ms;
539 }
540
541
542 //////////////////////////////////////////////////////////////////////
543
544
545 OctaveStream & operator<<(OctaveStream & ns, MathAtom const & at)
546 {
547         at->octave(ns);
548         return ns;
549 }
550
551
552 OctaveStream & operator<<(OctaveStream & ns, MathData const & ar)
553 {
554         octave(ar, ns);
555         return ns;
556 }
557
558
559 OctaveStream & operator<<(OctaveStream & ns, char const * s)
560 {
561         ns.os() << s;
562         return ns;
563 }
564
565
566 OctaveStream & operator<<(OctaveStream & ns, char c)
567 {
568         ns.os() << c;
569         return ns;
570 }
571
572
573 OctaveStream & operator<<(OctaveStream & ns, int i)
574 {
575         ns.os() << i;
576         return ns;
577 }
578
579
580 OctaveStream & operator<<(OctaveStream & ns, docstring const & s)
581 {
582         ns.os() << s;
583         return ns;
584 }
585
586
587 OctaveStream & operator<<(OctaveStream & ns, char_type c)
588 {
589         ns.os().put(c);
590         return ns;
591 }
592
593
594 OctaveStream & operator<<(OctaveStream & os, string const & s)
595 {
596         os.os() << from_utf8(s);
597         return os;
598 }
599
600
601 } // namespace lyx