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 "mathed/support.h"
29 /** \class MathedArray
30 \brief A resizable array.
32 A general purpose resizable array.
34 \author Alejandro Aguilar Sierra
36 \author Lars Gullik Bjønnes
37 \version February 2001
42 typedef std::vector<byte> buffer_type;
43 typedef byte value_type;
44 typedef buffer_type::size_type size_type;
45 typedef buffer_type::iterator iterator;
46 typedef buffer_type::const_iterator const_iterator;
51 MathedArray(MathedArray const &);
53 MathedArray & operator=(MathedArray const &);
62 const_iterator begin() const;
64 const_iterator end() const;
77 void swap(MathedArray &);
79 void shrink(int pos1, int pos2);
83 void insert(iterator pos, const_iterator beg, const_iterator end);
85 /// Merge \a dx elements from array \a a at \apos.
86 /// This doesn't changes the size (dangerous)
87 void merge(MathedArray const & a, int pos);
90 void raw_pointer_copy(MathedInset ** p, int pos) const;
93 void insertInset(int pos, MathedInset * p, int type);
95 MathedInset * getInset(int pos);
98 void raw_pointer_insert(void * p, int pos, int len);
101 void strange_copy(MathedArray * dest, int dpos, int spos, int len);
103 byte operator[](int) const;
105 byte & operator[](int i);
108 void move(int p, int shift);
110 void resize(int newsize);
111 /// Make sure we can access at least \a needed elements
112 void need_size(int needed);
124 InsetTable(int p, MathedInset * i)
125 : pos(p), inset(i) {}
129 typedef std::vector<InsetTable> InsetList;
130 /// The list of insets in this array.
131 InsetList insetList_;
133 /// Last position inserted.