#include "_globals.h" #include "column_wordcount.h" #include <algorithm> /* * ColWordCount */ ColWordCount::ColWordCount() : m_nVisMode(0), m_bDetail(true), m_hVisMode(NULL), m_hDetail(NULL) { } void ColWordCount::impl_copyConfig(const Column* pSource) { ColBaseWords::impl_copyConfig(pSource); const ColWordCount& src = *reinterpret_cast<const ColWordCount*>(pSource); m_nVisMode = src.m_nVisMode; m_bDetail = src.m_bDetail; } void ColWordCount::impl_configRead(const SettingsTree& settings) { ColBaseWords::impl_configRead(settings); m_nVisMode = settings.readIntRanged(con::KeyVisMode, 0, 0, 2); m_bDetail = settings.readBool(con::KeyDetail, true); } void ColWordCount::impl_configWrite(SettingsTree& settings) const { ColBaseWords::impl_configWrite(settings); settings.writeInt (con::KeyVisMode, m_nVisMode); settings.writeBool(con::KeyDetail, m_bDetail); } void ColWordCount::impl_configToUI(OptionsCtrl& Opt, OptionsCtrl::Item hGroup) { ColBaseWords::impl_configToUI(Opt, hGroup); OptionsCtrl::Group hTemp; hTemp = Opt.insertGroup(hGroup, TranslateT("Word count type")); m_hVisMode = Opt.insertRadio(hTemp, NULL, TranslateT("Total words")); Opt.insertRadio(hTemp, m_hVisMode, TranslateT("Distinct words")); Opt.insertRadio(hTemp, m_hVisMode, TranslateT("Ratio total/distinct words")); m_hDetail = Opt.insertCheck(hGroup, TranslateT("Additional info in tooltip (depends on type)")); Opt.setRadioChecked(m_hVisMode, m_nVisMode); Opt.checkItem (m_hDetail , m_bDetail ); } void ColWordCount::impl_configFromUI(OptionsCtrl& Opt) { ColBaseWords::impl_configFromUI(Opt); m_nVisMode = Opt.getRadioChecked(m_hVisMode); m_bDetail = Opt.isItemChecked (m_hDetail ); } void ColWordCount::impl_contactDataFree(Contact& contact) const { ColBaseWords::impl_contactDataFree(contact); size_t* pTrData = reinterpret_cast<size_t*>(contact.getSlot(contactDataTransformSlotGet())); if (pTrData) { delete pTrData; contact.setSlot(contactDataTransformSlotGet(), NULL); } } void ColWordCount::impl_contactDataTransform(Contact& contact) const { WordMap* pData = reinterpret_cast<WordMap*>(contact.getSlot(contactDataSlotGet())); size_t* pTrData = new size_t[2]; contact.setSlot(contactDataTransformSlotGet(), pTrData); // total words pTrData[0] = 0; citer_each_(WordMap, word, *pData) { pTrData[0] += word->second.total(); } // distinct words pTrData[1] = pData->size(); } void ColWordCount::impl_contactDataTransformCleanup(Contact& contact) const { WordMap* pData = reinterpret_cast<WordMap*>(contact.getSlot(contactDataSlotGet())); if (pData) { pData->clear(); delete[] pData; contact.setSlot(contactDataSlotGet(), NULL); } } void ColWordCount::impl_outputRenderHeader(ext::ostream& tos, int row, int rowSpan) const { static const TCHAR* szTypeDesc[] = { LPGENT("Total word count"), LPGENT("Distinct word count"), LPGENT("Ratio total/distinct words") }; static const TCHAR* szSourceDesc[] = { LPGENT("incoming messages"), LPGENT("outgoing messages"), LPGENT("all messages"), }; if (row == 1) { ext::string strTitle = str(ext::kformat(TranslateT("#{type} for #{data}")) % _T("#{type}") * TranslateTS(szTypeDesc[m_nVisMode]) % _T("#{data}") * TranslateTS(szSourceDesc[m_nSource])); writeRowspanTD(tos, getCustomTitle(TranslateTS(szTypeDesc[m_nVisMode]), strTitle), row, 1, rowSpan); } } void ColWordCount::impl_outputRenderRow(ext::ostream& tos, const Contact& contact, DisplayType display) { const size_t* pWordCount = reinterpret_cast<const size_t*>(contact.getSlot(contactDataTransformSlotGet())); switch (m_nVisMode) { case 0: { if (!m_bDetail) { tos << _T("<td class=\"num\">") << utils::intToGrouped(pWordCount[0]) << _T("</td>") << ext::endl; } else { tos << _T("<td class=\"num\" title=\"") << utils::htmlEscape(ext::str(ext::kformat(TranslateT("#{distict_words} distinct")) % _T("#{distict_words}") * utils::intToGrouped(pWordCount[1]))) << _T("\">") << utils::intToGrouped(pWordCount[0]) << _T("</td>") << ext::endl; } } break; case 1: { if (!m_bDetail) { tos << _T("<td class=\"num\">") << utils::intToGrouped(pWordCount[1]) << _T("</td>") << ext::endl; } else { tos << _T("<td class=\"num\" title=\"") << utils::htmlEscape(ext::str(ext::kformat(TranslateT("#{words} total")) % _T("#{words}") * utils::intToGrouped(pWordCount[0]))) << _T("\">") << utils::intToGrouped(pWordCount[1]) << _T("</td>") << ext::endl; } } break; default: { if (!m_bDetail) { tos << _T("<td class=\"num\">") << utils::ratioToString(pWordCount[0], pWordCount[1], 2) << _T("</td>") << ext::endl; } else { tos << _T("<td class=\"num\" title=\"") << utils::htmlEscape(ext::str(ext::kformat(TranslateT("#{words} total / #{distict_words} distinct")) % _T("#{words}") * utils::intToGrouped(pWordCount[0]) % _T("#{distict_words}") * utils::intToGrouped(pWordCount[1]))) << _T("\">") << utils::ratioToString(pWordCount[0], pWordCount[1], 2) << _T("</td>") << ext::endl; } } break; } }