vmime/src/parameter.cpp

183 lines
3.9 KiB
C++
Raw Normal View History

2004-10-05 10:28:21 +00:00
//
2005-03-18 21:33:11 +00:00
// VMime library (http://www.vmime.org)
// Copyright (C) 2002-2005 Vincent Richard <vincent@vincent-richard.net>
2004-10-05 10:28:21 +00:00
//
// 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 "vmime/parameter.hpp"
#include "vmime/parameterFactory.hpp"
2004-10-05 10:28:21 +00:00
namespace vmime
{
2005-07-12 22:28:02 +00:00
ref <component> parameter::clone() const
2004-10-05 10:28:21 +00:00
{
2005-07-12 22:28:02 +00:00
ref <parameter> p = parameterFactory::getInstance()->create(m_name);
2004-10-05 10:28:21 +00:00
p->copyFrom(*this);
return (p);
}
2004-10-21 15:05:47 +00:00
void parameter::copyFrom(const component& other)
2004-10-05 10:28:21 +00:00
{
2004-10-21 15:05:47 +00:00
const parameter& param = dynamic_cast <const parameter&>(other);
2004-10-05 10:28:21 +00:00
m_name = param.m_name;
2004-10-21 15:05:47 +00:00
getValue().copyFrom(param.getValue());
}
parameter& parameter::operator=(const parameter& other)
{
copyFrom(other);
return (*this);
}
const string& parameter::getName() const
{
return (m_name);
}
void parameter::parse(const string& buffer, const string::size_type position,
const string::size_type end, string::size_type* newPosition)
{
getValue().parse(buffer, position, end, newPosition);
2004-12-15 20:28:09 +00:00
setParsedBounds(position, end);
2005-04-12 18:42:54 +00:00
if (newPosition)
*newPosition = end;
}
void parameter::parse(const std::vector <valueChunk>& chunks)
{
string value;
for (std::vector <valueChunk>::const_iterator it = chunks.begin() ;
it != chunks.end() ; ++it)
{
value += (*it).data;
}
getValue().parse(value, 0, value.length(), NULL);
2004-10-21 15:05:47 +00:00
}
void parameter::generate(utility::outputStream& os, const string::size_type maxLineLength,
const string::size_type curLinePos, string::size_type* newLinePos) const
{
string::size_type pos = curLinePos;
if (pos + m_name.length() + 10 > maxLineLength)
{
os << NEW_LINE_SEQUENCE;
pos = NEW_LINE_SEQUENCE_LENGTH;
}
os << m_name << "=";
pos += m_name.length() + 1;
generateValue(os, maxLineLength, pos, newLinePos);
}
void parameter::generateValue(utility::outputStream& os, const string::size_type /* maxLineLength */,
const string::size_type curLinePos, string::size_type* newLinePos) const
{
2005-04-12 18:42:54 +00:00
// NOTE: This default implementation does not support parameter
// values that span on several lines ('defaultParameter' can do
// that, following rules specified in RFC-2231).
2004-10-21 15:05:47 +00:00
std::ostringstream valueStream;
utility::outputStreamAdapter valueStreamV(valueStream);
getValue().generate(valueStreamV, lineLengthLimits::infinite, 0, NULL);
const string value(valueStream.str());
std::ostringstream ss;
string::const_iterator start = value.begin();
bool quoted = false;
for (string::const_iterator i = value.begin() ; i != value.end() ; ++i)
{
switch (*i)
{
// Characters that need to be quoted _and_ escaped
case '"':
case '\\':
ss << string(start, i) << "\\" << *i;
start = i + 1;
quoted = true;
break;
// Other characters that need quoting
case ' ':
case '\t':
case '(':
case ')':
case '<':
case '>':
case '@':
case ',':
case ';':
case ':':
case '/':
case '[':
case ']':
case '?':
case '=':
quoted = true;
break;
}
}
if (start != value.end())
ss << string(start, value.end());
if (quoted)
os << "\"" << ss.str() << "\"";
else
os << ss.str();
if (newLinePos)
*newLinePos = curLinePos + ss.str().length() + 2;
2004-10-05 10:28:21 +00:00
}
2005-07-12 22:28:02 +00:00
const std::vector <ref <const component> > parameter::getChildComponents() const
{
2005-07-12 22:28:02 +00:00
std::vector <ref <const component> > list;
2005-07-12 22:28:02 +00:00
list.push_back(getValueImp());
return (list);
}
2004-10-05 10:28:21 +00:00
} // vmime