/* * (c) Copyright Ascensio System SIA 2010-2023 * * This program is a free software product. You can redistribute it and/or * modify it under the terms of the GNU Affero General Public License (AGPL) * version 3 as published by the Free Software Foundation. In accordance with * Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect * that Ascensio System SIA expressly excludes the warranty of non-infringement * of any third-party rights. * * This program is distributed WITHOUT ANY WARRANTY; without even the implied * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For * details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html * * You can contact Ascensio System SIA at 20A-6 Ernesta Birznieka-Upish * street, Riga, Latvia, EU, LV-1050. * * The interactive user interfaces in modified source and object code versions * of the Program must display Appropriate Legal Notices, as required under * Section 5 of the GNU AGPL version 3. * * Pursuant to Section 7(b) of the License you must retain the original Product * logo when distributing the program. Pursuant to Section 7(e) we decline to * grant you any rights under trademark law for use of our trademarks. * * All the Product's GUI elements, including illustrations and icon sets, as * well as technical writing content are licensed under the terms of the * Creative Commons Attribution-ShareAlike 4.0 International. See the License * terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode * */ #include "Converter.h" //#include "../utils.h" #include "../../Reader/Converter/StarMath2OOXML/cooxml2odf.h" #include "../../OOXML/DocxFormat/DocxFlat.h" #include "../../OOXML/DocxFormat/Math/OMath.h" #include "../../OOXML/DocxFormat/Math/oMathContent.h" #include "../../OOXML/DocxFormat/Math/oMathPara.h" #include "../Format/odf_conversion_context.h" #include "../Format/math_layout_elements.h" #include "../Format/math_limit_elements.h" #include "../Format/math_token_elements.h" #include "../Format/style_text_properties.h" #include #include #include #include #include namespace Oox2Odf { std::vector>& OoxConverter::brackets() { return odf_context()->math_context()->brackets; } int& OoxConverter::lvl_of_me() { return odf_context()->math_context()->lvl_of_me; } std::vector& OoxConverter::end_counter() { return odf_context()->math_context()->end_counter; } void OoxConverter::lvl_up_counter_increace(double val) { double& lvl_max = odf_context()->math_context()->lvl_max; double& lvl_up_counter = odf_context()->math_context()->lvl_up_counter; lvl_up_counter += val; if (lvl_max < lvl_up_counter) lvl_max = lvl_up_counter; } void OoxConverter::lvl_up_counter_decreace(double val) { double& lvl_up_counter = odf_context()->math_context()->lvl_up_counter; lvl_up_counter -= val; } void OoxConverter::lvl_down_counter_decreace(double val) { double& lvl_min = odf_context()->math_context()->lvl_min; double& lvl_down_counter = odf_context()->math_context()->lvl_down_counter; lvl_down_counter -= val; if (lvl_min > lvl_down_counter) lvl_min = lvl_down_counter; } void OoxConverter::lvl_down_counter_increace(double val) { double& lvl_down_counter = odf_context()->math_context()->lvl_down_counter; lvl_down_counter += val; } std::vector hexToIntColor(std::wstring clr) { std::vector rgb; std::wstringstream ss; for (size_t i = 0; i < 3; i++) { std::wstring substr; substr += clr[i * 2]; substr += clr[i * 2 + 1]; ss << std::hex << substr; int i_clr; ss >> i_clr; ss.clear(); rgb.push_back(i_clr); } return rgb; } double dist(std::vector point_1, std::vector point_2) { double sum = 0; for(size_t i = 0; i < 3; i++) { sum += pow((point_1[i] - point_2[i]), 2); } return sqrt(sum); } std::wstring coordToColor(std::vector rgb) { std::wstring arrColor[8] = { L"black", L"red", L"green", L"blue", L"magenta", L"cyan", L"yellow", L"white" }; std::vector> coord = { {0,0,0}, {255,0,0}, {0,255,0}, {0,0,255}, {255, 0, 255}, {0,255,255}, {255,255,0}, {255,255,255} }; std::vector distArr; for (size_t i = 0; i < 8; i++) { distArr.push_back(dist(coord[i], rgb)); } double min = distArr[0]; int index = 0; for (size_t i = 1; i < 8; i++) { if (min > distArr[i]) { min = distArr[i]; index = i; } } return arrColor[index]; } void OoxConverter::mrow() // обертка для тега { CREATE_MATH_TAG(L"mrow"); OPEN_MATH_TAG(elm); } void OoxConverter::endOfMrow() // закрывашка тега { CLOSE_MATH_TAG } void OoxConverter::resizeBrackets() { lvl_of_me()++; brackets().resize(brackets().size() + 1); } void OoxConverter::convert(OOX::Logic::COMath *oox_math) { if (!oox_math) return; brackets().resize(1); int base_font_size = current_font_size.empty() ? 12 : current_font_size.back(); std::wstring base_font_color; if (odf_context()->is_child_text_context() && odf_context()->drawing_context()) { if (odf_context()->drawing_context()->get_text_properties()) { if (odf_context()->drawing_context()->get_text_properties()->fo_color_) { base_font_color = odf_context()->drawing_context()->get_text_properties()->fo_color_->get_hex_value(); } } } else { if (odf_context()->text_context()->get_text_properties()) { if (odf_context()->text_context()->get_text_properties()->fo_color_) { base_font_color = odf_context()->drawing_context()->get_text_properties()->fo_color_->get_hex_value(); } } } bool bStart = odf_context()->start_math(base_font_size, base_font_color); bool bOldConvert = !bStart; if (bStart) { StarMath::COOXml2Odf starMathConverter; starMathConverter.SetBaseAttribute(base_font_color,base_font_size); starMathConverter.StartConversion(oox_math); std::wstring annotation_text = starMathConverter.GetAnnotation(); if (annotation_text.empty()) { bOldConvert = true; } else { std::wstring content = starMathConverter.GetOdf(); odf_context()->math_context()->add_content(content); StarMath::TFormulaSize size = starMathConverter.GetFormulaSize(); odf_context()->math_context()->symbol_counter = size.m_iWidth; odf_context()->math_context()->lvl_max = size.m_iHeight; odf_context()->math_context()->lvl_min = 0; odf_context()->end_math(); } } if (bOldConvert) { for (size_t i = 0; i < oox_math->m_arrItems.size(); ++i) { convert(oox_math->m_arrItems[i]); } if (bStart) odf_context()->end_math(); } } void OoxConverter::convert(OOX::Logic::CMathPr *oox_math_pr) { if (!oox_math_pr) return; // for (size_t i = 0; i < oox_math_pr->m_arrItems.size(); ++i) // { // convert(oox_math_pr->m_arrItems[i]); // } convert(oox_math_pr->m_oBrkBin.GetPointer()); convert(oox_math_pr->m_oBrkBinSub.GetPointer()); convert(oox_math_pr->m_oDefJc.GetPointer()); convert(oox_math_pr->m_oDispDef.GetPointer()); convert(oox_math_pr->m_oInterSp.GetPointer()); convert(oox_math_pr->m_oIntLim.GetPointer()); convert(oox_math_pr->m_oIntraSp.GetPointer()); convert(oox_math_pr->m_oLMargin.GetPointer()); convert(oox_math_pr->m_oMathFont.GetPointer()); convert(oox_math_pr->m_oNaryLim.GetPointer()); convert(oox_math_pr->m_oPostSp.GetPointer()); convert(oox_math_pr->m_oPreSp.GetPointer()); convert(oox_math_pr->m_oRMargin.GetPointer()); convert(oox_math_pr->m_oSmallFrac.GetPointer()); convert(oox_math_pr->m_oWrapIndent.GetPointer()); convert(oox_math_pr->m_oWrapRight.GetPointer()); } void OoxConverter::convert(OOX::Logic::COMathPara *oox_math_para) { if (!oox_math_para) return; int base_font_size = current_font_size.empty() ? 12 : current_font_size.back(); std::wstring base_font_color; if (odf_context()->is_child_text_context() && odf_context()->drawing_context()) { if (odf_context()->drawing_context()->get_text_properties()) { if (odf_context()->drawing_context()->get_text_properties()->fo_color_) { base_font_color = odf_context()->drawing_context()->get_text_properties()->fo_color_->get_hex_value(); } } } else { if (odf_context()->text_context()->get_text_properties()) { if (odf_context()->text_context()->get_text_properties()->fo_color_) { base_font_color = odf_context()->drawing_context()->get_text_properties()->fo_color_->get_hex_value(); } } } bool bStart = odf_context()->start_math(base_font_size, base_font_color); bool bOldConvert = false; if (bStart) { StarMath::COOXml2Odf starMathConverter; starMathConverter.SetBaseAttribute(base_font_color,base_font_size); starMathConverter.StartConversion(oox_math_para); std::wstring annotation_text = starMathConverter.GetAnnotation(); if (annotation_text.empty()) { bOldConvert = true; } else { std::wstring content = starMathConverter.GetOdf(); StarMath::TFormulaSize size = starMathConverter.GetFormulaSize(); odf_context()->math_context()->add_content(content); odf_context()->math_context()->symbol_counter = size.m_iWidth; odf_context()->math_context()->lvl_max = size.m_iHeight; odf_context()->math_context()->lvl_min = 0; odf_context()->end_math(); } } if (bOldConvert) { for (size_t i = 0; i < oox_math_para->m_arrItems.size(); ++i) { convert(oox_math_para->m_arrItems[i]); } if (bStart) odf_context()->end_math(); } } void OoxConverter::convert(OOX::Logic::COMathParaPr *oox_math_para_pr) { if (!oox_math_para_pr) return; } returnValues OoxConverter::convert(OOX::Logic::CCtrlPr *oox_ctrl_pr) { returnValues result; if (!oox_ctrl_pr) { result.auxFlag = false; return result; } //convert(oox_ctrl_pr->m_oARPr.GetPointer()); //convert(oox_ctrl_pr->m_oDel.GetPointer()); //convert(oox_ctrl_pr->m_oIns.GetPointer()); //result.colorFlag = convert(oox_ctrl_pr->m_oRPr.GetPointer()); return result; } void OoxConverter::convert(OOX::Logic::CAcc *oox_acc) { if (!oox_acc) return; returnValues values = convert(oox_acc->m_oAccPr.GetPointer()); CREATE_MATH_TAG(L"mover"); OPEN_MATH_TAG(elm); lvl_up_counter_increace(1); std::wstring diakSymbol = (oox_acc->m_oAccPr->m_oChr.IsInit()) ? oox_acc->m_oAccPr->m_oChr.get().m_val->GetValue() : L""; std::map& map = odf_context()->math_context()->diak_symbols; std::wstring symbol; symbol = (map[diakSymbol]); convert(oox_acc->m_oElement.GetPointer()); { CREATE_MATH_TAG(L"mo"); elm->add_text(symbol); OPEN_MATH_TAG(elm); CLOSE_MATH_TAG; } CLOSE_MATH_TAG; lvl_up_counter_decreace(1); if (values.colorFlag) { CLOSE_MATH_TAG; } } returnValues OoxConverter::convert(OOX::Logic::CAccPr *oox_acc_pr) { returnValues values; if (!oox_acc_pr) return values; //convert(oox_acc_pr->m_oChr.GetPointer()); values = convert(oox_acc_pr->m_oCtrlPr.GetPointer()); return values; } void OoxConverter::convert(OOX::Logic::CArgPr *oox_arg_pr) { if (!oox_arg_pr) return; convert(oox_arg_pr->m_oArgSz.GetPointer()); } void OoxConverter::convert(OOX::Logic::CArgSz *oox_arg_sz) { if (!oox_arg_sz) return; } void OoxConverter::convert(OOX::Logic::CBar *oox_bar) { if (!oox_bar) return; returnValues values = convert(oox_bar->m_oBarPr.GetPointer()); std::wstring tag; if (values.auxFlag) { tag = L"mover"; lvl_up_counter_increace(1); } else { tag = L"munder"; lvl_down_counter_decreace(1); } CREATE_MATH_TAG(tag.c_str()); OPEN_MATH_TAG(elm); { convert(oox_bar->m_oElement.GetPointer()); CREATE_MATH_TAG(L"mo"); if (values.auxFlag) elm->add_text(L"¯"); else elm->add_text(L"ˉ"); OPEN_MATH_TAG(elm); CLOSE_MATH_TAG; } CLOSE_MATH_TAG; if (values.auxFlag) lvl_up_counter_decreace(1); else lvl_down_counter_increace(1); if (values.colorFlag) { CLOSE_MATH_TAG; } } returnValues OoxConverter::convert(OOX::Logic::CBarPr *oox_bar_pr) { returnValues values; if (!oox_bar_pr) { values.auxFlag = false; return values; } values.colorFlag = convert(oox_bar_pr->m_oCtrlPr.GetPointer()).colorFlag; values.auxFlag = convert(oox_bar_pr->m_oPos.GetPointer()); return values; } void OoxConverter::convert(OOX::Logic::CBorderBox *oox_border_box) { if (!oox_border_box) return; returnValues values = convert(oox_border_box->m_oBorderBoxPr.GetPointer()); convert(oox_border_box->m_oElement.GetPointer()); if (values.colorFlag) { CLOSE_MATH_TAG; } } returnValues OoxConverter::convert(OOX::Logic::CBorderBoxPr *oox_border_box_pr) { returnValues values; if (!oox_border_box_pr) return values; values.colorFlag = convert(oox_border_box_pr->m_oCtrlPr.GetPointer()).colorFlag; convert(oox_border_box_pr->m_oHideBot.GetPointer()); convert(oox_border_box_pr->m_oHideLeft.GetPointer()); convert(oox_border_box_pr->m_oHideRight.GetPointer()); convert(oox_border_box_pr->m_oHideTop.GetPointer()); convert(oox_border_box_pr->m_oStrikeBLTR.GetPointer()); convert(oox_border_box_pr->m_oStrikeH.GetPointer()); convert(oox_border_box_pr->m_oStrikeTLBR.GetPointer()); convert(oox_border_box_pr->m_oStrikeV.GetPointer()); return values; } void OoxConverter::convert(OOX::Logic::CBox *oox_box) { if (!oox_box) return; returnValues val = convert(oox_box->m_oBoxPr.GetPointer()); if (val.auxFlag) { //annotation() += L"\""; convert(oox_box->m_oElement.GetPointer()); //annotation() += L"\""; } else convert(oox_box->m_oElement.GetPointer()); if (val.colorFlag) { CLOSE_MATH_TAG; } } returnValues OoxConverter::convert(OOX::Logic::CBoxPr *oox_box_pr) { returnValues values; if (!oox_box_pr) { values.auxFlag = false; return values; } convert(oox_box_pr->m_oAln.GetPointer()); convert(oox_box_pr->m_oBrk.GetPointer()); values.colorFlag = convert(oox_box_pr->m_oCtrlPr.GetPointer()).colorFlag; convert(oox_box_pr->m_oDiff.GetPointer()); convert(oox_box_pr->m_oNoBreak.GetPointer()); values.auxFlag = convert(oox_box_pr->m_oOpEmu.GetPointer()); return values; } void OoxConverter::convert(OOX::Logic::CNoBreak *oox_no_break) { if (!oox_no_break) return; } bool OoxConverter::convert(OOX::Logic::COpEmu *oox_op_emu) { if (!oox_op_emu) return false; if (!oox_op_emu->m_val.IsInit()) return false; if (oox_op_emu->m_val->ToBool())// == L"true") ||(oox_op_emu->m_val == L"1")) return true; else return false; } void OoxConverter::convert(OOX::Logic::CDiff *oox_diff) { if (!oox_diff) return; } void OoxConverter::convert(OOX::Logic::CBrk *oox_brk) { if (!oox_brk) return; } void OoxConverter::convert(OOX::Logic::CDelimiter *oox_del) { if (!oox_del) return; returnValues values; for (size_t i = 0; i < oox_del->m_arrItems.size(); ++i) { if(oox_del->m_arrItems[i]->getType() == OOX::et_m_dPr) values = convert((OOX::Logic::CDelimiterPr*)(oox_del->m_arrItems[i])); } mrow(); { CREATE_MATH_TAG(L"mo"); elm->add_text(values.begEndChrs.first); typedef odf_writer::math_mo* T; T tmp = dynamic_cast(elm.get()); if (tmp) { tmp->fence_ = true; tmp->form_ = L"prefix"; tmp->stretchy_ = true; } OPEN_MATH_TAG(elm); CLOSE_MATH_TAG; } for (size_t i = 0; i < oox_del->m_arrItems.size(); ++i) { if (!(oox_del->m_arrItems[i]->getType() == OOX::et_m_dPr)) convert(oox_del->m_arrItems[i]); } { CREATE_MATH_TAG(L"mo"); elm->add_text(values.begEndChrs.second); typedef odf_writer::math_mo* T; T tmp = dynamic_cast(elm.get()); if (tmp) { tmp->fence_ = true; tmp->form_ = L"postfix"; tmp->stretchy_ = true; } OPEN_MATH_TAG(elm); CLOSE_MATH_TAG; } endOfMrow(); if (values.colorFlag) { CLOSE_MATH_TAG; } } returnValues OoxConverter::convert(OOX::Logic::CDelimiterPr *oox_del_pr) { returnValues values; if (!oox_del_pr) return values; values.begEndChrs.first = convert(oox_del_pr->m_oBegChr.GetPointer()); values.colorFlag = convert(oox_del_pr->m_oCtrlPr.GetPointer()).colorFlag; convert(oox_del_pr->m_oGrow.GetPointer()); convert(oox_del_pr->m_oSepChr.GetPointer()); convert(oox_del_pr->m_oShp.GetPointer()); values.begEndChrs.second = convert(oox_del_pr->m_oEndChr.GetPointer()); return values; } std::wstring OoxConverter::convert(OOX::Logic::CBegChr * oox_beg_chr) { if (!oox_beg_chr) return L"("; if (false == oox_beg_chr->m_val.IsInit()) return L"("; std::wstring s_val = oox_beg_chr->m_val->GetValue(); //brackets()[lvl_of_me()].push_back(s_val); return s_val; } std::wstring OoxConverter::convert(OOX::Logic::CEndChr * oox_end_chr) { if (!oox_end_chr) return L")"; if (false == oox_end_chr->m_val.IsInit()) return L")"; std::wstring s_val = oox_end_chr->m_val->GetValue(); //brackets()[lvl_of_me()].push_back(s_val); return s_val; } void OoxConverter::convert(OOX::Logic::CEqArr *oox_eq_arr) { if (!oox_eq_arr) return; returnValues values; if(oox_eq_arr->m_arrItems[0]->getType() == OOX::EElementType::et_m_eqArrPr) values = convert((OOX::Logic::CEqArrPr*)(oox_eq_arr->m_arrItems[0])); CREATE_MATH_TAG(L"mtable"); OPEN_MATH_TAG(elm); { for (size_t i = 1; i < oox_eq_arr->m_arrItems.size(); ++i) { CREATE_MATH_TAG(L"mtr"); OPEN_MATH_TAG(elm); { CREATE_MATH_TAG(L"mtd"); OPEN_MATH_TAG(elm); mrow(); convert(oox_eq_arr->m_arrItems[i]); endOfMrow(); CLOSE_MATH_TAG; } CLOSE_MATH_TAG; } } CLOSE_MATH_TAG; if(values.colorFlag) { CLOSE_MATH_TAG; } } returnValues OoxConverter::convert(OOX::Logic::CEqArrPr *oox_eq_arr_pr) { returnValues values; if (!oox_eq_arr_pr) return values; convert(oox_eq_arr_pr->m_oBaseJc.GetPointer()); values.colorFlag = convert(oox_eq_arr_pr->m_oCtrlPr.GetPointer()).colorFlag; convert(oox_eq_arr_pr->m_oMaxDist.GetPointer()); convert(oox_eq_arr_pr->m_oObjDist.GetPointer()); convert(oox_eq_arr_pr->m_oRSp.GetPointer()); convert(oox_eq_arr_pr->m_oRSpRule.GetPointer()); return values; } void OoxConverter::convert(OOX::Logic::CBaseJc *oox_base_js) { if (!oox_base_js) return; } void OoxConverter::convert(OOX::Logic::CMaxDist *oox_max_dist) { if (!oox_max_dist) return; } void OoxConverter::convert(OOX::Logic::CObjDist *oox_obj_dist) // !!! ) { if (!oox_obj_dist) return; } void OoxConverter::convert(OOX::Logic::CRSp *oox_r_sp) { if (!oox_r_sp) return; } void OoxConverter::convert(OOX::Logic::CRSpRule *oox_r_sp_rule) { if (!oox_r_sp_rule) return; } void OoxConverter::convert(OOX::Logic::CFraction *oox_fraction) { if (!oox_fraction) return; returnValues val = convert(oox_fraction->m_oFPr.GetPointer()); if (val.str == L"lin") { mrow(); convert(oox_fraction->m_oNum.GetPointer()); endOfMrow(); CREATE_MATH_TAG(L"mo"); elm->add_text(L"/"); OPEN_MATH_TAG(elm); CLOSE_MATH_TAG; mrow(); convert(oox_fraction->m_oDen.GetPointer()); endOfMrow(); } else if (val.str == L"skw") { CREATE_MATH_TAG(L"mfrac"); lvl_up_counter_increace(1); lvl_down_counter_decreace(1); typedef odf_writer::math_mfrac* T; T tmp = dynamic_cast(elm.get()); if (tmp) { tmp->bevelled = true; } OPEN_MATH_TAG(elm); mrow(); convert(oox_fraction->m_oNum.GetPointer()); endOfMrow(); mrow(); convert(oox_fraction->m_oDen.GetPointer()); endOfMrow(); CLOSE_MATH_TAG; lvl_up_counter_decreace(1); lvl_down_counter_increace(1); } else if (val.str == L"noBar") { CREATE_MATH_TAG(L"mtable"); OPEN_MATH_TAG(elm); { CREATE_MATH_TAG(L"mtr"); OPEN_MATH_TAG(elm); { CREATE_MATH_TAG(L"mtd"); OPEN_MATH_TAG(elm); mrow(); convert(oox_fraction->m_oNum.GetPointer()); endOfMrow(); CLOSE_MATH_TAG; } CLOSE_MATH_TAG; } { CREATE_MATH_TAG(L"mtr"); OPEN_MATH_TAG(elm); { CREATE_MATH_TAG(L"mtd"); OPEN_MATH_TAG(elm); mrow(); convert(oox_fraction->m_oDen.GetPointer()); endOfMrow(); CLOSE_MATH_TAG; } CLOSE_MATH_TAG; } CLOSE_MATH_TAG; } else { CREATE_MATH_TAG(L"mfrac"); lvl_up_counter_increace(1); lvl_down_counter_decreace(1); OPEN_MATH_TAG(elm); mrow(); convert(oox_fraction->m_oNum.GetPointer()); endOfMrow(); mrow(); convert(oox_fraction->m_oDen.GetPointer()); endOfMrow(); CLOSE_MATH_TAG; lvl_up_counter_decreace(1); lvl_down_counter_increace(1); } if (val.colorFlag) { CLOSE_MATH_TAG; } } returnValues OoxConverter::convert(OOX::Logic::CFPr *oox_f_pr) { returnValues result; result.str = L""; if (!oox_f_pr) return result; result.str = convert(oox_f_pr->m_oType.GetPointer()); result.colorFlag = convert(oox_f_pr->m_oCtrlPr.GetPointer()).colorFlag; return result; } std::wstring OoxConverter::convert(OOX::Logic::CType *oox_type) { if (!oox_type) return L""; if (!oox_type->m_val.IsInit()) return L""; std::wstring val = oox_type->m_val->ToString(); return val; } void OoxConverter::convert(OOX::Logic::CNum *oox_num) { if (!oox_num) return; for (size_t i = 0; i < oox_num->m_arrItems.size(); ++i) { convert(oox_num->m_arrItems[i]); } } void OoxConverter::convert(OOX::Logic::CDen *oox_den) { if (!oox_den) return; for (size_t i = 0; i < oox_den->m_arrItems.size(); ++i) { convert(oox_den->m_arrItems[i]); } } void OoxConverter::convert(OOX::Logic::CFunc *oox_func) { if (!oox_func) return; returnValues values = convert(oox_func->m_oFuncPr.GetPointer()); bool flag = convert(oox_func->m_oFName.GetPointer(), oox_func->m_oElement.GetPointer()); if(!flag) convert(oox_func->m_oElement.GetPointer()); if (values.colorFlag) { CLOSE_MATH_TAG; } } returnValues OoxConverter::convert(OOX::Logic::CFuncPr *oox_func_pr) { returnValues values; if (!oox_func_pr) return values; values = convert(oox_func_pr->m_oCtrlPr.GetPointer()); return values; } bool OoxConverter::convert(OOX::Logic::CFName *oox_fname, OOX::Logic::CElement *oox_elm) { if (!oox_fname) return false; bool result = false; for (size_t i = 0; i < oox_fname->m_arrItems.size(); ++i) { if (oox_fname->m_arrItems[i]->getType() == OOX::et_m_limLow) { convert(dynamic_cast(oox_fname->m_arrItems[i]), oox_elm); result = true; } else { convert(oox_fname->m_arrItems[i]); result = false; } } return result; } void OoxConverter::convert(OOX::Logic::CGroupChr* oox_group_ch, OOX::Logic::CLim* oox_lim) { if (!oox_group_ch) return; returnValues values = convert(oox_group_ch->m_oGroupChrPr.GetPointer()); std::wstring tag; if (values.auxFlag) { tag = L"mover"; lvl_up_counter_increace(1); } else { tag = L"munder"; lvl_down_counter_decreace(1); } CREATE_MATH_TAG(tag.c_str()); if (values.auxFlag) { typedef odf_writer::math_mover* T; T tmp = dynamic_cast(elm.get()); tmp->accent = true; } else { typedef odf_writer::math_munder* T; T tmp = dynamic_cast(elm.get()); tmp->accentunder = true; } OPEN_MATH_TAG(elm); convert(oox_group_ch->m_oElement.GetPointer()); if (values.auxFlag) { if (oox_group_ch->m_oGroupChrPr->m_oChr.IsInit() && oox_group_ch->m_oGroupChrPr->m_oChr->m_val->GetValue() == L"⏞") { if (oox_lim) { convert(oox_lim); } } else { convert(oox_group_ch->m_oGroupChrPr->m_oChr.GetPointer()); } } else { if (oox_group_ch->m_oGroupChrPr->m_oChr.IsInit()) { convert(oox_group_ch->m_oGroupChrPr->m_oChr.GetPointer()); } else { CREATE_MATH_TAG(L"mo"); elm->add_text(L" ⏟ "); OPEN_MATH_TAG(elm); CLOSE_MATH_TAG; if (oox_lim) { convert(oox_lim); } } } CLOSE_MATH_TAG; if (values.auxFlag) lvl_up_counter_decreace(1); else lvl_down_counter_increace(1); if (values.colorFlag) { CLOSE_MATH_TAG; } } returnValues OoxConverter::convert(OOX::Logic::CGroupChrPr *oox_group_ch_pr) { returnValues values; if (!oox_group_ch_pr) return values; //convert(oox_group_ch_pr->m_oChr.GetPointer()); values.colorFlag = convert(oox_group_ch_pr->m_oCtrlPr.GetPointer()).colorFlag; values.auxFlag = convert(oox_group_ch_pr->m_oPos.GetPointer()); convert(oox_group_ch_pr->m_oVertJc.GetPointer()); return values; } bool OoxConverter::convert(OOX::Logic::CPos *oox_pos) { if (!oox_pos) return false; if (!oox_pos->m_val.IsInit()) return false; if (oox_pos->m_val->ToString() == L"top") return true; else return false; } void OoxConverter::convert(OOX::Logic::CVertJc *oox_vert_jc) { if (!oox_vert_jc) return; } void OoxConverter::convert(OOX::Logic::CLimLow *oox_lim_low, OOX::Logic::CElement *oox_elm) { if (!oox_lim_low) return; returnValues values = convert(oox_lim_low->m_oLimLowPr.GetPointer()); mrow(); CREATE_MATH_TAG(L"munder"); OPEN_MATH_TAG(elm); lvl_down_counter_decreace(1); if (oox_lim_low->m_oElement->m_arrItems[0]->getType() == OOX::EElementType::et_m_groupChr) { convert(dynamic_cast(oox_lim_low->m_oElement->m_arrItems[0]), oox_lim_low->m_oLim.GetPointer()); } else { mrow(); convert(oox_lim_low->m_oElement.GetPointer()); endOfMrow(); convert(oox_lim_low->m_oLim.GetPointer()); } CLOSE_MATH_TAG; lvl_down_counter_increace(1); if (oox_elm) convert(oox_elm); endOfMrow(); if (values.colorFlag) { CLOSE_MATH_TAG; } } void OoxConverter::convert(OOX::Logic::CLim *oox_lim) { if (!oox_lim) return; mrow(); for (size_t i = 0; i < oox_lim->m_arrItems.size(); ++i) convert(oox_lim->m_arrItems[i]); endOfMrow(); } returnValues OoxConverter::convert(OOX::Logic::CLimLowPr *oox_lim_low_pr) { returnValues values; if (!oox_lim_low_pr) return values; values.colorFlag = convert(oox_lim_low_pr->m_oCtrlPr.GetPointer()).colorFlag; return values; } void OoxConverter::convert(OOX::Logic::CLimUpp *oox_lim_upp) { if (!oox_lim_upp) return; returnValues values = convert(oox_lim_upp->m_oLimUppPr.GetPointer()); mrow(); CREATE_MATH_TAG(L"mover"); OPEN_MATH_TAG(elm); lvl_up_counter_increace(1); if (oox_lim_upp->m_oElement->m_arrItems[0]->getType() == OOX::EElementType::et_m_groupChr) { convert(dynamic_cast(oox_lim_upp->m_oElement->m_arrItems[0]), oox_lim_upp->m_oLim.GetPointer()); } else { mrow(); convert(oox_lim_upp->m_oElement.GetPointer()); endOfMrow(); convert(oox_lim_upp->m_oLim.GetPointer()); } CLOSE_MATH_TAG; lvl_up_counter_decreace(1); endOfMrow(); if (values.colorFlag) { CLOSE_MATH_TAG; } } returnValues OoxConverter::convert(OOX::Logic::CLimUppPr *oox_lim_upp_pr) { returnValues values; if (!oox_lim_upp_pr) return values; values.colorFlag = convert(oox_lim_upp_pr->m_oCtrlPr.GetPointer()).colorFlag; return values; } void OoxConverter::convert(OOX::Logic::CMathFont *oox_math_font) { if (!oox_math_font) return; } void OoxConverter::convert(OOX::Logic::CMatrix *oox_matrix) { if (!oox_matrix) return; int& matrix_row_counter = odf_context()->math_context()->matrix_row_counter; returnValues values; if (oox_matrix->m_arrItems[0]->getType() == OOX::EElementType::et_m_mPr) { matrix_row_counter = oox_matrix->m_arrItems.size() - 1; values = convert((OOX::Logic::CMPr*)(oox_matrix->m_arrItems[0])); } else matrix_row_counter = oox_matrix->m_arrItems.size(); CREATE_MATH_TAG(L"mtable"); OPEN_MATH_TAG(elm); for (size_t i = 0; i < oox_matrix->m_arrItems.size(); ++i) { if(oox_matrix->m_arrItems[i]->getType() != OOX::EElementType::et_m_mPr) convert(oox_matrix->m_arrItems[i]); } CLOSE_MATH_TAG; odf_context()->math_context()->matrix_row_counter = 0; if (values.colorFlag) { CLOSE_MATH_TAG; } } void OoxConverter::convert(OOX::Logic::CMc *oox_mc) { if (!oox_mc) return; convert(oox_mc->m_oMcPr.GetPointer()); } void OoxConverter::convert(OOX::Logic::CMcPr *oox_mc_pr) { if (!oox_mc_pr) return; convert(oox_mc_pr->m_oCount.GetPointer()); convert(oox_mc_pr->m_oMcJc.GetPointer()); } void OoxConverter::convert(OOX::Logic::CCount *oox_count) { if (!oox_count) return; } void OoxConverter::convert(OOX::Logic::CMcJc *oox_mc_jc) { if (!oox_mc_jc) return; } void OoxConverter::convert(OOX::Logic::CMcs *oox_mcs) { if (!oox_mcs) return; for (size_t i = 0; i < oox_mcs->m_arrItems.size(); ++i) { convert(oox_mcs->m_arrItems[i]); } } void OoxConverter::convert(OOX::Logic::CMDel *oox_m_del) { if (!oox_m_del) return; CREATE_MATH_TAG(L"mathMDel") OPEN_MATH_TAG(elm) convert(oox_m_del->m_oRun.GetPointer()); CLOSE_MATH_TAG } void OoxConverter::convert(OOX::Logic::CMIns *oox_m_ins) { if (!oox_m_ins) return; CREATE_MATH_TAG(L"mathMIns") OPEN_MATH_TAG(elm) convert(oox_m_ins->m_oRun.GetPointer()); CLOSE_MATH_TAG } returnValues OoxConverter::convert(OOX::Logic::CMPr *oox_m_pr) { returnValues values; if (!oox_m_pr) return values; convert(oox_m_pr->m_oBaseJc.GetPointer()); convert(oox_m_pr->m_oCGp.GetPointer()); convert(oox_m_pr->m_oCGpRule.GetPointer()); convert(oox_m_pr->m_oCSp.GetPointer()); values.colorFlag = convert(oox_m_pr->m_oCtrlPr.GetPointer()).colorFlag; convert(oox_m_pr->m_oMcs.GetPointer()); convert(oox_m_pr->m_oMcs.GetPointer()); convert(oox_m_pr->m_oPlcHide.GetPointer()); convert(oox_m_pr->m_oRSp.GetPointer()); convert(oox_m_pr->m_oRSpRule.GetPointer()); return values; } void OoxConverter::convert(OOX::Logic::CPlcHide *oox_plc_hide) { if (!oox_plc_hide) return; } void OoxConverter::convert(OOX::Logic::CMr *oox_mr) { if (!oox_mr) return; bool color_flag = false; for (size_t i = 0; i < oox_mr->m_arrItems.size(); ++i) { if (oox_mr->m_arrItems[i]->getType() == OOX::et_w_rPr) color_flag = convert((OOX::Logic::CRunProperty*)(oox_mr->m_arrItems[i])); } int& matrix_row_counter = odf_context()->math_context()->matrix_row_counter; CREATE_MATH_TAG(L"mtr"); OPEN_MATH_TAG(elm); for (size_t i = 0; i < oox_mr->m_arrItems.size(); ++i) { CREATE_MATH_TAG(L"mtd"); OPEN_MATH_TAG(elm); convert(oox_mr->m_arrItems[i]); CLOSE_MATH_TAG; } CLOSE_MATH_TAG; matrix_row_counter--; if(color_flag) { CLOSE_MATH_TAG; } } void OoxConverter::convert(OOX::Logic::CMRun *oox_mrun) { if (!oox_mrun) return; convert(oox_mrun->m_oDel.GetPointer()); convert(oox_mrun->m_oIns.GetPointer()); convert(oox_mrun->m_oARPr.GetPointer()); bool clrFlag = convert(oox_mrun->m_oRPr.GetPointer()); //convert(oox_mrun->m_oMRPr.GetPointer()); for (size_t i = 0; i < oox_mrun->m_arrItems.size(); ++i) { switch (oox_mrun->m_arrItems[i]->getType()) { case OOX::et_w_fldChar: { OOX::Logic::CFldChar* pFldChar = dynamic_cast(oox_mrun->m_arrItems[i]); convert(pFldChar); }break; case OOX::et_w_instrText: { OOX::Logic::CInstrText* pInstrText = dynamic_cast(oox_mrun->m_arrItems[i]); convert(pInstrText); }break; case OOX::et_w_delText: { OOX::Logic::CDelText* pDelText = dynamic_cast(oox_mrun->m_arrItems[i]); convert(pDelText); }break; case OOX::et_w_lastRenderedPageBreak: // не информативное .. может быть неверно записано { }break; case OOX::et_w_t: { OOX::Logic::CText* pText = dynamic_cast(oox_mrun->m_arrItems[i]); convert(pText); }break; case OOX::et_m_t: { OOX::Logic::CMText* pMText = dynamic_cast(oox_mrun->m_arrItems[i]); convert(pMText); }break; case OOX::et_w_sym: { OOX::Logic::CSym* pSym = dynamic_cast(oox_mrun->m_arrItems[i]); convert(pSym); }break; case OOX::et_w_tab: { OOX::Logic::CTab* pTab = dynamic_cast(oox_mrun->m_arrItems[i]); }break; case OOX::et_w_separator: case OOX::et_w_continuationSeparator: { }break; //contentPart //cr //dayLong, dayShort, monthLong, monthShort, yearLong, yearShort //noBreakHyphen //pgNum //ruby //softHyphen //delInstrText default: convert(oox_mrun->m_arrItems[i]); } } if (clrFlag) { CLOSE_MATH_TAG; } } bool OoxConverter::convert(OOX::Logic::CRunProperty *oox_r_pr) { if (!oox_r_pr) return false; if (odf_context()->math_context()->style_flag) { odf_context()->math_context()->style_flag = false; odf_context()->settings_context()->start_view(); if (oox_r_pr->m_oSz.IsInit() && oox_r_pr->m_oSz->m_oVal.IsInit()) { odf_context()->math_context()->font_size = oox_r_pr->m_oSz->m_oVal->GetValue(); } odf_context()->settings_context()->add_config_content_item(L"BaseFontHeight", L"short", std::to_wstring((int)odf_context()->math_context()->font_size)); if (!odf_context()->math_context()->font_color.empty()) { odf_context()->settings_context()->add_config_content_item(L"BaseFontColor", L"string", L"#" + odf_context()->math_context()->font_color); } if (oox_r_pr->m_oRFonts.IsInit() && oox_r_pr->m_oRFonts->m_sAscii.IsInit()) { odf_context()->math_context()->font_name = *oox_r_pr->m_oRFonts->m_sAscii; odf_context()->settings_context()->add_config_content_item(L"FontNameFunctions", L"string", *oox_r_pr->m_oRFonts->m_sAscii); odf_context()->settings_context()->add_config_content_item(L"FontNameNumbers", L"string", *oox_r_pr->m_oRFonts->m_sAscii); odf_context()->settings_context()->add_config_content_item(L"FontNameText", L"string", *oox_r_pr->m_oRFonts->m_sAscii); odf_context()->settings_context()->add_config_content_item(L"FontNameVariables", L"string", *oox_r_pr->m_oRFonts->m_sAscii); } odf_context()->settings_context()->end_view(); } if (oox_r_pr->m_oColor.IsInit() && oox_r_pr->m_oColor->m_oVal->ToString() != L"auto") { if (oox_r_pr->m_oColor->m_oVal.IsInit()) { std::wstring clr = oox_r_pr->m_oColor->m_oVal.GetPointer()->ToString(); std::wstring clr2(L"#"); clr.erase(0, 2); clr2 += clr; CREATE_MATH_TAG(L"mstyle"); typedef odf_writer::math_mstyle * T; T tmp = dynamic_cast(elm.get()); tmp->color_ = clr2; OPEN_MATH_TAG(elm); clr2.erase(0, 1); std::vector rgb = hexToIntColor(clr2); boost::to_upper(clr2); return true; } } return false; } void OoxConverter::convert(OOX::Logic::CMText *oox_text) { if (!oox_text) return; std::set& mo = odf_context()->math_context()->mo; std::wstring s_val = oox_text->m_sText; std::wstring sub_s_val = L""; for (size_t i = 0; i < s_val.size(); i++) { wchar_t w_val = s_val[i]; if (w_val == L'=') { if (sub_s_val.size() != 0) { CREATE_MATH_TAG(L"mi"); elm->add_text(sub_s_val); OPEN_MATH_TAG(elm); CLOSE_MATH_TAG; sub_s_val.clear(); } CREATE_MATH_TAG(L"mtext"); elm->add_text(std::wstring(1, s_val[i])); OPEN_MATH_TAG(elm); CLOSE_MATH_TAG; } else if (w_val <= 57 && w_val >= 48) { if (sub_s_val.size() != 0) { CREATE_MATH_TAG(L"mi"); elm->add_text(sub_s_val); OPEN_MATH_TAG(elm); CLOSE_MATH_TAG; sub_s_val.clear(); } CREATE_MATH_TAG(L"mn"); elm->add_text(std::wstring(1, s_val[i])); OPEN_MATH_TAG(elm); CLOSE_MATH_TAG; } else if (mo.find(w_val) != mo.end()) { if (sub_s_val.size() != 0) { CREATE_MATH_TAG(L"mi"); elm->add_text(sub_s_val); OPEN_MATH_TAG(elm); CLOSE_MATH_TAG; sub_s_val.clear(); } CREATE_MATH_TAG(L"mo"); elm->add_text(std::wstring(1, s_val[i])); OPEN_MATH_TAG(elm); CLOSE_MATH_TAG; } else // { sub_s_val += s_val[i]; } if ((i == s_val.size() - 1) && (sub_s_val.size() != 0)) { CREATE_MATH_TAG(L"mi"); elm->add_text(sub_s_val); OPEN_MATH_TAG(elm); CLOSE_MATH_TAG; } } } void OoxConverter::convert(OOX::Logic::CNary *oox_nary) { if (!oox_nary) return; mrow(); bool flag_nary = false; std::wstring tag; if ((oox_nary->m_oSub.GetPointer()->m_arrItems.size() != 0) && (oox_nary->m_oSup.GetPointer()->m_arrItems.size() != 0)) { tag = L"munderover"; flag_nary = true; lvl_up_counter_increace(1); lvl_down_counter_decreace(1); } else if ((oox_nary->m_oSub.GetPointer()->m_arrItems.size() != 0) && (oox_nary->m_oSup.GetPointer()->m_arrItems.size() == 0)) { tag = L"munder"; flag_nary = true; lvl_down_counter_decreace(1); } else if ((oox_nary->m_oSub.GetPointer()->m_arrItems.size() == 0) && (oox_nary->m_oSup.GetPointer()->m_arrItems.size() != 0)) { tag = L"mover"; flag_nary = true; lvl_up_counter_increace(1); } if (flag_nary) { CREATE_MATH_TAG(tag); OPEN_MATH_TAG(elm); } returnValues values = convert(oox_nary->m_oNaryPr.GetPointer()); std::wstring str1, str2; if (values.naryChr) { str1 = L" from {"; str2 = L" to {"; } else { str1 = L" csub {"; str2 = L" csup {"; } if (!values.narySubHide) { //mrow(); convert(oox_nary->m_oSub.GetPointer()); //endOfMrow(); } if (!values.narySupHide) { //mrow(); convert(oox_nary->m_oSup.GetPointer()); //endOfMrow(); } if (flag_nary) { CLOSE_MATH_TAG; if (tag == L"munderover") { lvl_up_counter_decreace(1); lvl_down_counter_increace(1); } else if (tag == L"mover") lvl_up_counter_decreace(1); else if (tag == L"munder") lvl_down_counter_increace(1); } convert(oox_nary->m_oElement.GetPointer()); endOfMrow(); if (values.colorFlag) { CLOSE_MATH_TAG; } } returnValues OoxConverter::convert(OOX::Logic::CNaryPr *oox_nary_pr) { returnValues values; if (!oox_nary_pr) { values.auxFlag = false; return values; } values.colorFlag = convert(oox_nary_pr->m_oCtrlPr.GetPointer()).colorFlag; values.naryChr = convert(oox_nary_pr->m_oChr.GetPointer()); convert(oox_nary_pr->m_oGrow.GetPointer()); values.narySubHide = convert(oox_nary_pr->m_oSubHide.GetPointer()); values.narySupHide = convert(oox_nary_pr->m_oSupHide.GetPointer()); return values; } void OoxConverter::convert(OOX::Logic::CGrow* oox_grow) { if (!oox_grow) return; } bool OoxConverter::convert(OOX::Logic::CSubHide *oox_subHide) { if (!oox_subHide) return false; if (!oox_subHide->m_val.IsInit()) return false; bool result = oox_subHide->m_val->ToBool(); return result; } bool OoxConverter::convert(OOX::Logic::CSupHide *oox_supHide) { if (!oox_supHide) return false; if (!oox_supHide->m_val.IsInit()) return false; bool result = oox_supHide->m_val->ToBool(); return result; } bool OoxConverter::convert(OOX::Logic::CChr * oox_chr) { bool flag = false; //if (!oox_chr) return; CREATE_MATH_TAG(L"mo"); typedef odf_writer::math_mo* T; T tmp = dynamic_cast(elm.get()); if (tmp) { tmp->stretchy_ = false; } if (!oox_chr || (oox_chr && !oox_chr->m_val.IsInit())) { elm->add_text(L"∫"); } else { std::wstring val = oox_chr->m_val->GetValue(); elm->add_text(val); } OPEN_MATH_TAG(elm); CLOSE_MATH_TAG; return flag; } void OoxConverter::convert(OOX::Logic::CPhant *oox_phant) { if (!oox_phant) return; CREATE_MATH_TAG(L"mathPhant") OPEN_MATH_TAG(elm) convert(oox_phant->m_oElement.GetPointer()); convert(oox_phant->m_oPhantPr.GetPointer()); CLOSE_MATH_TAG } void OoxConverter::convert(OOX::Logic::CPhantPr *oox_phant_pr) { if (!oox_phant_pr) return; CREATE_MATH_TAG(L"mathPhantPr") OPEN_MATH_TAG(elm) convert(oox_phant_pr->m_oCtrlPr.GetPointer()); convert(oox_phant_pr->m_oShow.GetPointer()); convert(oox_phant_pr->m_oTransp.GetPointer()); convert(oox_phant_pr->m_oZeroAsc.GetPointer()); convert(oox_phant_pr->m_oZeroDesc.GetPointer()); convert(oox_phant_pr->m_oZeroWid.GetPointer()); CLOSE_MATH_TAG } void OoxConverter::convert(OOX::Logic::CRad *oox_rad) { if (!oox_rad) return; returnValues val = convert(oox_rad->m_oRadPr.GetPointer()); if (val.auxFlag) { CREATE_MATH_TAG(L"msqrt"); OPEN_MATH_TAG(elm); mrow(); convert(oox_rad->m_oElement.GetPointer()); endOfMrow(); CLOSE_MATH_TAG; odf_context()->math_context()->symbol_counter++; } else convert(oox_rad->m_oDeg.GetPointer(), oox_rad->m_oElement.GetPointer()); if (val.colorFlag) { CLOSE_MATH_TAG; } } returnValues OoxConverter::convert(OOX::Logic::CRadPr *oox_rad_pr) { returnValues result; if (!oox_rad_pr) result.auxFlag = false; result.auxFlag = convert(oox_rad_pr->m_oDegHide.GetPointer()); result.colorFlag = convert(oox_rad_pr->m_oCtrlPr.GetPointer()).colorFlag; return result; } bool OoxConverter::convert(OOX::Logic::CDegHide *oox_deg_hide) { if (!oox_deg_hide) return false; if (!oox_deg_hide->m_val.IsInit()) return false; return oox_deg_hide->m_val->ToBool(); } void OoxConverter::convert(OOX::Logic::CDeg *oox_deg, OOX::Logic::CElement *oox_elm) { if (!oox_deg) return; if (oox_deg->m_arrItems.size() == 0) return; CREATE_MATH_TAG(L"mroot"); OPEN_MATH_TAG(elm); convert(oox_elm); mrow(); for (size_t i = 0; i < oox_deg->m_arrItems.size(); ++i) convert(oox_deg->m_arrItems[i]); endOfMrow(); CLOSE_MATH_TAG; } void OoxConverter::convert(OOX::Logic::CSPre *oox_s_pre) { if (!oox_s_pre) return; returnValues values = convert(oox_s_pre->m_oSPrePr.GetPointer()); CREATE_MATH_TAG(L"mmultiscripts"); OPEN_MATH_TAG(elm); lvl_up_counter_increace(0.4); lvl_down_counter_decreace(0.4); mrow(); convert(oox_s_pre->m_oElement.GetPointer()); endOfMrow(); { CREATE_MATH_TAG(L"mprescripts"); OPEN_MATH_TAG(elm); CLOSE_MATH_TAG; mrow(); convert(oox_s_pre->m_oSub.GetPointer()); endOfMrow(); mrow(); convert(oox_s_pre->m_oSup.GetPointer()); endOfMrow(); } CLOSE_MATH_TAG; lvl_up_counter_decreace(0.4); lvl_down_counter_increace(0.4); if (values.colorFlag) { CLOSE_MATH_TAG; } } returnValues OoxConverter::convert(OOX::Logic::CSPrePr *oox_s_pre_pr) { returnValues values; if (!oox_s_pre_pr) return values; values = convert(oox_s_pre_pr->m_oCtrlPr.GetPointer()); return values; } void OoxConverter::convert(OOX::Logic::CSup *oox_sup, OOX::Logic::CElement *oox_elm) { if (!oox_sup) return; CREATE_MATH_TAG(L"msup"); OPEN_MATH_TAG(elm); lvl_up_counter_increace(0.4); mrow(); convert(oox_elm); endOfMrow(); mrow(); for (size_t i = 0; i < oox_sup->m_arrItems.size(); ++i) { convert(oox_sup->m_arrItems[i]); } endOfMrow(); CLOSE_MATH_TAG; lvl_up_counter_decreace(0.4); } void OoxConverter::convert(OOX::Logic::CSub *oox_sub, OOX::Logic::CElement *oox_elm) { if (!oox_sub) return; CREATE_MATH_TAG(L"msub"); OPEN_MATH_TAG(elm); lvl_down_counter_decreace(0.4); mrow(); convert(oox_elm); endOfMrow(); for (size_t i = 0; i < oox_sub->m_arrItems.size(); ++i) { convert(oox_sub->m_arrItems[i]); } CLOSE_MATH_TAG; lvl_down_counter_increace(0.4); } void OoxConverter::convert(OOX::Logic::CSub *oox_csub) { mrow(); for (size_t i = 0; i < oox_csub->m_arrItems.size(); ++i) { convert(oox_csub->m_arrItems[i]); } endOfMrow(); } void OoxConverter::convert(OOX::Logic::CSup *oox_csup) { mrow(); for (size_t i = 0; i < oox_csup->m_arrItems.size(); ++i) { convert(oox_csup->m_arrItems[i]); } endOfMrow(); } void OoxConverter::convert(OOX::Logic::CSSub *oox_ssub) { if (!oox_ssub) return; returnValues values = convert(oox_ssub->m_oSSubPr.GetPointer()); convert(oox_ssub->m_oSub.GetPointer(), oox_ssub->m_oElement.GetPointer()); if (values.colorFlag) { CLOSE_MATH_TAG; } } returnValues OoxConverter::convert(OOX::Logic::CSSubPr*oox_ssub_pr) { returnValues values; if (!oox_ssub_pr) return values; values.colorFlag = convert(oox_ssub_pr->m_oCtrlPr.GetPointer()).colorFlag; return values; } void OoxConverter::convert(OOX::Logic::CSSubSup *oox_ssub_sup) { if (!oox_ssub_sup) return; returnValues values = convert(oox_ssub_sup->m_oSSubSupPr.GetPointer()); { CREATE_MATH_TAG(L"msubsup"); OPEN_MATH_TAG(elm); lvl_up_counter_increace(0.4); lvl_down_counter_decreace(0.4); mrow(); convert(oox_ssub_sup->m_oElement.GetPointer()); endOfMrow(); mrow(); convert(oox_ssub_sup->m_oSub.GetPointer()); endOfMrow(); mrow(); convert(oox_ssub_sup->m_oSup.GetPointer()); endOfMrow(); CLOSE_MATH_TAG; lvl_up_counter_decreace(0.4); lvl_down_counter_increace(0.4); } if (values.colorFlag) { CLOSE_MATH_TAG; } } returnValues OoxConverter::convert(OOX::Logic::CSSubSupPr *oox_ssub_sup_pr) { returnValues values; if (!oox_ssub_sup_pr) return values; convert(oox_ssub_sup_pr->m_oAlnScr.GetPointer()); values.colorFlag = convert(oox_ssub_sup_pr->m_oCtrlPr.GetPointer()).colorFlag; return values; } void OoxConverter::convert(OOX::Logic::CAlnScr* oox_aln_scr) { if (!oox_aln_scr) return; } void OoxConverter::convert(OOX::Logic::CSSup *oox_ssup) { if (!oox_ssup) return; returnValues values = convert(oox_ssup->m_oSSupPr.GetPointer()); convert(oox_ssup->m_oSup.GetPointer(), oox_ssup->m_oElement.GetPointer()); if (values.colorFlag) { CLOSE_MATH_TAG; } } returnValues OoxConverter::convert(OOX::Logic::CSSupPr *oox_ssup_pr) { returnValues values; if (!oox_ssup_pr) return values; values.colorFlag = convert(oox_ssup_pr->m_oCtrlPr.GetPointer()).colorFlag; return values; } void OoxConverter::convert(OOX::Logic::CElement *oox_elm) { if (!oox_elm) return; resizeBrackets(); if (!brackets()[lvl_of_me()].empty()) { for (size_t i = 0; i < brackets()[lvl_of_me()].size() / 2; ++i) { CREATE_MATH_TAG(L"mo") elm->add_text(brackets()[lvl_of_me()][i]); OPEN_MATH_TAG(elm) CLOSE_MATH_TAG } } mrow(); for (size_t i = 0; i < oox_elm->m_arrItems.size(); ++i) { convert(oox_elm->m_arrItems[i]); } endOfMrow(); if (!brackets()[lvl_of_me()].empty()) { for (size_t i = brackets()[lvl_of_me()].size() / 2; i < brackets()[lvl_of_me()].size(); ++i) { CREATE_MATH_TAG(L"mo") elm->add_text(brackets()[lvl_of_me()][i]); OPEN_MATH_TAG(elm) CLOSE_MATH_TAG } } brackets()[lvl_of_me()].clear(); if (lvl_of_me() != 0) { lvl_of_me()--; brackets().pop_back(); } if (!end_counter().empty()) { for (size_t i = 0; i < end_counter()[end_counter().size() - 1]; ++i) CLOSE_MATH_TAG end_counter().pop_back(); } } }