3 * Purpose: A general purpose resizable array.
4 * Author: Alejandro Aguilar Sierra <asierra@servidor.unam.mx>
5 * Created: January 1996
7 * Dependencies: None (almost)
9 * Copyright: 1996, Alejandro Aguilar Sierra
12 * You are free to use and modify this code under the terms of
13 * the GNU General Public Licence version 2 or later.
21 #include "math_atom.h"
34 \brief Low level container for math insets
36 \author Alejandro Aguilar Sierra
38 \author Lars Gullik Bjønnes
39 \version February 2001
45 typedef std::vector<MathAtom> buffer_type;
47 typedef buffer_type::const_iterator const_iterator;
49 typedef buffer_type::iterator iterator;
51 typedef buffer_type::size_type size_type;
57 MathArray(MathArray const &, size_type from, size_type to);
59 MathArray(iterator from, iterator to);
62 size_type size() const;
68 void swap(MathArray &);
71 void insert(size_type pos, MathAtom const &);
73 void insert(size_type pos, MathArray const &);
76 void erase(iterator pos1, iterator pos2);
78 void erase(iterator pos);
80 void erase(size_type pos1, size_type pos2);
82 void erase(size_type pos);
87 void push_back(MathAtom const &);
89 void push_back(MathArray const &);
98 MathAtom const & front() const;
105 void substitute(MathMacro const &);
107 bool match(MathArray const &) const;
109 void replace(ReplaceData &);
112 MathAtom & at(size_type pos);
114 MathAtom const & at(size_type pos) const;
116 void validate(LaTeXFeatures &) const;
118 const_iterator begin() const;
120 const_iterator end() const;