#ifndef MATH_MATHMLSTREAM_H
#define MATH_MATHMLSTREAM_H
-#include "LString.h"
-#include "support/LOstream.h"
+// Please keep all four streams in one file until the interface has
+// settled.
+
#include <iosfwd>
-struct MathArray;
-struct MathInset;
-struct Buffer;
+class MathArray;
+class MathInset;
+
+
+//
+// MathML
+//
struct MTag {
///
char const * const tag_;
};
-struct MathMLStream {
+class MathMLStream {
+public:
///
explicit MathMLStream(std::ostream & os);
///
- MathMLStream & operator<<(MathInset const *);
- ///
- MathMLStream & operator<<(MathArray const &);
+ void cr();
///
- MathMLStream & operator<<(char const *);
+ std::ostream & os() { return os_; }
///
- MathMLStream & operator<<(char);
+ int line() const { return line_; }
///
- MathMLStream & operator<<(MTag const &);
+ int & tab() { return tab_; }
///
- MathMLStream & operator<<(ETag const &);
- ///
- void cr();
-
+ friend MathMLStream & operator<<(MathMLStream &, char const *);
+private:
///
std::ostream & os_;
///
char lastchar_;
};
+///
+MathMLStream & operator<<(MathMLStream &, MathInset const *);
+///
+MathMLStream & operator<<(MathMLStream &, MathArray const &);
+///
+MathMLStream & operator<<(MathMLStream &, char const *);
+///
+MathMLStream & operator<<(MathMLStream &, char);
+///
+MathMLStream & operator<<(MathMLStream &, MTag const &);
+///
+MathMLStream & operator<<(MathMLStream &, ETag const &);
+
+
+
+//
+// Debugging
+//
-struct NormalStream {
+class NormalStream {
+public:
///
explicit NormalStream(std::ostream & os) : os_(os) {}
///
- std::ostream & os_;
- ///
- NormalStream & operator<<(MathInset const *);
- ///
- NormalStream & operator<<(MathArray const &);
+ std::ostream & os() { return os_; }
+private:
///
- NormalStream & operator<<(char const *);
- ///
- NormalStream & operator<<(char);
+ std::ostream & os_;
};
+///
+NormalStream & operator<<(NormalStream &, MathInset const *);
+///
+NormalStream & operator<<(NormalStream &, MathArray const &);
+///
+NormalStream & operator<<(NormalStream &, char const *);
+///
+NormalStream & operator<<(NormalStream &, char);
+
-struct MapleStream {
+
+
+//
+// Maple
+//
+
+
+class MapleStream {
+public:
///
explicit MapleStream(std::ostream & os) : os_(os) {}
///
- std::ostream & os_;
- ///
- MapleStream & operator<<(MathInset const *);
- ///
- MapleStream & operator<<(MathArray const &);
- ///
- MapleStream & operator<<(char const *);
+ std::ostream & os() { return os_; }
+private:
///
- MapleStream & operator<<(char);
- ///
- MapleStream & operator<<(int);
+ std::ostream & os_;
};
-struct OctaveStream {
+///
+MapleStream & operator<<(MapleStream &, MathInset const *);
+///
+MapleStream & operator<<(MapleStream &, MathArray const &);
+///
+MapleStream & operator<<(MapleStream &, char const *);
+///
+MapleStream & operator<<(MapleStream &, char);
+///
+MapleStream & operator<<(MapleStream &, int);
+
+
+//
+// Octave
+//
+
+
+class OctaveStream {
+public:
///
explicit OctaveStream(std::ostream & os) : os_(os) {}
///
- std::ostream & os_;
- ///
- OctaveStream & operator<<(MathInset const *);
+ std::ostream & os() { return os_; }
+private:
///
- OctaveStream & operator<<(MathArray const &);
- ///
- OctaveStream & operator<<(char const *);
- ///
- OctaveStream & operator<<(char);
+ std::ostream & os_;
};
+///
+OctaveStream & operator<<(OctaveStream &, MathInset const *);
+///
+OctaveStream & operator<<(OctaveStream &, MathArray const &);
+///
+OctaveStream & operator<<(OctaveStream &, char const *);
+///
+OctaveStream & operator<<(OctaveStream &, char);
+///
+OctaveStream & operator<<(OctaveStream &, int);
-struct WriteStream {
- ///
- WriteStream(Buffer const * buffer_, std::ostream & os_, bool fragile_);
- ///
- explicit WriteStream(std::ostream & os_);
+
+//
+// LaTeX/LyX
+//
+
+class WriteStream {
+public:
///
- WriteStream & operator<<(MathInset const *);
+ WriteStream(std::ostream & os, bool fragile, bool latex);
///
- WriteStream & operator<<(MathArray const &);
+ explicit WriteStream(std::ostream & os_);
///
- WriteStream & operator<<(string const &);
+ int line() const { return line_; }
///
- WriteStream & operator<<(char const *);
+ bool fragile() const { return fragile_; }
///
- WriteStream & operator<<(char);
+ bool latex() const { return latex_; }
///
- WriteStream & operator<<(int);
+ std::ostream & os() { return os_; }
///
- WriteStream & operator<<(unsigned int);
-
+ bool & firstitem() { return firstitem_; }
///
- Buffer const * buffer;
+ void addlines(unsigned int);
+private:
///
- std::ostream & os;
+ std::ostream & os_;
///
- bool fragile;
+ bool fragile_;
+ /// are we writing to .tex?
+ int latex_;
/// are we at the beginning of an MathArray?
- bool firstitem;
+ bool firstitem_;
///
int line_;
};
+///
+WriteStream & operator<<(WriteStream &, MathInset const *);
+///
+WriteStream & operator<<(WriteStream &, MathArray const &);
+///
+WriteStream & operator<<(WriteStream &, char const *);
+///
+WriteStream & operator<<(WriteStream &, char);
+///
+WriteStream & operator<<(WriteStream &, int);
+///
+WriteStream & operator<<(WriteStream &, unsigned int);
#endif