]> git.lyx.org Git - lyx.git/blob - src/mathed/MathStream.cpp
ac511dd917fe12c4eae5b99cd13b4c489b2c7540
[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)
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 //////////////////////////////////////////////////////////////////////
341
342
343 MapleStream & operator<<(MapleStream & ms, MathAtom const & at)
344 {
345         at->maple(ms);
346         return ms;
347 }
348
349
350 MapleStream & operator<<(MapleStream & ms, MathData const & ar)
351 {
352         maple(ar, ms);
353         return ms;
354 }
355
356
357 MapleStream & operator<<(MapleStream & ms, char const * s)
358 {
359         ms.os() << s;
360         return ms;
361 }
362
363
364 MapleStream & operator<<(MapleStream & ms, char c)
365 {
366         ms.os() << c;
367         return ms;
368 }
369
370
371 MapleStream & operator<<(MapleStream & ms, int i)
372 {
373         ms.os() << i;
374         return ms;
375 }
376
377
378 MapleStream & operator<<(MapleStream & ms, char_type c)
379 {
380         ms.os().put(c);
381         return ms;
382 }
383
384
385 MapleStream & operator<<(MapleStream & ms, docstring const & s)
386 {
387         ms.os() << s;
388         return ms;
389 }
390
391
392 //////////////////////////////////////////////////////////////////////
393
394
395 MaximaStream & operator<<(MaximaStream & ms, MathAtom const & at)
396 {
397         at->maxima(ms);
398         return ms;
399 }
400
401
402 MaximaStream & operator<<(MaximaStream & ms, MathData const & ar)
403 {
404         maxima(ar, ms);
405         return ms;
406 }
407
408
409 MaximaStream & operator<<(MaximaStream & ms, char const * s)
410 {
411         ms.os() << s;
412         return ms;
413 }
414
415
416 MaximaStream & operator<<(MaximaStream & ms, char c)
417 {
418         ms.os() << c;
419         return ms;
420 }
421
422
423 MaximaStream & operator<<(MaximaStream & ms, int i)
424 {
425         ms.os() << i;
426         return ms;
427 }
428
429
430 MaximaStream & operator<<(MaximaStream & ms, docstring const & s)
431 {
432         ms.os() << s;
433         return ms;
434 }
435
436
437 MaximaStream & operator<<(MaximaStream & ms, char_type c)
438 {
439         ms.os().put(c);
440         return ms;
441 }
442
443
444 //////////////////////////////////////////////////////////////////////
445
446
447 MathematicaStream & operator<<(MathematicaStream & ms, MathAtom const & at)
448 {
449         at->mathematica(ms);
450         return ms;
451 }
452
453
454 MathematicaStream & operator<<(MathematicaStream & ms, MathData const & ar)
455 {
456         mathematica(ar, ms);
457         return ms;
458 }
459
460
461 MathematicaStream & operator<<(MathematicaStream & ms, char const * s)
462 {
463         ms.os() << s;
464         return ms;
465 }
466
467
468 MathematicaStream & operator<<(MathematicaStream & ms, char c)
469 {
470         ms.os() << c;
471         return ms;
472 }
473
474
475 MathematicaStream & operator<<(MathematicaStream & ms, int i)
476 {
477         ms.os() << i;
478         return ms;
479 }
480
481
482 MathematicaStream & operator<<(MathematicaStream & ms, docstring const & s)
483 {
484         ms.os() << s;
485         return ms;
486 }
487
488
489 MathematicaStream & operator<<(MathematicaStream & ms, char_type c)
490 {
491         ms.os().put(c);
492         return ms;
493 }
494
495
496 //////////////////////////////////////////////////////////////////////
497
498
499 OctaveStream & operator<<(OctaveStream & ns, MathAtom const & at)
500 {
501         at->octave(ns);
502         return ns;
503 }
504
505
506 OctaveStream & operator<<(OctaveStream & ns, MathData const & ar)
507 {
508         octave(ar, ns);
509         return ns;
510 }
511
512
513 OctaveStream & operator<<(OctaveStream & ns, char const * s)
514 {
515         ns.os() << s;
516         return ns;
517 }
518
519
520 OctaveStream & operator<<(OctaveStream & ns, char c)
521 {
522         ns.os() << c;
523         return ns;
524 }
525
526
527 OctaveStream & operator<<(OctaveStream & ns, int i)
528 {
529         ns.os() << i;
530         return ns;
531 }
532
533
534 OctaveStream & operator<<(OctaveStream & ns, docstring const & s)
535 {
536         ns.os() << s;
537         return ns;
538 }
539
540
541 OctaveStream & operator<<(OctaveStream & ns, char_type c)
542 {
543         ns.os().put(c);
544         return ns;
545 }
546
547
548 OctaveStream & operator<<(OctaveStream & os, string const & s)
549 {
550         os.os() << from_utf8(s);
551         return os;
552 }
553
554
555 } // namespace lyx