diff options
Diffstat (limited to 'src/text.cpp')
-rw-r--r-- | src/text.cpp | 240 |
1 files changed, 240 insertions, 0 deletions
diff --git a/src/text.cpp b/src/text.cpp new file mode 100644 index 00000000..db993136 --- /dev/null +++ b/src/text.cpp @@ -0,0 +1,240 @@ +// +// VMime library (http://vmime.sourceforge.net) +// Copyright (C) 2002-2004 Vincent Richard <[email protected]> +// +// This program is free software; you can redistribute it and/or +// modify it under the terms of the GNU General Public License as +// published by the Free Software Foundation; either version 2 of +// the License, or (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program; if not, write to the Free Software +// Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. +// + +#include "text.hpp" + + +namespace vmime +{ + + +text::text() +{ +} + + +text::text(const text& t) +{ + operator=(t); +} + + +text::text(const string& t, const charset& ch) +{ + makeWordsFromText(t, ch, *this); +} + + +text::text(const string& t) +{ + makeWordsFromText(t, charset::getLocaleCharset(), *this); +} + + +text::text(const word& w) +{ + append(w); +} + + +text::~text() +{ + clear(); +} + + +#if VMIME_WIDE_CHAR_SUPPORT + +const wstring text::getDecodedText() const +{ + wstring out; + + for (std::vector <word*>::const_iterator i = m_words.begin() ; i != m_words.end() ; ++i) + { + out += (*i)->getDecodedText(); + } + + return (out); +} + +#endif + + +void text::append(const word& w) +{ + m_words.push_back(new word(w)); +} + + +void text::insert(const iterator it, const word& w) +{ + m_words.insert(it.m_iterator, new word(w)); +} + + +void text::clear() +{ + free_container(m_words); + + m_words.clear(); +} + + +void text::remove(const iterator it) +{ + delete (*it.m_iterator); + m_words.erase(it.m_iterator); +} + + +text& text::operator=(const text& t) +{ + clear(); + + for (std::vector <word*>::const_iterator i = t.m_words.begin() ; i != t.m_words.end() ; ++i) + m_words.push_back(new word(**i)); + + return (*this); +} + + +const bool text::operator==(const text& t) const +{ + if (size() == t.size()) + { + bool equal = false; + + std::vector <word*>::const_iterator i = m_words.begin(); + std::vector <word*>::const_iterator j = t.m_words.begin(); + + for ( ; equal && i != m_words.end() ; ++i, ++j) + equal = (*i == *j); + + return (equal); + } + + return (false); +} + + +const bool text::operator!=(const text& t) const +{ + return !(*this == t); +} + + +/** Return the text converted into the specified charset. + * The encoded-words are decoded and then converted in the + * destination charset. + * + * @param dest output charset + * @return text decoded in the specified charset + */ + +const string text::getConvertedText(const charset& dest) const +{ + string out; + + for (std::vector <word*>::const_iterator i = m_words.begin() ; i != m_words.end() ; ++i) + { + out += (*i)->getConvertedText(dest); + } + + return (out); +} + + +/** Check whether the list of encoded-words is empty. + * + * @return true if the list contains no encoded-word, false otherwise + */ + +const bool text::empty() const +{ + return (m_words.size() == 0); +} + + +/** Return the number of encoded-words in the list. + * + * @return number of encoded-words + */ + +const size_t text::count() const +{ + return (m_words.size()); +} + + +/** Return the number of encoded-words in the list. + * + * @return number of encoded-words + */ + +const size_t text::size() const +{ + return (m_words.size()); +} + + +/** Return the first encoded-word of the list. + * + * @return first encoded-word + */ + +word& text::front() +{ + return (*m_words.front()); +} + + +/** Return the first encoded-word of the list. + * + * @return first encoded-word + */ + +const word& text::front() const +{ + return (*m_words.front()); +} + + +/** Return the last encoded-word of the list. + * + * @return last encoded-word + */ + +word& text::back() +{ + return (*m_words.back()); +} + + +/** Return the last encoded-word of the list. + * + * @return last encoded-word + */ + +const word& text::back() const +{ + return (*m_words.back()); +} + + +} // vmime |