wxMaxima
Loading...
Searching...
No Matches
SubSupCell.h
1// -*- mode: c++; c-file-style: "linux"; c-basic-offset: 2; indent-tabs-mode: nil -*-
2//
3// Copyright (C) 2007-2015 Andrej Vodopivec <andrej.vodopivec@gmail.com>
4// (C) 2014-2016 Gunter Königsmann <wxMaxima@physikbuch.de>
5//
6// This program is free software; you can redistribute it and/or modify
7// it under the terms of the GNU General Public License as published by
8// the Free Software Foundation; either version 2 of the License, or
9// (at your option) any later version.
10//
11// This program is distributed in the hope that it will be useful,
12// but WITHOUT ANY WARRANTY; without even the implied warranty of
13// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14// GNU General Public License for more details.
15//
16//
17// You should have received a copy of the GNU General Public License
18// along with this program; if not, write to the Free Software
19// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20//
21// SPDX-License-Identifier: GPL-2.0+
22
23#ifndef SUBSUPCELL_H
24#define SUBSUPCELL_H
25
26#include "precomp.h"
27#include <memory>
28#include "Cell.h"
29
30class SubSupCell final : public Cell
31{
32public:
33 SubSupCell(GroupCell *group, Configuration *config, std::unique_ptr<Cell> &&base);
34 SubSupCell(GroupCell *group, const SubSupCell &cell);
35 const CellTypeInfo &GetInfo() override;
36 std::unique_ptr<Cell> Copy(GroupCell *group) const override;
37
38 size_t GetInnerCellCount() const override { return 5; }
39 Cell *GetInnerCell(size_t index) const override {
40 switch (index) {
41 case 0:
42 return m_baseCell.get();
43 case 1:
44 return m_postSubCell.get();
45 case 2:
46 return m_postSupCell.get();
47 case 3:
48 return m_preSubCell.get();
49 case 4:
50 return m_preSupCell.get();
51 default:
52 return nullptr;
53 }
54 }
55
56 void SetIndex(std::unique_ptr<Cell> &&index);
57 void SetExponent(std::unique_ptr<Cell> &&expt);
58 void SetPreSub(std::unique_ptr<Cell> &&index);
59 void SetPreSup(std::unique_ptr<Cell> &&index);
60 void SetPostSub(std::unique_ptr<Cell> &&index);
61 void SetPostSup(std::unique_ptr<Cell> &&index);
62
63 void Recalculate(const AFontSize fontsize) const override;
64
65 void Draw(wxPoint point, wxDC *dc, wxDC *antialiassingDC) override;
66
67 wxString ToMathML() const override;
68 wxString ToMatlab() const override;
69 wxString ToOMML() const override;
70 wxString ToString() const override;
71 wxString ToTeX() const override;
72 wxString ToXML() const override;
73
74 wxString GetDiffPart() const override;
75
76 void SetAltCopyText(const wxString &text) override { m_altCopyText = text; }
77 const wxString &GetAltCopyText() const override { return m_altCopyText; }
78
79private:
81 wxString m_altCopyText;
82
85 std::vector<Cell *> m_scriptCells;
86
87 // The pointers below point to inner cells and must be kept contiguous.
88 // ** All pointers must be the same: either Cell * or std::unique_ptr<Cell>.
89 // ** NO OTHER TYPES are allowed.
90 std::unique_ptr<Cell> m_baseCell;
91 std::unique_ptr<Cell> m_postSubCell;
92 std::unique_ptr<Cell> m_postSupCell;
93 std::unique_ptr<Cell> m_preSubCell;
94 std::unique_ptr<Cell> m_preSupCell;
95 // The pointers above point to inner cells and must be kept contiguous.
96
97//** Bitfield objects (0 bytes)
98//**
99 static void InitBitFields_SubSubCell()
100 { // Keep the initialization order below same as the order
101 // of bit fields in this class!
102 }
103};
104
105#endif // SUBSUPCELL_H
The definition of the base class of all cells the worksheet consists of.
A Type-Safe Fixed-Point Font Size.
Definition: FontAttribs.h:98
A class that carries information about the type of a cell.
Definition: Cell.h:93
The base class all cell types the worksheet can consist of are derived from.
Definition: Cell.h:142
The configuration storage for the current worksheet.
Definition: Configuration.h:85
A cell grouping input (and, if there is one, also the output) cell to a foldable item.
Definition: GroupCell.h:74
Definition: SubSupCell.h:31
wxString ToTeX() const override
Convert this cell to its LaTeX representation.
Definition: SubSupCell.cpp:251
Cell * GetInnerCell(size_t index) const override
Retrieve an inner cell with given index which must be less than GetInnerCellCount.
Definition: SubSupCell.h:39
size_t GetInnerCellCount() const override
The number of inner cells - for use by the iterators.
Definition: SubSupCell.h:38
const wxString & GetAltCopyText() const override
Get the text set using SetAltCopyText - may be empty.
Definition: SubSupCell.h:77
wxString ToOMML() const override
Returns the cell's representation as OMML.
Definition: SubSupCell.cpp:328
wxString ToMathML() const override
Convert this cell to a representation fit for saving in a .wxmx file.
Definition: SubSupCell.cpp:288
void SetAltCopyText(const wxString &text) override
What should end up if placing this cell on the clipboard?
Definition: SubSupCell.h:76
wxString ToString() const override
Returns the cell's representation as a string.
Definition: SubSupCell.cpp:198
wxString ToMatlab() const override
Convert this cell to its Matlab representation.
Definition: SubSupCell.cpp:222
wxString GetDiffPart() const override
Get the part for diff tag support.
Definition: SubSupCell.cpp:389
const CellTypeInfo & GetInfo() override
Returns the information about this cell's type.
std::unique_ptr< Cell > Copy(GroupCell *group) const override
Create a copy of this cell.
void Draw(wxPoint point, wxDC *dc, wxDC *antialiassingDC) override
Draw this cell.
Definition: SubSupCell.cpp:150
void Recalculate(const AFontSize fontsize) const override
Recalculate the size of the cell and the difference between top and center.
Definition: SubSupCell.cpp:108
wxString ToXML() const override
Convert this cell to a representation fit for saving in a .wxmx file.
Definition: SubSupCell.cpp:357