summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMark Brand <mabrand@mabrand.nl>2010-11-16 18:56:42 (GMT)
committerMark Brand <mabrand@mabrand.nl>2010-11-16 18:56:42 (GMT)
commitca315476968002229008a991208ad24b6c85b058 (patch)
tree67e66d66b62215c84f44c46cd6b3ec562bfe6110
parentc98fe1b13381b1b678a19b133d03de06e63a022c (diff)
downloadmxe-ca315476968002229008a991208ad24b6c85b058.zip
mxe-ca315476968002229008a991208ad24b6c85b058.tar.gz
mxe-ca315476968002229008a991208ad24b6c85b058.tar.bz2
upgrade package vmime to 0.9.1
-rw-r--r--src/vmime-1-fastforward.patch18445
-rw-r--r--src/vmime.mk4
2 files changed, 2 insertions, 18447 deletions
diff --git a/src/vmime-1-fastforward.patch b/src/vmime-1-fastforward.patch
deleted file mode 100644
index 9a55af8..0000000
--- a/src/vmime-1-fastforward.patch
+++ /dev/null
@@ -1,18445 +0,0 @@
-This file is part of mingw-cross-env.
-See doc/index.html for further information.
-
-Fast-forward to latest vmime 0.9.1 from svn
-http://sourceforge.net/projects/vmime/develop
-
-Produced with this script:
-#--------------------------------------------------------------------#
-#!/bin/bash
-
-(
- echo "This file is part of mingw-cross-env."
- echo "See doc/index.html for further information."
- echo
- echo "Fast-forward to latest vmime 0.9.1 from svn"
- echo "http://sourceforge.net/projects/vmime/develop"
- echo
- echo "Produced with this script:"
- echo "#--------------------------------------------------------------------#"
- cat "$0"
- echo "#--------------------------------------------------------------------#"
-) > src/vmime-1-fastforward.patch
-
-# setup git svn clone
-#cd ~/projects/vmime/git
-#git svn clone -s https://vmime.svn.sourceforge.net/svnroot/vmime
-#git reset --hard
-#git tag -f v0.9.1-start `git svn log --show-commit | grep r482 | cut -d "|" -f 2`
-# get updates
-#git svn fetch
-#git svn rebase
-
-GITDIR=~/projects/vmime/git/vmime/vmime
-PKGDIR=libvmime-0.9.0
-
-rm -rf $PKGDIR
-tar xf pkg/$PKGDIR.tar.bz2
-
-(
- cd $GITDIR
- git reset --hard
- git checkout master
-)
-
-# Create patch to reset the tarball tree to the
-# starting state in svn. This is actually one commit
-# before 0.9.1 started. This compensates for left out
-# and touched files. Only for files known to need it.
-lst="bootstrap \
- doc/book/intro.tex \
- doc/book/net.tex \
- examples/viewer/viewer.cpp \
- m4/acx_pthread.m4 \
- m4/ost_posix.m4 \
- m4/ost_prog.m4 \
- m4/ost_pthread.m4 \
- m4/ost_systime.m4"
-
-for a in $lst; do
- if [ -f $PKGDIR/$a ]; then
- cp $PKGDIR/$a $GITDIR/$a
- else
- rm $GITDIR/$a
- fi
-done
-
-# write reset patch
-(
- cd $GITDIR
- echo
- git diff --relative -R v0.9.1-start^ -- $lst
-) >> src/vmime-1-fastforward.patch
-
-(
- cd $GITDIR
- git reset --hard
-)
-
-# write fast forward commits
-(
- cd $GITDIR
- echo
- git log --relative --reverse -p ^v0.9.1-start^ HEAD
-) >> src/vmime-1-fastforward.patch
-
-# check the results
-patch -d $PKGDIR -p1 -s < src/vmime-1-fastforward.patch
-diff -rq $GITDIR $PKGDIR
-#--------------------------------------------------------------------#
-
-diff --git b/bootstrap a/bootstrap
-index cef3171..457eaa8 100755
---- b/bootstrap
-+++ a/bootstrap
-@@ -40,6 +40,7 @@ if test $DIE = 0 ; then
- || (echo "[NO]" ; cat bootstrap.tmpout ; rm -f bootstrap.tmpout ; not_a_command >& /dev/null) || DIE=1
- fi
-
-+# Bug with automake 1.10?
- touch autotools/config.rpath
-
- if test $DIE = 0 ; then
-diff --git b/doc/book/intro.tex a/doc/book/intro.tex
-new file mode 100644
-index 0000000..93a3675
---- /dev/null
-+++ a/doc/book/intro.tex
-@@ -0,0 +1,90 @@
-+\chapter{Introduction}
-+
-+% ============================================================================
-+\section{Overview}
-+
-+VMime is a powerful C++ class library for working with MIME messages and
-+Internet messaging services like IMAP, POP or SMTP.
-+
-+With VMime you can parse, generate and modify messages, and also connect to
-+store and transport services to receive or send messages over the Internet.
-+The library offers all the features to build a complete mail client.
-+
-+The main objectives of this library are:
-+
-+\begin{itemize}
-+\item fully RFC-compliant implementation;
-+\item object-oriented and modular design;
-+\item very easy-to-use (intuitive design);
-+\item well documented code;
-+\item very high reliability;
-+\item maximum portability.
-+\end{itemize}
-+
-+
-+% ============================================================================
-+\section{Features}
-+
-+\noindent MIME features:
-+
-+\begin{itemize}
-+\item Full support for RFC-2822 and multipart messages (RFC-1521)
-+\item Aggregate documents (MHTML) and embedded objects (RFC-2557)
-+\item Message Disposition Notification (RFC-3798)
-+\item 8-bit MIME (RFC-2047)
-+\item Encoded word extensions (RFC-2231)
-+\item Attachments
-+\end{itemize}
-+
-+\noindent Network features:
-+
-+\begin{itemize}
-+\item Support for IMAP, POP3 and maildir stores
-+\item Support for SMTP and sendmail transport methods
-+\item Extraction of whole message or specific parts
-+\item TLS/SSL security layer
-+\item SASL authentication
-+\end{itemize}
-+
-+
-+% ============================================================================
-+\section{Copyright and license}
-+
-+VMime library is Free Software and is licensed under the terms of the GNU
-+General Public License\footnote{See Appendix \ref{appendix_license} and
-+\url{http://www.gnu.org/copyleft/gpl.html}} (GPL):
-+
-+\begin{verbatim}
-+ Copyright (C) 2002-2008 Vincent Richard
-+
-+ VMime library 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.
-+
-+ VMime 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.
-+
-+ Linking this library statically or dynamically with other
-+ modules is making a combined work based on this library.
-+ Thus, the terms and conditions of the GNU General Public
-+ License cover the whole combination.
-+\end{verbatim}
-+
-+\newpage
-+\noindent This document is released under the terms of the
-+GNU Free Documentation
-+License\footnote{See \url{http://www.gnu.org/copyleft/fdl.html}} (FDL):
-+
-+\begin{verbatim}
-+ Copyright (C) 2004-2007 Vincent Richard
-+
-+ Permission is granted to copy, distribute and/or modify
-+ this document under the terms of the GNU Free Documentation
-+ License, Version 1.2 or any later version published by the
-+ Free Software Foundation; with no Invariant Sections, no
-+ Front-Cover Texts, and no Back-Cover Texts.
-+\end{verbatim}
-+
-diff --git b/doc/book/net.tex a/doc/book/net.tex
-new file mode 100644
-index 0000000..08b7df5
---- /dev/null
-+++ a/doc/book/net.tex
-@@ -0,0 +1,976 @@
-+\chapter{Working with Messaging Services}
-+
-+% ============================================================================
-+\section{Introduction}
-+
-+In addition to parsing and building MIME messages, VMime also offers a lot of
-+features to work with messaging services. This includes connecting to remote
-+messaging stores (like IMAP or POP3), local stores (maildir) and transport
-+services (send messages over SMTP or local sendmail), through an unified
-+interface (see Figure \ref{uml_messaging_module}). That means that you can
-+use independently IMAP of POP3 without having to change any line of code.
-+
-+Source code of {\vexample Example6} covers all features presented in this
-+chapter, so it is important you take some time to read it.
-+
-+\begin{figure}
-+ \center\includegraphics[width=0.9\textwidth]
-+ {images/messaging-services.png}
-+ \caption{Overall structure of the messaging module}
-+ \label{uml_messaging_module}
-+\end{figure}
-+
-+The interface is composed of five classes:
-+
-+\begin{itemize}
-+\item {\vcode vmime::net::service}: this is the base interface for a
-+messaging service. It can be either a store service or a transport
-+service.
-+
-+\item {\vcode vmime::net::serviceFactory}: create instances of a service.
-+This is used internally by the session object (see below).
-+
-+\item {\vcode vmime::net::store}: interface for a store service. A store
-+service offers access to a set of folders containing messages. This is
-+used for IMAP, POP3 and maildir.
-+
-+\item {\vcode vmime::net::transport}: interface for a transport service.
-+A transport service is capable of sending messages. This is used for
-+SMTP and sendmail.
-+
-+\item {\vcode vmime::net::session}: a session oject is used to store the
-+parameters used by a service (eg. connection parameters). Each service
-+instance is associated with only one session. The session object is capable
-+of creating instances of services.
-+\end{itemize}
-+
-+The following classes are specific to store services:
-+
-+\begin{itemize}
-+\item {\vcode vmime::net::folder}: a folder can either contain other folders
-+or messages, or both.
-+
-+\item {\vcode vmime::net::message}: this is the interface for dealing with
-+messages. For a given message, you can have access to its flags, its MIME
-+structure and you can also extract the whole message data or given parts (if
-+supported by the underlying protocol).
-+\end{itemize}
-+
-+
-+% ============================================================================
-+\section{Working with sessions}
-+
-+\subsection{Setting properties} % --------------------------------------------
-+
-+Sessions are used to store configuration parameters for services. They
-+contains a set of typed properties that can modify the behaviour of the
-+services. Before using a messaging service, you must create and
-+initialize a session object:
-+
-+\begin{lstlisting}
-+vmime::ref <net::session> theSession = vmime::create <net::session>();
-+\end{lstlisting}
-+
-+Session properties include:
-+
-+\begin{itemize}
-+\item connection parameters: host and port to connect to;
-+\item authentication parameters: user credentials required to use the
-+service (if any);
-+\item protocol-specific parameters: enable or disable extensions (eg. APOP
-+support in POP3).
-+\end{itemize}
-+
-+Properties are stored using a dotted notation, to specify the service type,
-+the protocol name, the category and the name of the property:
-+
-+\begin{verbatim}
-+ {service_type}.{protocol}.category.name
-+\end{verbatim}
-+
-+An example of property is \emph{store.pop3.options.apop} (used to enable or
-+disable the use of APOP authentication). The \emph{store.pop3} part is called
-+the \emph{prefix}. This allow specifying different values for the same
-+property depending on the protocol used.
-+
-+The session properties are stored in a {\vcode vmime::propertySet} object.
-+To set the value of a property, you can use either:
-+
-+\begin{lstlisting}
-+theSession->getProperties().setProperty("property-name", value);
-+\end{lstlisting}
-+
-+or:
-+
-+\begin{lstlisting}
-+theSession->getProperties()["property-name"] = value;
-+\end{lstlisting}
-+
-+
-+\subsection{Available properties} % ------------------------------------------
-+
-+Following is a list of available properties and the protocols they apply to,
-+as the time of writing this documentation\footnote{You can get an up-to-date
-+list of the properties by running \vexample{Example7}}. For better clarity,
-+the prefixes do not appear in this table.
-+
-+\begin{table}[!ht]
-+\noindent\begin{tabularx}{1.0\textwidth}{|l|c|X|c|c|c|c|c|c|c|c|}
-+\hline
-+ {\bf Property name} &
-+ {\bf Type} &
-+ {\bf Description} &
-+ \verti{\bf POP3} &
-+ \verti{\bf POP3S} &
-+ \verti{\bf IMAP} &
-+ \verti{\bf IMAPS} &
-+ \verti{\bf SMTP} &
-+ \verti{\bf SMTPS} &
-+ \verti{\bf maildir} &
-+ \verti{\bf sendmail} \\
-+\hline
-+\hline
-+options.sasl & bool & Set to {\vcode true} to use SASL authentication, if
-+available. & \vdot & \vdot & \vdot & \vdot & \vdot & \vdot & & \\
-+\hline
-+options.sasl.fallback & bool & Fail if SASL authentication failed (do not
-+try other authentication mechanisms). & \vdot & \vdot & \vdot & \vdot &
-+\vdot & \vdot & & \\
-+\hline
-+auth.username\footnote{You should use authenticators
-+instead.\label{fn_auth_username}} & string & Set the username of the account
-+to connect to. & \vdot & \vdot & \vdot & \vdot & \vdot & \vdot & & \\
-+\hline
-+auth.password\footref{fn_auth_username} & string & Set the password of the
-+account. & \vdot & \vdot & \vdot & \vdot & \vdot & \vdot & & \\
-+\hline
-+connection.tls & bool & Set to {\vcode true} to start a secured connection
-+using STARTTLS extension, if available. & \vdot & & \vdot & & \vdot & & & \\
-+\hline
-+connection.tls.required & bool & Fail if a secured connection cannot be
-+started. & \vdot & & \vdot & & \vdot & & & \\
-+\hline
-+server.address & string & Server host name or IP address. &\vdot & \vdot &
-+\vdot & \vdot & \vdot & \vdot & & \\
-+\hline
-+server.port & int & Server port. & \vdot & \vdot & \vdot & \vdot &
-+\vdot & \vdot & & \\
-+\hline
-+server.rootpath & string & Root directory for mail repository (eg.
-+\emph{/home/vincent/Mail}). & & & & & & & \vdot & \\
-+\hline
-+\end{tabularx}
-+\caption{Properties common to all protocols}
-+\end{table}
-+
-+\newpage
-+These are the protocol-specific options:
-+
-+\begin{table}[!ht]
-+\noindent\begin{tabularx}{1.0\textwidth}{|l|c|X|}
-+\hline
-+ {\bf Property name} &
-+ {\bf Type} &
-+ {\bf Description} \\
-+% POP3/POP3S
-+\hline
-+\multicolumn{3}{|c|}{POP3, POP3S} \\
-+\hline
-+store.pop3.options.apop & bool & Enable or disable authentication with
-+APOP (if SASL is enabled, this occurs after all SASL mechanisms have been
-+tried). \\
-+\hline
-+store.pop3.options.apop.fallback & bool & If set to {\vcode true} and
-+APOP fails, the authentication process fails (ie. unsecure plain text
-+authentication is not used). \\
-+\hline
-+% SMTP
-+\multicolumn{3}{|c|}{SMTP, SMTPS} \\
-+\hline
-+transport.smtp.options.need-authentication & bool & Set to \emph{true} if
-+the server requires to authenticate before sending messages. \\
-+\hline
-+% sendmail
-+\multicolumn{3}{|c|}{sendmail} \\
-+\hline
-+transport.sendmail.binpath & string & The path to the \emph{sendmail}
-+executable on your system. The default is the one found by the configuration
-+script when VMime was built. \\
-+\hline
-+\end{tabularx}
-+\caption{Protocol-specific options}
-+\end{table}
-+
-+
-+\subsection{Instanciating services} % ----------------------------------------
-+
-+You can create a service either by specifying its protocol name, or by
-+specifying the URL of the service. Creation by name is deprecated so
-+this chapter only presents the latter option.
-+
-+The URL scheme for connecting to services is:
-+
-+\begin{verbatim}
-+ protocol://[username[:password]@]host[:port]/[root-path]
-+\end{verbatim}
-+
-+\vnote{For local services (ie. \emph{sendmail} and \emph{maildir}), the host
-+part is not used, but it must not be empty (you can use "localhost").}
-+
-+The following table shows an example URL for each service:
-+
-+\noindent\begin{tabularx}{1.0\textwidth}{|c|X|}
-+\hline
-+ {\bf Service} &
-+ {\bf Connection URL} \\
-+\hline
-+imap, imaps & {\tt imap://imap.example.com},
-+{\tt imaps://vincent:pass@example.com} \\
-+\hline
-+pop3, pop3s & {\tt pop3://pop3.example.com} \\
-+\hline
-+smtp, smtps & {\tt smtp://smtp.example.com} \\
-+\hline
-+maildir & {\tt maildir://localhost/home/vincent/Mail} (host not used) \\
-+\hline
-+sendmail & {\tt sendmail://localhost} (host not used, always localhost) \\
-+\hline
-+\end{tabularx}
-+
-+\newpage
-+
-+When you have the connection URL, instanciating the service is quite simple.
-+Depending on the type of service, you will use either {\vcode getStore()} or
-+{\vcode getTransport()}. For example, for store services, use:
-+
-+\begin{lstlisting}
-+vmime::utility:url url("imap://user:pass@imap.example.com");
-+vmime::ref <vmime::net::store> st = sess->getStore(url);
-+\end{lstlisting}
-+
-+and for transport services:
-+
-+\begin{lstlisting}
-+vmime::utility:url url("smtp://smtp.example.com");
-+vmime::ref <vmime::net::transport> tr = sess->getTransport(url);
-+\end{lstlisting}
-+
-+
-+% ============================================================================
-+\section{User credentials and authenticators}
-+
-+Some services need some user credentials (eg. username and password) to open
-+a session. In VMime, user credentials can be specified in the session
-+properties or by using a custom authenticator (callback).
-+
-+\begin{lstlisting}[caption={Setting user credentials using session
-+properties}]
-+vmime::ref <vmime::net::session> sess; // Suppose we have a session
-+
-+sess->getProperties()["store.imap.auth.username"] = "vincent";
-+sess->getProperties()["store.imap.auth.password"] = "my-password";
-+\end{lstlisting}
-+
-+Although not recommended, you can also specify username and password
-+directly in the connection URL,
-+ie: \emph{imap://username:password@imap.example.com/}. This works only for
-+services requiring an username and a password as user credentials, and no
-+other information.
-+
-+Sometimes, it may not be very convenient to set username/password in the
-+session properties, or not possible (eg. extended SASL mechanisms) . That's
-+why VMime offers an alternate way of getting user credentials: the
-+{\vcode authenticator} object. Basically, an authenticator is an object that
-+can return user credentials on-demand (like a callback).
-+
-+Currently, there are two types of authenticator in VMime: a basic
-+authenticator (class {\vcode vmime::security::authenticator}) and, if SASL
-+support is enabled, a SASL authenticator
-+(class {\vcode vmime::security::sasl::SASLAuthenticator}). Usually, you
-+should use the default implementations, or at least make your own
-+implementation inherit from them.
-+
-+The following example shows how to use a custom authenticator to request
-+the user to enter her/his credentials:
-+
-+\begin{lstlisting}[caption={A simple interactive authenticator}]
-+class myAuthenticator : public vmime::security::defaultAuthenticator
-+{
-+ const string getUsername() const
-+ {
-+ std::cout << "Enter your username: " << std::endl;
-+
-+ vmime::string res;
-+ std::getline(std::cin, res);
-+
-+ return res;
-+ }
-+
-+ const string getPassword() const
-+ {
-+ std::cout << "Enter your password: " << std::endl;
-+
-+ vmime::string res;
-+ std::getline(std::cin, res);
-+
-+ return res;
-+ }
-+};
-+\end{lstlisting}
-+
-+This is how to use it:
-+
-+\begin{lstlisting}
-+// First, create a session
-+vmime::ref <vmime::net::session> sess =
-+ vmime::create <vmime::net::session>();
-+
-+// Next, initialize a service which will use our authenticator
-+vmime::ref <vmime::net::store> st =
-+ sess->getStore(vmime::utility::url("imap://imap.example.com"),
-+ /* use our authenticator */ vmime::create <myAuthenticator>());
-+\end{lstlisting}
-+
-+\vnote{An authenticator object should be used with one and only one service
-+at a time. This is required because the authentication process may need to
-+retrieve the service name (SASL).}
-+
-+Of course, this example is quite simplified. For example, if several
-+authentication mechanisms are tried, the user may be requested to enter the
-+same information multiple times. See {\vexample Example6} for a more complex
-+implementation of an authenticator, with caching support.
-+
-+If you want to use SASL (ie. if \emph{options.sasl} is set to \emph{true}),
-+your authenticator must inherit from
-+{\vcode vmime::security::sasl::SASLAuthenticator} or
-+{\vcode vmime::security::sasl::defaultSASLAuthenticator}, even if you do not
-+use the SASL-specific methods {\vcode getAcceptableMechanisms()} and
-+{\vcode setSASLMechanism()}. Have a look at {\vexample Example6} to see an
-+implementation of an SASL authenticator.
-+
-+\begin{lstlisting}[caption={A simple SASL authenticator}]
-+class mySASLAuthenticator : public vmime::security::sasl::defaultSASLAuthenticator
-+{
-+ typedef vmime::security::sasl::SASLMechanism mechanism; // save us typing
-+
-+ const std::vector <vmime::ref <mechanism > getAcceptableMechanisms
-+ (const std::vector <vmime::ref <mechanism> >& available,
-+ vmime::ref <mechanism> suggested) const
-+ {
-+ // Here, you can sort the SASL mechanisms in the order they will be
-+ // tried. If no SASL mechanism is acceptable (ie. for example, not
-+ // enough secure), you can return an empty list.
-+ //
-+ // If you do not want to bother with this, you can simply return
-+ // the default list, which is ordered by security strength.
-+ return defaultSASLAuthenticator::
-+ getAcceptableMechanisms(available, suggested);
-+ }
-+
-+ void setSASLMechanism(vmime::ref <mechanism> mech)
-+ {
-+ // This is called when the authentication process is going to
-+ // try the specified mechanism.
-+ //
-+ // The mechanism name is in mech->getName()
-+
-+ defaultSASLAuthenticator::setSASLMechanism(mech);
-+ }
-+
-+ // ...implement getUsername() and getPassword()...
-+};
-+\end{lstlisting}
-+
-+
-+% ============================================================================
-+\section{Using transport service}
-+
-+You have two possibilities for giving message data to the service when you
-+want to send a message:
-+
-+\begin{itemize}
-+\item either you have a reference to a message (type {\vcode vmime::message})
-+and you can simply call {\vcode send(msg)};
-+\item or you only have raw message data (as a string, for example), and you
-+have to call the second overload of {\vcode send()}, which takes additional
-+parameters (corresponding to message envelope);
-+\end{itemize}
-+
-+The following example illustrates the use of a transport service to send a
-+message using the second method:
-+
-+\begin{lstlisting}[caption={Using a transport service}]
-+const vmime::string msgData =
-+ "From: me@example.org \r\n"
-+ "To: you@example.org \r\n"
-+ "Date: Sun, Oct 30 2005 17:06:42 +0200 \r\n"
-+ "Subject: Test \r\n"
-+ "\r\n"
-+ "Message body";
-+
-+// Create a new session
-+vmime::utility::url url("smtp://example.com");
-+
-+vmime::ref <vmime::net::session> sess =
-+ vmime::create <vmime::net::session>();
-+
-+// Create an instance of the transport service
-+vmime::ref <vmime::net::transport> tr = sess->getTransport(url);
-+
-+// Connect it
-+tr->connect();
-+
-+// Send the message
-+vmime::utility::inputStreamStringAdapter is(msgData);
-+
-+vmime::mailbox from("me@example.org");
-+vmime::mailboxList to;
-+to.appendMailbox(vmime::create <vmime::mailbox>("you@example.org"));
-+
-+tr->send(
-+ /* expeditor */ from,
-+ /* recipient(s) */ to,
-+ /* data */ is,
-+ /* total length */ msgData.length());
-+
-+// We have finished using the service
-+tr->disconnect();
-+\end{lstlisting}
-+
-+\vnote{Exceptions can be thrown at any time when using a service. For better
-+clarity, exceptions are not caught here, but be sure to catch them in your own
-+application to provide error feedback to the user.}
-+
-+If you use SMTP, you can enable authentication by setting some properties
-+on the session object ({\vcode service::setProperty()} is a shortcut for
-+setting properties on the session with the correct prefix):
-+
-+\begin{lstlisting}
-+tr->setProperty("options.need-authentication", true);
-+tr->setProperty("auth.username", "user");
-+tr->setProperty("auth.password", "password");
-+\end{lstlisting}
-+
-+
-+% ============================================================================
-+\section{Using store service}
-+
-+\subsection{Connecting to a store} % -----------------------------------------
-+
-+The first basic step for using a store service is to connect to it. The
-+following example shows how to initialize a session and instanciate the
-+store service:
-+
-+\begin{lstlisting}[caption={Connecting to a store service}]
-+// Create a new session
-+vmime::utility::url url("imap://vincent:password@imap:example.org");
-+
-+vmime::ref <vmime::net::session> sess =
-+ vmime::create <vmime::net::session>();
-+
-+// Create an instance of the transport service
-+vmime::ref <vmime::net::store> store = sess->getStore(url);
-+
-+// Connect it
-+store->connect();
-+\end{lstlisting}
-+
-+\vnote{{\vexample Example6} contains a more complete example for connecting
-+to a store service, with support for a custom authenticator.}
-+
-+\subsection{Opening a folder} % ----------------------------------------------
-+
-+You can open a folder using two different access modes: either in
-+\emph{read-only} mode (where you can only read message flags and contents), or
-+in \emph{read-write} mode (where you can read messages, but also delete them
-+or add new ones). When you have a reference to a folder, simply call the
-+{\vcode open()} method with the desired access mode:
-+
-+\begin{lstlisting}
-+folder->open(vmime::net::folder::MODE_READ_WRITE);
-+\end{lstlisting}
-+
-+\vnote{Not all stores support the \emph{read-write} mode. By default, if the
-+\emph{read-write} mode is not available, the folder silently fall backs on
-+the \emph{read-only} mode, unless the \emph{failIfModeIsNotAvailable} argument
-+to {\vcode open()} is set to true.}
-+
-+Call {\vcode getDefaultFolder()} on the store to obtain a reference to the
-+default folder, which is usually the INBOX folder (where messages arrive when
-+they are received).
-+
-+You can also open a specific folder by specifying its path. The following
-+example will open a folder named \emph{bar}, which is a child of \emph{foo}
-+in the root folder:
-+
-+\begin{lstlisting}[caption={Opening a folder from its path}]
-+vmime::net::folder::path path;
-+path /= vmime::net::folder::path::component("foo");
-+path /= vmime::net::folder::path::component("bar");
-+
-+vmime::ref <vmime::net::folder> fld = store->getFolder(path);
-+fld->open(vmime::net::folder::MODE_READ_WRITE);
-+\end{lstlisting}
-+
-+\vnote{You can specify a path as a string as there is no way to get the
-+separator used to delimitate path components. Always use {\vcode operator/=}
-+or {\vcode appendComponent}.}
-+
-+\vnote{Path components are of type {\vcode vmime::word}, which means that
-+VMime supports folder names with extended characters, not only 7-bit
-+US-ASCII. However, be careful that this may not be supported by the
-+underlying store protocol (IMAP supports it, because it uses internally a
-+modified UTF-7 encoding).}
-+
-+\subsection{Fetching messages} % ---------------------------------------------
-+
-+You can fetch some information about a message without having to download the
-+whole message. Moreover, folders support fetching for multiple messages in
-+a single request, for better performance. The following items are currently
-+available for fetching:
-+
-+\begin{itemize}
-+\item {\bf envelope}: sender, recipients, date and subject;
-+\item {\bf structure}: MIME structure of the message;
-+\item {\bf content-info}: content-type of the root part;
-+\item {\bf flags}: message flags;
-+\item {\bf size}: message size;
-+\item {\bf header}: retrieve all the header fields of a message;
-+\item {\bf uid}: unique identifier of a message;
-+\item {\bf importance}: fetch header fields suitable for use with
-+{\vcode misc::importanceHelper}.
-+\end{itemize}
-+
-+\vnote{Not all services support all fetchable items. Call
-+{\vcode getFetchCapabilities()} on a folder to know which information can be
-+fetched by a service.}
-+
-+The following code shows how to list all the messages in a folder, and
-+retrieve basic information to show them to the user:
-+
-+\begin{lstlisting}[caption={Fetching information about multiple messages}]
-+std::vector <ref <vmime::net::message> > allMessages = folder->getMessages();
-+
-+folder->fetchMessages(allMessages,
-+ vmime::net::folder::FETCH_FLAGS |
-+ vmime::net::folder::FETCH_ENVELOPE);
-+
-+for (unsigned int i = 0 ; i < allMessages.size() ; ++i)
-+{
-+ vmime::ref <vmime::net::message> msg = allMessages[i];
-+
-+ const int flags = msg->getFlags();
-+
-+ std::cout << "Message " << i << ":" << std::endl;
-+
-+ if (flags & vmime::net::message::FLAG_SEEN)
-+ std::cout << " - is read" << std::endl;
-+ if (flags & vmime::net::message::FLAG_DELETED)
-+ std::cout << " - is deleted" << std::endl;
-+
-+ vmime::ref <const vmime::header> hdr = msg->getHeader();
-+
-+ std::cout << " - sent on " << hdr->Date()->generate() << std::endl;
-+ std::cout << " - sent by " << hdr->From()->generate() << std::endl;
-+}
-+\end{lstlisting}
-+
-+\subsection{Extracting messages and parts}
-+
-+To extract the whole contents of a message (including headers), use the
-+{\vcode extract()} method on a {\vcode vmime::net::message} object. The
-+following example extracts the first message in the default folder:
-+
-+\begin{lstlisting}[caption={Extracting messages}]
-+// Get a reference to the folder and to its first message
-+vmime::ref <vmime::net::folder> folder = store->getDefaultFolder();
-+vmime::ref <vmime::net::message> msg = folder->getMessage(1);
-+
-+// Write the message contents to the standard output
-+vmime::utility::outputStreamAdapter out(std::cout);
-+msg->extract(out);
-+\end{lstlisting}
-+
-+Some protocols (like IMAP) also support the extraction of specific MIME parts
-+of a message without downloading the whole message. This can save bandwidth
-+and time. The method {\vcode extractPart()} is used in this case:
-+
-+\begin{lstlisting}[caption={Extracting a specific MIME part of a message}]
-+// Fetching structure is required before extracting a part
-+folder->fetchMessage(msg, vmime::net::folder::FETCH_STRUCTURE);
-+
-+// Now, we can extract the part
-+msg->extractPart(msg->getStructure()->getPartAt(0)->getPartAt(1));
-+\end{lstlisting}
-+
-+Suppose we have a message with the following structure:
-+
-+\begin{verbatim}
-+ multipart/mixed
-+ text/html
-+ image/jpeg [*]
-+\end{verbatim}
-+
-+The previous example will extract the header and body of the \emph{image/jpeg}
-+part.
-+
-+\subsection{Events} % --------------------------------------------------------
-+
-+As a result of executing some operation (or from time to time, even if no
-+operation has been performed), a store service can send events to notify you
-+that something has changed (eg. the number of messages in a folder). These
-+events may allow you to update the user interface associated to a message
-+store.
-+
-+Currently, there are three types of event:
-+
-+\begin{itemize}
-+\item {\bf message change}: sent when the number of messages in a folder
-+has changed (ie. some messages have been added or removed);
-+\item {\bf message count change}: sent when one or more message(s) have
-+changed (eg. flags or deleted status);
-+\item {\bf folder change}: sent when a folder has been created, renamed or
-+deleted.
-+\end{itemize}
-+
-+You can register a listener for each event type by using the corresponding
-+methods on a {\vcode folder} object: {\vcode addMessageChangedListener()},
-+{\vcode addMessageCountListener()} or {\vcode addFolderListener()}. For more
-+information, please read the class documentation for
-+{\vcode vmime::net::events} namespace.
-+
-+
-+% ============================================================================
-+\section{Handling time-outs}
-+
-+Unexpected errors can occur while messaging services are performing
-+operations and waiting a response from the server (eg. server stops
-+responding, network link falls down). As all operations as synchronous,
-+they can be ``blocked'' a long time before returning (in fact, they loop
-+until they either receive a response from the server, or the underlying
-+socket system returns an error).
-+
-+VMime provides a mechanism to control the duration of operations. This
-+mechanism allows the program to cancel an operation that is currently
-+running.
-+
-+An interface called {\vcode timeoutHandler} is provided:
-+
-+\begin{lstlisting}
-+class timeoutHandler : public object
-+{
-+ /** Called to test if the time limit has been reached.
-+ *
-+ * @return true if the time-out delay is elapsed
-+ */
-+ virtual const bool isTimeOut() = 0;
-+
-+ /** Called to reset the time-out counter.
-+ */
-+ virtual void resetTimeOut() = 0;
-+
-+ /** Called when the time limit has been reached (when
-+ * isTimeOut() returned true).
-+ *
-+ * @return true to continue (and reset the time-out)
-+ * or false to cancel the current operation
-+ */
-+ virtual const bool handleTimeOut() = 0;
-+};
-+\end{lstlisting}
-+
-+While the operation runs, the service calls {\vcode isTimeout()} at variable
-+intervals. If the function returns {\vcode true}, then
-+{\vcode handleTimeout()} is called. If it also returns {\vcode true}, the
-+operation is cancelled and an {\vcode operation\_timed\_out} exception is
-+thrown. The function {\vcode resetTimeout()} is called each time data has
-+been received from the server to reset time-out delay.
-+
-+The following example shows how to implement a simple time-out handler:
-+
-+\begin{lstlisting}[caption={Implementing a simple time-out handler}]
-+class myTimeoutHandler : public vmime::net::timeoutHandler
-+{
-+public:
-+
-+ const bool isTimeOut()
-+ {
-+ return (getTime() >= m_last + 30); // 30 seconds time-out
-+ }
-+
-+ void resetTimeOut()
-+ {
-+ m_last = getTime();
-+ }
-+
-+ const bool handleTimeOut()
-+ {
-+ std::cout << "Operation timed out." << std::endl;
-+ << "Press [Y] to continue, or [N] to "
-+ << "cancel the operation." << std::endl;
-+
-+ std::string response;
-+ std::cin >> response;
-+
-+ return (response == "y" || response == "Y");
-+ }
-+
-+private:
-+
-+ const unsigned int getTime() const
-+ {
-+ return vmime::platform::getHandler()->getUnixTime();
-+ }
-+
-+ unsigned int m_last;
-+};
-+\end{lstlisting}
-+
-+To make the service use your time-out handler, you need to write a factory
-+class, to allow the service to create instances of the handler class. This
-+is required because the service can use several connections to the server
-+simultaneously, and each connection needs its own time-out handler.
-+
-+\begin{lstlisting}
-+class myTimeoutHandlerFactory : public vmime::net::timeoutHandlerFactory
-+{
-+public:
-+
-+ ref <timeoutHandler> create()
-+ {
-+ return vmime::create <myTimeoutHandler>();
-+ }
-+};
-+\end{lstlisting}
-+
-+Then, call the {\vcode setTimeoutHandlerFactory()} method on the service object
-+to set the time-out handler factory to use during the session:
-+
-+\begin{lstlisting}
-+theService->setTimeoutHandlerFactory(vmime::create <myTimeoutHandlerFactory>());
-+\end{lstlisting}
-+
-+
-+% ============================================================================
-+\newpage
-+\section{Secured connection using TLS/SSL}
-+
-+\subsection{Introduction} % --------------------------------------------------
-+
-+If you have enabled TLS support in VMime, you can configure messaging services
-+so that they use a secured connection.
-+
-+Quoting from RFC-2246 - the TLS 1.0 protocol specification: \emph{`` The TLS
-+protocol provides communications privacy over the Internet. The protocol
-+allows client/server applications to communicate in a way that is designed
-+to prevent eavesdropping, tampering, or message forgery.''}
-+
-+TLS has the following advantages:
-+
-+\begin{itemize}
-+\item authentication: server identity can be verified;
-+\item privacy: transmission of data between client and server cannot be read
-+by someone in the middle of the connection;
-+\item integrity: original data which is transferred between a client and a
-+server can not be modified by an attacker without being detected.
-+\end{itemize}
-+
-+\vnote{What is the difference between SSL and TLS? SSL is a protocol designed
-+by Netscape. TLS is a standard protocol, and is partly based on version 3 of
-+the SSL protocol. The two protocols are not interoperable, but TLS does
-+support a mechanism to back down to SSL 3.}
-+
-+VMime offers two possibilities for using a secured connection:
-+
-+\begin{itemize}
-+\item you can connect to a server listening on a special port (eg. IMAPS
-+instead of IMAP): this is the classical use of SSL, but is now deprecated;
-+\item connect to a server listening on the default port, and then begin a
-+secured connection: this is STARTTLS.
-+\end{itemize}
-+
-+
-+\subsection{Setting up a secured connection} % -------------------------------
-+
-+\subsubsection{Connecting to a ``secured'' port} % ...........................
-+
-+To use the classical SSL/TLS way, simply use the ``S'' version of the protocol
-+to connect to the server (eg. \emph{imaps} instead of \emph{imap}). This is
-+currently available for SMTP, POP3 and IMAP.
-+
-+\begin{lstlisting}
-+vmime::ref <vmime::net::store> store =
-+ theSession->getStore(vmime::utility::url("imaps://example.org"));
-+\end{lstlisting}
-+
-+\subsubsection{Using STARTTLS} % .............................................
-+
-+To make the service start a secured session using the STARTTLS method, simply
-+set the \emph{connection.tls} property:
-+
-+\begin{lstlisting}
-+theService->setProperty("connection.tls", true);
-+\end{lstlisting}
-+
-+\vnote{If, for some reason, a secured connection cannot be started, the
-+default behaviour is to fallback on a normal connection. To make
-+{\vcode connect()} fail if STARTTLS fails, set the
-+\emph{connection.tls.required} to \emph{true}.}
-+
-+\subsection{Certificate verification} % --------------------------------------
-+
-+\subsubsection{How it works} % ...............................................
-+
-+If you tried the previous examples, a
-+{\vcode certificate\_verification\_exception} might have been thrown.
-+This is because the default certificate verifier in VMime did not manage to
-+verify the certificate, and so could not trust it.
-+
-+Basically, when you connect to a server using TLS, the server responds with
-+a list of certificates, called a certificate chain (usually, certificates are
-+of type X.509\footnote{And VMime currently supports only X.509 certificates}).
-+The certificate chain is ordered so that the first certificate is the subject
-+certificate, the second is the subject's issuer one, the third is the issuer's
-+issuer, and so on.
-+
-+To decide whether the server can be trusted or not, you have to verify that
-+\emph{each} certificate is valid (ie. is trusted). For more information
-+about X.509 and certificate verification, see related articles on Wikipedia
-+\footnote{See \url{http://wikipedia.org/wiki/Public\_key\_certificate}}.
-+
-+\subsubsection{Using the default certificate verifier} % .....................
-+
-+The default certificate verifier maintains a list of root (CAs) and user
-+certificates that are trusted. By default, the list is empty. So, you have
-+to initialize it before using the verifier.
-+
-+The algorithm\footnote{See
-+\url{http://wikipedia.org/wiki/Certification\_path\_validation\_algorithm}}
-+used is quite simple:
-+
-+\begin{enumerate}
-+\item for every certificate in the chain, verify that the certificate has been
-+issued by the next certificate in the chain;
-+\item for every certificate in the chain, verify that the certificate is valid
-+at the current time;
-+\item decide whether the subject's certificate can be trusted:
-+ \begin{itemize}
-+ \item first, verify that the the last certificate in the chain was
-+ issued by a third-party that we trust (root CAs);
-+ \item if the issuer certificate cannot be verified against root CAs,
-+ compare the subject's certificate against the trusted certificates
-+ (the certificates the user has decided to trust).
-+ \end{itemize}
-+\end{enumerate}
-+
-+First, we need some code to load existing X.509 certificates:
-+
-+\begin{lstlisting}[caption={Reading a X.509 certificate from a file}]
-+vmime::ref <vmime::security::cert::X509Certificate>
-+ loadX509CertificateFromFile(const std::string& path)
-+{
-+ std::ifstream certFile;
-+ certFile.open(path.c_str(), std::ios::in | std::ios::binary);
-+
-+ if (!certFile)
-+ {
-+ // ...handle error...
-+ }
-+
-+ vmime::utility::inputStreamAdapter is(certFile);
-+ vmime::ref <vmime::security::cert::X509Certificate> cert;
-+
-+ // Try DER format
-+ cert = vmime::security::cert::X509Certificate::import
-+ (is, vmime::security::cert::X509Certificate::FORMAT_DER);
-+
-+ if (cert != NULL)
-+ return cert;
-+
-+ // Try PEM format
-+ is.reset();
-+ cert = vmime::security::cert::X509Certificate::import
-+ (is, vmime::security::cert::X509Certificate::FORMAT_PEM);
-+
-+ return cert;
-+}
-+\end{lstlisting}
-+
-+Then, we can use the {\vcode loadX509CertificateFromFile} function to load
-+certificates and initialize the certificate verifier:
-+
-+\begin{lstlisting}[caption={Using the default certificate verifier}]
-+vmime::ref <vmime::security::cert::defaultCertificateVerifier> vrf =
-+ vmime::create <vmime::security::cert::defaultCertificateVerifier>();
-+
-+// Load root CAs (such as Verisign or Thawte)
-+std::vector <vmime::ref <vmime::security::cert::X509Certificate> > rootCAs;
-+
-+rootCAs.push_back(loadX509CertificateFromFile("/path/to/root-ca1.cer");
-+rootCAs.push_back(loadX509CertificateFromFile("/path/to/root-ca2.cer");
-+rootCAs.push_back(loadX509CertificateFromFile("/path/to/root-ca3.cer");
-+
-+vrf->setX509RootCAs(rootCAs);
-+
-+// Then, load certificates that the user explicitely chose to trust
-+std::vector <vmime::ref <vmime::security::cert::X509Certificate> > trusted;
-+
-+trusted.push_back(loadX509CertificateFromFile("/path/to/trusted-site1.cer");
-+trusted.push_back(loadX509CertificateFromFile("/path/to/trusted-site2.cer");
-+
-+vrf->setX509TrustedCerts(trusted);
-+\end{lstlisting}
-+
-+
-+\subsubsection{Writing your own certificate verifier} % ......................
-+
-+If you need to do more complex verifications on certificates, you will have to
-+write your own verifier. Your verifier should inherit from the
-+{\vcode vmime::security::cert::certificateVerifier} class and implement the
-+method {\vcode verify()}. Then, if the specified certificate chain is trusted,
-+simply return from the function, or else throw a
-+{\vcode certificate\_verification\_exception}.
-+
-+The following example shows how to implement an interactive certificate
-+verifier which relies on the user's decision, and nothing else (you SHOULD NOT
-+use this in a production application as this is obviously a serious security
-+issue):
-+
-+\begin{lstlisting}[caption={A custom certificate verifier}]
-+class myCertVerifier : public vmime::security::cert::certificateVerifier
-+{
-+public:
-+
-+ void verify(vmime::ref <certificateChain> certs)
-+ {
-+ // Obtain the subject's certificate
-+ vmime::ref <vmime::security::cert::certificate> cert = chain->getAt(0);
-+
-+ std::cout << std::endl;
-+ std::cout << "Server sent a '" << cert->getType() << "'"
-+ << " certificate." << std::endl;
-+ std::cout << "Do you want to accept this certificate? (Y/n) ";
-+ std::cout.flush();
-+
-+ std::string answer;
-+ std::getline(std::cin, answer);
-+
-+ if (answer.length() != 0 && (answer[0] == 'Y' || answer[0] == 'y'))
-+ return; // OK, we trust the certificate
-+
-+ // Don't trust this certificate
-+ throw exceptions::certificate_verification_exception();
-+ }
-+};
-+\end{lstlisting}
-+
-+\vnote{In production code, it may be a good idea to remember user's decisions
-+about which certificates to trust and which not. See {\vexample Example6} for
-+a basic cache implementation.}
-+
-+Finally, to make the service use your own certificate verifier, simply write:
-+
-+\begin{lstlisting}
-+theService->setCertificateVerifier(vmime::create <myCertVerifier>());
-+\end{lstlisting}
-+
-diff --git b/examples/viewer/viewer.cpp a/examples/viewer/viewer.cpp
-new file mode 100644
-index 0000000..50862b3
---- /dev/null
-+++ a/examples/viewer/viewer.cpp
-@@ -0,0 +1,293 @@
-+//
-+// VMime library (http://www.vmime.org)
-+// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+//
-+// 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.,
-+// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
-+//
-+// Linking this library statically or dynamically with other modules is making
-+// a combined work based on this library. Thus, the terms and conditions of
-+// the GNU General Public License cover the whole combination.
-+//
-+
-+//
-+// EXAMPLE DESCRIPTION:
-+// ====================
-+// A simple MIME viewer to show all the components of a message.
-+// The user interface is written using GTK+ 2.6.
-+//
-+// For more information, please visit:
-+// http://www.vmime.org/
-+//
-+
-+#include <iostream>
-+#include <fstream>
-+#include <vector>
-+
-+#include <gtk/gtk.h>
-+
-+#include "vmime/vmime.hpp"
-+#include "vmime/platforms/posix/posixHandler.hpp"
-+
-+
-+
-+GtkWidget* window = NULL;
-+GtkWidget* treeView = NULL;
-+GtkWidget* textArea = NULL;
-+
-+GtkTreeStore* treeModel = NULL;
-+
-+vmime::ref <vmime::message> currentMessage = NULL;
-+
-+
-+
-+void insertRowInModel(GtkTreeStore* model, vmime::ref <const vmime::component> comp, GtkTreeIter* parent = NULL)
-+{
-+ GtkTreeIter iter;
-+
-+ gtk_tree_store_append(model, &iter, parent);
-+ gtk_tree_store_set(model, &iter, 0, typeid(*comp).name(), 1, comp.get(), -1);
-+
-+ const std::vector <vmime::ref <const vmime::component> > children = comp->getChildComponents();
-+
-+ for (int i = 0 ; i < children.size() ; ++i)
-+ {
-+ insertRowInModel(model, children[i], &iter);
-+ }
-+}
-+
-+
-+void updateTreeView()
-+{
-+ GtkTreeStore* model = GTK_TREE_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(treeView)));
-+
-+ g_object_ref(model);
-+ gtk_tree_view_set_model(GTK_TREE_VIEW(treeView), NULL);
-+
-+ gtk_tree_store_clear(model);
-+
-+ insertRowInModel(model, currentMessage);
-+
-+ gtk_tree_view_set_model(GTK_TREE_VIEW(treeView), GTK_TREE_MODEL(model));
-+ g_object_unref(model);
-+}
-+
-+
-+static void treeViewSelChanged(GtkTreeView* treeView, gpointer userData)
-+{
-+ GtkTreePath* path = NULL;
-+ GtkTreeViewColumn* col = NULL;
-+
-+ gtk_tree_view_get_cursor(treeView, &path, &col);
-+
-+ GtkTreeIter iter;
-+ gtk_tree_model_get_iter(GTK_TREE_MODEL(treeModel), &iter, path);
-+
-+ vmime::component* comp = NULL;
-+ gtk_tree_model_get(GTK_TREE_MODEL(treeModel), &iter, 1, &comp, -1);
-+
-+ GtkTextBuffer* textBuffer = gtk_text_view_get_buffer(GTK_TEXT_VIEW(textArea));
-+ GtkTextIter start, end;
-+
-+ gtk_text_buffer_get_iter_at_offset(textBuffer, &start, comp->getParsedOffset());
-+ gtk_text_buffer_get_iter_at_offset(textBuffer, &end, comp->getParsedOffset() + comp->getParsedLength());
-+
-+ gtk_text_buffer_select_range(textBuffer, &start, &end);
-+
-+ gtk_text_view_scroll_to_iter(GTK_TEXT_VIEW(textArea), &start, 0.0, FALSE, 0.0, 0.0);
-+
-+ gtk_tree_path_free(path);
-+}
-+
-+
-+static void destroy(GtkWidget* widget, gpointer data)
-+{
-+ gtk_main_quit();
-+}
-+
-+
-+void openFile(const std::string& filename)
-+{
-+ std::ifstream file;
-+ file.open(filename.c_str(), std::ios::in | std::ios::binary);
-+
-+ if (!file)
-+ {
-+ std::cerr << "Can't open file '" << filename << "'." << std::endl;
-+ return;
-+ }
-+
-+ vmime::string data;
-+ char buffer[16384];
-+
-+ do
-+ {
-+ file.read(buffer, sizeof(buffer));
-+ data += vmime::string(buffer, file.gcount());
-+ }
-+ while (file.gcount());
-+
-+ vmime::ref <vmime::message> msg = vmime::create <vmime::message>();
-+ msg->parse(data);
-+
-+ currentMessage = msg;
-+
-+ char* convData = g_convert_with_fallback(data.c_str(), data.length(),
-+ "UTF-8", "ISO-8859-1", "?", NULL, NULL, NULL);
-+
-+ if (convData == NULL)
-+ {
-+ gtk_text_buffer_set_text(gtk_text_view_get_buffer(GTK_TEXT_VIEW(textArea)),
-+ "GLib UTF-8 conversion error.", -1);
-+ }
-+ else
-+ {
-+ gtk_text_buffer_set_text(gtk_text_view_get_buffer(GTK_TEXT_VIEW(textArea)),
-+ convData, strlen(convData));
-+
-+ g_free(convData);
-+ }
-+
-+ updateTreeView();
-+}
-+
-+
-+static void onFileOpen()
-+{
-+ GtkWidget* dlg = gtk_file_chooser_dialog_new
-+ ("Open Message File", GTK_WINDOW(window), GTK_FILE_CHOOSER_ACTION_OPEN,
-+ GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
-+ GTK_STOCK_OPEN, GTK_RESPONSE_ACCEPT,
-+ NULL);
-+
-+ if (gtk_dialog_run(GTK_DIALOG(dlg)) == GTK_RESPONSE_ACCEPT)
-+ {
-+ char* filename = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dlg));
-+
-+ openFile(filename);
-+
-+ g_free(filename);
-+ }
-+
-+ gtk_widget_destroy(dlg);
-+}
-+
-+
-+
-+// UI definitions
-+static const GtkActionEntry uiActions[] =
-+{
-+ { "FileMenu", NULL, "_File" },
-+ { "FileOpen", GTK_STOCK_OPEN, "_Open...", "<control>O", NULL, G_CALLBACK(onFileOpen) },
-+ { "FileExit", GTK_STOCK_QUIT, "_Exit", "<control>Q", NULL, G_CALLBACK(gtk_main_quit) }
-+};
-+
-+static const char* uiDefinition =
-+ "<ui>" \
-+ " <menubar name=\"MainMenuBar\">" \
-+ " <menu action=\"FileMenu\">" \
-+ " <menuitem action=\"FileOpen\"/>" \
-+ " <menuitem action=\"FileExit\"/>" \
-+ " </menu>" \
-+ " </menubar>" \
-+ "</ui>";
-+
-+
-+int main(int argc, char* argv[])
-+{
-+ // VMime initialization
-+ vmime::platform::setHandler<vmime::platforms::posix::posixHandler>();
-+
-+ // GTK+ initialization
-+ gtk_init(&argc, &argv);
-+
-+ // Create a new window
-+ window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
-+
-+ gtk_window_set_default_size(GTK_WINDOW(window), 800, 550);
-+ gtk_window_set_title(GTK_WINDOW(window), "VMime Viewer Example");
-+
-+ g_signal_connect(G_OBJECT(window), "destroy", G_CALLBACK(destroy), NULL);
-+
-+ GtkWidget* vbox = gtk_vbox_new(FALSE, 0);
-+ gtk_container_add(GTK_CONTAINER(window), vbox);
-+
-+ // Menubar
-+ GtkActionGroup* actionGroup = gtk_action_group_new ("Actions");
-+ gtk_action_group_add_actions(actionGroup, uiActions, G_N_ELEMENTS(uiActions), NULL);
-+
-+ GtkUIManager* uiManager = gtk_ui_manager_new();
-+ gtk_ui_manager_insert_action_group(uiManager, actionGroup, 1);
-+ gtk_ui_manager_add_ui_from_string(uiManager, uiDefinition, -1, NULL);
-+
-+ GtkWidget* menuBar = gtk_ui_manager_get_widget(uiManager, "/MainMenuBar");
-+
-+ gtk_box_pack_start(GTK_BOX(vbox), menuBar, FALSE, FALSE, 0);
-+
-+ // Horizontal Pane
-+ GtkWidget* hpane = gtk_hpaned_new();
-+ gtk_box_pack_start(GTK_BOX(vbox), hpane, TRUE, TRUE, 0);
-+
-+ // Tree View
-+ treeModel = gtk_tree_store_new(2, G_TYPE_STRING, G_TYPE_POINTER);
-+
-+ treeView = gtk_tree_view_new();
-+
-+ g_signal_connect(G_OBJECT(treeView), "cursor-changed", G_CALLBACK(treeViewSelChanged), NULL);
-+
-+ GtkWidget* scroll = gtk_scrolled_window_new(NULL, NULL);
-+
-+ gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scroll), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
-+ gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(scroll), GTK_SHADOW_IN);
-+ gtk_container_add(GTK_CONTAINER(scroll), treeView);
-+
-+ gtk_paned_add1(GTK_PANED(hpane), scroll);
-+
-+ GtkTreeViewColumn* col = gtk_tree_view_column_new();
-+ gtk_tree_view_column_set_title(col, "Component Name");
-+ gtk_tree_view_append_column(GTK_TREE_VIEW(treeView), col);
-+
-+ GtkCellRenderer* renderer = gtk_cell_renderer_text_new();
-+
-+ gtk_tree_view_column_pack_start(col, renderer, TRUE);
-+ gtk_tree_view_column_add_attribute(col, renderer, "text", 0);
-+
-+ gtk_tree_view_set_model(GTK_TREE_VIEW(treeView), GTK_TREE_MODEL(treeModel));
-+ g_object_unref(treeModel);
-+
-+ gtk_widget_set_size_request(treeView, 200, 100);
-+
-+ // Text Area
-+ textArea = gtk_text_view_new();
-+
-+ gtk_text_view_set_editable(GTK_TEXT_VIEW(textArea), FALSE);
-+
-+ scroll = gtk_scrolled_window_new(NULL, NULL);
-+
-+ gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scroll), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
-+ gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(scroll), GTK_SHADOW_IN);
-+ gtk_container_add(GTK_CONTAINER(scroll), textArea);
-+
-+ gtk_paned_add2(GTK_PANED(hpane), scroll);
-+
-+ // Show main window
-+ gtk_widget_show_all(window);
-+
-+ // GTK main loop
-+ gtk_main();
-+
-+ return 0;
-+}
-+
-+
-diff --git b/m4/acx_pthread.m4 a/m4/acx_pthread.m4
-new file mode 100644
-index 0000000..b7f692a
---- /dev/null
-+++ a/m4/acx_pthread.m4
-@@ -0,0 +1,235 @@
-+dnl @synopsis ACX_PTHREAD([ACTION-IF-FOUND[, ACTION-IF-NOT-FOUND]])
-+dnl
-+dnl This macro figures out how to build C programs using POSIX threads.
-+dnl It sets the PTHREAD_LIBS output variable to the threads library and
-+dnl linker flags, and the PTHREAD_CFLAGS output variable to any special
-+dnl C compiler flags that are needed. (The user can also force certain
-+dnl compiler flags/libs to be tested by setting these environment
-+dnl variables.)
-+dnl
-+dnl Also sets PTHREAD_CC to any special C compiler that is needed for
-+dnl multi-threaded programs (defaults to the value of CC otherwise).
-+dnl (This is necessary on AIX to use the special cc_r compiler alias.)
-+dnl
-+dnl NOTE: You are assumed to not only compile your program with these
-+dnl flags, but also link it with them as well. e.g. you should link
-+dnl with $PTHREAD_CC $CFLAGS $PTHREAD_CFLAGS $LDFLAGS ... $PTHREAD_LIBS
-+dnl $LIBS
-+dnl
-+dnl If you are only building threads programs, you may wish to use
-+dnl these variables in your default LIBS, CFLAGS, and CC:
-+dnl
-+dnl LIBS="$PTHREAD_LIBS $LIBS"
-+dnl CFLAGS="$CFLAGS $PTHREAD_CFLAGS"
-+dnl CC="$PTHREAD_CC"
-+dnl
-+dnl In addition, if the PTHREAD_CREATE_JOINABLE thread-attribute
-+dnl constant has a nonstandard name, defines PTHREAD_CREATE_JOINABLE to
-+dnl that name (e.g. PTHREAD_CREATE_UNDETACHED on AIX).
-+dnl
-+dnl ACTION-IF-FOUND is a list of shell commands to run if a threads
-+dnl library is found, and ACTION-IF-NOT-FOUND is a list of commands to
-+dnl run it if it is not found. If ACTION-IF-FOUND is not specified, the
-+dnl default action will define HAVE_PTHREAD.
-+dnl
-+dnl Please let the authors know if this macro fails on any platform, or
-+dnl if you have any other suggestions or comments. This macro was based
-+dnl on work by SGJ on autoconf scripts for FFTW (www.fftw.org) (with
-+dnl help from M. Frigo), as well as ac_pthread and hb_pthread macros
-+dnl posted by Alejandro Forero Cuervo to the autoconf macro repository.
-+dnl We are also grateful for the helpful feedback of numerous users.
-+dnl
-+dnl @category InstalledPackages
-+dnl @author Steven G. Johnson <stevenj@alum.mit.edu>
-+dnl @version 2005-01-14
-+dnl @license GPLWithACException
-+
-+AC_DEFUN([ACX_PTHREAD], [
-+AC_REQUIRE([AC_CANONICAL_HOST])
-+AC_LANG_SAVE
-+AC_LANG_C
-+acx_pthread_ok=no
-+
-+# We used to check for pthread.h first, but this fails if pthread.h
-+# requires special compiler flags (e.g. on True64 or Sequent).
-+# It gets checked for in the link test anyway.
-+
-+# First of all, check if the user has set any of the PTHREAD_LIBS,
-+# etcetera environment variables, and if threads linking works using
-+# them:
-+if test x"$PTHREAD_LIBS$PTHREAD_CFLAGS" != x; then
-+ save_CFLAGS="$CFLAGS"
-+ CFLAGS="$CFLAGS $PTHREAD_CFLAGS"
-+ save_LIBS="$LIBS"
-+ LIBS="$PTHREAD_LIBS $LIBS"
-+ AC_MSG_CHECKING([for pthread_join in LIBS=$PTHREAD_LIBS with CFLAGS=$PTHREAD_CFLAGS])
-+ AC_TRY_LINK_FUNC(pthread_join, acx_pthread_ok=yes)
-+ AC_MSG_RESULT($acx_pthread_ok)
-+ if test x"$acx_pthread_ok" = xno; then
-+ PTHREAD_LIBS=""
-+ PTHREAD_CFLAGS=""
-+ fi
-+ LIBS="$save_LIBS"
-+ CFLAGS="$save_CFLAGS"
-+fi
-+
-+# We must check for the threads library under a number of different
-+# names; the ordering is very important because some systems
-+# (e.g. DEC) have both -lpthread and -lpthreads, where one of the
-+# libraries is broken (non-POSIX).
-+
-+# Create a list of thread flags to try. Items starting with a "-" are
-+# C compiler flags, and other items are library names, except for "none"
-+# which indicates that we try without any flags at all, and "pthread-config"
-+# which is a program returning the flags for the Pth emulation library.
-+
-+acx_pthread_flags="pthreads none -Kthread -kthread lthread -pthread -pthreads -mthreads pthread --thread-safe -mt pthread-config"
-+
-+# The ordering *is* (sometimes) important. Some notes on the
-+# individual items follow:
-+
-+# pthreads: AIX (must check this before -lpthread)
-+# none: in case threads are in libc; should be tried before -Kthread and
-+# other compiler flags to prevent continual compiler warnings
-+# -Kthread: Sequent (threads in libc, but -Kthread needed for pthread.h)
-+# -kthread: FreeBSD kernel threads (preferred to -pthread since SMP-able)
-+# lthread: LinuxThreads port on FreeBSD (also preferred to -pthread)
-+# -pthread: Linux/gcc (kernel threads), BSD/gcc (userland threads)
-+# -pthreads: Solaris/gcc
-+# -mthreads: Mingw32/gcc, Lynx/gcc
-+# -mt: Sun Workshop C (may only link SunOS threads [-lthread], but it
-+# doesn't hurt to check since this sometimes defines pthreads too;
-+# also defines -D_REENTRANT)
-+# pthread: Linux, etcetera
-+# --thread-safe: KAI C++
-+# pthread-config: use pthread-config program (for GNU Pth library)
-+
-+case "${host_cpu}-${host_os}" in
-+ *solaris*)
-+
-+ # On Solaris (at least, for some versions), libc contains stubbed
-+ # (non-functional) versions of the pthreads routines, so link-based
-+ # tests will erroneously succeed. (We need to link with -pthread or
-+ # -lpthread.) (The stubs are missing pthread_cleanup_push, or rather
-+ # a function called by this macro, so we could check for that, but
-+ # who knows whether they'll stub that too in a future libc.) So,
-+ # we'll just look for -pthreads and -lpthread first:
-+
-+ acx_pthread_flags="-pthread -pthreads pthread -mt $acx_pthread_flags"
-+ ;;
-+esac
-+
-+if test x"$acx_pthread_ok" = xno; then
-+for flag in $acx_pthread_flags; do
-+
-+ case $flag in
-+ none)
-+ AC_MSG_CHECKING([whether pthreads work without any flags])
-+ ;;
-+
-+ -*)
-+ AC_MSG_CHECKING([whether pthreads work with $flag])
-+ PTHREAD_CFLAGS="$flag"
-+ ;;
-+
-+ pthread-config)
-+ AC_CHECK_PROG(acx_pthread_config, pthread-config, yes, no)
-+ if test x"$acx_pthread_config" = xno; then continue; fi
-+ PTHREAD_CFLAGS="`pthread-config --cflags`"
-+ PTHREAD_LIBS="`pthread-config --ldflags` `pthread-config --libs`"
-+ ;;
-+
-+ *)
-+ AC_MSG_CHECKING([for the pthreads library -l$flag])
-+ PTHREAD_LIBS="-l$flag"
-+ ;;
-+ esac
-+
-+ save_LIBS="$LIBS"
-+ save_CFLAGS="$CFLAGS"
-+ LIBS="$PTHREAD_LIBS $LIBS"
-+ CFLAGS="$CFLAGS $PTHREAD_CFLAGS"
-+
-+ # Check for various functions. We must include pthread.h,
-+ # since some functions may be macros. (On the Sequent, we
-+ # need a special flag -Kthread to make this header compile.)
-+ # We check for pthread_join because it is in -lpthread on IRIX
-+ # while pthread_create is in libc. We check for pthread_attr_init
-+ # due to DEC craziness with -lpthreads. We check for
-+ # pthread_cleanup_push because it is one of the few pthread
-+ # functions on Solaris that doesn't have a non-functional libc stub.
-+ # We try pthread_create on general principles.
-+ AC_TRY_LINK([#include <pthread.h>],
-+ [pthread_t th; pthread_join(th, 0);
-+ pthread_attr_init(0); pthread_cleanup_push(0, 0);
-+ pthread_create(0,0,0,0); pthread_cleanup_pop(0); ],
-+ [acx_pthread_ok=yes])
-+
-+ LIBS="$save_LIBS"
-+ CFLAGS="$save_CFLAGS"
-+
-+ AC_MSG_RESULT($acx_pthread_ok)
-+ if test "x$acx_pthread_ok" = xyes; then
-+ break;
-+ fi
-+
-+ PTHREAD_LIBS=""
-+ PTHREAD_CFLAGS=""
-+done
-+fi
-+
-+# Various other checks:
-+if test "x$acx_pthread_ok" = xyes; then
-+ save_LIBS="$LIBS"
-+ LIBS="$PTHREAD_LIBS $LIBS"
-+ save_CFLAGS="$CFLAGS"
-+ CFLAGS="$CFLAGS $PTHREAD_CFLAGS"
-+
-+ # Detect AIX lossage: JOINABLE attribute is called UNDETACHED.
-+ AC_MSG_CHECKING([for joinable pthread attribute])
-+ attr_name=unknown
-+ for attr in PTHREAD_CREATE_JOINABLE PTHREAD_CREATE_UNDETACHED; do
-+ AC_TRY_LINK([#include <pthread.h>], [int attr=$attr;],
-+ [attr_name=$attr; break])
-+ done
-+ AC_MSG_RESULT($attr_name)
-+ if test "$attr_name" != PTHREAD_CREATE_JOINABLE; then
-+ AC_DEFINE_UNQUOTED(PTHREAD_CREATE_JOINABLE, $attr_name,
-+ [Define to necessary symbol if this constant
-+ uses a non-standard name on your system.])
-+ fi
-+
-+ AC_MSG_CHECKING([if more special flags are required for pthreads])
-+ flag=no
-+ case "${host_cpu}-${host_os}" in
-+ *-aix* | *-freebsd* | *-darwin*) flag="-D_THREAD_SAFE";;
-+ *solaris* | *-osf* | *-hpux*) flag="-D_REENTRANT";;
-+ esac
-+ AC_MSG_RESULT(${flag})
-+ if test "x$flag" != xno; then
-+ PTHREAD_CFLAGS="$flag $PTHREAD_CFLAGS"
-+ fi
-+
-+ LIBS="$save_LIBS"
-+ CFLAGS="$save_CFLAGS"
-+
-+ # More AIX lossage: must compile with cc_r
-+ AC_CHECK_PROG(PTHREAD_CC, cc_r, cc_r, ${CC})
-+else
-+ PTHREAD_CC="$CC"
-+fi
-+
-+AC_SUBST(PTHREAD_LIBS)
-+AC_SUBST(PTHREAD_CFLAGS)
-+AC_SUBST(PTHREAD_CC)
-+
-+# Finally, execute ACTION-IF-FOUND/ACTION-IF-NOT-FOUND:
-+if test x"$acx_pthread_ok" = xyes; then
-+ ifelse([$1],,AC_DEFINE(HAVE_PTHREAD,1,[Define if you have POSIX threads libraries and header files.]),[$1])
-+ :
-+else
-+ acx_pthread_ok=no
-+ $2
-+fi
-+AC_LANG_RESTORE
-+])dnl ACX_PTHREAD
-diff --git b/m4/ost_posix.m4 a/m4/ost_posix.m4
-new file mode 100644
-index 0000000..6572b1e
---- /dev/null
-+++ a/m4/ost_posix.m4
-@@ -0,0 +1,87 @@
-+dnl Copyright (C) 1999-2001 Open Source Telecom Corporation.
-+dnl
-+dnl This program is free software; you can redistribute it and/or modify
-+dnl it under the terms of the GNU General Public License as published by
-+dnl the Free Software Foundation; either version 2 of the License, or
-+dnl (at your option) any later version.
-+dnl
-+dnl This program is distributed in the hope that it will be useful,
-+dnl but WITHOUT ANY WARRANTY; without even the implied warranty of
-+dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-+dnl GNU General Public License for more details.
-+dnl
-+dnl You should have received a copy of the GNU General Public License
-+dnl along with this program; if not, write to the Free Software
-+dnl Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
-+dnl
-+dnl As a special exception to the GNU General Public License, if you
-+dnl distribute this file as part of a program that contains a configuration
-+dnl script generated by Autoconf, you may include it under the same
-+dnl distribution terms that you use for the rest of that program.
-+
-+AC_DEFUN(OST_SYS_POSIX,[
-+ AC_REQUIRE([OST_PROG_CC_POSIX])
-+ AC_CACHE_CHECK(whether system meets Posix.1,
-+ ost_cv_sys_posix1,
-+ AC_TRY_COMPILE([
-+ #include <sys/types.h>
-+ #include <unistd.h>
-+ ],[
-+ #ifndef _POSIX_VERSION
-+ fatal
-+ #endif
-+ ],
-+ ost_cv_sys_posix1=yes,
-+ ost_cv_sys_posix1=no
-+ )
-+ )
-+ if test $ost_cv_sys_posix1 = no ; then
-+ AC_CHECK_HEADERS(unistd.h)
-+ else
-+ AC_DEFINE(HAVE_UNISTD_H, [1], [have unix header])
-+ fi
-+ AC_CHECK_HEADERS(features.h)
-+ AH_TOP([
-+/* hack for BROKEN autoheader, since it will not predicitably order
-+ macros by any obvious means. */
-+
-+#undef HAVE_UNISTD_H
-+#undef HAVE_FEATURES_H
-+#undef HAVE_SYS_TYPES_H
-+
-+#ifdef HAVE_UNISTD_H
-+#include <unistd.h>
-+#endif
-+
-+#ifndef WIN32
-+#ifdef HAVE_FEATURES_H
-+#include <features.h>
-+#endif
-+#endif
-+
-+#ifdef HAVE_SYS_TYPES_H
-+#include <sys/types.h>
-+#endif
-+ ])
-+])
-+
-+AC_DEFUN(OST_CC_FCNTL,[
-+ AC_REQUIRE([OST_SYS_POSIX])
-+ AC_CHECK_HEADERS(fcntl.h sys/fcntl.h)
-+AH_BOTTOM([
-+
-+#ifndef HAVE_FCNTL_H
-+#ifdef HAVE_SYS_FCNTL_H
-+#include <sys/fcntl.h>
-+#endif
-+#else
-+#include <fcntl.h>
-+#ifndef O_NDELAY
-+#ifdef HAVE_SYS_FCNTL_H
-+#include <sys/fcntl.h>
-+#endif
-+#endif
-+#endif
-+ ])
-+])
-+
-diff --git b/m4/ost_prog.m4 a/m4/ost_prog.m4
-new file mode 100644
-index 0000000..c9e66f5
---- /dev/null
-+++ a/m4/ost_prog.m4
-@@ -0,0 +1,61 @@
-+dnl Copyright (C) 1999-2001 Open Source Telecom Corporation.
-+dnl
-+dnl This program is free software; you can redistribute it and/or modify
-+dnl it under the terms of the GNU General Public License as published by
-+dnl the Free Software Foundation; either version 2 of the License, or
-+dnl (at your option) any later version.
-+dnl
-+dnl This program is distributed in the hope that it will be useful,
-+dnl but WITHOUT ANY WARRANTY; without even the implied warranty of
-+dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-+dnl GNU General Public License for more details.
-+dnl
-+dnl You should have received a copy of the GNU General Public License
-+dnl along with this program; if not, write to the Free Software
-+dnl Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
-+dnl
-+dnl As a special exception to the GNU General Public License, if you
-+dnl distribute this file as part of a program that contains a configuration
-+dnl script generated by Autoconf, you may include it under the same
-+dnl distribution terms that you use for the rest of that program.
-+
-+AC_DEFUN(OST_PROG_CC_POSIX,[
-+ AC_PROG_CC
-+ AC_PROG_CPP
-+ AC_ISC_POSIX]
-+)
-+
-+AC_DEFUN(OST_PROG_COMMON,[
-+ AC_REQUIRE([AC_PROG_INSTALL])
-+ AC_REQUIRE([AC_PROG_MAKE_SET])
-+])
-+
-+AC_DEFUN(OST_PROJ_LIBRARY,[
-+ AC_REQUIRE([AM_PROG_LIBTOOL])
-+ AC_REQUIRE([AC_PROG_RANLIB])
-+ if test ! -z "[$2]" ; then
-+ if test ! -z "[$3]" ; then
-+ LT_[$1]_VERSION="-version-info [$3] -release [$2]"
-+ else
-+ LT_[$1]_VERSION="-release [$2]"
-+ fi
-+ AC_SUBST(LT_[$1]_VERSION)
-+ fi
-+])
-+
-+AC_DEFUN(OST_PROG_LIBVER,[
-+ LT_MAJOR="`echo $LT_VERSION | sed s/:.*$//`"
-+ AC_SUBST(LT_RELEASE)
-+ AC_SUBST(LT_MAJOR)
-+])
-+
-+
-+AC_DEFUN(OST_PROG_LIBRARY,[
-+ AC_REQUIRE([AM_PROG_LIBTOOL])
-+ AC_REQUIRE([AC_PROG_RANLIB])
-+ if test ! -z "[$2]" ; then
-+ LT_[$1]_VERSION="-version-info [$2]"
-+ AC_SUBST(LT_[$1]_VERSION)
-+ fi
-+])
-+
-diff --git b/m4/ost_pthread.m4 a/m4/ost_pthread.m4
-new file mode 100644
-index 0000000..d427c73
---- /dev/null
-+++ a/m4/ost_pthread.m4
-@@ -0,0 +1,582 @@
-+dnl Copyright (C) 1999-2001 Open Source Telecom Corporation.
-+dnl
-+dnl This program is free software; you can redistribute it and/or modify
-+dnl it under the terms of the GNU General Public License as published by
-+dnl the Free Software Foundation; either version 2 of the License, or
-+dnl (at your option) any later version.
-+dnl
-+dnl This program is distributed in the hope that it will be useful,
-+dnl but WITHOUT ANY WARRANTY; without even the implied warranty of
-+dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-+dnl GNU General Public License for more details.
-+dnl
-+dnl You should have received a copy of the GNU General Public License
-+dnl along with this program; if not, write to the Free Software
-+dnl Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
-+dnl
-+dnl As a special exception to the GNU General Public License, if you
-+dnl distribute this file as part of a program that contains a configuration
-+dnl script generated by Autoconf, you may include it under the same
-+dnl distribution terms that you use for the rest of that program.
-+
-+AC_DEFUN([OST_LIB_PTHREAD],
-+[
-+ AC_REQUIRE([OST_SYS_POSIX])
-+ AC_REQUIRE([OST_CC_SYSTIME])
-+ THREAD_FLAGS=""
-+ THREAD_LIBS=""
-+ ost_cv_thread_library="none"
-+ ost_cv_rt_library="none"
-+ ost_cv_cxx_mode=false
-+
-+ AC_ARG_WITH(pthread, [ --with-pthread[=lib] using specified pthread library],
-+ [if test "$withval" != "" ; then ost_cv_thread_library=$withval ; fi]
-+ )
-+
-+ AC_ARG_WITH(linuxthreads, [ --with-linuxthreads use linux kernel mode library],
-+ [ost_cv_thread_library=lthread
-+ AC_DEFINE(WITH_LINUXTHREADS, [1], [bsd system using linuxthreads])
-+ if test "$withval" != "yes" ; then
-+ THREAD_FLAGS="-D__USE_GNU -D__USE_UNIX98 -I$withval $THREAD_FLAGS"
-+ CFLAGS="-D__USE_GNU -D__USE_UNIX98 -I$withval $CFLAGS"
-+ else
-+ THREAD_FLAGS="-D__USE_GNU -D__USE_UNIX98 -I/usr/local/include/pthread/linuxthreads $THREAD_FLAGS"
-+ CFLAGS="-D__USE_GNU -D__USE_UNIX98 -I/usr/local/include/pthread/linuxthreads $CFLAGS"
-+ fi
-+ ])
-+
-+ AC_CHECK_HEADERS(pthread.h, [
-+ AC_DEFINE(HAVE_PTHREAD_H, [1], [posix thread header])
-+ ost_cv_posix_threads=yes],
-+ ost_cv_posix_threads=no)
-+
-+ if test $ost_cv_posix_threads = no ; then
-+ AC_LANG_SAVE
-+ AC_LANG_CPLUSPLUS
-+ SAVE_CXXFLAGS="$CXXFLAGS"
-+ CXXFLAGS="$CXXFLAGS -pthread"
-+ AC_TRY_COMPILE([#include <pthread.h>],[],
-+ AC_DEFINE(HAVE_PTHREAD_H, [1])
-+ ost_cv_cxx_mode=true
-+ ost_cv_posix_threads=yes)
-+ CXXFLAGS="$SAVE_CXXFLAGS"
-+ AC_LANG_RESTORE
-+ fi
-+
-+AC_LANG_SAVE
-+AC_LANG_CPLUSPLUS
-+
-+ ost_cv_posix_atomic=no
-+ AC_CHECK_HEADERS(sys/atomic_op.h,[
-+ AC_DEFINE(HAVE_ATOMIC_AIX, [1], [atomic aix operations])
-+ ])
-+ AC_CHECK_HEADERS([sys/atomic.h],
-+ ost_cv_posix_sys_atomic=yes,
-+ ost_cv_posix_sys_atomic=no)
-+ if test $ost_cv_posix_sys_atomic = yes ; then
-+ AC_MSG_CHECKING([for atomic_t])
-+ AC_TRY_COMPILE([#include <sys/atomic.h>],
-+ [
-+ atomic_t at; at.counter = 1;
-+ atomic_dec_and_test(&at);
-+ atomic_sub(4, &at);
-+ atomic_inc(&at);
-+ atomic_add(3, &at);
-+ ],
-+ [ost_cv_posix_atomic=yes
-+ AC_DEFINE(HAVE_WORKING_SYS_ATOMIC_H, [1], [has usable atomic functions])],
-+ [ost_cv_posix_atomic=no])
-+ AC_MSG_RESULT($ost_cv_posix_atomic)
-+ fi
-+
-+ dnl check for gcc's bits/atomicity and the atomic functions therein
-+ AC_CHECK_HEADERS([bits/atomicity.h],
-+ ost_cv_bits_atomicity=yes,
-+ ost_cv_bits_atomicity=no)
-+ if test $ost_cv_bits_atomicity = yes ; then
-+ AC_MSG_CHECKING([for _Atomic_word])
-+ AC_TRY_COMPILE([#include <bits/atomicity.h>],
-+ [
-+ _Atomic_word i = 0;
-+ __atomic_add(&i, 1);
-+ __exchange_and_add(&i, 1);
-+ ],
-+ [ost_cv_gcc_atomic=yes
-+ AC_DEFINE(HAVE_GCC_BITS_ATOMIC, [1], [has gcc atomic functions])],
-+ [ost_cv_gcc_atomic=no])
-+ AC_MSG_RESULT($ost_cv_gcc_atomic)
-+
-+ AC_MSG_CHECKING([for __gnu_cxx::_Atomic_word])
-+ AC_TRY_COMPILE([#include <bits/atomicity.h>],
-+ [
-+ using namespace __gnu_cxx;
-+ _Atomic_word i = 0;
-+ __atomic_add(&i, 1);
-+ __exchange_and_add(&i, 1);
-+ ],
-+ [ost_cv_gcc_cxx_atomic=yes
-+ AC_DEFINE(HAVE_GCC_CXX_BITS_ATOMIC, [1],
-+ [has __gnu_cxx atomic functions])],
-+ [ost_cv_gcc_cxx_atomic=no])
-+ AC_MSG_RESULT($ost_cv_gcc_cxx_atomic)
-+ fi
-+
-+AC_LANG_RESTORE
-+
-+ if test "$target" = NONE ; then
-+ targetdir=""
-+ else
-+ targetdir="$target"
-+ fi
-+
-+ AC_CHECK_HEADERS(thread.h)
-+ if test "$prefix" = NONE ; then
-+ thrprefix="/usr/$targetdir/include"
-+ if test -d /usr/$targetdir/sys-include ; then
-+ thrprefix="$prefix/$targetdir/sys-include" ; fi
-+ else
-+ thrprefix="$prefix/$targetdir/include"
-+ if test -d "$prefix/$targetdir/sys-include" ; then
-+ thrprefix="$prefix/$targetdir/sys-include" ; fi
-+ fi
-+
-+ if test ! -f $thrprefix/thread.h ; then
-+ thrprefix=/usr/include
-+ fi
-+
-+ AC_SUBST(thrprefix)
-+
-+ if test $ost_cv_posix_threads = yes ; then
-+ if test "$ost_cv_thread_library" = "none" ; then
-+
-+ ost_cv_thread_flags=""
-+ for flags in -kthread -pthread -mthreads -pthreads -Kthread --threadsafe -mt ; do
-+
-+ AC_MSG_CHECKING(whether ${CC-cc} accepts $flags)
-+ echo 'void f(){}' >conftest.c
-+ if test -z "`${CC-cc} $flags -c conftest.c 2>&1`"; then
-+ ost_cv_thread_flags=$flags
-+ AC_MSG_RESULT(yes)
-+ else
-+ AC_MSG_RESULT(no)
-+ fi
-+ rm -f conftest*
-+ if test ! -z "$ost_cv_thread_flags" ; then break ; fi
-+ done
-+# if test "$ost_cv_prog_cc_pthread" = "no" ; then
-+# AC_CACHE_CHECK(whether ${CC-cc} accepts -mthreads,
-+# ost_cv_prog_cc_mthreads,
-+# [echo 'void f(){}' >conftest.c
-+# if test -z "`${CC-cc} -mthreads -c conftest.c 2>&1`"; then
-+# ost_cv_prog_cc_mthreads=yes
-+# else
-+# ost_cv_prog_cc_mthreads=no
-+# fi
-+# rm -f conftest*
-+# ])
-+# fi
-+ ost_cv_thread_library=none
-+ AC_CHECK_LIB(pthread, pthread_self,
-+ ost_cv_thread_library=pthread,
-+ AC_CHECK_LIB(c_r, pthread_self,
-+ ost_cv_thread_library=c_r,
-+ AC_CHECK_LIB(pthread, pthread_kill,
-+ ost_cv_thread_library=pthread,
-+ AC_CHECK_LIB(pthreads, pthread_self,
-+ ost_cv_thread_library=pthreads,
-+ AC_CHECK_LIB(thread, pthread_self,
-+ ost_cv_thread_library=thread)))))
-+
-+ if test $ost_cv_thread_library = none ; then
-+ AC_CHECK_LIB(gthreads, pthread_self,[
-+ AC_CHECK_LIB(malloc, malloc)
-+ ost_cv_thread_library=gthreads])
-+ fi
-+ if test $ost_cv_thread_library = none ; then
-+ AC_CHECK_LIB(cma, pthread_self,
-+ ost_cv_thread_library=cma)
-+ fi
-+
-+ if test $ost_cv_thread_library = none ; then
-+ AC_CHECK_LIB(c, pthread_self,
-+ ost_cv_thread_library=c)
-+ fi
-+
-+ if test $ost_cv_thread_library = none ; then
-+ AC_MSG_ERROR(no library for posix threads found!)
-+ fi
-+ else
-+# ost_cv_prog_cc_pthread=no
-+# ost_cv_prog_cc_mthreads=no
-+ ost_cv_thread_flags=""
-+ fi
-+
-+ AC_CHECK_LIB(${ost_cv_thread_library}, pthread_mach_thread_np,
-+ AC_DEFINE(HAVE_PTHREAD_MACH_THREAD_NP, [1], [has mach link])
-+ )
-+
-+ AC_CHECK_LIB(${ost_cv_thread_library}, nanosleep,
-+ AC_DEFINE(HAVE_PTHREAD_NANOSLEEP, [1], [has nanosleep]),[
-+ AC_CHECK_LIB(posix4, nanosleep,[
-+ AC_DEFINE(HAVE_PTHREAD_NANOSLEEP, [1])
-+ THREAD_LIBS="$THREAD_LIBS -lposix4"
-+ ],[
-+ AC_CHECK_LIB(rt, nanosleep,[
-+ AC_DEFINE(HAVE_PTHREAD_NANOSLEEP, [1])
-+ ost_cv_rt_library="-lrt"])
-+ ])
-+
-+ ])
-+
-+ AC_CHECK_LIB(rt, clock_gettime,[
-+ ost_cv_rt_library="-lrt"
-+ AC_DEFINE(HAVE_HIRES_TIMER, [1], [have hires])
-+ ],[
-+ AC_CHECK_FUNCS(clock_gettime,[
-+ AC_DEFINE(HAVE_HIRES_TIMER, [1], [have hires])
-+ ])
-+ ])
-+
-+ AC_CHECK_LIB(rt, mlockall,[
-+ AC_DEFINE(HAVE_MLOCK, [1], [have mlock])
-+ AC_DEFINE(HAVE_MLOCKALL, [1], [have memlockall])
-+ ost_cv_rt_library="-lrt"],
-+ [
-+ AC_CHECK_FUNCS(mlock)
-+ AC_CHECK_FUNCS(mlockall)
-+ ])
-+
-+ if test "$ost_cv_rt_library" != "none" ; then
-+ THREAD_LIBS="$THREAD_LIBS $ost_cv_rt_library" ; fi
-+
-+ if test ! -z "$ost_cv_thread_flags" ; then
-+ THREAD_LIBS="$THREAD_LIBS $ost_cv_thread_flags"
-+ else
-+ THREAD_LIBS="$THREAD_LIBS -l$ost_cv_thread_library"
-+ fi
-+
-+ AC_MSG_CHECKING([if more special flags are required for pthreads])
-+ flag=no
-+ case "${host_cpu}-${host_os}" in
-+ *-aix* | *-freebsd*) flag="-D_THREAD_SAFE";;
-+ *solaris* | alpha*-osf*) flag="-D_REENTRANT";;
-+ esac
-+ AC_MSG_RESULT(${flag})
-+ if test "x$flag" != xno; then
-+ THREAD_FLAGS="$flag"
-+ fi
-+
-+ AC_SUBST(THREAD_FLAGS)
-+ AC_SUBST(THREAD_LIBS)
-+# LIBS="$THREAD_LIBS $LIBS"
-+ if test "$ost_cv_thread_library" != "lthread" ; then
-+ AC_CHECK_HEADERS(pthread_np.h)
-+ fi
-+ AC_CHECK_HEADERS(semaphore.h)
-+ AC_CHECK_HEADERS(sched.h)
-+ AC_CHECK_HEADERS(sys/sched.h)
-+ AC_CHECK_FUNCS(sched_getscheduler)
-+ AC_CACHE_CHECK([for recursive mutex type support], ost_cv_mutex_recursive,
-+ [
-+ ost_cv_mutex_recursive="none"
-+
-+ if test "$ost_cv_cxx_mode" = true ; then
-+ AC_LANG_SAVE
-+ AC_LANG_CPLUSPLUS
-+ SAVE_CXXFLAGS="$CXXFLAGS"
-+ CXXFLAGS="$CXXFLAGS -pthread"
-+ fi
-+
-+ AC_TRY_COMPILE(
-+ [#include <pthread.h>],
-+ [
-+ #ifndef PTHREAD_MUTEXTYPE_RECURSIVE
-+ #ifdef PTHREAD_MUTEX_RECURSIVE
-+ #define PTHREAD_MUTEXTYPE_RECURSIVE PTHREAD_MUTEX_RECURSIVE
-+ #endif
-+ #endif
-+ return (int)PTHREAD_MUTEXTYPE_RECURSIVE;
-+ ],
-+ ost_cv_mutex_recursive="portable",
-+ [
-+ AC_EGREP_HEADER(PTHREAD_MUTEXTYPE_RECURSIVE_NP,pthread.h,
-+ ost_cv_mutex_recursive=non-portable)
-+ AC_EGREP_HEADER(PTHREAD_MUTEX_RECURSIVE_INITIALIZER_NP, pthread.h,
-+ ost_cv_mutex_recursive=lthread)
-+ AC_EGREP_HEADER(PTHREAD_MUTEX_RECURSIVE_NP,pthread.h,
-+ ost_cv_mutex_recursive=linux)
-+ AC_EGREP_HEADER(MUTEX_TYPE_COUNTING_FAST,pthread.h,
-+ ost_cv_mutex_recursive=counting)
-+ ])
-+ if test $ost_cv_mutex_recursive = "none" ; then
-+ if test $ost_cv_thread_library = "lthread" ; then
-+ ost_cv_mutex_recursive=linux
-+ fi
-+ fi
-+ rm -f conftest*
-+ ])
-+
-+ if test $ost_cv_mutex_recursive = "none" ; then
-+ AC_TRY_COMPILE(
-+ [#include <pthread.h>],
-+ [return MUTEX_TYPE_COUNTING_FAST;],
-+ ost_cv_mutex_recursive=counting)
-+ fi
-+
-+ if test "$ost_cv_cxx_mode" = true ; then
-+ CXXFLAGS="$SAVE_CXXFLAGS"
-+ AC_LANG_RESTORE
-+ fi
-+
-+
-+ case $ost_cv_mutex_recursive in
-+ non-portable)
-+ AC_DEFINE(PTHREAD_MUTEXTYPE_RECURSIVE,
-+ PTHREAD_MUTEXTYPE_RECURSIVE_NP, [mutex type])
-+ ;;
-+ linux)
-+ AC_DEFINE(PTHREAD_MUTEXTYPE_RECURSIVE,
-+ PTHREAD_MUTEX_RECURSIVE_NP)
-+ ;;
-+ counting)
-+ AC_DEFINE(PTHREAD_MUTEXTYPE_RECURSIVE,
-+ MUTEX_TYPE_COUNTING_FAST)
-+ ;;
-+ esac
-+
-+ AC_CHECK_LIB(${ost_cv_thread_library}, pthread_mutexattr_settype,
-+ AC_DEFINE(HAVE_PTHREAD_MUTEXATTR_SETTYPE, [1], [has setttype]),
-+ [
-+ AC_CHECK_LIB(${ost_cv_thread_library}, pthread_mutexattr_settype_np,
-+ AC_DEFINE(HAVE_PTHREAD_MUTEXATTR_SETTYPE_NP,
-+ [1], [has non portable settype]))
-+ AC_CHECK_LIB(${ost_cv_thread_library}, pthread_mutexattr_setkind_np,
-+ AC_DEFINE(HAVE_PTHREAD_MUTEXATTR_SETKIND_NP,
-+ [1], [has non portable setkind]))
-+ ]
-+ )
-+
-+ ost_cv_thread_rwlock=false
-+ AC_CHECK_LIB(${ost_cv_thread_library}, pthread_rwlock_init,[
-+ ost_cv_thread_rwlock=true
-+ AC_DEFINE(HAVE_PTHREAD_RWLOCK, [1], [has rwlock support])])
-+
-+ AC_CHECK_LIB(c, pread,[
-+ AC_DEFINE(HAVE_PREAD_PWRITE, [1], [has pwrite])],[
-+ AC_CHECK_LIB(${ost_cv_thread_library}, pread,[
-+ AC_DEFINE(HAVE_PREAD_PWRITE, [1])],[
-+ AC_CHECK_LIB(c_r, pread,[AC_DEFINE(HAVE_PREAD_PWRITE)])
-+ ])
-+ ])
-+
-+ AC_CHECK_LIB(${ost_cv_thread_library}, pthread_suspend,
-+ AC_DEFINE(HAVE_PTHREAD_SUSPEND, [1], [has suspend]))
-+
-+ AC_CHECK_LIB(${ost_cv_thread_library}, pthread_attr_setstacksize,
-+ AC_DEFINE(HAVE_PTHREAD_ATTR_SETSTACKSIZE, [1], [has stack size]))
-+
-+ AC_CHECK_LIB(${ost_cv_thread_library}, pthread_yield_np,
-+ AC_DEFINE(HAVE_PTHREAD_YIELD_NP, [1], [has np yield]),[
-+ AC_CHECK_LIB(${ost_cv_thread_library}, pthread_yield,
-+ AC_DEFINE(HAVE_PTHREAD_YIELD, [1], [has yield]),[
-+ AC_CHECK_LIB(${ost_cv_thread_library}, sched_yield,
-+ AC_DEFINE(HAVE_PTHREAD_SCHED_YIELD, [1], [has sched yield]))
-+ ])
-+ ])
-+
-+ AC_CHECK_LIB(${ost_cv_thread_library}, pthread_cancel,[
-+ AC_DEFINE(HAVE_PTHREAD_CANCEL, [1], [has cancel])
-+ AC_CHECK_LIB(${ost_cv_thread_library},
-+ pthread_setcanceltype,
-+ AC_DEFINE(HAVE_PTHREAD_SETCANCELTYPE, [1], [has setcanceltype]),
-+ AC_CHECK_LIB($ost_cv_thread_library, pthread_setcanel,
-+ AC_DEFINE(HAVE_PTHREAD_SETCANCEL, [1], [has setcancel])))
-+ ],[
-+ AC_CHECK_LIB(${ost_cv_thread_library},
-+ pthread_setcanceltype,[
-+ AC_DEFINE(HAVE_PTHREAD_CANCEL)
-+ AC_DEFINE(HAVE_PTHREAD_SETCANCELTYPE)])
-+
-+ ])
-+
-+ AC_CHECK_LIB(${ost_cv_thread_library}, pthread_delay_np,
-+ AC_DEFINE(HAVE_PTHREAD_DELAY_NP, [1], [has non portable delay]))
-+
-+ fi
-+
-+ UNAME=`uname`
-+ if test "$UNAME" = "AIX" ; then
-+ AC_CHECK_PROG(PTHREAD_CC, cc_r, cc_r, ${CC})
-+ CC=$PTHREAD_CC
-+ AC_DEFINE(COMMON_AIX_FIXES, [1], [aix fixes needed])
-+ fi
-+
-+AH_BOTTOM([
-+#ifdef HAVE_THREAD_H
-+#include "@thrprefix@/thread.h"
-+#if defined(i386) && defined(__svr4__) && !defined(__sun)
-+#define _THR_UNIXWARE
-+#endif
-+#if defined(__SVR4) && defined(__sun)
-+#define _THR_SUNOS5
-+#else
-+#if defined(__SVR4__) && defined(__SUN__)
-+#define _THR_SUNOS5
-+#endif
-+#endif
-+#endif
-+
-+#ifdef HAVE_WORKING_SYS_ATOMIC_H
-+#include <sys/atomic.h>
-+#define HAVE_ATOMIC
-+#elif defined(HAVE_ATOMIC_AIX)
-+#include <sys/atomic_op.h>
-+#ifndef HAVE_ATOMIC
-+#define HAVE_ATOMIC
-+#endif
-+#endif
-+
-+#if defined(__cplusplus)
-+#if defined(HAVE_GCC_BITS_ATOMIC) || defined(HAVE_GCC_CXX_BITS_ATOMIC)
-+#include <bits/atomicity.h>
-+#define HAVE_ATOMIC
-+#endif
-+#endif
-+
-+#if defined(HAVE_PTHREAD_H) && ( defined(_THREAD_SAFE) || defined(_REENTRANT) )
-+
-+#ifdef __QNX__
-+#define __EXT_QNX
-+#endif
-+
-+#include <pthread.h>
-+
-+#ifdef HAVE_PTHREAD_NP_H
-+#include <pthread_np.h>
-+#endif
-+
-+#ifdef HAVE_SEMAPHORE_H
-+#include <semaphore.h>
-+#endif
-+#ifdef _POSIX_PRIORITY_SCHEDULING
-+#ifdef HAVE_SCHED_H
-+#include <sched.h>
-+#else
-+#ifdef HAVE_SYS_SCHED_H
-+#include <sys/sched.h>
-+#endif
-+#endif
-+#endif
-+
-+#define __PTHREAD_H__
-+#ifndef PTHREAD_MUTEXTYPE_RECURSIVE
-+#ifdef MUTEX_TYPE_COUNTING_FAST
-+#define PTHREAD_MUTEXTYPE_RECURSIVE MUTEX_TYPE_COUNTING_FAST
-+#endif
-+#endif
-+#ifndef PTHREAD_MUTEXTYPE_RECURSIVE
-+#ifdef PTHREAD_MUTEX_RECURSIVE
-+#define PTHREAD_MUTEXTYPE_RECURSIVE PTHREAD_MUTEX_RECURSIVE
-+#endif
-+#endif
-+#ifndef HAVE_PTHREAD_MUTEXATTR_SETTYPE
-+#if HAVE_PTHREAD_MUTEXATTR_SETKIND_NP
-+#ifndef PTHREAD_MUTEXTYPE_RECURSIVE
-+#define PTHREAD_MUTEXTYPE_RECURSIVE PTHREAD_MUTEX_RECURSIVE_NP
-+#endif
-+#define pthread_mutexattr_gettype(x, y) pthread_mutexattr_getkind_np(x, y)
-+#define pthread_mutexattr_settype(x, y) pthread_mutexattr_setkind_np(x, y)
-+#endif
-+#if HAVE_PTHREAD_MUTEXATTR_SETTYPE_NP
-+#ifndef PTHREAD_MUTEXTYPE_RECURSIVE
-+#define PTHREAD_MUTEXTYPE_RECURSIVE PTHREAD_MUTEXTYPE_RECURSIVE_NP
-+#endif
-+#define pthread_mutexattr_settype(x, y) pthread_mutexattr_settype_np(x, y)
-+#define pthread_mutexattr_gettype(x, y) pthread_mutexattr_gettype_np(x, y)
-+#endif
-+#endif
-+
-+#ifdef HAVE_PTHREAD_MACH_THREAD_NP
-+#define _THR_MACH
-+#endif
-+
-+#ifndef HAVE_PTHREAD_YIELD
-+#ifdef HAVE_PTHREAD_YIELD_NP
-+#define pthread_yield() pthread_yield_np()
-+#define HAVE_PTHREAD_YIELD
-+#endif
-+#endif
-+
-+#ifndef HAVE_PTHREAD_YIELD
-+#ifdef HAVE_PTHREAD_SCHED_YIELD
-+#define pthread_yield() sched_yield()
-+#define HAVE_PTHREAD_YIELD
-+#endif
-+#endif
-+
-+#ifndef HAVE_PTHREAD_DELAY
-+#ifdef HAVE_PTHREAD_DELAY_NP
-+#define HAVE_PTHREAD_DELAY
-+#define pthread_delay(x) pthread_delay_np(x)
-+#endif
-+#if defined(HAVE_PTHREAD_NANOSLEEP)
-+#ifndef HAVE_PTHREAD_DELAY
-+#define HAVE_PTHREAD_DELAY
-+#ifdef __FreeBSD__
-+#ifdef __cplusplus
-+extern "C" int nanosleep(const struct timespec *rqtp, struct timespec *rmtp);
-+#endif
-+#endif
-+#define pthread_delay(x) nanosleep(x, NULL)
-+#endif
-+#endif
-+#endif
-+
-+#ifdef HAVE_PTHREAD_ATTR_SETSTACK
-+#ifndef PTHREAD_STACK_MIN
-+#define PTHREAD_STACK_MIN 32768
-+#endif
-+#endif
-+
-+#ifndef HAVE_PTHREAD_CANCEL
-+#ifdef SIGCANCEL
-+#define CCXX_SIG_THREAD_CANCEL SIGCANCEL
-+#else
-+#define CCXX_SIG_THREAD_CANCEL SIGQUIT
-+#endif
-+#define pthread_cancel(x) pthread_kill(x, CCXX_SIG_THREAD_CANCEL)
-+#define pthread_setcanceltype(x, y)
-+#define pthread_setcancelstate(x, y)
-+#endif
-+
-+#ifndef HAVE_PTHREAD_SETCANCELTYPE
-+#ifdef HAVE_PTHREAD_SETCANCEL
-+enum
-+{ PTHREAD_CANCEL_ASYNCHRONOUS = CANCEL_ON,
-+ PTHREAD_CANCEL_DEFERRED = CANCEL_OFF};
-+enum
-+{ PTHREAD_CANCEL_ENABLE = CANCEL_ON,
-+ PTHREAD_CANCEL_DISABLE = CANCEL_OFF};
-+#define pthread_setcancelstate(x, y) \
-+ (y == NULL) ? pthread_setcancel(x) : *y = pthread_setcancel
-+#define pthread_setcanceltype(x, y) \
-+ (y == NULL) ? pthread_setasynccancel(x) | *y = pthread_setasynccancel(x)
-+#else
-+#define pthread_setcanceltype(x, y)
-+#define pthread_setcancelstate(x, y)
-+#endif
-+#endif
-+
-+#ifdef _AIX
-+#ifdef HAVE_PTHREAD_SUSPEND
-+#undef HAVE_PTHREAD_SUSPEND
-+#endif
-+#endif
-+
-+#endif
-+
-+
-+ ])
-+
-+])
-+
-diff --git b/m4/ost_systime.m4 a/m4/ost_systime.m4
-new file mode 100644
-index 0000000..f48f207
---- /dev/null
-+++ a/m4/ost_systime.m4
-@@ -0,0 +1,40 @@
-+dnl Copyright (C) 1999-2001 Open Source Telecom Corporation.
-+dnl
-+dnl This program is free software; you can redistribute it and/or modify
-+dnl it under the terms of the GNU General Public License as published by
-+dnl the Free Software Foundation; either version 2 of the License, or
-+dnl (at your option) any later version.
-+dnl
-+dnl This program is distributed in the hope that it will be useful,
-+dnl but WITHOUT ANY WARRANTY; without even the implied warranty of
-+dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-+dnl GNU General Public License for more details.
-+dnl
-+dnl You should have received a copy of the GNU General Public License
-+dnl along with this program; if not, write to the Free Software
-+dnl Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
-+dnl
-+dnl As a special exception to the GNU General Public License, if you
-+dnl distribute this file as part of a program that contains a configuration
-+dnl script generated by Autoconf, you may include it under the same
-+dnl distribution terms that you use for the rest of that program.
-+
-+AC_DEFUN(OST_CC_SYSTIME,[
-+ AC_HEADER_TIME
-+ AC_CHECK_HEADERS(sys/time.h)
-+AH_TOP([
-+#undef HAVE_SYS_TIME_H
-+#if TIME_WITH_SYS_TIME
-+#include <sys/time.h>
-+#include <time.h>
-+#else
-+#if HAVE_SYS_TIME_H
-+#include <sys/time.h>
-+#else
-+#include <time.h>
-+#endif
-+#endif
-+ ])
-+
-+])
-+
-
-commit 7b304172a261034b049b0bf4b41208eac54ebd90
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sun Oct 19 14:39:02 2008 +0000
-
- Started version 0.9.1.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@482 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/ChangeLog b/ChangeLog
-index 5162192..b9a510f 100644
---- a/ChangeLog
-+++ b/ChangeLog
-@@ -1,4 +1,12 @@
-
-+VERSION 0.9.1svn
-+================
-+
-+2008-10-19 Vincent Richard <vincent@vincent-richard.net>
-+
-+ * Started version 0.9.1.
-+
-+
- VERSION 0.9.0
- =============
-
-diff --git a/SConstruct b/SConstruct
-index 6014385..7f62876 100644
---- a/SConstruct
-+++ b/SConstruct
-@@ -29,7 +29,7 @@ import string
- # Package version number
- packageVersionMajor = 0
- packageVersionMinor = 9
--packageVersionMicro = 0
-+packageVersionMicro = 1
-
- # API version number (libtool)
- #
-
-commit d0960f6bbb000849505e4fd47de1ab10c3a17627
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sun Nov 9 13:48:04 2008 +0000
-
- Missing #include for GCC 4.4 (thanks to Martin Michlmayr).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@483 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/platforms/posix/posixFile.cpp b/src/platforms/posix/posixFile.cpp
-index 4d063d4..e89b9ab 100644
---- a/src/platforms/posix/posixFile.cpp
-+++ b/src/platforms/posix/posixFile.cpp
-@@ -32,6 +32,7 @@
-
- #include <dirent.h>
-
-+#include <stdio.h>
- #include <string.h>
-
- #include "vmime/exception.hpp"
-
-commit 9b74d48f383169f9269dbd6612e0b180f9f7119b
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Dec 16 21:44:42 2008 +0000
-
- Send CRLF in the same packet as command to avoid problems with some servers.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@484 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/net/smtp/SMTPTransport.cpp b/src/net/smtp/SMTPTransport.cpp
-index 3ce8d21..5ad8d70 100644
---- a/src/net/smtp/SMTPTransport.cpp
-+++ b/src/net/smtp/SMTPTransport.cpp
-@@ -617,8 +617,10 @@ void SMTPTransport::send(const mailbox& expeditor, const mailboxList& recipients
-
- void SMTPTransport::sendRequest(const string& buffer, const bool end)
- {
-- m_socket->send(buffer);
-- if (end) m_socket->send("\r\n");
-+ if (end)
-+ m_socket->send(buffer + "\r\n");
-+ else
-+ m_socket->send(buffer);
- }
-
-
-
-commit 72c169401644272043bbb4e536e13fbf9df494b2
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Mon Dec 29 21:46:08 2008 +0000
-
- Fixed week of year for 53th week (non ISO-compliant).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@485 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/utility/datetimeUtils.cpp b/src/utility/datetimeUtils.cpp
-index ed9fb4b..cc06f50 100644
---- a/src/utility/datetimeUtils.cpp
-+++ b/src/utility/datetimeUtils.cpp
-@@ -322,6 +322,9 @@ int datetimeUtils::getWeekOfYear(const int year, const int month, const int day)
- WeekNumber -= 1;
- }
-
-+ if (WeekNumber == 1 && month == 12)
-+ WeekNumber = 53;
-+
- return WeekNumber;
- }
-
-
-commit bf516d786e3af88e2663cb96ba7026f8fb9b09cb
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Fri Jan 9 21:07:42 2009 +0000
-
- Fixed non-numeric timezone parsing (thanks to John van der Kamp, Zarafa).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@486 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/dateTime.cpp b/src/dateTime.cpp
-index 3af6da7..66cd992 100644
---- a/src/dateTime.cpp
-+++ b/src/dateTime.cpp
-@@ -427,7 +427,7 @@ void datetime::parse(const string& buffer, const string::size_type position,
- zone[zoneLength++] = *p;
- ++p;
- }
-- while (zoneLength < 3 && p < pend && parserHelpers::isDigit(*p));
-+ while (zoneLength < 3 && p < pend);
-
- switch (zone[0])
- {
-@@ -491,6 +491,8 @@ void datetime::parse(const string& buffer, const string::size_type position,
-
- break;
- }
-+ case 'g':
-+ case 'G':
- case 'u':
- case 'U':
- {
-
-commit 248d19bf70b8b71e9cdb9f92a09f338289ff5b2a
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sun Mar 1 21:23:40 2009 +0000
-
- Use Decider() method instead of deprecated SourceSignatures/TargetSignatures().
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@487 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/SConstruct b/SConstruct
-index 7f62876..4bfddd8 100644
---- a/SConstruct
-+++ b/SConstruct
-@@ -439,9 +439,7 @@ EnsureSConsVersion(0, 94)
-
- SetOption('implicit_cache', 1)
-
--#SourceSignatures('timestamp')
--SourceSignatures('MD5')
--TargetSignatures('build')
-+Decider('MD5-timestamp')
-
-
- #############
-
-commit 0131dcb8198dc1253bf2b5e86709ff009f4fa448
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Thu Apr 9 18:15:50 2009 +0000
-
- Fixed block size through filtered streams.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@488 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/utility/filteredStream.cpp b/src/utility/filteredStream.cpp
-index eda0c64..5db0104 100644
---- a/src/utility/filteredStream.cpp
-+++ b/src/utility/filteredStream.cpp
-@@ -30,6 +30,22 @@ namespace vmime {
- namespace utility {
-
-
-+// filteredInputStream
-+
-+stream::size_type filteredInputStream::getBlockSize()
-+{
-+ return std::min(inputStream::getBlockSize(), getPreviousInputStream().getBlockSize());
-+}
-+
-+
-+// filteredOutputStream
-+
-+stream::size_type filteredOutputStream::getBlockSize()
-+{
-+ return std::min(outputStream::getBlockSize(), getNextOutputStream().getBlockSize());
-+}
-+
-+
- // dotFilteredInputStream
-
- dotFilteredInputStream::dotFilteredInputStream(inputStream& is)
-diff --git a/src/utility/stream.cpp b/src/utility/stream.cpp
-index bb5300e..8fbf337 100644
---- a/src/utility/stream.cpp
-+++ b/src/utility/stream.cpp
-@@ -38,7 +38,7 @@ namespace utility {
-
- // stream
-
--stream::size_type stream::getBlockSize() const
-+stream::size_type stream::getBlockSize()
- {
- return 32768; // 32 KB
- }
-@@ -468,7 +468,7 @@ void outputStreamSocketAdapter::flush()
- }
-
-
--stream::size_type outputStreamSocketAdapter::getBlockSize() const
-+stream::size_type outputStreamSocketAdapter::getBlockSize()
- {
- return 16384; // 16 KB
- }
-@@ -511,7 +511,7 @@ stream::size_type inputStreamSocketAdapter::skip
- }
-
-
--stream::size_type inputStreamSocketAdapter::getBlockSize() const
-+stream::size_type inputStreamSocketAdapter::getBlockSize()
- {
- return 16384; // 16 KB
- }
-diff --git a/vmime/utility/filteredStream.hpp b/vmime/utility/filteredStream.hpp
-index 9f64ba9..1e03697 100644
---- a/vmime/utility/filteredStream.hpp
-+++ b/vmime/utility/filteredStream.hpp
-@@ -41,6 +41,8 @@ class filteredInputStream : public inputStream
- {
- public:
-
-+ virtual size_type getBlockSize();
-+
- /** Return a reference to the stream being filtered.
- *
- * @return stream being filtered
-@@ -56,6 +58,8 @@ class filteredOutputStream : public outputStream
- {
- public:
-
-+ virtual size_type getBlockSize();
-+
- /** Return a reference to the stream being filtered.
- *
- * @return destination stream for filtered data
-diff --git a/vmime/utility/stream.hpp b/vmime/utility/stream.hpp
-index a9c079b..5f7bfa2 100644
---- a/vmime/utility/stream.hpp
-+++ b/vmime/utility/stream.hpp
-@@ -77,7 +77,7 @@ public:
- *
- * @return block size, in bytes
- */
-- virtual size_type getBlockSize() const;
-+ virtual size_type getBlockSize();
- };
-
-
-@@ -239,6 +239,7 @@ public:
- void write(const value_type* const data, const size_type count);
- void flush();
-
-+size_type getBlockSize(){return 8192;}
- private:
-
- string& m_buffer;
-@@ -402,7 +403,7 @@ public:
- void write(const value_type* const data, const size_type count);
- void flush();
-
-- size_type getBlockSize() const;
-+ size_type getBlockSize();
-
- private:
-
-@@ -426,7 +427,7 @@ public:
- size_type read(value_type* const data, const size_type count);
- size_type skip(const size_type count);
-
-- size_type getBlockSize() const;
-+ size_type getBlockSize();
-
- private:
-
-
-commit 11e0721c996957696f41f7450d4161fefad2f450
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Thu Apr 9 20:24:08 2009 +0000
-
- Fixed duplicate switch case on AIX (thanks to Robin Rawson-Tetley).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@489 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/platforms/posix/posixFile.cpp b/src/platforms/posix/posixFile.cpp
-index e89b9ab..b371fe7 100644
---- a/src/platforms/posix/posixFile.cpp
-+++ b/src/platforms/posix/posixFile.cpp
-@@ -488,7 +488,9 @@ void posixFileSystemFactory::reportError(const vmime::utility::path& path, const
- case ENOMEM: desc = "ENOMEM: insufficient kernel memory."; break;
- case EMFILE: desc = "ENFILE: limit on number of files open by the process has been reached."; break;
- case ENFILE: desc = "ENFILE: limit on number of files open on the system has been reached."; break;
-+#ifndef AIX
- case ENOTEMPTY: desc = "ENOTEMPTY: directory is not empty."; break;
-+#endif
-
- default:
-
-
-commit d5783e1bfc66a3632820379f4d3f45957469a260
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Thu Apr 9 20:31:16 2009 +0000
-
- Removed '-pipe' compiler flags, as it is not available on all platforms.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@490 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/SConstruct b/SConstruct
-index 4bfddd8..7ba1b27 100644
---- a/SConstruct
-+++ b/SConstruct
-@@ -590,7 +590,6 @@ env.Append(CPPPATH = [ '.' ])
-
- env.Append(CPPDEFINES = ['_REENTRANT=1'])
-
--env.Append(CXXFLAGS = ['-pipe'])
- env.Append(CXXFLAGS = ['-W'])
- env.Append(CXXFLAGS = ['-Wall'])
- env.Append(CXXFLAGS = ['-ansi'])
-@@ -1831,7 +1830,7 @@ EXTRA_CFLAGS="$EXTRA_CFLAGS $lt_prog_compiler_pic"
-
- """)
-
-- compilerFlags = [ '-pipe', '-ansi', '-pedantic', '-W', '-Wall', '-Wpointer-arith', '-Wold-style-cast', '-Wconversion' ]
-+ compilerFlags = [ '-ansi', '-pedantic', '-W', '-Wall', '-Wpointer-arith', '-Wold-style-cast', '-Wconversion' ]
-
- for f in compilerFlags:
- configure_in.write('# ' + f + '\n')
-
-commit 71398fc74b32da917bb7e8bc8b7d7c1dc79dd03c
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Fri May 1 17:11:20 2009 +0000
-
- Fixed dynamic_cast support detection on HPUX (aCC).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@491 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/SConstruct b/SConstruct
-index 7ba1b27..2a01b61 100644
---- a/SConstruct
-+++ b/SConstruct
-@@ -1414,8 +1414,8 @@ AC_TRY_COMPILE(
- AC_MSG_CHECKING([if C++ compiler supports dynamic_cast<> (required)])
- AC_TRY_COMPILE(
- [
-- class foo { virtual ~foo() { } };
-- class bar : public foo { };
-+ class foo { public: virtual ~foo() { } };
-+ class bar : public foo { public: virtual ~bar() { } };
- ],[
- foo *c=0;
- bar *c1=dynamic_cast<bar*>(c);
-
-commit 72074634c0810f69abc92c312199263921c1a619
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sun Jun 21 20:57:03 2009 +0000
-
- Check return status of fsync (Georg Sauthoff).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@492 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/AUTHORS b/AUTHORS
-index da6f087..d252ee3 100644
---- a/AUTHORS
-+++ b/AUTHORS
-@@ -19,4 +19,5 @@ Other contributors:
- - Benjamin Biron <benbiron@gmail.com>
- - Bertrand Benoit <bsquare@bsquare.levillage.org>
- - Tim Teulings <rael@edge.ping.de>
-+ - Georg Sauthoff <gsauthof@techfak.uni-bielefeld.de>
-
-diff --git a/src/platforms/posix/posixFile.cpp b/src/platforms/posix/posixFile.cpp
-index b371fe7..d04ebc2 100644
---- a/src/platforms/posix/posixFile.cpp
-+++ b/src/platforms/posix/posixFile.cpp
-@@ -126,7 +126,8 @@ void posixFileWriterOutputStream::write(const value_type* const data, const size
-
- void posixFileWriterOutputStream::flush()
- {
-- ::fsync(m_fd);
-+ if (::fsync(m_fd) == -1)
-+ posixFileSystemFactory::reportError(m_path, errno);
- }
-
-
-
-commit 063e9acffbbdff0ba65b69e27492551a4370673c
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sun Jun 21 21:05:16 2009 +0000
-
- Added other missing return error checks for posix system calls; check consistent for -1 (Georg Sauthoff).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@493 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/platforms/posix/posixFile.cpp b/src/platforms/posix/posixFile.cpp
-index d04ebc2..79da351 100644
---- a/src/platforms/posix/posixFile.cpp
-+++ b/src/platforms/posix/posixFile.cpp
-@@ -63,7 +63,10 @@ posixFileIterator::posixFileIterator(const vmime::utility::file::path& path, con
- posixFileIterator::~posixFileIterator()
- {
- if (m_dir != NULL)
-- ::closedir(m_dir);
-+ {
-+ if (::closedir(m_dir) == -1)
-+ posixFileSystemFactory::reportError(m_path, errno);
-+ }
- }
-
-
-@@ -86,6 +89,8 @@ ref <vmime::utility::file> posixFileIterator::nextElement()
-
- void posixFileIterator::getNextElement()
- {
-+ errno = 0;
-+
- while ((m_dirEntry = ::readdir(m_dir)) != NULL)
- {
- const char* name = m_dirEntry->d_name;
-@@ -97,6 +102,9 @@ void posixFileIterator::getNextElement()
- break;
- }
- }
-+
-+ if (errno)
-+ posixFileSystemFactory::reportError(m_path, errno);
- }
-
-
-@@ -144,7 +152,8 @@ posixFileReaderInputStream::posixFileReaderInputStream(const vmime::utility::fil
-
- posixFileReaderInputStream::~posixFileReaderInputStream()
- {
-- ::close(m_fd);
-+ if (::close(m_fd) == -1)
-+ posixFileSystemFactory::reportError(m_path, errno);
- }
-
-
-@@ -156,7 +165,8 @@ bool posixFileReaderInputStream::eof() const
-
- void posixFileReaderInputStream::reset()
- {
-- ::lseek(m_fd, 0, SEEK_SET);
-+ if (::lseek(m_fd, 0, SEEK_SET) == off_t(-1))
-+ posixFileSystemFactory::reportError(m_path, errno);
- }
-
-
-@@ -178,8 +188,15 @@ vmime::utility::stream::size_type posixFileReaderInputStream::read
- vmime::utility::stream::size_type posixFileReaderInputStream::skip(const size_type count)
- {
- const off_t curPos = ::lseek(m_fd, 0, SEEK_CUR);
-+
-+ if (curPos == off_t(-1))
-+ posixFileSystemFactory::reportError(m_path, errno);
-+
- const off_t newPos = ::lseek(m_fd, count, SEEK_CUR);
-
-+ if (newPos == off_t(-1))
-+ posixFileSystemFactory::reportError(m_path, errno);
-+
- return static_cast <size_type>(newPos - curPos);
- }
-
-@@ -246,7 +263,8 @@ void posixFile::createFile()
- if ((fd = ::open(m_nativePath.c_str(), O_CREAT | O_EXCL | O_WRONLY, 0660)) == -1)
- posixFileSystemFactory::reportError(m_path, errno);
-
-- ::close(fd);
-+ if (::close(fd) == -1)
-+ posixFileSystemFactory::reportError(m_path, errno);
- }
-
-
-@@ -259,32 +277,58 @@ void posixFile::createDirectory(const bool createAll)
- bool posixFile::isFile() const
- {
- struct stat buf;
-- return (::stat(m_nativePath.c_str(), &buf) == 0 && S_ISREG(buf.st_mode));
-+
-+ if (::stat(m_nativePath.c_str(), &buf) == -1)
-+ {
-+ posixFileSystemFactory::reportError(m_path, errno);
-+ return false;
-+ }
-+
-+ return S_ISREG(buf.st_mode);
- }
-
-
- bool posixFile::isDirectory() const
- {
- struct stat buf;
-- return (::stat(m_nativePath.c_str(), &buf) == 0 && S_ISDIR(buf.st_mode));
-+
-+ if (::stat(m_nativePath.c_str(), &buf) == -1)
-+ {
-+ posixFileSystemFactory::reportError(m_path, errno);
-+ return false;
-+ }
-+
-+ return S_ISDIR(buf.st_mode);
- }
-
-
- bool posixFile::canRead() const
- {
- struct stat buf;
-- return (::stat(m_nativePath.c_str(), &buf) == 0 &&
-- S_ISREG(buf.st_mode) &&
-- ::access(m_nativePath.c_str(), R_OK | F_OK) == 0);
-+
-+ if (::stat(m_nativePath.c_str(), &buf) == -1)
-+ {
-+ posixFileSystemFactory::reportError(m_path, errno);
-+ return false;
-+ }
-+
-+ return S_ISREG(buf.st_mode) &&
-+ ::access(m_nativePath.c_str(), R_OK | F_OK) == 0;
- }
-
-
- bool posixFile::canWrite() const
- {
- struct stat buf;
-- return (::stat(m_nativePath.c_str(), &buf) == 0 &&
-- S_ISREG(buf.st_mode) &&
-- ::access(m_nativePath.c_str(), W_OK | F_OK) == 0);
-+
-+ if (::stat(m_nativePath.c_str(), &buf) == -1)
-+ {
-+ posixFileSystemFactory::reportError(m_path, errno);
-+ return false;
-+ }
-+
-+ return S_ISREG(buf.st_mode) &&
-+ ::access(m_nativePath.c_str(), W_OK | F_OK) == 0;
- }
-
-
-@@ -292,7 +336,7 @@ posixFile::length_type posixFile::getLength()
- {
- struct stat buf;
-
-- if (::stat(m_nativePath.c_str(), &buf) != 0)
-+ if (::stat(m_nativePath.c_str(), &buf) == -1)
- posixFileSystemFactory::reportError(m_path, errno);
-
- return static_cast <length_type>(buf.st_size);
-@@ -325,7 +369,7 @@ void posixFile::rename(const path& newName)
- {
- const vmime::string newNativePath = posixFileSystemFactory::pathToStringImpl(newName);
-
-- if (::rename(m_nativePath.c_str(), newNativePath.c_str()) != 0)
-+ if (::rename(m_nativePath.c_str(), newNativePath.c_str()) == -1)
- posixFileSystemFactory::reportError(m_path, errno);
-
- m_path = newName;
-@@ -337,17 +381,17 @@ void posixFile::remove()
- {
- struct stat buf;
-
-- if (::stat(m_nativePath.c_str(), &buf) != 0)
-+ if (::stat(m_nativePath.c_str(), &buf) == -1)
- posixFileSystemFactory::reportError(m_path, errno);
-
- if (S_ISDIR(buf.st_mode))
- {
-- if (::rmdir(m_nativePath.c_str()) != 0)
-+ if (::rmdir(m_nativePath.c_str()) == -1)
- posixFileSystemFactory::reportError(m_path, errno);
- }
- else if (S_ISREG(buf.st_mode))
- {
-- if (::unlink(m_nativePath.c_str()) != 0)
-+ if (::unlink(m_nativePath.c_str()) == -1)
- posixFileSystemFactory::reportError(m_path, errno);
- }
- }
-@@ -386,7 +430,7 @@ void posixFile::createDirectoryImpl(const vmime::utility::file::path& fullPath,
- if (!path.isEmpty() && recursive)
- createDirectoryImpl(fullPath, path.getParent(), true);
-
-- if (::mkdir(nativePath.c_str(), 0750) != 0)
-+ if (::mkdir(nativePath.c_str(), 0750) == -1)
- posixFileSystemFactory::reportError(fullPath, errno);
- }
-
-
-commit da3d98391ef7004969845593d583812d06d904e7
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sun Jun 21 21:07:35 2009 +0000
-
- Changed posix write wrapper since a) write can be interrupted and b) write can write less than specified without error (Georg Sauthoff).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@494 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/platforms/posix/posixFile.cpp b/src/platforms/posix/posixFile.cpp
-index 79da351..9b16d03 100644
---- a/src/platforms/posix/posixFile.cpp
-+++ b/src/platforms/posix/posixFile.cpp
-@@ -127,8 +127,29 @@ posixFileWriterOutputStream::~posixFileWriterOutputStream()
-
- void posixFileWriterOutputStream::write(const value_type* const data, const size_type count)
- {
-- if (::write(m_fd, data, count) == -1)
-- posixFileSystemFactory::reportError(m_path, errno);
-+ const value_type* array = data;
-+ size_t size = count;
-+
-+ while (1)
-+ {
-+ ssize_t ret = ::write(m_fd, array, size);
-+
-+ if (ret == -1)
-+ {
-+ if (errno == EINTR)
-+ continue;
-+
-+ posixFileSystemFactory::reportError(m_path, errno);
-+ break;
-+ }
-+ else if (size_t(ret) < size)
-+ {
-+ array += ret;
-+ size -= ret;
-+ }
-+
-+ break;
-+ }
- }
-
-
-
-commit 33c37b2603fc3a0608fc75d2951408057d38ba60
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sun Jun 21 21:08:56 2009 +0000
-
- Use ::flush() (aka fsync()) after a maildir message is written (Georg Sauthoff).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@495 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/net/maildir/maildirFolder.cpp b/src/net/maildir/maildirFolder.cpp
-index 4f0acaf..9a52171 100644
---- a/src/net/maildir/maildirFolder.cpp
-+++ b/src/net/maildir/maildirFolder.cpp
-@@ -945,6 +945,8 @@ void maildirFolder::copyMessageImpl(const utility::file::path& tmpDirPath,
- if (progress)
- progress->progress(total, size);
- }
-+
-+ os->flush();
- }
- catch (exception& e)
- {
-
-commit 58afd9dee9633c8e66eb9b9a4d781fdd5de402e9
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sun Jun 21 21:19:00 2009 +0000
-
- Include hostname in message id (ensure unicity when working on a network file system).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@496 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/net/maildir/maildirUtils.cpp b/src/net/maildir/maildirUtils.cpp
-index 67d52fe..13311a5 100644
---- a/src/net/maildir/maildirUtils.cpp
-+++ b/src/net/maildir/maildirUtils.cpp
-@@ -25,6 +25,7 @@
- #include "vmime/net/maildir/maildirStore.hpp"
-
- #include "vmime/utility/random.hpp"
-+#include "vmime/platform.hpp"
-
- #include "vmime/exception.hpp"
-
-@@ -153,6 +154,8 @@ const utility::file::path::component maildirUtils::generateId()
- oss << utility::random::getProcess();
- oss << ".";
- oss << utility::random::getString(6);
-+ oss << ".";
-+ oss << platform::getHandler()->getHostName();
-
- return (utility::file::path::component(oss.str()));
- }
-
-commit 184dacc1ff75195fa594a18fb697b80dd8e08e43
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sun Jun 21 21:32:25 2009 +0000
-
- gnutls_x509_crt_list_import does not support multiple DER certificates (Georg Sauthoff).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@497 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/net/tls/TLSSocket.cpp b/src/net/tls/TLSSocket.cpp
-index 73af1da..4f64967 100644
---- a/src/net/tls/TLSSocket.cpp
-+++ b/src/net/tls/TLSSocket.cpp
-@@ -292,27 +292,26 @@ ref <security::cert::certificateChain> TLSSocket::getPeerCertificates() const
- // Try X.509
- gnutls_x509_crt* x509Certs = new gnutls_x509_crt[certCount];
-
-- unsigned int count = certCount;
--
-- int res = gnutls_x509_crt_list_import
-- (x509Certs, &count, rawData, GNUTLS_X509_FMT_PEM, 0);
--
-- if (res <= 0)
-+ for (unsigned int i = 0; i < certCount; ++i)
- {
-- count = certCount;
-+ gnutls_x509_crt_init(x509Certs + i);
-
-- res = gnutls_x509_crt_list_import
-- (x509Certs, &count, rawData, GNUTLS_X509_FMT_DER, 0);
-+ int res = gnutls_x509_crt_import(x509Certs[i], rawData + i,
-+ GNUTLS_X509_FMT_DER);
-+
-+ if (res < 0)
-+ {
-+ // XXX more fine-grained error reporting?
-+ delete [] x509Certs;
-+ return NULL;
-+ }
- }
-
-- if (res >= 1)
- {
- std::vector <ref <security::cert::certificate> > certs;
- bool error = false;
-
-- count = static_cast <unsigned int>(res);
--
-- for (unsigned int i = 0 ; i < count ; ++i)
-+ for (unsigned int i = 0 ; i < certCount ; ++i)
- {
- size_t dataSize = 0;
-
-
-commit c0cec33b83284f8ad6112c63cea9c11f4c067e0c
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sat Jul 11 12:21:59 2009 +0000
-
- Ensure 'unsigned long' is 4 bytes long (Georg Sauthoff).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@498 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/security/digest/sha1/sha1MessageDigest.cpp b/src/security/digest/sha1/sha1MessageDigest.cpp
-index a51e250..51eec6a 100644
---- a/src/security/digest/sha1/sha1MessageDigest.cpp
-+++ b/src/security/digest/sha1/sha1MessageDigest.cpp
-@@ -27,6 +27,7 @@
- #include "vmime/security/digest/sha1/sha1MessageDigest.hpp"
-
- #include <cstring>
-+#include <cassert>
-
-
- namespace vmime {
-@@ -161,8 +162,8 @@ void sha1MessageDigest::finalize()
- i = j = 0;
-
- std::memset(m_buffer, 0, 64);
-- std::memset(m_state, 0, 20);
-- std::memset(m_count, 0, 8);
-+ std::memset(m_state, 0, 5 * sizeof(unsigned long));
-+ std::memset(m_count, 0, 2 * sizeof(unsigned long));
- std::memset(&finalcount, 0, 8);
- }
-
-@@ -201,6 +202,8 @@ void sha1MessageDigest::transform
- unsigned long l[16];
- } CHAR64LONG16;
-
-+ assert(sizeof(unsigned long) == 4);
-+
- CHAR64LONG16* block;
- static unsigned char workspace[64];
-
-
-commit ab6295012905d625d8606408905c8e4bb63b0635
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sat Jul 11 12:31:18 2009 +0000
-
- fsync() in posixFile::fileCreate(); changed posixFile::rename to exclusive semantics - if dst exists it fails (Georg Sauthoff).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@499 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/platforms/posix/posixFile.cpp b/src/platforms/posix/posixFile.cpp
-index 9b16d03..2a1356a 100644
---- a/src/platforms/posix/posixFile.cpp
-+++ b/src/platforms/posix/posixFile.cpp
-@@ -284,6 +284,9 @@ void posixFile::createFile()
- if ((fd = ::open(m_nativePath.c_str(), O_CREAT | O_EXCL | O_WRONLY, 0660)) == -1)
- posixFileSystemFactory::reportError(m_path, errno);
-
-+ if (::fsync(fd) == -1)
-+ posixFileSystemFactory::reportError(m_path, errno);
-+
- if (::close(fd) == -1)
- posixFileSystemFactory::reportError(m_path, errno);
- }
-@@ -390,6 +393,9 @@ void posixFile::rename(const path& newName)
- {
- const vmime::string newNativePath = posixFileSystemFactory::pathToStringImpl(newName);
-
-+ posixFile dest(newName);
-+ dest.createFile();
-+
- if (::rename(m_nativePath.c_str(), newNativePath.c_str()) == -1)
- posixFileSystemFactory::reportError(m_path, errno);
-
-
-commit 37807bc97a51d0ef561c9102580b2dd12d66c08a
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sat Jul 11 12:39:36 2009 +0000
-
- maildirFolder::addMessage() : iff FLAG_RECENT is present, add message to 'new' instead of 'cur' (Georg Sauthoff).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@500 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/net/maildir/maildirFolder.cpp b/src/net/maildir/maildirFolder.cpp
-index 9a52171..65abdcf 100644
---- a/src/net/maildir/maildirFolder.cpp
-+++ b/src/net/maildir/maildirFolder.cpp
-@@ -835,9 +835,12 @@ void maildirFolder::addMessage(utility::inputStream& is, const int size,
- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-
- utility::file::path tmpDirPath = store->getFormat()->
-- folderPathToFileSystemPath(m_path, maildirFormat::TMP_DIRECTORY);
-- utility::file::path curDirPath = store->getFormat()->
-- folderPathToFileSystemPath(m_path, maildirFormat::CUR_DIRECTORY);
-+ folderPathToFileSystemPath(m_path,maildirFormat::TMP_DIRECTORY);
-+ utility::file::path dstDirPath = store->getFormat()->
-+ folderPathToFileSystemPath(m_path,
-+ flags == message::FLAG_RECENT ?
-+ maildirFormat::NEW_DIRECTORY :
-+ maildirFormat::CUR_DIRECTORY);
-
- const utility::file::path::component filename =
- maildirUtils::buildFilename(maildirUtils::generateId(),
-@@ -855,7 +858,7 @@ void maildirFolder::addMessage(utility::inputStream& is, const int size,
-
- try
- {
-- ref <utility::file> curDir = fsf->create(curDirPath);
-+ ref <utility::file> curDir = fsf->create(dstDirPath);
- curDir->createDirectory(true);
- }
- catch (exceptions::filesystem_exception&)
-@@ -864,7 +867,7 @@ void maildirFolder::addMessage(utility::inputStream& is, const int size,
- }
-
- // Actually add the message
-- copyMessageImpl(tmpDirPath, curDirPath, filename, is, size, progress);
-+ copyMessageImpl(tmpDirPath, dstDirPath, filename, is, size, progress);
-
- // Append the message to the cache list
- messageInfos msgInfos;
-@@ -910,7 +913,8 @@ void maildirFolder::addMessage(utility::inputStream& is, const int size,
-
-
- void maildirFolder::copyMessageImpl(const utility::file::path& tmpDirPath,
-- const utility::file::path& curDirPath, const utility::file::path::component& filename,
-+ const utility::file::path& dstDirPath,
-+ const utility::file::path::component& filename,
- utility::inputStream& is, const utility::stream::size_type size,
- utility::progressListener* progress)
- {
-@@ -970,7 +974,7 @@ void maildirFolder::copyMessageImpl(const utility::file::path& tmpDirPath,
- // ...then, move it to 'cur'
- try
- {
-- file->rename(curDirPath / filename);
-+ file->rename(dstDirPath / filename);
- }
- catch (exception& e)
- {
-@@ -980,7 +984,8 @@ void maildirFolder::copyMessageImpl(const utility::file::path& tmpDirPath,
- // Delete temporary file
- try
- {
-- ref <utility::file> file = fsf->create(tmpDirPath / filename);
-+ file->remove();
-+ ref <utility::file> file = fsf->create(dstDirPath / filename);
- file->remove();
- }
- catch (exceptions::filesystem_exception&)
-diff --git a/src/net/maildir/maildirUtils.cpp b/src/net/maildir/maildirUtils.cpp
-index 13311a5..bb2b69f 100644
---- a/src/net/maildir/maildirUtils.cpp
-+++ b/src/net/maildir/maildirUtils.cpp
-@@ -129,18 +129,24 @@ const utility::file::path::component maildirUtils::buildFlags(const int flags)
- const utility::file::path::component maildirUtils::buildFilename
- (const utility::file::path::component& id, const int flags)
- {
-- return (buildFilename(id, buildFlags(flags)));
-+ if (flags == message::FLAG_RECENT)
-+ return id;
-+ else
-+ return (buildFilename(id, buildFlags(flags)));
- }
-
-
- const utility::file::path::component maildirUtils::buildFilename
-- (const utility::file::path::component& id, const utility::file::path::component& flags)
-+ (const utility::file::path::component& id,
-+ const utility::file::path::component& flags)
- {
- #if VMIME_BUILTIN_PLATFORM_WINDOWS
-- return (utility::path::component(id.getBuffer() + "-" + flags.getBuffer())); // use dash
-+ static const char DELIMITER[] = "-";
- #else
-- return (utility::path::component(id.getBuffer() + ":" + flags.getBuffer())); // use colon
-+ static const char DELIMITER[] = ":";
- #endif
-+
-+ return utility::path::component(id.getBuffer() + DELIMITER + flags.getBuffer());
- }
-
-
-
-commit 867808f0e40d69009755419d77f764d2224b8a78
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Aug 19 18:41:20 2009 +0000
-
- Use pkg-config for gnutls 2.8.0 and later (thanks to Andreas Metzler).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@501 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/SConstruct b/SConstruct
-index 2a01b61..2e86832 100644
---- a/SConstruct
-+++ b/SConstruct
-@@ -1617,7 +1617,7 @@ AC_ARG_ENABLE(tls,
-
- if test "x$conf_tls" = "xyes"; then
- # -- GNU TLS Library (http://www.gnu.org/software/gnutls/)
-- AM_PATH_LIBGNUTLS(1.2.0, have_gnutls=yes, have_gnutls=no)
-+ PKG_CHECK_MODULES([LIBGNUTLS], [gnutls >= 1.2.0], have_gnutls=yes, have_gnutls=no)
-
- if test "x$have_gnutls" = "xyes"; then
- AM_CONDITIONAL(VMIME_HAVE_TLS_SUPPORT, true)
-
-commit 0dc22247b059382321a3228bb07e0819596466d0
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sun Sep 6 12:02:10 2009 +0000
-
- Relicensed VMime under the GNU GPL version 3. Changed copyright year to 2009.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@502 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/AUTHORS b/AUTHORS
-index d252ee3..8391c18 100644
---- a/AUTHORS
-+++ b/AUTHORS
-@@ -1,17 +1,14 @@
-
--VMIME AUTHORS AND CONTRIBUTORS
--==============================
-+VMIME AUTHOR
-+============
-
- Vincent Richard <vincent@vincent-richard.net>
--Project originator, design, core implementation.
-+Project owner and creator. VMime was created in 1998, and publicly released
-+under the GNU GPL license in 2003.
-
--Pierre Thierry <nowhere.man@levallois.eu.org>
--Patches for STL algorithms.
-
--Zarafa <http://developer.zarafa.com/VmimePatches>
--Miscellaneous patches.
--
--Other contributors:
-+VMIME CONTRIBUTORS
-+==================
-
- - Stefan Uhrig <stefanuhrig@gmx.net>
- - Rafael Fernandez <prf@adinet.com.uy>
-@@ -20,4 +17,9 @@ Other contributors:
- - Bertrand Benoit <bsquare@bsquare.levillage.org>
- - Tim Teulings <rael@edge.ping.de>
- - Georg Sauthoff <gsauthof@techfak.uni-bielefeld.de>
-+ - Pierre Thierry <nowhere.man@levallois.eu.org> (patches for STL algorithms)
-+ - Zarafa <http://developer.zarafa.com/VmimePatches>
-+
-+Please apologize if I have forgotten someone here. ;)
-+See SVN Changelog for full list.
-
-diff --git a/COPYING b/COPYING
-index 5b6e7c6..94a9ed0 100644
---- a/COPYING
-+++ b/COPYING
-@@ -1,285 +1,626 @@
-- GNU GENERAL PUBLIC LICENSE
-- Version 2, June 1991
-+ GNU GENERAL PUBLIC LICENSE
-+ Version 3, 29 June 2007
-
-- Copyright (C) 1989, 1991 Free Software Foundation, Inc.
-- 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
-+ Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
- Everyone is permitted to copy and distribute verbatim copies
- of this license document, but changing it is not allowed.
-
-- Preamble
-+ Preamble
-
-- The licenses for most software are designed to take away your
--freedom to share and change it. By contrast, the GNU General Public
--License is intended to guarantee your freedom to share and change free
--software--to make sure the software is free for all its users. This
--General Public License applies to most of the Free Software
--Foundation's software and to any other program whose authors commit to
--using it. (Some other Free Software Foundation software is covered by
--the GNU Library General Public License instead.) You can apply it to
-+ The GNU General Public License is a free, copyleft license for
-+software and other kinds of works.
-+
-+ The licenses for most software and other practical works are designed
-+to take away your freedom to share and change the works. By contrast,
-+the GNU General Public License is intended to guarantee your freedom to
-+share and change all versions of a program--to make sure it remains free
-+software for all its users. We, the Free Software Foundation, use the
-+GNU General Public License for most of our software; it applies also to
-+any other work released this way by its authors. You can apply it to
- your programs, too.
-
- When we speak of free software, we are referring to freedom, not
- price. Our General Public Licenses are designed to make sure that you
- have the freedom to distribute copies of free software (and charge for
--this service if you wish), that you receive source code or can get it
--if you want it, that you can change the software or use pieces of it
--in new free programs; and that you know you can do these things.
-+them if you wish), that you receive source code or can get it if you
-+want it, that you can change the software or use pieces of it in new
-+free programs, and that you know you can do these things.
-
-- To protect your rights, we need to make restrictions that forbid
--anyone to deny you these rights or to ask you to surrender the rights.
--These restrictions translate to certain responsibilities for you if you
--distribute copies of the software, or if you modify it.
-+ To protect your rights, we need to prevent others from denying you
-+these rights or asking you to surrender the rights. Therefore, you have
-+certain responsibilities if you distribute copies of the software, or if
-+you modify it: responsibilities to respect the freedom of others.
-
- For example, if you distribute copies of such a program, whether
--gratis or for a fee, you must give the recipients all the rights that
--you have. You must make sure that they, too, receive or can get the
--source code. And you must show them these terms so they know their
--rights.
--
-- We protect your rights with two steps: (1) copyright the software, and
--(2) offer you this license which gives you legal permission to copy,
--distribute and/or modify the software.
--
-- Also, for each author's protection and ours, we want to make certain
--that everyone understands that there is no warranty for this free
--software. If the software is modified by someone else and passed on, we
--want its recipients to know that what they have is not the original, so
--that any problems introduced by others will not reflect on the original
--authors' reputations.
--
-- Finally, any free program is threatened constantly by software
--patents. We wish to avoid the danger that redistributors of a free
--program will individually obtain patent licenses, in effect making the
--program proprietary. To prevent this, we have made it clear that any
--patent must be licensed for everyone's free use or not licensed at all.
-+gratis or for a fee, you must pass on to the recipients the same
-+freedoms that you received. You must make sure that they, too, receive
-+or can get the source code. And you must show them these terms so they
-+know their rights.
-+
-+ Developers that use the GNU GPL protect your rights with two steps:
-+(1) assert copyright on the software, and (2) offer you this License
-+giving you legal permission to copy, distribute and/or modify it.
-+
-+ For the developers' and authors' protection, the GPL clearly explains
-+that there is no warranty for this free software. For both users' and
-+authors' sake, the GPL requires that modified versions be marked as
-+changed, so that their problems will not be attributed erroneously to
-+authors of previous versions.
-+
-+ Some devices are designed to deny users access to install or run
-+modified versions of the software inside them, although the manufacturer
-+can do so. This is fundamentally incompatible with the aim of
-+protecting users' freedom to change the software. The systematic
-+pattern of such abuse occurs in the area of products for individuals to
-+use, which is precisely where it is most unacceptable. Therefore, we
-+have designed this version of the GPL to prohibit the practice for those
-+products. If such problems arise substantially in other domains, we
-+stand ready to extend this provision to those domains in future versions
-+of the GPL, as needed to protect the freedom of users.
-+
-+ Finally, every program is threatened constantly by software patents.
-+States should not allow patents to restrict development and use of
-+software on general-purpose computers, but in those that do, we wish to
-+avoid the special danger that patents applied to a free program could
-+make it effectively proprietary. To prevent this, the GPL assures that
-+patents cannot be used to render the program non-free.
-
- The precise terms and conditions for copying, distribution and
- modification follow.
--
-- GNU GENERAL PUBLIC LICENSE
-- TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
--
-- 0. This License applies to any program or other work which contains
--a notice placed by the copyright holder saying it may be distributed
--under the terms of this General Public License. The "Program", below,
--refers to any such program or work, and a "work based on the Program"
--means either the Program or any derivative work under copyright law:
--that is to say, a work containing the Program or a portion of it,
--either verbatim or with modifications and/or translated into another
--language. (Hereinafter, translation is included without limitation in
--the term "modification".) Each licensee is addressed as "you".
--
--Activities other than copying, distribution and modification are not
--covered by this License; they are outside its scope. The act of
--running the Program is not restricted, and the output from the Program
--is covered only if its contents constitute a work based on the
--Program (independent of having been made by running the Program).
--Whether that is true depends on what the Program does.
--
-- 1. You may copy and distribute verbatim copies of the Program's
--source code as you receive it, in any medium, provided that you
--conspicuously and appropriately publish on each copy an appropriate
--copyright notice and disclaimer of warranty; keep intact all the
--notices that refer to this License and to the absence of any warranty;
--and give any other recipients of the Program a copy of this License
--along with the Program.
--
--You may charge a fee for the physical act of transferring a copy, and
--you may at your option offer warranty protection in exchange for a fee.
--
-- 2. You may modify your copy or copies of the Program or any portion
--of it, thus forming a work based on the Program, and copy and
--distribute such modifications or work under the terms of Section 1
--above, provided that you also meet all of these conditions:
--
-- a) You must cause the modified files to carry prominent notices
-- stating that you changed the files and the date of any change.
--
-- b) You must cause any work that you distribute or publish, that in
-- whole or in part contains or is derived from the Program or any
-- part thereof, to be licensed as a whole at no charge to all third
-- parties under the terms of this License.
--
-- c) If the modified program normally reads commands interactively
-- when run, you must cause it, when started running for such
-- interactive use in the most ordinary way, to print or display an
-- announcement including an appropriate copyright notice and a
-- notice that there is no warranty (or else, saying that you provide
-- a warranty) and that users may redistribute the program under
-- these conditions, and telling the user how to view a copy of this
-- License. (Exception: if the Program itself is interactive but
-- does not normally print such an announcement, your work based on
-- the Program is not required to print an announcement.)
--
--These requirements apply to the modified work as a whole. If
--identifiable sections of that work are not derived from the Program,
--and can be reasonably considered independent and separate works in
--themselves, then this License, and its terms, do not apply to those
--sections when you distribute them as separate works. But when you
--distribute the same sections as part of a whole which is a work based
--on the Program, the distribution of the whole must be on the terms of
--this License, whose permissions for other licensees extend to the
--entire whole, and thus to each and every part regardless of who wrote it.
--
--Thus, it is not the intent of this section to claim rights or contest
--your rights to work written entirely by you; rather, the intent is to
--exercise the right to control the distribution of derivative or
--collective works based on the Program.
--
--In addition, mere aggregation of another work not based on the Program
--with the Program (or with a work based on the Program) on a volume of
--a storage or distribution medium does not bring the other work under
--the scope of this License.
--
-- 3. You may copy and distribute the Program (or a work based on it,
--under Section 2) in object code or executable form under the terms of
--Sections 1 and 2 above provided that you also do one of the following:
--
-- a) Accompany it with the complete corresponding machine-readable
-- source code, which must be distributed under the terms of Sections
-- 1 and 2 above on a medium customarily used for software interchange; or,
--
-- b) Accompany it with a written offer, valid for at least three
-- years, to give any third party, for a charge no more than your
-- cost of physically performing source distribution, a complete
-- machine-readable copy of the corresponding source code, to be
-- distributed under the terms of Sections 1 and 2 above on a medium
-- customarily used for software interchange; or,
--
-- c) Accompany it with the information you received as to the offer
-- to distribute corresponding source code. (This alternative is
-- allowed only for noncommercial distribution and only if you
-- received the program in object code or executable form with such
-- an offer, in accord with Subsection b above.)
--
--The source code for a work means the preferred form of the work for
--making modifications to it. For an executable work, complete source
--code means all the source code for all modules it contains, plus any
--associated interface definition files, plus the scripts used to
--control compilation and installation of the executable. However, as a
--special exception, the source code distributed need not include
--anything that is normally distributed (in either source or binary
--form) with the major components (compiler, kernel, and so on) of the
--operating system on which the executable runs, unless that component
--itself accompanies the executable.
--
--If distribution of executable or object code is made by offering
--access to copy from a designated place, then offering equivalent
--access to copy the source code from the same place counts as
--distribution of the source code, even though third parties are not
--compelled to copy the source along with the object code.
--
-- 4. You may not copy, modify, sublicense, or distribute the Program
--except as expressly provided under this License. Any attempt
--otherwise to copy, modify, sublicense or distribute the Program is
--void, and will automatically terminate your rights under this License.
--However, parties who have received copies, or rights, from you under
--this License will not have their licenses terminated so long as such
--parties remain in full compliance.
--
-- 5. You are not required to accept this License, since you have not
--signed it. However, nothing else grants you permission to modify or
--distribute the Program or its derivative works. These actions are
--prohibited by law if you do not accept this License. Therefore, by
--modifying or distributing the Program (or any work based on the
--Program), you indicate your acceptance of this License to do so, and
--all its terms and conditions for copying, distributing or modifying
--the Program or works based on it.
--
-- 6. Each time you redistribute the Program (or any work based on the
--Program), the recipient automatically receives a license from the
--original licensor to copy, distribute or modify the Program subject to
--these terms and conditions. You may not impose any further
--restrictions on the recipients' exercise of the rights granted herein.
--You are not responsible for enforcing compliance by third parties to
-+
-+ TERMS AND CONDITIONS
-+
-+ 0. Definitions.
-+
-+ "This License" refers to version 3 of the GNU General Public License.
-+
-+ "Copyright" also means copyright-like laws that apply to other kinds of
-+works, such as semiconductor masks.
-+
-+ "The Program" refers to any copyrightable work licensed under this
-+License. Each licensee is addressed as "you". "Licensees" and
-+"recipients" may be individuals or organizations.
-+
-+ To "modify" a work means to copy from or adapt all or part of the work
-+in a fashion requiring copyright permission, other than the making of an
-+exact copy. The resulting work is called a "modified version" of the
-+earlier work or a work "based on" the earlier work.
-+
-+ A "covered work" means either the unmodified Program or a work based
-+on the Program.
-+
-+ To "propagate" a work means to do anything with it that, without
-+permission, would make you directly or secondarily liable for
-+infringement under applicable copyright law, except executing it on a
-+computer or modifying a private copy. Propagation includes copying,
-+distribution (with or without modification), making available to the
-+public, and in some countries other activities as well.
-+
-+ To "convey" a work means any kind of propagation that enables other
-+parties to make or receive copies. Mere interaction with a user through
-+a computer network, with no transfer of a copy, is not conveying.
-+
-+ An interactive user interface displays "Appropriate Legal Notices"
-+to the extent that it includes a convenient and prominently visible
-+feature that (1) displays an appropriate copyright notice, and (2)
-+tells the user that there is no warranty for the work (except to the
-+extent that warranties are provided), that licensees may convey the
-+work under this License, and how to view a copy of this License. If
-+the interface presents a list of user commands or options, such as a
-+menu, a prominent item in the list meets this criterion.
-+
-+ 1. Source Code.
-+
-+ The "source code" for a work means the preferred form of the work
-+for making modifications to it. "Object code" means any non-source
-+form of a work.
-+
-+ A "Standard Interface" means an interface that either is an official
-+standard defined by a recognized standards body, or, in the case of
-+interfaces specified for a particular programming language, one that
-+is widely used among developers working in that language.
-+
-+ The "System Libraries" of an executable work include anything, other
-+than the work as a whole, that (a) is included in the normal form of
-+packaging a Major Component, but which is not part of that Major
-+Component, and (b) serves only to enable use of the work with that
-+Major Component, or to implement a Standard Interface for which an
-+implementation is available to the public in source code form. A
-+"Major Component", in this context, means a major essential component
-+(kernel, window system, and so on) of the specific operating system
-+(if any) on which the executable work runs, or a compiler used to
-+produce the work, or an object code interpreter used to run it.
-+
-+ The "Corresponding Source" for a work in object code form means all
-+the source code needed to generate, install, and (for an executable
-+work) run the object code and to modify the work, including scripts to
-+control those activities. However, it does not include the work's
-+System Libraries, or general-purpose tools or generally available free
-+programs which are used unmodified in performing those activities but
-+which are not part of the work. For example, Corresponding Source
-+includes interface definition files associated with source files for
-+the work, and the source code for shared libraries and dynamically
-+linked subprograms that the work is specifically designed to require,
-+such as by intimate data communication or control flow between those
-+subprograms and other parts of the work.
-+
-+ The Corresponding Source need not include anything that users
-+can regenerate automatically from other parts of the Corresponding
-+Source.
-+
-+ The Corresponding Source for a work in source code form is that
-+same work.
-+
-+ 2. Basic Permissions.
-+
-+ All rights granted under this License are granted for the term of
-+copyright on the Program, and are irrevocable provided the stated
-+conditions are met. This License explicitly affirms your unlimited
-+permission to run the unmodified Program. The output from running a
-+covered work is covered by this License only if the output, given its
-+content, constitutes a covered work. This License acknowledges your
-+rights of fair use or other equivalent, as provided by copyright law.
-+
-+ You may make, run and propagate covered works that you do not
-+convey, without conditions so long as your license otherwise remains
-+in force. You may convey covered works to others for the sole purpose
-+of having them make modifications exclusively for you, or provide you
-+with facilities for running those works, provided that you comply with
-+the terms of this License in conveying all material for which you do
-+not control copyright. Those thus making or running the covered works
-+for you must do so exclusively on your behalf, under your direction
-+and control, on terms that prohibit them from making any copies of
-+your copyrighted material outside their relationship with you.
-+
-+ Conveying under any other circumstances is permitted solely under
-+the conditions stated below. Sublicensing is not allowed; section 10
-+makes it unnecessary.
-+
-+ 3. Protecting Users' Legal Rights From Anti-Circumvention Law.
-+
-+ No covered work shall be deemed part of an effective technological
-+measure under any applicable law fulfilling obligations under article
-+11 of the WIPO copyright treaty adopted on 20 December 1996, or
-+similar laws prohibiting or restricting circumvention of such
-+measures.
-+
-+ When you convey a covered work, you waive any legal power to forbid
-+circumvention of technological measures to the extent such circumvention
-+is effected by exercising rights under this License with respect to
-+the covered work, and you disclaim any intention to limit operation or
-+modification of the work as a means of enforcing, against the work's
-+users, your or third parties' legal rights to forbid circumvention of
-+technological measures.
-+
-+ 4. Conveying Verbatim Copies.
-+
-+ You may convey verbatim copies of the Program's source code as you
-+receive it, in any medium, provided that you conspicuously and
-+appropriately publish on each copy an appropriate copyright notice;
-+keep intact all notices stating that this License and any
-+non-permissive terms added in accord with section 7 apply to the code;
-+keep intact all notices of the absence of any warranty; and give all
-+recipients a copy of this License along with the Program.
-+
-+ You may charge any price or no price for each copy that you convey,
-+and you may offer support or warranty protection for a fee.
-+
-+ 5. Conveying Modified Source Versions.
-+
-+ You may convey a work based on the Program, or the modifications to
-+produce it from the Program, in the form of source code under the
-+terms of section 4, provided that you also meet all of these conditions:
-+
-+ a) The work must carry prominent notices stating that you modified
-+ it, and giving a relevant date.
-+
-+ b) The work must carry prominent notices stating that it is
-+ released under this License and any conditions added under section
-+ 7. This requirement modifies the requirement in section 4 to
-+ "keep intact all notices".
-+
-+ c) You must license the entire work, as a whole, under this
-+ License to anyone who comes into possession of a copy. This
-+ License will therefore apply, along with any applicable section 7
-+ additional terms, to the whole of the work, and all its parts,
-+ regardless of how they are packaged. This License gives no
-+ permission to license the work in any other way, but it does not
-+ invalidate such permission if you have separately received it.
-+
-+ d) If the work has interactive user interfaces, each must display
-+ Appropriate Legal Notices; however, if the Program has interactive
-+ interfaces that do not display Appropriate Legal Notices, your
-+ work need not make them do so.
-+
-+ A compilation of a covered work with other separate and independent
-+works, which are not by their nature extensions of the covered work,
-+and which are not combined with it such as to form a larger program,
-+in or on a volume of a storage or distribution medium, is called an
-+"aggregate" if the compilation and its resulting copyright are not
-+used to limit the access or legal rights of the compilation's users
-+beyond what the individual works permit. Inclusion of a covered work
-+in an aggregate does not cause this License to apply to the other
-+parts of the aggregate.
-+
-+ 6. Conveying Non-Source Forms.
-+
-+ You may convey a covered work in object code form under the terms
-+of sections 4 and 5, provided that you also convey the
-+machine-readable Corresponding Source under the terms of this License,
-+in one of these ways:
-+
-+ a) Convey the object code in, or embodied in, a physical product
-+ (including a physical distribution medium), accompanied by the
-+ Corresponding Source fixed on a durable physical medium
-+ customarily used for software interchange.
-+
-+ b) Convey the object code in, or embodied in, a physical product
-+ (including a physical distribution medium), accompanied by a
-+ written offer, valid for at least three years and valid for as
-+ long as you offer spare parts or customer support for that product
-+ model, to give anyone who possesses the object code either (1) a
-+ copy of the Corresponding Source for all the software in the
-+ product that is covered by this License, on a durable physical
-+ medium customarily used for software interchange, for a price no
-+ more than your reasonable cost of physically performing this
-+ conveying of source, or (2) access to copy the
-+ Corresponding Source from a network server at no charge.
-+
-+ c) Convey individual copies of the object code with a copy of the
-+ written offer to provide the Corresponding Source. This
-+ alternative is allowed only occasionally and noncommercially, and
-+ only if you received the object code with such an offer, in accord
-+ with subsection 6b.
-+
-+ d) Convey the object code by offering access from a designated
-+ place (gratis or for a charge), and offer equivalent access to the
-+ Corresponding Source in the same way through the same place at no
-+ further charge. You need not require recipients to copy the
-+ Corresponding Source along with the object code. If the place to
-+ copy the object code is a network server, the Corresponding Source
-+ may be on a different server (operated by you or a third party)
-+ that supports equivalent copying facilities, provided you maintain
-+ clear directions next to the object code saying where to find the
-+ Corresponding Source. Regardless of what server hosts the
-+ Corresponding Source, you remain obligated to ensure that it is
-+ available for as long as needed to satisfy these requirements.
-+
-+ e) Convey the object code using peer-to-peer transmission, provided
-+ you inform other peers where the object code and Corresponding
-+ Source of the work are being offered to the general public at no
-+ charge under subsection 6d.
-+
-+ A separable portion of the object code, whose source code is excluded
-+from the Corresponding Source as a System Library, need not be
-+included in conveying the object code work.
-+
-+ A "User Product" is either (1) a "consumer product", which means any
-+tangible personal property which is normally used for personal, family,
-+or household purposes, or (2) anything designed or sold for incorporation
-+into a dwelling. In determining whether a product is a consumer product,
-+doubtful cases shall be resolved in favor of coverage. For a particular
-+product received by a particular user, "normally used" refers to a
-+typical or common use of that class of product, regardless of the status
-+of the particular user or of the way in which the particular user
-+actually uses, or expects or is expected to use, the product. A product
-+is a consumer product regardless of whether the product has substantial
-+commercial, industrial or non-consumer uses, unless such uses represent
-+the only significant mode of use of the product.
-+
-+ "Installation Information" for a User Product means any methods,
-+procedures, authorization keys, or other information required to install
-+and execute modified versions of a covered work in that User Product from
-+a modified version of its Corresponding Source. The information must
-+suffice to ensure that the continued functioning of the modified object
-+code is in no case prevented or interfered with solely because
-+modification has been made.
-+
-+ If you convey an object code work under this section in, or with, or
-+specifically for use in, a User Product, and the conveying occurs as
-+part of a transaction in which the right of possession and use of the
-+User Product is transferred to the recipient in perpetuity or for a
-+fixed term (regardless of how the transaction is characterized), the
-+Corresponding Source conveyed under this section must be accompanied
-+by the Installation Information. But this requirement does not apply
-+if neither you nor any third party retains the ability to install
-+modified object code on the User Product (for example, the work has
-+been installed in ROM).
-+
-+ The requirement to provide Installation Information does not include a
-+requirement to continue to provide support service, warranty, or updates
-+for a work that has been modified or installed by the recipient, or for
-+the User Product in which it has been modified or installed. Access to a
-+network may be denied when the modification itself materially and
-+adversely affects the operation of the network or violates the rules and
-+protocols for communication across the network.
-+
-+ Corresponding Source conveyed, and Installation Information provided,
-+in accord with this section must be in a format that is publicly
-+documented (and with an implementation available to the public in
-+source code form), and must require no special password or key for
-+unpacking, reading or copying.
-+
-+ 7. Additional Terms.
-+
-+ "Additional permissions" are terms that supplement the terms of this
-+License by making exceptions from one or more of its conditions.
-+Additional permissions that are applicable to the entire Program shall
-+be treated as though they were included in this License, to the extent
-+that they are valid under applicable law. If additional permissions
-+apply only to part of the Program, that part may be used separately
-+under those permissions, but the entire Program remains governed by
-+this License without regard to the additional permissions.
-+
-+ When you convey a copy of a covered work, you may at your option
-+remove any additional permissions from that copy, or from any part of
-+it. (Additional permissions may be written to require their own
-+removal in certain cases when you modify the work.) You may place
-+additional permissions on material, added by you to a covered work,
-+for which you have or can give appropriate copyright permission.
-+
-+ Notwithstanding any other provision of this License, for material you
-+add to a covered work, you may (if authorized by the copyright holders of
-+that material) supplement the terms of this License with terms:
-+
-+ a) Disclaiming warranty or limiting liability differently from the
-+ terms of sections 15 and 16 of this License; or
-+
-+ b) Requiring preservation of specified reasonable legal notices or
-+ author attributions in that material or in the Appropriate Legal
-+ Notices displayed by works containing it; or
-+
-+ c) Prohibiting misrepresentation of the origin of that material, or
-+ requiring that modified versions of such material be marked in
-+ reasonable ways as different from the original version; or
-+
-+ d) Limiting the use for publicity purposes of names of licensors or
-+ authors of the material; or
-+
-+ e) Declining to grant rights under trademark law for use of some
-+ trade names, trademarks, or service marks; or
-+
-+ f) Requiring indemnification of licensors and authors of that
-+ material by anyone who conveys the material (or modified versions of
-+ it) with contractual assumptions of liability to the recipient, for
-+ any liability that these contractual assumptions directly impose on
-+ those licensors and authors.
-+
-+ All other non-permissive additional terms are considered "further
-+restrictions" within the meaning of section 10. If the Program as you
-+received it, or any part of it, contains a notice stating that it is
-+governed by this License along with a term that is a further
-+restriction, you may remove that term. If a license document contains
-+a further restriction but permits relicensing or conveying under this
-+License, you may add to a covered work material governed by the terms
-+of that license document, provided that the further restriction does
-+not survive such relicensing or conveying.
-+
-+ If you add terms to a covered work in accord with this section, you
-+must place, in the relevant source files, a statement of the
-+additional terms that apply to those files, or a notice indicating
-+where to find the applicable terms.
-+
-+ Additional terms, permissive or non-permissive, may be stated in the
-+form of a separately written license, or stated as exceptions;
-+the above requirements apply either way.
-+
-+ 8. Termination.
-+
-+ You may not propagate or modify a covered work except as expressly
-+provided under this License. Any attempt otherwise to propagate or
-+modify it is void, and will automatically terminate your rights under
-+this License (including any patent licenses granted under the third
-+paragraph of section 11).
-+
-+ However, if you cease all violation of this License, then your
-+license from a particular copyright holder is reinstated (a)
-+provisionally, unless and until the copyright holder explicitly and
-+finally terminates your license, and (b) permanently, if the copyright
-+holder fails to notify you of the violation by some reasonable means
-+prior to 60 days after the cessation.
-+
-+ Moreover, your license from a particular copyright holder is
-+reinstated permanently if the copyright holder notifies you of the
-+violation by some reasonable means, this is the first time you have
-+received notice of violation of this License (for any work) from that
-+copyright holder, and you cure the violation prior to 30 days after
-+your receipt of the notice.
-+
-+ Termination of your rights under this section does not terminate the
-+licenses of parties who have received copies or rights from you under
-+this License. If your rights have been terminated and not permanently
-+reinstated, you do not qualify to receive new licenses for the same
-+material under section 10.
-+
-+ 9. Acceptance Not Required for Having Copies.
-+
-+ You are not required to accept this License in order to receive or
-+run a copy of the Program. Ancillary propagation of a covered work
-+occurring solely as a consequence of using peer-to-peer transmission
-+to receive a copy likewise does not require acceptance. However,
-+nothing other than this License grants you permission to propagate or
-+modify any covered work. These actions infringe copyright if you do
-+not accept this License. Therefore, by modifying or propagating a
-+covered work, you indicate your acceptance of this License to do so.
-+
-+ 10. Automatic Licensing of Downstream Recipients.
-+
-+ Each time you convey a covered work, the recipient automatically
-+receives a license from the original licensors, to run, modify and
-+propagate that work, subject to this License. You are not responsible
-+for enforcing compliance by third parties with this License.
-+
-+ An "entity transaction" is a transaction transferring control of an
-+organization, or substantially all assets of one, or subdividing an
-+organization, or merging organizations. If propagation of a covered
-+work results from an entity transaction, each party to that
-+transaction who receives a copy of the work also receives whatever
-+licenses to the work the party's predecessor in interest had or could
-+give under the previous paragraph, plus a right to possession of the
-+Corresponding Source of the work from the predecessor in interest, if
-+the predecessor has it or can get it with reasonable efforts.
-+
-+ You may not impose any further restrictions on the exercise of the
-+rights granted or affirmed under this License. For example, you may
-+not impose a license fee, royalty, or other charge for exercise of
-+rights granted under this License, and you may not initiate litigation
-+(including a cross-claim or counterclaim in a lawsuit) alleging that
-+any patent claim is infringed by making, using, selling, offering for
-+sale, or importing the Program or any portion of it.
-+
-+ 11. Patents.
-+
-+ A "contributor" is a copyright holder who authorizes use under this
-+License of the Program or a work on which the Program is based. The
-+work thus licensed is called the contributor's "contributor version".
-+
-+ A contributor's "essential patent claims" are all patent claims
-+owned or controlled by the contributor, whether already acquired or
-+hereafter acquired, that would be infringed by some manner, permitted
-+by this License, of making, using, or selling its contributor version,
-+but do not include claims that would be infringed only as a
-+consequence of further modification of the contributor version. For
-+purposes of this definition, "control" includes the right to grant
-+patent sublicenses in a manner consistent with the requirements of
- this License.
-
-- 7. If, as a consequence of a court judgment or allegation of patent
--infringement or for any other reason (not limited to patent issues),
--conditions are imposed on you (whether by court order, agreement or
-+ Each contributor grants you a non-exclusive, worldwide, royalty-free
-+patent license under the contributor's essential patent claims, to
-+make, use, sell, offer for sale, import and otherwise run, modify and
-+propagate the contents of its contributor version.
-+
-+ In the following three paragraphs, a "patent license" is any express
-+agreement or commitment, however denominated, not to enforce a patent
-+(such as an express permission to practice a patent or covenant not to
-+sue for patent infringement). To "grant" such a patent license to a
-+party means to make such an agreement or commitment not to enforce a
-+patent against the party.
-+
-+ If you convey a covered work, knowingly relying on a patent license,
-+and the Corresponding Source of the work is not available for anyone
-+to copy, free of charge and under the terms of this License, through a
-+publicly available network server or other readily accessible means,
-+then you must either (1) cause the Corresponding Source to be so
-+available, or (2) arrange to deprive yourself of the benefit of the
-+patent license for this particular work, or (3) arrange, in a manner
-+consistent with the requirements of this License, to extend the patent
-+license to downstream recipients. "Knowingly relying" means you have
-+actual knowledge that, but for the patent license, your conveying the
-+covered work in a country, or your recipient's use of the covered work
-+in a country, would infringe one or more identifiable patents in that
-+country that you have reason to believe are valid.
-+
-+ If, pursuant to or in connection with a single transaction or
-+arrangement, you convey, or propagate by procuring conveyance of, a
-+covered work, and grant a patent license to some of the parties
-+receiving the covered work authorizing them to use, propagate, modify
-+or convey a specific copy of the covered work, then the patent license
-+you grant is automatically extended to all recipients of the covered
-+work and works based on it.
-+
-+ A patent license is "discriminatory" if it does not include within
-+the scope of its coverage, prohibits the exercise of, or is
-+conditioned on the non-exercise of one or more of the rights that are
-+specifically granted under this License. You may not convey a covered
-+work if you are a party to an arrangement with a third party that is
-+in the business of distributing software, under which you make payment
-+to the third party based on the extent of your activity of conveying
-+the work, and under which the third party grants, to any of the
-+parties who would receive the covered work from you, a discriminatory
-+patent license (a) in connection with copies of the covered work
-+conveyed by you (or copies made from those copies), or (b) primarily
-+for and in connection with specific products or compilations that
-+contain the covered work, unless you entered into that arrangement,
-+or that patent license was granted, prior to 28 March 2007.
-+
-+ Nothing in this License shall be construed as excluding or limiting
-+any implied license or other defenses to infringement that may
-+otherwise be available to you under applicable patent law.
-+
-+ 12. No Surrender of Others' Freedom.
-+
-+ If conditions are imposed on you (whether by court order, agreement or
- otherwise) that contradict the conditions of this License, they do not
--excuse you from the conditions of this License. If you cannot
--distribute so as to satisfy simultaneously your obligations under this
--License and any other pertinent obligations, then as a consequence you
--may not distribute the Program at all. For example, if a patent
--license would not permit royalty-free redistribution of the Program by
--all those who receive copies directly or indirectly through you, then
--the only way you could satisfy both it and this License would be to
--refrain entirely from distribution of the Program.
--
--If any portion of this section is held invalid or unenforceable under
--any particular circumstance, the balance of the section is intended to
--apply and the section as a whole is intended to apply in other
--circumstances.
--
--It is not the purpose of this section to induce you to infringe any
--patents or other property right claims or to contest validity of any
--such claims; this section has the sole purpose of protecting the
--integrity of the free software distribution system, which is
--implemented by public license practices. Many people have made
--generous contributions to the wide range of software distributed
--through that system in reliance on consistent application of that
--system; it is up to the author/donor to decide if he or she is willing
--to distribute software through any other system and a licensee cannot
--impose that choice.
--
--This section is intended to make thoroughly clear what is believed to
--be a consequence of the rest of this License.
--
-- 8. If the distribution and/or use of the Program is restricted in
--certain countries either by patents or by copyrighted interfaces, the
--original copyright holder who places the Program under this License
--may add an explicit geographical distribution limitation excluding
--those countries, so that distribution is permitted only in or among
--countries not thus excluded. In such case, this License incorporates
--the limitation as if written in the body of this License.
--
-- 9. The Free Software Foundation may publish revised and/or new versions
--of the General Public License from time to time. Such new versions will
-+excuse you from the conditions of this License. If you cannot convey a
-+covered work so as to satisfy simultaneously your obligations under this
-+License and any other pertinent obligations, then as a consequence you may
-+not convey it at all. For example, if you agree to terms that obligate you
-+to collect a royalty for further conveying from those to whom you convey
-+the Program, the only way you could satisfy both those terms and this
-+License would be to refrain entirely from conveying the Program.
-+
-+ 13. Use with the GNU Affero General Public License.
-+
-+ Notwithstanding any other provision of this License, you have
-+permission to link or combine any covered work with a work licensed
-+under version 3 of the GNU Affero General Public License into a single
-+combined work, and to convey the resulting work. The terms of this
-+License will continue to apply to the part which is the covered work,
-+but the special requirements of the GNU Affero General Public License,
-+section 13, concerning interaction through a network will apply to the
-+combination as such.
-+
-+ 14. Revised Versions of this License.
-+
-+ The Free Software Foundation may publish revised and/or new versions of
-+the GNU General Public License from time to time. Such new versions will
- be similar in spirit to the present version, but may differ in detail to
- address new problems or concerns.
-
--Each version is given a distinguishing version number. If the Program
--specifies a version number of this License which applies to it and "any
--later version", you have the option of following the terms and conditions
--either of that version or of any later version published by the Free
--Software Foundation. If the Program does not specify a version number of
--this License, you may choose any version ever published by the Free Software
--Foundation.
--
-- 10. If you wish to incorporate parts of the Program into other free
--programs whose distribution conditions are different, write to the author
--to ask for permission. For software which is copyrighted by the Free
--Software Foundation, write to the Free Software Foundation; we sometimes
--make exceptions for this. Our decision will be guided by the two goals
--of preserving the free status of all derivatives of our free software and
--of promoting the sharing and reuse of software generally.
--
-- NO WARRANTY
--
-- 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
--FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
--OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
--PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
--OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
--MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
--TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
--PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
--REPAIR OR CORRECTION.
--
-- 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
--WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
--REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
--INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
--OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
--TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
--YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
--PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
--POSSIBILITY OF SUCH DAMAGES.
--
-- END OF TERMS AND CONDITIONS
--
-- How to Apply These Terms to Your New Programs
-+ Each version is given a distinguishing version number. If the
-+Program specifies that a certain numbered version of the GNU General
-+Public License "or any later version" applies to it, you have the
-+option of following the terms and conditions either of that numbered
-+version or of any later version published by the Free Software
-+Foundation. If the Program does not specify a version number of the
-+GNU General Public License, you may choose any version ever published
-+by the Free Software Foundation.
-+
-+ If the Program specifies that a proxy can decide which future
-+versions of the GNU General Public License can be used, that proxy's
-+public statement of acceptance of a version permanently authorizes you
-+to choose that version for the Program.
-+
-+ Later license versions may give you additional or different
-+permissions. However, no additional obligations are imposed on any
-+author or copyright holder as a result of your choosing to follow a
-+later version.
-+
-+ 15. Disclaimer of Warranty.
-+
-+ THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
-+APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
-+HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
-+OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
-+THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
-+PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
-+IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
-+ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
-+
-+ 16. Limitation of Liability.
-+
-+ IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
-+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
-+THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
-+GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
-+USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
-+DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
-+PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
-+EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
-+SUCH DAMAGES.
-+
-+ 17. Interpretation of Sections 15 and 16.
-+
-+ If the disclaimer of warranty and limitation of liability provided
-+above cannot be given local legal effect according to their terms,
-+reviewing courts shall apply local law that most closely approximates
-+an absolute waiver of all civil liability in connection with the
-+Program, unless a warranty or assumption of liability accompanies a
-+copy of the Program in return for a fee.
-+
-+ END OF TERMS AND CONDITIONS
-+
-+ How to Apply These Terms to Your New Programs
-
- If you develop a new program, and you want it to be of the greatest
- possible use to the public, the best way to achieve this is to make it
-@@ -287,15 +628,15 @@ free software which everyone can redistribute and change under these terms.
-
- To do so, attach the following notices to the program. It is safest
- to attach them to the start of each source file to most effectively
--convey the exclusion of warranty; and each file should have at least
-+state the exclusion of warranty; and each file should have at least
- the "copyright" line and a pointer to where the full notice is found.
-
- <one line to give the program's name and a brief idea of what it does.>
- Copyright (C) <year> <name of author>
-
-- This program is free software; you can redistribute it and/or modify
-+ 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
-+ the Free Software Foundation, either version 3 of the License, or
- (at your option) any later version.
-
- This program is distributed in the hope that it will be useful,
-@@ -304,37 +645,30 @@ the "copyright" line and a pointer to where the full notice is found.
- 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
--
-+ along with this program. If not, see <http://www.gnu.org/licenses/>.
-
- Also add information on how to contact you by electronic and paper mail.
-
--If the program is interactive, make it output a short notice like this
--when it starts in an interactive mode:
-+ If the program does terminal interaction, make it output a short
-+notice like this when it starts in an interactive mode:
-
-- Gnomovision version 69, Copyright (C) year name of author
-- Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
-+ <program> Copyright (C) <year> <name of author>
-+ This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
- This is free software, and you are welcome to redistribute it
- under certain conditions; type `show c' for details.
-
- The hypothetical commands `show w' and `show c' should show the appropriate
--parts of the General Public License. Of course, the commands you use may
--be called something other than `show w' and `show c'; they could even be
--mouse-clicks or menu items--whatever suits your program.
--
--You should also get your employer (if you work as a programmer) or your
--school, if any, to sign a "copyright disclaimer" for the program, if
--necessary. Here is a sample; alter the names:
--
-- Yoyodyne, Inc., hereby disclaims all copyright interest in the program
-- `Gnomovision' (which makes passes at compilers) written by James Hacker.
--
-- <signature of Ty Coon>, 1 April 1989
-- Ty Coon, President of Vice
--
--This General Public License does not permit incorporating your program into
--proprietary programs. If your program is a subroutine library, you may
--consider it more useful to permit linking proprietary applications with the
--library. If this is what you want to do, use the GNU Library General
--Public License instead of this License.
-+parts of the General Public License. Of course, your program's commands
-+might be different; for a GUI interface, you would use an "about box".
-+
-+ You should also get your employer (if you work as a programmer) or school,
-+if any, to sign a "copyright disclaimer" for the program, if necessary.
-+For more information on this, and how to apply and follow the GNU GPL, see
-+<http://www.gnu.org/licenses/>.
-+
-+ The GNU General Public License does not permit incorporating your program
-+into proprietary programs. If your program is a subroutine library, you
-+may consider it more useful to permit linking proprietary applications with
-+the library. If this is what you want to do, use the GNU Lesser General
-+Public License instead of this License. But first, please read
-+<http://www.gnu.org/philosophy/why-not-lgpl.html>.
-diff --git a/ChangeLog b/ChangeLog
-index b9a510f..4031746 100644
---- a/ChangeLog
-+++ b/ChangeLog
-@@ -2,6 +2,11 @@
- VERSION 0.9.1svn
- ================
-
-+2009-09-06 Vincent Richard <vincent@vincent-richard.net>
-+
-+ * Relicensed VMime under the GNU GPL license version 3. Dual licensing
-+ is now available. More info here: http://www.vmime.org/pages/Licensing
-+
- 2008-10-19 Vincent Richard <vincent@vincent-richard.net>
-
- * Started version 0.9.1.
-diff --git a/doc/book/intro.tex b/doc/book/intro.tex
-index 93a3675..26d9abe 100644
---- a/doc/book/intro.tex
-+++ b/doc/book/intro.tex
-@@ -52,14 +52,14 @@ The main objectives of this library are:
-
- VMime library is Free Software and is licensed under the terms of the GNU
- General Public License\footnote{See Appendix \ref{appendix_license} and
--\url{http://www.gnu.org/copyleft/gpl.html}} (GPL):
-+\url{http://www.gnu.org/copyleft/gpl.html}} (GPL) version 3:
-
- \begin{verbatim}
-- Copyright (C) 2002-2008 Vincent Richard
-+ Copyright (C) 2002-2009 Vincent Richard
-
- VMime library 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
-+ published by the Free Software Foundation; either version 3 of
- the License, or (at your option) any later version.
-
- VMime is distributed in the hope that it will be useful, but
-@@ -79,7 +79,7 @@ GNU Free Documentation
- License\footnote{See \url{http://www.gnu.org/copyleft/fdl.html}} (FDL):
-
- \begin{verbatim}
-- Copyright (C) 2004-2007 Vincent Richard
-+ Copyright (C) 2004-2009 Vincent Richard
-
- Permission is granted to copy, distribute and/or modify
- this document under the terms of the GNU Free Documentation
-diff --git a/examples/example1.cpp b/examples/example1.cpp
-index 5552510..a340f1d 100644
---- a/examples/example1.cpp
-+++ b/examples/example1.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/examples/example2.cpp b/examples/example2.cpp
-index 953d669..af91f12 100644
---- a/examples/example2.cpp
-+++ b/examples/example2.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/examples/example3.cpp b/examples/example3.cpp
-index 0a260a9..cb3e6ae 100644
---- a/examples/example3.cpp
-+++ b/examples/example3.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/examples/example4.cpp b/examples/example4.cpp
-index 09c2dad..6a746da 100644
---- a/examples/example4.cpp
-+++ b/examples/example4.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/examples/example5.cpp b/examples/example5.cpp
-index 11ceb83..ad84db9 100644
---- a/examples/example5.cpp
-+++ b/examples/example5.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/examples/example6.cpp b/examples/example6.cpp
-index 8bf7b44..bcb2df9 100644
---- a/examples/example6.cpp
-+++ b/examples/example6.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/examples/example7.cpp b/examples/example7.cpp
-index 79445ea..1ddb3d0 100644
---- a/examples/example7.cpp
-+++ b/examples/example7.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/examples/viewer/viewer.cpp b/examples/viewer/viewer.cpp
-index 50862b3..ee21f01 100644
---- a/examples/viewer/viewer.cpp
-+++ b/examples/viewer/viewer.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/address.cpp b/src/address.cpp
-index 17220c1..88c39a3 100644
---- a/src/address.cpp
-+++ b/src/address.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/addressList.cpp b/src/addressList.cpp
-index fd7b35c..31a2a3d 100644
---- a/src/addressList.cpp
-+++ b/src/addressList.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/attachmentHelper.cpp b/src/attachmentHelper.cpp
-index ec6e2f7..65e8c88 100644
---- a/src/attachmentHelper.cpp
-+++ b/src/attachmentHelper.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/base.cpp b/src/base.cpp
-index 71c63cd..2e47ca3 100644
---- a/src/base.cpp
-+++ b/src/base.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/body.cpp b/src/body.cpp
-index 0e34762..3f5ff0f 100644
---- a/src/body.cpp
-+++ b/src/body.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/bodyPart.cpp b/src/bodyPart.cpp
-index b35346b..20bb102 100644
---- a/src/bodyPart.cpp
-+++ b/src/bodyPart.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/bodyPartAttachment.cpp b/src/bodyPartAttachment.cpp
-index b4fb7b1..f3b6b66 100644
---- a/src/bodyPartAttachment.cpp
-+++ b/src/bodyPartAttachment.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/charset.cpp b/src/charset.cpp
-index 798d34f..e3c11da 100644
---- a/src/charset.cpp
-+++ b/src/charset.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/charsetConverter.cpp b/src/charsetConverter.cpp
-index 26609db..ec74ae5 100644
---- a/src/charsetConverter.cpp
-+++ b/src/charsetConverter.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/component.cpp b/src/component.cpp
-index 69a6049..fbf677b 100644
---- a/src/component.cpp
-+++ b/src/component.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/constants.cpp b/src/constants.cpp
-index ba6f194..b3f51a2 100644
---- a/src/constants.cpp
-+++ b/src/constants.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/contentDisposition.cpp b/src/contentDisposition.cpp
-index 7ffa424..0ab7c45 100644
---- a/src/contentDisposition.cpp
-+++ b/src/contentDisposition.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/contentDispositionField.cpp b/src/contentDispositionField.cpp
-index 0630a51..355e820 100644
---- a/src/contentDispositionField.cpp
-+++ b/src/contentDispositionField.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/contentHandler.cpp b/src/contentHandler.cpp
-index 5d50283..6022411 100644
---- a/src/contentHandler.cpp
-+++ b/src/contentHandler.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/contentTypeField.cpp b/src/contentTypeField.cpp
-index 7b5a3e2..406a06e 100644
---- a/src/contentTypeField.cpp
-+++ b/src/contentTypeField.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/dateTime.cpp b/src/dateTime.cpp
-index 66cd992..089a900 100644
---- a/src/dateTime.cpp
-+++ b/src/dateTime.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/defaultAttachment.cpp b/src/defaultAttachment.cpp
-index c2ad61e..b61d52e 100644
---- a/src/defaultAttachment.cpp
-+++ b/src/defaultAttachment.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/disposition.cpp b/src/disposition.cpp
-index 1b420fb..b8059a7 100644
---- a/src/disposition.cpp
-+++ b/src/disposition.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/emptyContentHandler.cpp b/src/emptyContentHandler.cpp
-index bbee986..5245341 100644
---- a/src/emptyContentHandler.cpp
-+++ b/src/emptyContentHandler.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/encoding.cpp b/src/encoding.cpp
-index a45573d..58ce71d 100644
---- a/src/encoding.cpp
-+++ b/src/encoding.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/exception.cpp b/src/exception.cpp
-index 54be174..60ec95b 100644
---- a/src/exception.cpp
-+++ b/src/exception.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/fileAttachment.cpp b/src/fileAttachment.cpp
-index 20b8083..e643491 100644
---- a/src/fileAttachment.cpp
-+++ b/src/fileAttachment.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/generatedMessageAttachment.cpp b/src/generatedMessageAttachment.cpp
-index 205b549..e9bd1a6 100644
---- a/src/generatedMessageAttachment.cpp
-+++ b/src/generatedMessageAttachment.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/header.cpp b/src/header.cpp
-index 78424b3..443aab8 100644
---- a/src/header.cpp
-+++ b/src/header.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/headerField.cpp b/src/headerField.cpp
-index 0057712..52fe7e8 100644
---- a/src/headerField.cpp
-+++ b/src/headerField.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/headerFieldFactory.cpp b/src/headerFieldFactory.cpp
-index 6d949f0..807a2b3 100644
---- a/src/headerFieldFactory.cpp
-+++ b/src/headerFieldFactory.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/htmlTextPart.cpp b/src/htmlTextPart.cpp
-index a287573..7713034 100644
---- a/src/htmlTextPart.cpp
-+++ b/src/htmlTextPart.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/mailbox.cpp b/src/mailbox.cpp
-index b1ed7a2..2f62521 100644
---- a/src/mailbox.cpp
-+++ b/src/mailbox.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/mailboxField.cpp b/src/mailboxField.cpp
-index 0fc5773..0d9bd83 100644
---- a/src/mailboxField.cpp
-+++ b/src/mailboxField.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/mailboxGroup.cpp b/src/mailboxGroup.cpp
-index ac7202c..94f7ba6 100644
---- a/src/mailboxGroup.cpp
-+++ b/src/mailboxGroup.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/mailboxList.cpp b/src/mailboxList.cpp
-index e9fe7f9..0023d9d 100644
---- a/src/mailboxList.cpp
-+++ b/src/mailboxList.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/mdn/MDNHelper.cpp b/src/mdn/MDNHelper.cpp
-index a4a4ee4..b419b85 100644
---- a/src/mdn/MDNHelper.cpp
-+++ b/src/mdn/MDNHelper.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/mdn/MDNInfos.cpp b/src/mdn/MDNInfos.cpp
-index 82d580d..cd8e38f 100644
---- a/src/mdn/MDNInfos.cpp
-+++ b/src/mdn/MDNInfos.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/mdn/receivedMDNInfos.cpp b/src/mdn/receivedMDNInfos.cpp
-index 366d46f..cff211c 100644
---- a/src/mdn/receivedMDNInfos.cpp
-+++ b/src/mdn/receivedMDNInfos.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/mdn/sendableMDNInfos.cpp b/src/mdn/sendableMDNInfos.cpp
-index 953e492..d274ae0 100644
---- a/src/mdn/sendableMDNInfos.cpp
-+++ b/src/mdn/sendableMDNInfos.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/mediaType.cpp b/src/mediaType.cpp
-index 569ccc3..725f933 100644
---- a/src/mediaType.cpp
-+++ b/src/mediaType.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/message.cpp b/src/message.cpp
-index 04d1287..6f4b046 100644
---- a/src/message.cpp
-+++ b/src/message.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/messageBuilder.cpp b/src/messageBuilder.cpp
-index cef4f73..d619554 100644
---- a/src/messageBuilder.cpp
-+++ b/src/messageBuilder.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/messageId.cpp b/src/messageId.cpp
-index 08a8e37..961fb63 100644
---- a/src/messageId.cpp
-+++ b/src/messageId.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/messageIdSequence.cpp b/src/messageIdSequence.cpp
-index 6011358..08103d0 100644
---- a/src/messageIdSequence.cpp
-+++ b/src/messageIdSequence.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/messageParser.cpp b/src/messageParser.cpp
-index 639ac5f..35e0bba 100644
---- a/src/messageParser.cpp
-+++ b/src/messageParser.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/misc/importanceHelper.cpp b/src/misc/importanceHelper.cpp
-index 763753c..22d0cdf 100644
---- a/src/misc/importanceHelper.cpp
-+++ b/src/misc/importanceHelper.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/builtinServices.inl b/src/net/builtinServices.inl
-index e74766e..4a6ac87 100644
---- a/src/net/builtinServices.inl
-+++ b/src/net/builtinServices.inl
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/defaultConnectionInfos.cpp b/src/net/defaultConnectionInfos.cpp
-index ee706a3..41f1e0f 100644
---- a/src/net/defaultConnectionInfos.cpp
-+++ b/src/net/defaultConnectionInfos.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/events.cpp b/src/net/events.cpp
-index a6674a7..52c13ee 100644
---- a/src/net/events.cpp
-+++ b/src/net/events.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/folder.cpp b/src/net/folder.cpp
-index 20291be..47ec317 100644
---- a/src/net/folder.cpp
-+++ b/src/net/folder.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/imap/IMAPConnection.cpp b/src/net/imap/IMAPConnection.cpp
-index 7c78b78..c3ee574 100644
---- a/src/net/imap/IMAPConnection.cpp
-+++ b/src/net/imap/IMAPConnection.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/imap/IMAPFolder.cpp b/src/net/imap/IMAPFolder.cpp
-index 2130211..c06a8d4 100644
---- a/src/net/imap/IMAPFolder.cpp
-+++ b/src/net/imap/IMAPFolder.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/imap/IMAPMessage.cpp b/src/net/imap/IMAPMessage.cpp
-index 90bebf3..29c2aea 100644
---- a/src/net/imap/IMAPMessage.cpp
-+++ b/src/net/imap/IMAPMessage.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/imap/IMAPSStore.cpp b/src/net/imap/IMAPSStore.cpp
-index 0b4b90b..9e92f92 100644
---- a/src/net/imap/IMAPSStore.cpp
-+++ b/src/net/imap/IMAPSStore.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/imap/IMAPServiceInfos.cpp b/src/net/imap/IMAPServiceInfos.cpp
-index 1604411..33898f4 100644
---- a/src/net/imap/IMAPServiceInfos.cpp
-+++ b/src/net/imap/IMAPServiceInfos.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/imap/IMAPStore.cpp b/src/net/imap/IMAPStore.cpp
-index 753adc6..f260e55 100644
---- a/src/net/imap/IMAPStore.cpp
-+++ b/src/net/imap/IMAPStore.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/imap/IMAPTag.cpp b/src/net/imap/IMAPTag.cpp
-index 7b8ce3f..abb7924 100644
---- a/src/net/imap/IMAPTag.cpp
-+++ b/src/net/imap/IMAPTag.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/imap/IMAPUtils.cpp b/src/net/imap/IMAPUtils.cpp
-index 18ca00c..c4651ed 100644
---- a/src/net/imap/IMAPUtils.cpp
-+++ b/src/net/imap/IMAPUtils.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/maildir/format/courierMaildirFormat.cpp b/src/net/maildir/format/courierMaildirFormat.cpp
-index 1118c27..6dbda80 100644
---- a/src/net/maildir/format/courierMaildirFormat.cpp
-+++ b/src/net/maildir/format/courierMaildirFormat.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/maildir/format/kmailMaildirFormat.cpp b/src/net/maildir/format/kmailMaildirFormat.cpp
-index eeedd41..5fb75fe 100644
---- a/src/net/maildir/format/kmailMaildirFormat.cpp
-+++ b/src/net/maildir/format/kmailMaildirFormat.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/maildir/maildirFolder.cpp b/src/net/maildir/maildirFolder.cpp
-index 65abdcf..3e361ae 100644
---- a/src/net/maildir/maildirFolder.cpp
-+++ b/src/net/maildir/maildirFolder.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/maildir/maildirFormat.cpp b/src/net/maildir/maildirFormat.cpp
-index 17899a2..607ed61 100644
---- a/src/net/maildir/maildirFormat.cpp
-+++ b/src/net/maildir/maildirFormat.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/maildir/maildirMessage.cpp b/src/net/maildir/maildirMessage.cpp
-index 1ae83ee..ed87cdb 100644
---- a/src/net/maildir/maildirMessage.cpp
-+++ b/src/net/maildir/maildirMessage.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/maildir/maildirServiceInfos.cpp b/src/net/maildir/maildirServiceInfos.cpp
-index 48869dc..55ba64e 100644
---- a/src/net/maildir/maildirServiceInfos.cpp
-+++ b/src/net/maildir/maildirServiceInfos.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/maildir/maildirStore.cpp b/src/net/maildir/maildirStore.cpp
-index 8e4e002..3b77024 100644
---- a/src/net/maildir/maildirStore.cpp
-+++ b/src/net/maildir/maildirStore.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/maildir/maildirUtils.cpp b/src/net/maildir/maildirUtils.cpp
-index bb2b69f..19887b2 100644
---- a/src/net/maildir/maildirUtils.cpp
-+++ b/src/net/maildir/maildirUtils.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/message.cpp b/src/net/message.cpp
-index 37f020b..9a54809 100644
---- a/src/net/message.cpp
-+++ b/src/net/message.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/pop3/POP3Folder.cpp b/src/net/pop3/POP3Folder.cpp
-index ba70f2b..d5fc687 100644
---- a/src/net/pop3/POP3Folder.cpp
-+++ b/src/net/pop3/POP3Folder.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/pop3/POP3Message.cpp b/src/net/pop3/POP3Message.cpp
-index 6cdd455..b38951b 100644
---- a/src/net/pop3/POP3Message.cpp
-+++ b/src/net/pop3/POP3Message.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/pop3/POP3SStore.cpp b/src/net/pop3/POP3SStore.cpp
-index 154f049..59aacb8 100644
---- a/src/net/pop3/POP3SStore.cpp
-+++ b/src/net/pop3/POP3SStore.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/pop3/POP3ServiceInfos.cpp b/src/net/pop3/POP3ServiceInfos.cpp
-index da67f84..77faa5f 100644
---- a/src/net/pop3/POP3ServiceInfos.cpp
-+++ b/src/net/pop3/POP3ServiceInfos.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/pop3/POP3Store.cpp b/src/net/pop3/POP3Store.cpp
-index 16a5dff..e5e8ba7 100644
---- a/src/net/pop3/POP3Store.cpp
-+++ b/src/net/pop3/POP3Store.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/pop3/POP3Utils.cpp b/src/net/pop3/POP3Utils.cpp
-index b8df9fd..de70dfe 100644
---- a/src/net/pop3/POP3Utils.cpp
-+++ b/src/net/pop3/POP3Utils.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/sendmail/sendmailServiceInfos.cpp b/src/net/sendmail/sendmailServiceInfos.cpp
-index de23e2b..fb5fb54 100644
---- a/src/net/sendmail/sendmailServiceInfos.cpp
-+++ b/src/net/sendmail/sendmailServiceInfos.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/sendmail/sendmailTransport.cpp b/src/net/sendmail/sendmailTransport.cpp
-index c1aded6..53ff0d1 100644
---- a/src/net/sendmail/sendmailTransport.cpp
-+++ b/src/net/sendmail/sendmailTransport.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/service.cpp b/src/net/service.cpp
-index 2fae23f..f12c78f 100644
---- a/src/net/service.cpp
-+++ b/src/net/service.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/serviceFactory.cpp b/src/net/serviceFactory.cpp
-index 0abeeb3..65f9aa1 100644
---- a/src/net/serviceFactory.cpp
-+++ b/src/net/serviceFactory.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/serviceInfos.cpp b/src/net/serviceInfos.cpp
-index d6aee29..069d9e1 100644
---- a/src/net/serviceInfos.cpp
-+++ b/src/net/serviceInfos.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/serviceRegistration.inl b/src/net/serviceRegistration.inl
-index 75fa435..6eaca1e 100644
---- a/src/net/serviceRegistration.inl
-+++ b/src/net/serviceRegistration.inl
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/session.cpp b/src/net/session.cpp
-index ff23bc5..3898a8d 100644
---- a/src/net/session.cpp
-+++ b/src/net/session.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/smtp/SMTPResponse.cpp b/src/net/smtp/SMTPResponse.cpp
-index 24301c5..03c199b 100644
---- a/src/net/smtp/SMTPResponse.cpp
-+++ b/src/net/smtp/SMTPResponse.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/smtp/SMTPSTransport.cpp b/src/net/smtp/SMTPSTransport.cpp
-index 2b70731..db7fc6f 100644
---- a/src/net/smtp/SMTPSTransport.cpp
-+++ b/src/net/smtp/SMTPSTransport.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/smtp/SMTPServiceInfos.cpp b/src/net/smtp/SMTPServiceInfos.cpp
-index 7c39ea5..d2d0dcc 100644
---- a/src/net/smtp/SMTPServiceInfos.cpp
-+++ b/src/net/smtp/SMTPServiceInfos.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/smtp/SMTPTransport.cpp b/src/net/smtp/SMTPTransport.cpp
-index 5ad8d70..917a56c 100644
---- a/src/net/smtp/SMTPTransport.cpp
-+++ b/src/net/smtp/SMTPTransport.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/tls/TLSSecuredConnectionInfos.cpp b/src/net/tls/TLSSecuredConnectionInfos.cpp
-index 55df5e2..2a37069 100644
---- a/src/net/tls/TLSSecuredConnectionInfos.cpp
-+++ b/src/net/tls/TLSSecuredConnectionInfos.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/tls/TLSSession.cpp b/src/net/tls/TLSSession.cpp
-index d90be8e..1146d1b 100644
---- a/src/net/tls/TLSSession.cpp
-+++ b/src/net/tls/TLSSession.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/tls/TLSSocket.cpp b/src/net/tls/TLSSocket.cpp
-index 4f64967..c2f91f6 100644
---- a/src/net/tls/TLSSocket.cpp
-+++ b/src/net/tls/TLSSocket.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/net/transport.cpp b/src/net/transport.cpp
-index 5db70d2..dd4663d 100644
---- a/src/net/transport.cpp
-+++ b/src/net/transport.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/object.cpp b/src/object.cpp
-index a15417a..1424f68 100644
---- a/src/object.cpp
-+++ b/src/object.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/options.cpp b/src/options.cpp
-index a7c838e..f75da99 100644
---- a/src/options.cpp
-+++ b/src/options.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/parameter.cpp b/src/parameter.cpp
-index 466df3d..6cd8d1f 100644
---- a/src/parameter.cpp
-+++ b/src/parameter.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/parameterizedHeaderField.cpp b/src/parameterizedHeaderField.cpp
-index a45c627..090d5b4 100644
---- a/src/parameterizedHeaderField.cpp
-+++ b/src/parameterizedHeaderField.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/parsedMessageAttachment.cpp b/src/parsedMessageAttachment.cpp
-index 3ef17ac..bde56aa 100644
---- a/src/parsedMessageAttachment.cpp
-+++ b/src/parsedMessageAttachment.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/path.cpp b/src/path.cpp
-index 5816787..37a4090 100644
---- a/src/path.cpp
-+++ b/src/path.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/plainTextPart.cpp b/src/plainTextPart.cpp
-index dee3f39..7a674e7 100644
---- a/src/plainTextPart.cpp
-+++ b/src/plainTextPart.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/platform.cpp b/src/platform.cpp
-index 9db92cc..d1d23de 100644
---- a/src/platform.cpp
-+++ b/src/platform.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/platforms/posix/posixChildProcess.cpp b/src/platforms/posix/posixChildProcess.cpp
-index d1a0d91..68ef021 100644
---- a/src/platforms/posix/posixChildProcess.cpp
-+++ b/src/platforms/posix/posixChildProcess.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/platforms/posix/posixFile.cpp b/src/platforms/posix/posixFile.cpp
-index 2a1356a..4ec2ef3 100644
---- a/src/platforms/posix/posixFile.cpp
-+++ b/src/platforms/posix/posixFile.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/platforms/posix/posixHandler.cpp b/src/platforms/posix/posixHandler.cpp
-index 94a5072..f43972e 100644
---- a/src/platforms/posix/posixHandler.cpp
-+++ b/src/platforms/posix/posixHandler.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/platforms/posix/posixSocket.cpp b/src/platforms/posix/posixSocket.cpp
-index 4c2375c..6740995 100644
---- a/src/platforms/posix/posixSocket.cpp
-+++ b/src/platforms/posix/posixSocket.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/platforms/windows/windowsFile.cpp b/src/platforms/windows/windowsFile.cpp
-index c94076c..5412a3b 100644
---- a/src/platforms/windows/windowsFile.cpp
-+++ b/src/platforms/windows/windowsFile.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://vmime.sourceforge.net)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/platforms/windows/windowsHandler.cpp b/src/platforms/windows/windowsHandler.cpp
-index 58b1ae9..404d3cb 100644
---- a/src/platforms/windows/windowsHandler.cpp
-+++ b/src/platforms/windows/windowsHandler.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://vmime.sourceforge.net)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/platforms/windows/windowsSocket.cpp b/src/platforms/windows/windowsSocket.cpp
-index 9450efc..8a42583 100644
---- a/src/platforms/windows/windowsSocket.cpp
-+++ b/src/platforms/windows/windowsSocket.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://vmime.sourceforge.net)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/propertySet.cpp b/src/propertySet.cpp
-index c980d96..1b37179 100644
---- a/src/propertySet.cpp
-+++ b/src/propertySet.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/relay.cpp b/src/relay.cpp
-index b86ea14..5cd454f 100644
---- a/src/relay.cpp
-+++ b/src/relay.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/security/cert/X509Certificate.cpp b/src/security/cert/X509Certificate.cpp
-index ac1f7e0..1cd079c 100644
---- a/src/security/cert/X509Certificate.cpp
-+++ b/src/security/cert/X509Certificate.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/security/cert/certificateChain.cpp b/src/security/cert/certificateChain.cpp
-index 0425d00..71b8ab4 100644
---- a/src/security/cert/certificateChain.cpp
-+++ b/src/security/cert/certificateChain.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/security/cert/defaultCertificateVerifier.cpp b/src/security/cert/defaultCertificateVerifier.cpp
-index dc082a8..6fde551 100644
---- a/src/security/cert/defaultCertificateVerifier.cpp
-+++ b/src/security/cert/defaultCertificateVerifier.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/security/defaultAuthenticator.cpp b/src/security/defaultAuthenticator.cpp
-index 8019106..088ef0d 100644
---- a/src/security/defaultAuthenticator.cpp
-+++ b/src/security/defaultAuthenticator.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/security/digest/md5/md5MessageDigest.cpp b/src/security/digest/md5/md5MessageDigest.cpp
-index d83908f..84ca99a 100644
---- a/src/security/digest/md5/md5MessageDigest.cpp
-+++ b/src/security/digest/md5/md5MessageDigest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/security/digest/messageDigest.cpp b/src/security/digest/messageDigest.cpp
-index 6a5de13..4217984 100644
---- a/src/security/digest/messageDigest.cpp
-+++ b/src/security/digest/messageDigest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/security/digest/messageDigestFactory.cpp b/src/security/digest/messageDigestFactory.cpp
-index 1348d65..0326931 100644
---- a/src/security/digest/messageDigestFactory.cpp
-+++ b/src/security/digest/messageDigestFactory.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/security/digest/sha1/sha1MessageDigest.cpp b/src/security/digest/sha1/sha1MessageDigest.cpp
-index 51eec6a..6d99e3f 100644
---- a/src/security/digest/sha1/sha1MessageDigest.cpp
-+++ b/src/security/digest/sha1/sha1MessageDigest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/security/sasl/SASLContext.cpp b/src/security/sasl/SASLContext.cpp
-index fca95c7..51c2bed 100644
---- a/src/security/sasl/SASLContext.cpp
-+++ b/src/security/sasl/SASLContext.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/security/sasl/SASLMechanismFactory.cpp b/src/security/sasl/SASLMechanismFactory.cpp
-index a866e0c..285d6d3 100644
---- a/src/security/sasl/SASLMechanismFactory.cpp
-+++ b/src/security/sasl/SASLMechanismFactory.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/security/sasl/SASLSession.cpp b/src/security/sasl/SASLSession.cpp
-index f7f80f5..c1688b7 100644
---- a/src/security/sasl/SASLSession.cpp
-+++ b/src/security/sasl/SASLSession.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/security/sasl/SASLSocket.cpp b/src/security/sasl/SASLSocket.cpp
-index 5f86aed..118429a 100644
---- a/src/security/sasl/SASLSocket.cpp
-+++ b/src/security/sasl/SASLSocket.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/security/sasl/builtinSASLMechanism.cpp b/src/security/sasl/builtinSASLMechanism.cpp
-index 1c95831..767caf9 100644
---- a/src/security/sasl/builtinSASLMechanism.cpp
-+++ b/src/security/sasl/builtinSASLMechanism.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/security/sasl/defaultSASLAuthenticator.cpp b/src/security/sasl/defaultSASLAuthenticator.cpp
-index 085493a..06ffc49 100644
---- a/src/security/sasl/defaultSASLAuthenticator.cpp
-+++ b/src/security/sasl/defaultSASLAuthenticator.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/streamContentHandler.cpp b/src/streamContentHandler.cpp
-index b5f02bf..9edf4aa 100644
---- a/src/streamContentHandler.cpp
-+++ b/src/streamContentHandler.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/stringContentHandler.cpp b/src/stringContentHandler.cpp
-index 84cada5..248fca4 100644
---- a/src/stringContentHandler.cpp
-+++ b/src/stringContentHandler.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/text.cpp b/src/text.cpp
-index 2c811c4..f9ded7c 100644
---- a/src/text.cpp
-+++ b/src/text.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/textPartFactory.cpp b/src/textPartFactory.cpp
-index 977ba07..c490845 100644
---- a/src/textPartFactory.cpp
-+++ b/src/textPartFactory.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/datetimeUtils.cpp b/src/utility/datetimeUtils.cpp
-index cc06f50..cf05a93 100644
---- a/src/utility/datetimeUtils.cpp
-+++ b/src/utility/datetimeUtils.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/encoder/b64Encoder.cpp b/src/utility/encoder/b64Encoder.cpp
-index c4ba2b3..58ef320 100644
---- a/src/utility/encoder/b64Encoder.cpp
-+++ b/src/utility/encoder/b64Encoder.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/encoder/binaryEncoder.cpp b/src/utility/encoder/binaryEncoder.cpp
-index 2bc77d2..81da790 100644
---- a/src/utility/encoder/binaryEncoder.cpp
-+++ b/src/utility/encoder/binaryEncoder.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/encoder/defaultEncoder.cpp b/src/utility/encoder/defaultEncoder.cpp
-index db833c8..4d0ffb5 100644
---- a/src/utility/encoder/defaultEncoder.cpp
-+++ b/src/utility/encoder/defaultEncoder.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/encoder/eightBitEncoder.cpp b/src/utility/encoder/eightBitEncoder.cpp
-index 88f07bc..25ca6c5 100644
---- a/src/utility/encoder/eightBitEncoder.cpp
-+++ b/src/utility/encoder/eightBitEncoder.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/encoder/encoder.cpp b/src/utility/encoder/encoder.cpp
-index 893ed4f..85b3708 100644
---- a/src/utility/encoder/encoder.cpp
-+++ b/src/utility/encoder/encoder.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/encoder/encoderFactory.cpp b/src/utility/encoder/encoderFactory.cpp
-index 9d7c107..428788d 100644
---- a/src/utility/encoder/encoderFactory.cpp
-+++ b/src/utility/encoder/encoderFactory.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/encoder/qpEncoder.cpp b/src/utility/encoder/qpEncoder.cpp
-index 737d488..c3a8c6d 100644
---- a/src/utility/encoder/qpEncoder.cpp
-+++ b/src/utility/encoder/qpEncoder.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/encoder/sevenBitEncoder.cpp b/src/utility/encoder/sevenBitEncoder.cpp
-index 812afa9..40f0fbf 100644
---- a/src/utility/encoder/sevenBitEncoder.cpp
-+++ b/src/utility/encoder/sevenBitEncoder.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/encoder/uuEncoder.cpp b/src/utility/encoder/uuEncoder.cpp
-index 0e72599..d2974e6 100644
---- a/src/utility/encoder/uuEncoder.cpp
-+++ b/src/utility/encoder/uuEncoder.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/filteredStream.cpp b/src/utility/filteredStream.cpp
-index 5db0104..619f9da 100644
---- a/src/utility/filteredStream.cpp
-+++ b/src/utility/filteredStream.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/path.cpp b/src/utility/path.cpp
-index 053e612..9e314e6 100644
---- a/src/utility/path.cpp
-+++ b/src/utility/path.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/progressListener.cpp b/src/utility/progressListener.cpp
-index c7babcb..4bce372 100644
---- a/src/utility/progressListener.cpp
-+++ b/src/utility/progressListener.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/random.cpp b/src/utility/random.cpp
-index 2e373bb..d12989b 100644
---- a/src/utility/random.cpp
-+++ b/src/utility/random.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/smartPtr.cpp b/src/utility/smartPtr.cpp
-index bbc4843..e039036 100644
---- a/src/utility/smartPtr.cpp
-+++ b/src/utility/smartPtr.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/smartPtrInt.cpp b/src/utility/smartPtrInt.cpp
-index 4b4ce13..2ee677b 100644
---- a/src/utility/smartPtrInt.cpp
-+++ b/src/utility/smartPtrInt.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/stream.cpp b/src/utility/stream.cpp
-index 8fbf337..483784c 100644
---- a/src/utility/stream.cpp
-+++ b/src/utility/stream.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/stringProxy.cpp b/src/utility/stringProxy.cpp
-index 60093b6..a4ba6d2 100644
---- a/src/utility/stringProxy.cpp
-+++ b/src/utility/stringProxy.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/stringUtils.cpp b/src/utility/stringUtils.cpp
-index 9566599..03b2057 100644
---- a/src/utility/stringUtils.cpp
-+++ b/src/utility/stringUtils.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/url.cpp b/src/utility/url.cpp
-index 7f609c7..6dfa68a 100644
---- a/src/utility/url.cpp
-+++ b/src/utility/url.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/utility/urlUtils.cpp b/src/utility/urlUtils.cpp
-index d4243df..6df5794 100644
---- a/src/utility/urlUtils.cpp
-+++ b/src/utility/urlUtils.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/word.cpp b/src/word.cpp
-index 95adc5c..958c33e 100644
---- a/src/word.cpp
-+++ b/src/word.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/src/wordEncoder.cpp b/src/wordEncoder.cpp
-index ab7c004..154b4ef 100644
---- a/src/wordEncoder.cpp
-+++ b/src/wordEncoder.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/charset/main.cpp b/tests/charset/main.cpp
-index dd043ac..3e3a50b 100644
---- a/tests/charset/main.cpp
-+++ b/tests/charset/main.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/misc/importanceHelperTest.cpp b/tests/misc/importanceHelperTest.cpp
-index de3e7fc..d200cdf 100644
---- a/tests/misc/importanceHelperTest.cpp
-+++ b/tests/misc/importanceHelperTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/net/maildir/maildirStoreTest.cpp b/tests/net/maildir/maildirStoreTest.cpp
-index f24023b..5aad90b 100644
---- a/tests/net/maildir/maildirStoreTest.cpp
-+++ b/tests/net/maildir/maildirStoreTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/net/smtp/SMTPResponseTest.cpp b/tests/net/smtp/SMTPResponseTest.cpp
-index 3fbb19a..4ad284f 100644
---- a/tests/net/smtp/SMTPResponseTest.cpp
-+++ b/tests/net/smtp/SMTPResponseTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/net/smtp/SMTPTransportTest.cpp b/tests/net/smtp/SMTPTransportTest.cpp
-index 640b2a1..5015552 100644
---- a/tests/net/smtp/SMTPTransportTest.cpp
-+++ b/tests/net/smtp/SMTPTransportTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/parser/attachmentHelperTest.cpp b/tests/parser/attachmentHelperTest.cpp
-index d1ae10a..142730c 100644
---- a/tests/parser/attachmentHelperTest.cpp
-+++ b/tests/parser/attachmentHelperTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/parser/bodyPartTest.cpp b/tests/parser/bodyPartTest.cpp
-index d6fff5e..12c4f74 100644
---- a/tests/parser/bodyPartTest.cpp
-+++ b/tests/parser/bodyPartTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/parser/charsetTest.cpp b/tests/parser/charsetTest.cpp
-index 5a791c5..8ad71d7 100644
---- a/tests/parser/charsetTest.cpp
-+++ b/tests/parser/charsetTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/parser/datetimeTest.cpp b/tests/parser/datetimeTest.cpp
-index b8ceea2..11f9b55 100644
---- a/tests/parser/datetimeTest.cpp
-+++ b/tests/parser/datetimeTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/parser/dispositionTest.cpp b/tests/parser/dispositionTest.cpp
-index dc79d66..d0572b0 100644
---- a/tests/parser/dispositionTest.cpp
-+++ b/tests/parser/dispositionTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/parser/headerTest.cpp b/tests/parser/headerTest.cpp
-index e2807ad..04cd14f 100644
---- a/tests/parser/headerTest.cpp
-+++ b/tests/parser/headerTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/parser/htmlTextPartTest.cpp b/tests/parser/htmlTextPartTest.cpp
-index 6276db2..c9fa588 100644
---- a/tests/parser/htmlTextPartTest.cpp
-+++ b/tests/parser/htmlTextPartTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/parser/mailboxTest.cpp b/tests/parser/mailboxTest.cpp
-index 64b8e45..8411daa 100644
---- a/tests/parser/mailboxTest.cpp
-+++ b/tests/parser/mailboxTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/parser/mediaTypeTest.cpp b/tests/parser/mediaTypeTest.cpp
-index 4741bda..c69fd89 100644
---- a/tests/parser/mediaTypeTest.cpp
-+++ b/tests/parser/mediaTypeTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/parser/messageIdSequenceTest.cpp b/tests/parser/messageIdSequenceTest.cpp
-index 82d871f..17e9a96 100644
---- a/tests/parser/messageIdSequenceTest.cpp
-+++ b/tests/parser/messageIdSequenceTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/parser/messageIdTest.cpp b/tests/parser/messageIdTest.cpp
-index 40e38eb..79154a8 100644
---- a/tests/parser/messageIdTest.cpp
-+++ b/tests/parser/messageIdTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/parser/parameterTest.cpp b/tests/parser/parameterTest.cpp
-index f9a6113..fb7a429 100644
---- a/tests/parser/parameterTest.cpp
-+++ b/tests/parser/parameterTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/parser/pathTest.cpp b/tests/parser/pathTest.cpp
-index 76a944f..b977061 100644
---- a/tests/parser/pathTest.cpp
-+++ b/tests/parser/pathTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/parser/textTest.cpp b/tests/parser/textTest.cpp
-index 152dbc4..5c9b521 100644
---- a/tests/parser/textTest.cpp
-+++ b/tests/parser/textTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/security/digest/md5Test.cpp b/tests/security/digest/md5Test.cpp
-index d2049cd..926e023 100644
---- a/tests/security/digest/md5Test.cpp
-+++ b/tests/security/digest/md5Test.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/security/digest/sha1Test.cpp b/tests/security/digest/sha1Test.cpp
-index 2de0296..3a73a80 100644
---- a/tests/security/digest/sha1Test.cpp
-+++ b/tests/security/digest/sha1Test.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/testRunner.cpp b/tests/testRunner.cpp
-index e286a10..332a14d 100644
---- a/tests/testRunner.cpp
-+++ b/tests/testRunner.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/testUtils.cpp b/tests/testUtils.cpp
-index 0fa816c..456b8ad 100644
---- a/tests/testUtils.cpp
-+++ b/tests/testUtils.cpp
-@@ -4,7 +4,7 @@
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/testUtils.hpp b/tests/testUtils.hpp
-index 42e8879..96daba8 100644
---- a/tests/testUtils.hpp
-+++ b/tests/testUtils.hpp
-@@ -4,7 +4,7 @@
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/utility/datetimeUtilsTest.cpp b/tests/utility/datetimeUtilsTest.cpp
-index 89e8118..4fd3e43 100644
---- a/tests/utility/datetimeUtilsTest.cpp
-+++ b/tests/utility/datetimeUtilsTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/utility/encoderTest.cpp b/tests/utility/encoderTest.cpp
-index 648af78..4e2c9a7 100644
---- a/tests/utility/encoderTest.cpp
-+++ b/tests/utility/encoderTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/utility/filteredStreamTest.cpp b/tests/utility/filteredStreamTest.cpp
-index bcc785e..ad26e6c 100644
---- a/tests/utility/filteredStreamTest.cpp
-+++ b/tests/utility/filteredStreamTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/utility/pathTest.cpp b/tests/utility/pathTest.cpp
-index 6c1e442..1c9b4fb 100644
---- a/tests/utility/pathTest.cpp
-+++ b/tests/utility/pathTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/utility/smartPtrTest.cpp b/tests/utility/smartPtrTest.cpp
-index ce0b941..4f68be4 100644
---- a/tests/utility/smartPtrTest.cpp
-+++ b/tests/utility/smartPtrTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/utility/stringProxyTest.cpp b/tests/utility/stringProxyTest.cpp
-index e1ba6cb..40648d7 100644
---- a/tests/utility/stringProxyTest.cpp
-+++ b/tests/utility/stringProxyTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/utility/stringUtilsTest.cpp b/tests/utility/stringUtilsTest.cpp
-index cbdb688..2144bda 100644
---- a/tests/utility/stringUtilsTest.cpp
-+++ b/tests/utility/stringUtilsTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/tests/utility/urlTest.cpp b/tests/utility/urlTest.cpp
-index 245657a..66d1d08 100644
---- a/tests/utility/urlTest.cpp
-+++ b/tests/utility/urlTest.cpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/address.hpp b/vmime/address.hpp
-index 31d00f0..188d6ec 100644
---- a/vmime/address.hpp
-+++ b/vmime/address.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/addressList.hpp b/vmime/addressList.hpp
-index 7bb7635..2e537c0 100644
---- a/vmime/addressList.hpp
-+++ b/vmime/addressList.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/attachment.hpp b/vmime/attachment.hpp
-index 0df96ca..f45ad28 100644
---- a/vmime/attachment.hpp
-+++ b/vmime/attachment.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/attachmentHelper.hpp b/vmime/attachmentHelper.hpp
-index f696b7e..3ce86c8 100644
---- a/vmime/attachmentHelper.hpp
-+++ b/vmime/attachmentHelper.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/base.hpp b/vmime/base.hpp
-index a25ad7a..ad00d3f 100644
---- a/vmime/base.hpp
-+++ b/vmime/base.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/body.hpp b/vmime/body.hpp
-index 30ac798..80c1bb5 100644
---- a/vmime/body.hpp
-+++ b/vmime/body.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/bodyPart.hpp b/vmime/bodyPart.hpp
-index b1edafc..47c11cb 100644
---- a/vmime/bodyPart.hpp
-+++ b/vmime/bodyPart.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/bodyPartAttachment.hpp b/vmime/bodyPartAttachment.hpp
-index f805b5a..4e1caa0 100644
---- a/vmime/bodyPartAttachment.hpp
-+++ b/vmime/bodyPartAttachment.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/charset.hpp b/vmime/charset.hpp
-index 0630692..1d25b74 100644
---- a/vmime/charset.hpp
-+++ b/vmime/charset.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/charsetConverter.hpp b/vmime/charsetConverter.hpp
-index 36b52f2..14f0dd9 100644
---- a/vmime/charsetConverter.hpp
-+++ b/vmime/charsetConverter.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/component.hpp b/vmime/component.hpp
-index 007cfc0..f30a76c 100644
---- a/vmime/component.hpp
-+++ b/vmime/component.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/constants.hpp b/vmime/constants.hpp
-index 30bc6ef..a1a59da 100644
---- a/vmime/constants.hpp
-+++ b/vmime/constants.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software FOUNDATION; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/contentDisposition.hpp b/vmime/contentDisposition.hpp
-index 19b13c2..9d1749b 100644
---- a/vmime/contentDisposition.hpp
-+++ b/vmime/contentDisposition.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/contentDispositionField.hpp b/vmime/contentDispositionField.hpp
-index d4be481..3474604 100644
---- a/vmime/contentDispositionField.hpp
-+++ b/vmime/contentDispositionField.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/contentHandler.hpp b/vmime/contentHandler.hpp
-index 303b08c..aa485f5 100644
---- a/vmime/contentHandler.hpp
-+++ b/vmime/contentHandler.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/contentTypeField.hpp b/vmime/contentTypeField.hpp
-index 8712941..bd812e2 100644
---- a/vmime/contentTypeField.hpp
-+++ b/vmime/contentTypeField.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/dateTime.hpp b/vmime/dateTime.hpp
-index 0776575..8e99640 100644
---- a/vmime/dateTime.hpp
-+++ b/vmime/dateTime.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/defaultAttachment.hpp b/vmime/defaultAttachment.hpp
-index ea3f59c..0d2c3e5 100644
---- a/vmime/defaultAttachment.hpp
-+++ b/vmime/defaultAttachment.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/disposition.hpp b/vmime/disposition.hpp
-index 44bde21..05bfca2 100644
---- a/vmime/disposition.hpp
-+++ b/vmime/disposition.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/emptyContentHandler.hpp b/vmime/emptyContentHandler.hpp
-index d5aaffd..727c065 100644
---- a/vmime/emptyContentHandler.hpp
-+++ b/vmime/emptyContentHandler.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/encoding.hpp b/vmime/encoding.hpp
-index aa99853..fa72dfb 100644
---- a/vmime/encoding.hpp
-+++ b/vmime/encoding.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/exception.hpp b/vmime/exception.hpp
-index c96d145..5b68bd7 100644
---- a/vmime/exception.hpp
-+++ b/vmime/exception.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/fileAttachment.hpp b/vmime/fileAttachment.hpp
-index dbf1710..0662c8e 100644
---- a/vmime/fileAttachment.hpp
-+++ b/vmime/fileAttachment.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/generatedMessageAttachment.hpp b/vmime/generatedMessageAttachment.hpp
-index 47da8a5..58eacbd 100644
---- a/vmime/generatedMessageAttachment.hpp
-+++ b/vmime/generatedMessageAttachment.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/header.hpp b/vmime/header.hpp
-index 65236cf..95a9326 100644
---- a/vmime/header.hpp
-+++ b/vmime/header.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/headerField.hpp b/vmime/headerField.hpp
-index 3d8f26a..50494c9 100644
---- a/vmime/headerField.hpp
-+++ b/vmime/headerField.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/headerFieldFactory.hpp b/vmime/headerFieldFactory.hpp
-index fc074fb..4b1e567 100644
---- a/vmime/headerFieldFactory.hpp
-+++ b/vmime/headerFieldFactory.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/headerFieldValue.hpp b/vmime/headerFieldValue.hpp
-index b313d4d..adfdeb2 100644
---- a/vmime/headerFieldValue.hpp
-+++ b/vmime/headerFieldValue.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/htmlTextPart.hpp b/vmime/htmlTextPart.hpp
-index 140b4dd..5795eeb 100644
---- a/vmime/htmlTextPart.hpp
-+++ b/vmime/htmlTextPart.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/mailbox.hpp b/vmime/mailbox.hpp
-index 2717ec5..2072be8 100644
---- a/vmime/mailbox.hpp
-+++ b/vmime/mailbox.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/mailboxField.hpp b/vmime/mailboxField.hpp
-index 754ac26..edd2d28 100644
---- a/vmime/mailboxField.hpp
-+++ b/vmime/mailboxField.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/mailboxGroup.hpp b/vmime/mailboxGroup.hpp
-index 8038c06..0061d5b 100644
---- a/vmime/mailboxGroup.hpp
-+++ b/vmime/mailboxGroup.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/mailboxList.hpp b/vmime/mailboxList.hpp
-index 33b2ace..11e4e79 100644
---- a/vmime/mailboxList.hpp
-+++ b/vmime/mailboxList.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/mdn/MDNHelper.hpp b/vmime/mdn/MDNHelper.hpp
-index ee9f421..f9764fa 100644
---- a/vmime/mdn/MDNHelper.hpp
-+++ b/vmime/mdn/MDNHelper.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/mdn/MDNInfos.hpp b/vmime/mdn/MDNInfos.hpp
-index 5b7624c..3c52a60 100644
---- a/vmime/mdn/MDNInfos.hpp
-+++ b/vmime/mdn/MDNInfos.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/mdn/receivedMDNInfos.hpp b/vmime/mdn/receivedMDNInfos.hpp
-index 685bd79..1c258a2 100644
---- a/vmime/mdn/receivedMDNInfos.hpp
-+++ b/vmime/mdn/receivedMDNInfos.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/mdn/sendableMDNInfos.hpp b/vmime/mdn/sendableMDNInfos.hpp
-index 451a467..1f766ea 100644
---- a/vmime/mdn/sendableMDNInfos.hpp
-+++ b/vmime/mdn/sendableMDNInfos.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/mediaType.hpp b/vmime/mediaType.hpp
-index 59d8020..658b21f 100644
---- a/vmime/mediaType.hpp
-+++ b/vmime/mediaType.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/message.hpp b/vmime/message.hpp
-index 449348e..f3be229 100644
---- a/vmime/message.hpp
-+++ b/vmime/message.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/messageAttachment.hpp b/vmime/messageAttachment.hpp
-index 2cc3abc..bdd4e8b 100644
---- a/vmime/messageAttachment.hpp
-+++ b/vmime/messageAttachment.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/messageBuilder.hpp b/vmime/messageBuilder.hpp
-index b94fe82..0371288 100644
---- a/vmime/messageBuilder.hpp
-+++ b/vmime/messageBuilder.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/messageId.hpp b/vmime/messageId.hpp
-index 60f62ad..3686b11 100644
---- a/vmime/messageId.hpp
-+++ b/vmime/messageId.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/messageIdSequence.hpp b/vmime/messageIdSequence.hpp
-index e1989fe..5dfb840 100644
---- a/vmime/messageIdSequence.hpp
-+++ b/vmime/messageIdSequence.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/messageParser.hpp b/vmime/messageParser.hpp
-index 211fac7..c7d5646 100644
---- a/vmime/messageParser.hpp
-+++ b/vmime/messageParser.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/misc/importanceHelper.hpp b/vmime/misc/importanceHelper.hpp
-index a139ffb..37f3497 100644
---- a/vmime/misc/importanceHelper.hpp
-+++ b/vmime/misc/importanceHelper.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/connectionInfos.hpp b/vmime/net/connectionInfos.hpp
-index 302aecb..03f01b9 100644
---- a/vmime/net/connectionInfos.hpp
-+++ b/vmime/net/connectionInfos.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/defaultConnectionInfos.hpp b/vmime/net/defaultConnectionInfos.hpp
-index 0c99684..518b4bc 100644
---- a/vmime/net/defaultConnectionInfos.hpp
-+++ b/vmime/net/defaultConnectionInfos.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/events.hpp b/vmime/net/events.hpp
-index 66ce207..be05c6e 100644
---- a/vmime/net/events.hpp
-+++ b/vmime/net/events.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/folder.hpp b/vmime/net/folder.hpp
-index 0ae33c5..b20e9c9 100644
---- a/vmime/net/folder.hpp
-+++ b/vmime/net/folder.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/imap/IMAPConnection.hpp b/vmime/net/imap/IMAPConnection.hpp
-index 865a4df..147c4df 100644
---- a/vmime/net/imap/IMAPConnection.hpp
-+++ b/vmime/net/imap/IMAPConnection.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/imap/IMAPFolder.hpp b/vmime/net/imap/IMAPFolder.hpp
-index 434653a..dec3878 100644
---- a/vmime/net/imap/IMAPFolder.hpp
-+++ b/vmime/net/imap/IMAPFolder.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/imap/IMAPMessage.hpp b/vmime/net/imap/IMAPMessage.hpp
-index caab819..690e5e2 100644
---- a/vmime/net/imap/IMAPMessage.hpp
-+++ b/vmime/net/imap/IMAPMessage.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/imap/IMAPParser.hpp b/vmime/net/imap/IMAPParser.hpp
-index b307957..0f3e9ec 100644
---- a/vmime/net/imap/IMAPParser.hpp
-+++ b/vmime/net/imap/IMAPParser.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/imap/IMAPSStore.hpp b/vmime/net/imap/IMAPSStore.hpp
-index efd8126..5772ad9 100644
---- a/vmime/net/imap/IMAPSStore.hpp
-+++ b/vmime/net/imap/IMAPSStore.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/imap/IMAPServiceInfos.hpp b/vmime/net/imap/IMAPServiceInfos.hpp
-index 82b8c15..7286b3a 100644
---- a/vmime/net/imap/IMAPServiceInfos.hpp
-+++ b/vmime/net/imap/IMAPServiceInfos.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/imap/IMAPStore.hpp b/vmime/net/imap/IMAPStore.hpp
-index bf8235e..ebff2e6 100644
---- a/vmime/net/imap/IMAPStore.hpp
-+++ b/vmime/net/imap/IMAPStore.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/imap/IMAPTag.hpp b/vmime/net/imap/IMAPTag.hpp
-index 04c8b94..cab2d48 100644
---- a/vmime/net/imap/IMAPTag.hpp
-+++ b/vmime/net/imap/IMAPTag.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/imap/IMAPUtils.hpp b/vmime/net/imap/IMAPUtils.hpp
-index 181bd46..d1ed5c8 100644
---- a/vmime/net/imap/IMAPUtils.hpp
-+++ b/vmime/net/imap/IMAPUtils.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/maildir/format/courierMaildirFormat.hpp b/vmime/net/maildir/format/courierMaildirFormat.hpp
-index b533abc..e8036d5 100644
---- a/vmime/net/maildir/format/courierMaildirFormat.hpp
-+++ b/vmime/net/maildir/format/courierMaildirFormat.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/maildir/format/kmailMaildirFormat.hpp b/vmime/net/maildir/format/kmailMaildirFormat.hpp
-index 0dfb964..e5f7222 100644
---- a/vmime/net/maildir/format/kmailMaildirFormat.hpp
-+++ b/vmime/net/maildir/format/kmailMaildirFormat.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/maildir/maildirFolder.hpp b/vmime/net/maildir/maildirFolder.hpp
-index c0165fa..7474b1a 100644
---- a/vmime/net/maildir/maildirFolder.hpp
-+++ b/vmime/net/maildir/maildirFolder.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/maildir/maildirFormat.hpp b/vmime/net/maildir/maildirFormat.hpp
-index e00dfdf..a47c854 100644
---- a/vmime/net/maildir/maildirFormat.hpp
-+++ b/vmime/net/maildir/maildirFormat.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/maildir/maildirMessage.hpp b/vmime/net/maildir/maildirMessage.hpp
-index 067bdcb..ba3c88e 100644
---- a/vmime/net/maildir/maildirMessage.hpp
-+++ b/vmime/net/maildir/maildirMessage.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/maildir/maildirServiceInfos.hpp b/vmime/net/maildir/maildirServiceInfos.hpp
-index 88ac754..f3b0df8 100644
---- a/vmime/net/maildir/maildirServiceInfos.hpp
-+++ b/vmime/net/maildir/maildirServiceInfos.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/maildir/maildirStore.hpp b/vmime/net/maildir/maildirStore.hpp
-index 0c78943..40ecec3 100644
---- a/vmime/net/maildir/maildirStore.hpp
-+++ b/vmime/net/maildir/maildirStore.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/maildir/maildirUtils.hpp b/vmime/net/maildir/maildirUtils.hpp
-index 8c9920b..c4aa0b6 100644
---- a/vmime/net/maildir/maildirUtils.hpp
-+++ b/vmime/net/maildir/maildirUtils.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/message.hpp b/vmime/net/message.hpp
-index 2d8dc1a..a0cc1da 100644
---- a/vmime/net/message.hpp
-+++ b/vmime/net/message.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/pop3/POP3Folder.hpp b/vmime/net/pop3/POP3Folder.hpp
-index 951abc5..abaa8eb 100644
---- a/vmime/net/pop3/POP3Folder.hpp
-+++ b/vmime/net/pop3/POP3Folder.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/pop3/POP3Message.hpp b/vmime/net/pop3/POP3Message.hpp
-index ccfa089..5dbea3f 100644
---- a/vmime/net/pop3/POP3Message.hpp
-+++ b/vmime/net/pop3/POP3Message.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/pop3/POP3SStore.hpp b/vmime/net/pop3/POP3SStore.hpp
-index 9144f95..1f98bfa 100644
---- a/vmime/net/pop3/POP3SStore.hpp
-+++ b/vmime/net/pop3/POP3SStore.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/pop3/POP3ServiceInfos.hpp b/vmime/net/pop3/POP3ServiceInfos.hpp
-index 23bc81d..d2dff58 100644
---- a/vmime/net/pop3/POP3ServiceInfos.hpp
-+++ b/vmime/net/pop3/POP3ServiceInfos.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/pop3/POP3Store.hpp b/vmime/net/pop3/POP3Store.hpp
-index 55c0ce4..16fcce4 100644
---- a/vmime/net/pop3/POP3Store.hpp
-+++ b/vmime/net/pop3/POP3Store.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/pop3/POP3Utils.hpp b/vmime/net/pop3/POP3Utils.hpp
-index 51bb527..2640c0e 100644
---- a/vmime/net/pop3/POP3Utils.hpp
-+++ b/vmime/net/pop3/POP3Utils.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/securedConnectionInfos.hpp b/vmime/net/securedConnectionInfos.hpp
-index 880e6c9..b27d30b 100644
---- a/vmime/net/securedConnectionInfos.hpp
-+++ b/vmime/net/securedConnectionInfos.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/sendmail/sendmailServiceInfos.hpp b/vmime/net/sendmail/sendmailServiceInfos.hpp
-index 4c2df63..a86a4dd 100644
---- a/vmime/net/sendmail/sendmailServiceInfos.hpp
-+++ b/vmime/net/sendmail/sendmailServiceInfos.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/sendmail/sendmailTransport.hpp b/vmime/net/sendmail/sendmailTransport.hpp
-index 8383e11..5ff8cf2 100644
---- a/vmime/net/sendmail/sendmailTransport.hpp
-+++ b/vmime/net/sendmail/sendmailTransport.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/service.hpp b/vmime/net/service.hpp
-index c260f2a..5205fee 100644
---- a/vmime/net/service.hpp
-+++ b/vmime/net/service.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/serviceFactory.hpp b/vmime/net/serviceFactory.hpp
-index 730df2e..0362b47 100644
---- a/vmime/net/serviceFactory.hpp
-+++ b/vmime/net/serviceFactory.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/serviceInfos.hpp b/vmime/net/serviceInfos.hpp
-index 745f85e..eac77a1 100644
---- a/vmime/net/serviceInfos.hpp
-+++ b/vmime/net/serviceInfos.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/session.hpp b/vmime/net/session.hpp
-index 3eb4cfb..426fe7a 100644
---- a/vmime/net/session.hpp
-+++ b/vmime/net/session.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/smtp/SMTPResponse.hpp b/vmime/net/smtp/SMTPResponse.hpp
-index 313f6a3..5ef4f09 100644
---- a/vmime/net/smtp/SMTPResponse.hpp
-+++ b/vmime/net/smtp/SMTPResponse.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/smtp/SMTPSTransport.hpp b/vmime/net/smtp/SMTPSTransport.hpp
-index 4922ba2..393a4f5 100644
---- a/vmime/net/smtp/SMTPSTransport.hpp
-+++ b/vmime/net/smtp/SMTPSTransport.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/smtp/SMTPServiceInfos.hpp b/vmime/net/smtp/SMTPServiceInfos.hpp
-index 15ea735..61f5aa8 100644
---- a/vmime/net/smtp/SMTPServiceInfos.hpp
-+++ b/vmime/net/smtp/SMTPServiceInfos.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/smtp/SMTPTransport.hpp b/vmime/net/smtp/SMTPTransport.hpp
-index de0092e..050fedd 100644
---- a/vmime/net/smtp/SMTPTransport.hpp
-+++ b/vmime/net/smtp/SMTPTransport.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/socket.hpp b/vmime/net/socket.hpp
-index 88e1f3c..9b0319c 100644
---- a/vmime/net/socket.hpp
-+++ b/vmime/net/socket.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/store.hpp b/vmime/net/store.hpp
-index e60721b..1c9ac1c 100644
---- a/vmime/net/store.hpp
-+++ b/vmime/net/store.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/timeoutHandler.hpp b/vmime/net/timeoutHandler.hpp
-index 0877ec1..6a20665 100644
---- a/vmime/net/timeoutHandler.hpp
-+++ b/vmime/net/timeoutHandler.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/tls/TLSSecuredConnectionInfos.hpp b/vmime/net/tls/TLSSecuredConnectionInfos.hpp
-index 5451633..d0e4087 100644
---- a/vmime/net/tls/TLSSecuredConnectionInfos.hpp
-+++ b/vmime/net/tls/TLSSecuredConnectionInfos.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/tls/TLSSession.hpp b/vmime/net/tls/TLSSession.hpp
-index 639babe..e6bd64f 100644
---- a/vmime/net/tls/TLSSession.hpp
-+++ b/vmime/net/tls/TLSSession.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/tls/TLSSocket.hpp b/vmime/net/tls/TLSSocket.hpp
-index 1c1d324..5112550 100644
---- a/vmime/net/tls/TLSSocket.hpp
-+++ b/vmime/net/tls/TLSSocket.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/net/transport.hpp b/vmime/net/transport.hpp
-index 4ece804..45dc5a5 100644
---- a/vmime/net/transport.hpp
-+++ b/vmime/net/transport.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/object.hpp b/vmime/object.hpp
-index 2782189..2a33aed 100644
---- a/vmime/object.hpp
-+++ b/vmime/object.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/options.hpp b/vmime/options.hpp
-index 5edb051..7e96c2b 100644
---- a/vmime/options.hpp
-+++ b/vmime/options.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/parameter.hpp b/vmime/parameter.hpp
-index 2d21cd1..e1b13a1 100644
---- a/vmime/parameter.hpp
-+++ b/vmime/parameter.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/parameterizedHeaderField.hpp b/vmime/parameterizedHeaderField.hpp
-index c2c8502..2940ca3 100644
---- a/vmime/parameterizedHeaderField.hpp
-+++ b/vmime/parameterizedHeaderField.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/parsedMessageAttachment.hpp b/vmime/parsedMessageAttachment.hpp
-index e66c6c0..abc2ff5 100644
---- a/vmime/parsedMessageAttachment.hpp
-+++ b/vmime/parsedMessageAttachment.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/parserHelpers.hpp b/vmime/parserHelpers.hpp
-index 9be6e4a..9b075f7 100644
---- a/vmime/parserHelpers.hpp
-+++ b/vmime/parserHelpers.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/path.hpp b/vmime/path.hpp
-index aa0d8cb..beaa72b 100644
---- a/vmime/path.hpp
-+++ b/vmime/path.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/plainTextPart.hpp b/vmime/plainTextPart.hpp
-index c9419b5..72c12ac 100644
---- a/vmime/plainTextPart.hpp
-+++ b/vmime/plainTextPart.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/platform.hpp b/vmime/platform.hpp
-index 293320f..d390571 100644
---- a/vmime/platform.hpp
-+++ b/vmime/platform.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/platforms/posix/posixChildProcess.hpp b/vmime/platforms/posix/posixChildProcess.hpp
-index e689065..c25aaca 100644
---- a/vmime/platforms/posix/posixChildProcess.hpp
-+++ b/vmime/platforms/posix/posixChildProcess.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/platforms/posix/posixFile.hpp b/vmime/platforms/posix/posixFile.hpp
-index b7296c6..70986df 100644
---- a/vmime/platforms/posix/posixFile.hpp
-+++ b/vmime/platforms/posix/posixFile.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/platforms/posix/posixHandler.hpp b/vmime/platforms/posix/posixHandler.hpp
-index bc78719..397a5dd 100644
---- a/vmime/platforms/posix/posixHandler.hpp
-+++ b/vmime/platforms/posix/posixHandler.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/platforms/posix/posixSocket.hpp b/vmime/platforms/posix/posixSocket.hpp
-index c230944..0d0dae6 100644
---- a/vmime/platforms/posix/posixSocket.hpp
-+++ b/vmime/platforms/posix/posixSocket.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/platforms/windows/windowsFile.hpp b/vmime/platforms/windows/windowsFile.hpp
-index 7e81859..a2a9e92 100644
---- a/vmime/platforms/windows/windowsFile.hpp
-+++ b/vmime/platforms/windows/windowsFile.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://vmime.sourceforge.net)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/platforms/windows/windowsHandler.hpp b/vmime/platforms/windows/windowsHandler.hpp
-index 2f65651..701edf0 100644
---- a/vmime/platforms/windows/windowsHandler.hpp
-+++ b/vmime/platforms/windows/windowsHandler.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://vmime.sourceforge.net)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/platforms/windows/windowsSocket.hpp b/vmime/platforms/windows/windowsSocket.hpp
-index 6890ddc..61475c3 100644
---- a/vmime/platforms/windows/windowsSocket.hpp
-+++ b/vmime/platforms/windows/windowsSocket.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://vmime.sourceforge.net)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/propertySet.hpp b/vmime/propertySet.hpp
-index 94cf1fd..e5cbf1f 100644
---- a/vmime/propertySet.hpp
-+++ b/vmime/propertySet.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/relay.hpp b/vmime/relay.hpp
-index 46b6351..583ad80 100644
---- a/vmime/relay.hpp
-+++ b/vmime/relay.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/authenticator.hpp b/vmime/security/authenticator.hpp
-index d339975..a31fc5e 100644
---- a/vmime/security/authenticator.hpp
-+++ b/vmime/security/authenticator.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/cert/X509Certificate.hpp b/vmime/security/cert/X509Certificate.hpp
-index e7ca309..b916cff 100644
---- a/vmime/security/cert/X509Certificate.hpp
-+++ b/vmime/security/cert/X509Certificate.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/cert/certificate.hpp b/vmime/security/cert/certificate.hpp
-index 440a1a8..b7447fe 100644
---- a/vmime/security/cert/certificate.hpp
-+++ b/vmime/security/cert/certificate.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/cert/certificateChain.hpp b/vmime/security/cert/certificateChain.hpp
-index bb21313..02e3d55 100644
---- a/vmime/security/cert/certificateChain.hpp
-+++ b/vmime/security/cert/certificateChain.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/cert/certificateVerifier.hpp b/vmime/security/cert/certificateVerifier.hpp
-index e04b11c..cf03826 100644
---- a/vmime/security/cert/certificateVerifier.hpp
-+++ b/vmime/security/cert/certificateVerifier.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/cert/defaultCertificateVerifier.hpp b/vmime/security/cert/defaultCertificateVerifier.hpp
-index 5b4bab6..6f650f3 100644
---- a/vmime/security/cert/defaultCertificateVerifier.hpp
-+++ b/vmime/security/cert/defaultCertificateVerifier.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/defaultAuthenticator.hpp b/vmime/security/defaultAuthenticator.hpp
-index 641dcfe..dfb8298 100644
---- a/vmime/security/defaultAuthenticator.hpp
-+++ b/vmime/security/defaultAuthenticator.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/digest/md5/md5MessageDigest.hpp b/vmime/security/digest/md5/md5MessageDigest.hpp
-index 893cb05..682e7cc 100644
---- a/vmime/security/digest/md5/md5MessageDigest.hpp
-+++ b/vmime/security/digest/md5/md5MessageDigest.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/digest/messageDigest.hpp b/vmime/security/digest/messageDigest.hpp
-index 95c3b2b..9e432c7 100644
---- a/vmime/security/digest/messageDigest.hpp
-+++ b/vmime/security/digest/messageDigest.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/digest/messageDigestFactory.hpp b/vmime/security/digest/messageDigestFactory.hpp
-index 54d6d76..763d5fa 100644
---- a/vmime/security/digest/messageDigestFactory.hpp
-+++ b/vmime/security/digest/messageDigestFactory.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/digest/sha1/sha1MessageDigest.hpp b/vmime/security/digest/sha1/sha1MessageDigest.hpp
-index 129db80..906009a 100644
---- a/vmime/security/digest/sha1/sha1MessageDigest.hpp
-+++ b/vmime/security/digest/sha1/sha1MessageDigest.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/sasl/SASLAuthenticator.hpp b/vmime/security/sasl/SASLAuthenticator.hpp
-index 76e1c5d..daa090a 100644
---- a/vmime/security/sasl/SASLAuthenticator.hpp
-+++ b/vmime/security/sasl/SASLAuthenticator.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/sasl/SASLContext.hpp b/vmime/security/sasl/SASLContext.hpp
-index e1d2de4..7703ab1 100644
---- a/vmime/security/sasl/SASLContext.hpp
-+++ b/vmime/security/sasl/SASLContext.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/sasl/SASLMechanism.hpp b/vmime/security/sasl/SASLMechanism.hpp
-index 3283831..dbb7cd2 100644
---- a/vmime/security/sasl/SASLMechanism.hpp
-+++ b/vmime/security/sasl/SASLMechanism.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/sasl/SASLMechanismFactory.hpp b/vmime/security/sasl/SASLMechanismFactory.hpp
-index 13d0efd..7b86061 100644
---- a/vmime/security/sasl/SASLMechanismFactory.hpp
-+++ b/vmime/security/sasl/SASLMechanismFactory.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/sasl/SASLSession.hpp b/vmime/security/sasl/SASLSession.hpp
-index 8c9eca6..79acfa9 100644
---- a/vmime/security/sasl/SASLSession.hpp
-+++ b/vmime/security/sasl/SASLSession.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/sasl/SASLSocket.hpp b/vmime/security/sasl/SASLSocket.hpp
-index fc6fc39..3ff27e3 100644
---- a/vmime/security/sasl/SASLSocket.hpp
-+++ b/vmime/security/sasl/SASLSocket.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/sasl/builtinSASLMechanism.hpp b/vmime/security/sasl/builtinSASLMechanism.hpp
-index a1ea531..ac7421c 100644
---- a/vmime/security/sasl/builtinSASLMechanism.hpp
-+++ b/vmime/security/sasl/builtinSASLMechanism.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/security/sasl/defaultSASLAuthenticator.hpp b/vmime/security/sasl/defaultSASLAuthenticator.hpp
-index 0b1c06e..a896b65 100644
---- a/vmime/security/sasl/defaultSASLAuthenticator.hpp
-+++ b/vmime/security/sasl/defaultSASLAuthenticator.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/streamContentHandler.hpp b/vmime/streamContentHandler.hpp
-index b9e8e97..aa62b2f 100644
---- a/vmime/streamContentHandler.hpp
-+++ b/vmime/streamContentHandler.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/stringContentHandler.hpp b/vmime/stringContentHandler.hpp
-index 0e7d1e3..8d36889 100644
---- a/vmime/stringContentHandler.hpp
-+++ b/vmime/stringContentHandler.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/text.hpp b/vmime/text.hpp
-index 34427b5..dd4534d 100644
---- a/vmime/text.hpp
-+++ b/vmime/text.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/textPart.hpp b/vmime/textPart.hpp
-index 1e8a485..acd9fb3 100644
---- a/vmime/textPart.hpp
-+++ b/vmime/textPart.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/textPartFactory.hpp b/vmime/textPartFactory.hpp
-index 89e48e3..3650293 100644
---- a/vmime/textPartFactory.hpp
-+++ b/vmime/textPartFactory.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/types.hpp b/vmime/types.hpp
-index de02192..bdf627e 100644
---- a/vmime/types.hpp
-+++ b/vmime/types.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/childProcess.hpp b/vmime/utility/childProcess.hpp
-index b4bc257..33cb633 100644
---- a/vmime/utility/childProcess.hpp
-+++ b/vmime/utility/childProcess.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/datetimeUtils.hpp b/vmime/utility/datetimeUtils.hpp
-index 23d1a96..b56533c 100644
---- a/vmime/utility/datetimeUtils.hpp
-+++ b/vmime/utility/datetimeUtils.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/encoder/b64Encoder.hpp b/vmime/utility/encoder/b64Encoder.hpp
-index 831e9f6..6a3a3c6 100644
---- a/vmime/utility/encoder/b64Encoder.hpp
-+++ b/vmime/utility/encoder/b64Encoder.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/encoder/binaryEncoder.hpp b/vmime/utility/encoder/binaryEncoder.hpp
-index 783f831..02ff794 100644
---- a/vmime/utility/encoder/binaryEncoder.hpp
-+++ b/vmime/utility/encoder/binaryEncoder.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/encoder/defaultEncoder.hpp b/vmime/utility/encoder/defaultEncoder.hpp
-index 3ddad1f..daba3ee 100644
---- a/vmime/utility/encoder/defaultEncoder.hpp
-+++ b/vmime/utility/encoder/defaultEncoder.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/encoder/eightBitEncoder.hpp b/vmime/utility/encoder/eightBitEncoder.hpp
-index 2e9b138..2de002f 100644
---- a/vmime/utility/encoder/eightBitEncoder.hpp
-+++ b/vmime/utility/encoder/eightBitEncoder.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/encoder/encoder.hpp b/vmime/utility/encoder/encoder.hpp
-index eec0003..49f3c30 100644
---- a/vmime/utility/encoder/encoder.hpp
-+++ b/vmime/utility/encoder/encoder.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/encoder/encoderFactory.hpp b/vmime/utility/encoder/encoderFactory.hpp
-index 22f28f4..6abb223 100644
---- a/vmime/utility/encoder/encoderFactory.hpp
-+++ b/vmime/utility/encoder/encoderFactory.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/encoder/qpEncoder.hpp b/vmime/utility/encoder/qpEncoder.hpp
-index 6af3c90..098b4c8 100644
---- a/vmime/utility/encoder/qpEncoder.hpp
-+++ b/vmime/utility/encoder/qpEncoder.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/encoder/sevenBitEncoder.hpp b/vmime/utility/encoder/sevenBitEncoder.hpp
-index 98a999a..2f4870d 100644
---- a/vmime/utility/encoder/sevenBitEncoder.hpp
-+++ b/vmime/utility/encoder/sevenBitEncoder.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/encoder/uuEncoder.hpp b/vmime/utility/encoder/uuEncoder.hpp
-index 6cb5fa1..6289ae0 100644
---- a/vmime/utility/encoder/uuEncoder.hpp
-+++ b/vmime/utility/encoder/uuEncoder.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/file.hpp b/vmime/utility/file.hpp
-index 390c4f4..61ede80 100644
---- a/vmime/utility/file.hpp
-+++ b/vmime/utility/file.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/filteredStream.hpp b/vmime/utility/filteredStream.hpp
-index 1e03697..00be785 100644
---- a/vmime/utility/filteredStream.hpp
-+++ b/vmime/utility/filteredStream.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/path.hpp b/vmime/utility/path.hpp
-index c4aed26..e43291c 100644
---- a/vmime/utility/path.hpp
-+++ b/vmime/utility/path.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/progressListener.hpp b/vmime/utility/progressListener.hpp
-index f26599d..39b884a 100644
---- a/vmime/utility/progressListener.hpp
-+++ b/vmime/utility/progressListener.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/random.hpp b/vmime/utility/random.hpp
-index 1db15f5..f706c55 100644
---- a/vmime/utility/random.hpp
-+++ b/vmime/utility/random.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/smartPtr.hpp b/vmime/utility/smartPtr.hpp
-index d2a78a6..c448632 100644
---- a/vmime/utility/smartPtr.hpp
-+++ b/vmime/utility/smartPtr.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/smartPtrInt.hpp b/vmime/utility/smartPtrInt.hpp
-index a7c7345..453c00e 100644
---- a/vmime/utility/smartPtrInt.hpp
-+++ b/vmime/utility/smartPtrInt.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/stream.hpp b/vmime/utility/stream.hpp
-index 5f7bfa2..1faab55 100644
---- a/vmime/utility/stream.hpp
-+++ b/vmime/utility/stream.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/stringProxy.hpp b/vmime/utility/stringProxy.hpp
-index d080e67..21c65ea 100644
---- a/vmime/utility/stringProxy.hpp
-+++ b/vmime/utility/stringProxy.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/stringUtils.hpp b/vmime/utility/stringUtils.hpp
-index 89fd386..b6589db 100644
---- a/vmime/utility/stringUtils.hpp
-+++ b/vmime/utility/stringUtils.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/url.hpp b/vmime/utility/url.hpp
-index 99585b1..7537428 100644
---- a/vmime/utility/url.hpp
-+++ b/vmime/utility/url.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/utility/urlUtils.hpp b/vmime/utility/urlUtils.hpp
-index 3d2955a..ba0fbf6 100644
---- a/vmime/utility/urlUtils.hpp
-+++ b/vmime/utility/urlUtils.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/vmime.hpp b/vmime/vmime.hpp
-index 0e54d7b..f187b9e 100644
---- a/vmime/vmime.hpp
-+++ b/vmime/vmime.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/word.hpp b/vmime/word.hpp
-index 14f8b0e..d787073 100644
---- a/vmime/word.hpp
-+++ b/vmime/word.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-diff --git a/vmime/wordEncoder.hpp b/vmime/wordEncoder.hpp
-index 09c141d..17ca808 100644
---- a/vmime/wordEncoder.hpp
-+++ b/vmime/wordEncoder.hpp
-@@ -1,10 +1,10 @@
- //
- // VMime library (http://www.vmime.org)
--// Copyright (C) 2002-2008 Vincent Richard <vincent@vincent-richard.net>
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
- //
- // 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
-+// published by the Free Software Foundation; either version 3 of
- // the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
-
-commit cc633d7aafc1736a866c34ffda272842fe6a154c
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Mon Sep 14 15:07:06 2009 +0000
-
- Added workaround for Decider() for legacy versions of SCons.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@503 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/SConstruct b/SConstruct
-index 2e86832..89b58f6 100644
---- a/SConstruct
-+++ b/SConstruct
-@@ -439,7 +439,11 @@ EnsureSConsVersion(0, 94)
-
- SetOption('implicit_cache', 1)
-
--Decider('MD5-timestamp')
-+try:
-+ Decider('MD5-timestamp')
-+except:
-+ SourceSignatures('MD5')
-+ TargetSignatures('build')
-
-
- #############
-
-commit 1fade7261d02652f39ffc70fdf29cfad02244732
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Sep 15 19:36:03 2009 +0000
-
- Fixed possible segfault (thanks to John van der Kamp, from Zarafa).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@504 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/messageBuilder.cpp b/src/messageBuilder.cpp
-index d619554..a70372f 100644
---- a/src/messageBuilder.cpp
-+++ b/src/messageBuilder.cpp
-@@ -142,6 +142,9 @@ ref <message> messageBuilder::construct() const
- {
- const bodyPart& part = *msg->getBody()->getPartAt(0);
-
-+ // Make a full copy of the body, otherwise the copyFrom() will delete the body we're copying
-+ ref <body> bodyCopy = part.getBody()->clone().dynamicCast <body>();
-+
- // First, copy (and replace) the header fields
- const std::vector <ref <const headerField> > fields = part.getHeader()->getFieldList();
-
-@@ -153,7 +156,7 @@ ref <message> messageBuilder::construct() const
-
- // Second, copy the body contents and sub-parts (this also remove
- // the body part we are copying...)
-- msg->getBody()->copyFrom(*part.getBody());
-+ msg->getBody()->copyFrom(*bodyCopy);
- }
-
- return (msg);
-
-commit df1b82b80f63d1e4c6f30f8be03dd4b3e859b341
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Nov 3 12:37:51 2009 +0000
-
- Fixed possible segfault (thanks to László Vadócz).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@505 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/utility/stringUtils.cpp b/src/utility/stringUtils.cpp
-index 03b2057..abae8f9 100644
---- a/src/utility/stringUtils.cpp
-+++ b/src/utility/stringUtils.cpp
-@@ -142,7 +142,7 @@ string::size_type stringUtils::countASCIIchars
- {
- if (parserHelpers::isAscii(*i))
- {
-- if (*i != '=' || *(i + 1) != '?') // To avoid bad behaviour...
-+ if (*i != '=' || ((i + 1) != end && *(i + 1) != '?')) // To avoid bad behaviour...
- ++count;
- }
- }
-
-commit 8391dcfb8e65645d473a0a67e3f5c860d30817b7
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Nov 3 14:17:55 2009 +0000
-
- Reset EOF flag when stream is reset.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@506 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/platforms/posix/posixFile.cpp b/src/platforms/posix/posixFile.cpp
-index 4ec2ef3..7ee9f19 100644
---- a/src/platforms/posix/posixFile.cpp
-+++ b/src/platforms/posix/posixFile.cpp
-@@ -188,6 +188,8 @@ void posixFileReaderInputStream::reset()
- {
- if (::lseek(m_fd, 0, SEEK_SET) == off_t(-1))
- posixFileSystemFactory::reportError(m_path, errno);
-+
-+ m_eof = false;
- }
-
-
-@@ -199,7 +201,7 @@ vmime::utility::stream::size_type posixFileReaderInputStream::read
- if ((c = ::read(m_fd, data, count)) == -1)
- posixFileSystemFactory::reportError(m_path, errno);
-
-- if (c == 0)
-+ if (c == 0 && count != 0)
- m_eof = true;
-
- return static_cast <size_type>(c);
-
-commit 746d6ccc4c9a8c2387f3d4311d7b4c670d8f5e8b
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Nov 4 12:52:49 2009 +0000
-
- Removed some unnecessary consts on integral types where overrides conflict. Added <cctype> to get the std::isspace that doesn't require a 2nd arg 'locale' (thanks to Ben Jackson).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@507 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/platforms/windows/windowsFile.cpp b/src/platforms/windows/windowsFile.cpp
-index 5412a3b..82c5696 100644
---- a/src/platforms/windows/windowsFile.cpp
-+++ b/src/platforms/windows/windowsFile.cpp
-@@ -464,7 +464,7 @@ void windowsFileReaderInputStream::reset()
- SetFilePointer(m_hFile, 0, NULL, FILE_BEGIN);
- }
-
--const vmime::utility::stream::size_type windowsFileReaderInputStream::read(value_type* const data, const size_type count)
-+vmime::utility::stream::size_type windowsFileReaderInputStream::read(value_type* const data, const size_type count)
- {
- DWORD dwBytesRead;
- if (!ReadFile(m_hFile, (LPVOID)data, (DWORD)count, &dwBytesRead, NULL))
-@@ -472,7 +472,7 @@ const vmime::utility::stream::size_type windowsFileReaderInputStream::read(value
- return dwBytesRead;
- }
-
--const vmime::utility::stream::size_type windowsFileReaderInputStream::skip(const size_type count)
-+vmime::utility::stream::size_type windowsFileReaderInputStream::skip(const size_type count)
- {
- DWORD dwCurPos = SetFilePointer(m_hFile, 0, NULL, FILE_CURRENT);
- DWORD dwNewPos = SetFilePointer(m_hFile, (LONG)count, NULL, FILE_CURRENT);
-diff --git a/vmime/base.hpp b/vmime/base.hpp
-index ad00d3f..ce544e1 100644
---- a/vmime/base.hpp
-+++ b/vmime/base.hpp
-@@ -29,6 +29,7 @@
- #include <vector>
- #include <map>
- #include <sstream>
-+#include <cctype>
- #include <locale>
-
- #include "vmime/config.hpp"
-diff --git a/vmime/platforms/windows/windowsFile.hpp b/vmime/platforms/windows/windowsFile.hpp
-index a2a9e92..6e1c8fb 100644
---- a/vmime/platforms/windows/windowsFile.hpp
-+++ b/vmime/platforms/windows/windowsFile.hpp
-@@ -73,7 +73,7 @@ public:
- bool canRead() const;
- bool canWrite() const;
-
-- const length_type getLength();
-+ length_type getLength();
-
- const path& getFullPath() const;
-
-
-commit eba83b2cb02ef40da3fa519fac6255735cf980b5
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Nov 4 14:12:06 2009 +0000
-
- Auto-detect filename. Renamed 'filename' argument to 'filepath' for disambiguity. Added constructor for input stream. Use 'word' instead of 'string' for filename.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@508 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/fileAttachment.cpp b/src/fileAttachment.cpp
-index e643491..da7c4b7 100644
---- a/src/fileAttachment.cpp
-+++ b/src/fileAttachment.cpp
-@@ -31,48 +31,93 @@
-
- #include "vmime/contentDispositionField.hpp"
-
-+#include "vmime/platform.hpp"
-+#include "vmime/utility/file.hpp"
-+
-
- namespace vmime
- {
-
-
--fileAttachment::fileAttachment(const string& filename, const mediaType& type)
-+fileAttachment::fileAttachment(const string& filepath, const mediaType& type)
- {
- m_type = type;
-
-- setData(filename);
-+ setData(filepath);
-
- m_encoding = encoding::decide(m_data);
- }
-
-
--fileAttachment::fileAttachment(const string& filename, const mediaType& type, const text& desc)
-+fileAttachment::fileAttachment(const string& filepath, const mediaType& type, const text& desc)
- {
- m_type = type;
- m_desc = desc;
-
-- setData(filename);
-+ setData(filepath);
-
- m_encoding = encoding::decide(m_data);
- }
-
-
--fileAttachment::fileAttachment(const string& filename, const mediaType& type,
-+fileAttachment::fileAttachment(const string& filepath, const mediaType& type,
- const text& desc, const encoding& enc)
- {
- m_type = type;
- m_desc = desc;
-
-- setData(filename);
-+ setData(filepath);
-+
-+ m_encoding = enc;
-+}
-+
-+
-+fileAttachment::fileAttachment(ref <utility::inputStream> is, const word& filename, const mediaType& type)
-+{
-+ if (!filename.isEmpty())
-+ m_fileInfo.setFilename(filename);
-+
-+ m_type = type;
-+
-+ setData(is);
-+
-+ m_encoding = encoding::decide(m_data);
-+}
-+
-+
-+fileAttachment::fileAttachment(ref <utility::inputStream> is, const word& filename,
-+ const mediaType& type, const text& desc)
-+{
-+ if (!filename.isEmpty())
-+ m_fileInfo.setFilename(filename);
-+
-+ m_type = type;
-+ m_desc = desc;
-+
-+ setData(is);
-+
-+ m_encoding = encoding::decide(m_data);
-+}
-+
-+
-+fileAttachment::fileAttachment(ref <utility::inputStream> is, const word& filename,
-+ const mediaType& type, const text& desc, const encoding& enc)
-+{
-+ if (!filename.isEmpty())
-+ m_fileInfo.setFilename(filename);
-
-+ m_type = type;
-+ m_desc = desc;
- m_encoding = enc;
-+
-+ setData(is);
- }
-
-
--void fileAttachment::setData(const string& filename)
-+void fileAttachment::setData(const string& filepath)
- {
- std::ifstream* file = new std::ifstream();
-- file->open(filename.c_str(), std::ios::in | std::ios::binary);
-+ file->open(filepath.c_str(), std::ios::in | std::ios::binary);
-
- if (!*file)
- {
-@@ -82,6 +127,15 @@ void fileAttachment::setData(const string& filename)
-
- ref <utility::inputStream> is = vmime::create <utility::inputStreamPointerAdapter>(file, true);
-
-+ setData(is);
-+
-+ utility::file::path path = platform::getHandler()->getFileSystemFactory()->stringToPath(filepath);
-+ m_fileInfo.setFilename(path.getLastComponent());
-+}
-+
-+
-+void fileAttachment::setData(ref <utility::inputStream> is)
-+{
- m_data = vmime::create <streamContentHandler>(is, 0);
- }
-
-@@ -94,7 +148,7 @@ void fileAttachment::generatePart(ref <bodyPart> part) const
- dynamicCast <contentDispositionField>();
-
- if (m_fileInfo.hasSize()) cdf->setSize(utility::stringUtils::toString(m_fileInfo.getSize()));
-- if (m_fileInfo.hasFilename()) cdf->setFilename(m_fileInfo.getFilename());
-+ if (m_fileInfo.hasFilename() && !m_fileInfo.getFilename().isEmpty()) cdf->setFilename(m_fileInfo.getFilename());
- if (m_fileInfo.hasCreationDate()) cdf->setCreationDate(m_fileInfo.getCreationDate());
- if (m_fileInfo.hasModificationDate()) cdf->setModificationDate(m_fileInfo.getModificationDate());
- if (m_fileInfo.hasReadDate()) cdf->setReadDate(m_fileInfo.getReadDate());
-@@ -134,8 +188,9 @@ fileAttachment::fileInfo::~fileInfo()
- }
-
- bool fileAttachment::fileInfo::hasFilename() const { return (m_filename != NULL); }
--const string& fileAttachment::fileInfo::getFilename() const { return (*m_filename); }
--void fileAttachment::fileInfo::setFilename(const string& name) { if (m_filename) { *m_filename = name; } else { m_filename = new string(name); } }
-+const word& fileAttachment::fileInfo::getFilename() const { return (*m_filename); }
-+void fileAttachment::fileInfo::setFilename(const string& name) { if (m_filename) { *m_filename = name; } else { m_filename = new word(name); } }
-+void fileAttachment::fileInfo::setFilename(const word& name) { if (m_filename) { *m_filename = name; } else { m_filename = new word(name); } }
-
- bool fileAttachment::fileInfo::hasCreationDate() const { return (m_creationDate != NULL); }
- const datetime& fileAttachment::fileInfo::getCreationDate() const { return (*m_creationDate); }
-diff --git a/src/word.cpp b/src/word.cpp
-index 958c33e..ce5ddfc 100644
---- a/src/word.cpp
-+++ b/src/word.cpp
-@@ -699,6 +699,12 @@ string& word::getBuffer()
- }
-
-
-+bool word::isEmpty() const
-+{
-+ return m_buffer.empty();
-+}
-+
-+
- void word::setBuffer(const string& buffer)
- {
- m_buffer = buffer;
-diff --git a/vmime/fileAttachment.hpp b/vmime/fileAttachment.hpp
-index 0662c8e..1516a9d 100644
---- a/vmime/fileAttachment.hpp
-+++ b/vmime/fileAttachment.hpp
-@@ -41,9 +41,13 @@ class fileAttachment : public defaultAttachment
- {
- public:
-
-- fileAttachment(const string& filename, const mediaType& type);
-- fileAttachment(const string& filename, const mediaType& type, const text& desc);
-- fileAttachment(const string& filename, const mediaType& type, const text& desc, const encoding& enc);
-+ fileAttachment(const string& filepath, const mediaType& type);
-+ fileAttachment(const string& filepath, const mediaType& type, const text& desc);
-+ fileAttachment(const string& filepath, const mediaType& type, const text& desc, const encoding& enc);
-+
-+ fileAttachment(ref <utility::inputStream> is, const word& filename, const mediaType& type);
-+ fileAttachment(ref <utility::inputStream> is, const word& filename, const mediaType& type, const text& desc);
-+ fileAttachment(ref <utility::inputStream> is, const word& filename, const mediaType& type, const text& desc, const encoding& enc);
-
- /** Stores information about a file attachment.
- */
-@@ -65,7 +69,7 @@ public:
- *
- * @return file name
- */
-- const string& getFilename() const;
-+ const word& getFilename() const;
-
- /** Set the value of the 'filename' property.
- *
-@@ -73,6 +77,12 @@ public:
- */
- void setFilename(const string& name);
-
-+ /** Set the value of the 'filename' property.
-+ *
-+ * @param name file name
-+ */
-+ void setFilename(const word& name);
-+
- /** Check whether the 'creation-date' property is present.
- *
- * @return true if the 'creation-date' property is set,
-@@ -151,7 +161,7 @@ public:
-
- private:
-
-- string* m_filename;
-+ word* m_filename;
- unsigned int* m_size;
- datetime* m_creationDate;
- datetime* m_modifDate;
-@@ -163,7 +173,8 @@ public:
-
- private:
-
-- void setData(const string& filename);
-+ void setData(const string& filepath);
-+ void setData(ref <utility::inputStream> is);
-
- fileInfo m_fileInfo;
-
-diff --git a/vmime/word.hpp b/vmime/word.hpp
-index d787073..78a88e8 100644
---- a/vmime/word.hpp
-+++ b/vmime/word.hpp
-@@ -60,6 +60,12 @@ public:
- */
- string& getBuffer();
-
-+ /** Tests whether this word is empty.
-+ *
-+ * @return true if the buffer is empty, false otherwise
-+ */
-+ bool isEmpty() const;
-+
- /** Set the raw data for this encoded word.
- *
- * @param buffer raw data buffer
-
-commit ef738c99e183fe0452394f4f58441cbf0297a7d0
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Thu Nov 12 15:40:56 2009 +0000
-
- Quote mailbox name instead of encoding it whenever it's possible.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@509 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/mailbox.cpp b/src/mailbox.cpp
-index 2f62521..f6df516 100644
---- a/src/mailbox.cpp
-+++ b/src/mailbox.cpp
-@@ -415,7 +415,7 @@ void mailbox::generate(utility::outputStream& os, const string::size_type maxLin
- bool newLine = true;
-
- m_name.encodeAndFold(os, maxLineLength, pos, &pos,
-- forceEncode ? text::FORCE_ENCODING : 0);
-+ text::QUOTE_IF_POSSIBLE | (forceEncode ? text::FORCE_ENCODING : 0));
-
- if (pos + m_email.length() + 3 > maxLineLength)
- {
-diff --git a/src/word.cpp b/src/word.cpp
-index ce5ddfc..ea8244a 100644
---- a/src/word.cpp
-+++ b/src/word.cpp
-@@ -352,10 +352,22 @@ void word::generate(utility::outputStream& os, const string::size_type maxLineLe
- noEncoding = false;
- }
-
-- if (noEncoding)
-+ // If possible and requested (with flag), quote the buffer (no folding is performed).
-+ // Quoting is possible if and only if:
-+ // - the whole buffer is ASCII-only
-+ // - the buffer does not contain quoting character (")
-+ // - there is enough remaining space on the current line to hold the whole buffer
-+ if ((flags & text::QUOTE_IF_POSSIBLE) &&
-+ asciiCount == m_buffer.length() &&
-+ m_buffer.find('"') == string::npos &&
-+ (curLineLength + 2 /* 2 x " */ + m_buffer.length()) < maxLineLength)
-+ {
-+ os << '"' << m_buffer << '"';
-+ curLineLength += 2 + m_buffer.length();
-+ }
-+ // We will fold lines without encoding them.
-+ else if (noEncoding)
- {
-- // We will fold lines without encoding them.
--
- string::const_iterator lastWSpos = m_buffer.end(); // last white-space position
- string::const_iterator curLineStart = m_buffer.begin(); // current line start
-
-diff --git a/vmime/text.hpp b/vmime/text.hpp
-index dd4534d..9760c48 100644
---- a/vmime/text.hpp
-+++ b/vmime/text.hpp
-@@ -197,7 +197,8 @@ public:
-
- FORCE_NO_ENCODING = (1 << 0), /**< Just fold lines, don't encode them. */
- FORCE_ENCODING = (1 << 1), /**< Encode lines even if they are plain ASCII text. */
-- NO_NEW_LINE_SEQUENCE = (1 << 2) /**< Use CRLF instead of new-line sequence (CRLF + TAB). */
-+ NO_NEW_LINE_SEQUENCE = (1 << 2), /**< Use CRLF instead of new-line sequence (CRLF + TAB). */
-+ QUOTE_IF_POSSIBLE = (1 << 3) /**< Use quoting instead of encoding when possible (even if FORCE_ENCODING is specified). */
- };
-
- /** Encode and fold text in respect to RFC-2047.
-
-commit 71e41f1d41ff1f87654e03a5e1247e30311677c2
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Mon Nov 30 13:04:15 2009 +0000
-
- Added block size on sockets to allow different buffer size for SSL.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@510 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/net/imap/IMAPConnection.cpp b/src/net/imap/IMAPConnection.cpp
-index c3ee574..6e5a265 100644
---- a/src/net/imap/IMAPConnection.cpp
-+++ b/src/net/imap/IMAPConnection.cpp
-@@ -718,6 +718,12 @@ ref <session> IMAPConnection::getSession()
- }
-
-
-+ref <const socket> IMAPConnection::getSocket() const
-+{
-+ return m_socket;
-+}
-+
-+
- } // imap
- } // net
- } // vmime
-diff --git a/src/net/imap/IMAPFolder.cpp b/src/net/imap/IMAPFolder.cpp
-index c06a8d4..0122d21 100644
---- a/src/net/imap/IMAPFolder.cpp
-+++ b/src/net/imap/IMAPFolder.cpp
-@@ -1284,7 +1284,11 @@ void IMAPFolder::addMessage(utility::inputStream& is, const int size, const int
- if (progress)
- progress->start(total);
-
-- char buffer[65536];
-+ const socket::size_type blockSize = std::min(is.getBlockSize(),
-+ static_cast <size_t>(m_connection->getSocket()->getBlockSize()));
-+
-+ std::vector <char> vbuffer(blockSize);
-+ char* buffer = &vbuffer.front();
-
- while (!is.eof())
- {
-diff --git a/src/net/tls/TLSSocket.cpp b/src/net/tls/TLSSocket.cpp
-index c2f91f6..dab0338 100644
---- a/src/net/tls/TLSSocket.cpp
-+++ b/src/net/tls/TLSSocket.cpp
-@@ -90,6 +90,12 @@ bool TLSSocket::isConnected() const
- }
-
-
-+TLSSocket::size_type TLSSocket::getBlockSize() const
-+{
-+ return 16384; // 16 KB
-+}
-+
-+
- void TLSSocket::receive(string& buffer)
- {
- const int size = receiveRaw(m_buffer, sizeof(m_buffer));
-@@ -103,7 +109,7 @@ void TLSSocket::send(const string& buffer)
- }
-
-
--int TLSSocket::receiveRaw(char* buffer, const int count)
-+TLSSocket::size_type TLSSocket::receiveRaw(char* buffer, const size_type count)
- {
- const ssize_t ret = gnutls_record_recv
- (*m_session->m_gnutlsSession,
-@@ -124,7 +130,7 @@ int TLSSocket::receiveRaw(char* buffer, const int count)
- }
-
-
--void TLSSocket::sendRaw(const char* buffer, const int count)
-+void TLSSocket::sendRaw(const char* buffer, const size_type count)
- {
- gnutls_record_send
- (*m_session->m_gnutlsSession,
-diff --git a/src/platforms/posix/posixSocket.cpp b/src/platforms/posix/posixSocket.cpp
-index 6740995..807ec47 100644
---- a/src/platforms/posix/posixSocket.cpp
-+++ b/src/platforms/posix/posixSocket.cpp
-@@ -217,6 +217,12 @@ void posixSocket::disconnect()
- }
-
-
-+posixSocket::size_type posixSocket::getBlockSize() const
-+{
-+ return 16384; // 16 KB
-+}
-+
-+
- void posixSocket::receive(vmime::string& buffer)
- {
- const int size = receiveRaw(m_buffer, sizeof(m_buffer));
-@@ -224,7 +230,7 @@ void posixSocket::receive(vmime::string& buffer)
- }
-
-
--int posixSocket::receiveRaw(char* buffer, const int count)
-+posixSocket::size_type posixSocket::receiveRaw(char* buffer, const size_type count)
- {
- const int ret = ::recv(m_desc, buffer, count, 0);
-
-@@ -252,9 +258,9 @@ void posixSocket::send(const vmime::string& buffer)
- }
-
-
--void posixSocket::sendRaw(const char* buffer, const int count)
-+void posixSocket::sendRaw(const char* buffer, const size_type count)
- {
-- int size = count;
-+ size_type size = count;
-
- while (size > 0)
- {
-diff --git a/src/platforms/windows/windowsSocket.cpp b/src/platforms/windows/windowsSocket.cpp
-index 8a42583..3ff9ad5 100644
---- a/src/platforms/windows/windowsSocket.cpp
-+++ b/src/platforms/windows/windowsSocket.cpp
-@@ -121,6 +121,12 @@ void windowsSocket::disconnect()
- }
-
-
-+windowsSocket::size_type windowsSocket::getBlockSize() const
-+{
-+ return 16384; // 16 KB
-+}
-+
-+
- void windowsSocket::receive(vmime::string& buffer)
- {
- int ret = ::recv(m_desc, m_buffer, sizeof(m_buffer), 0);
-@@ -137,7 +143,7 @@ void windowsSocket::receive(vmime::string& buffer)
- }
-
-
--int windowsSocket::receiveRaw(char* buffer, const int count)
-+windowsSocket::size_type windowsSocket::receiveRaw(char* buffer, const size_type count)
- {
- int ret = ::recv(m_desc, buffer, count, 0);
-
-@@ -159,7 +165,7 @@ void windowsSocket::send(const vmime::string& buffer)
- }
-
-
--void windowsSocket::sendRaw(const char* buffer, const int count)
-+void windowsSocket::sendRaw(const char* buffer, const size_type count)
- {
- ::send(m_desc, buffer, count, 0);
- }
-diff --git a/src/security/sasl/SASLSocket.cpp b/src/security/sasl/SASLSocket.cpp
-index 118429a..d88153e 100644
---- a/src/security/sasl/SASLSocket.cpp
-+++ b/src/security/sasl/SASLSocket.cpp
-@@ -69,6 +69,12 @@ bool SASLSocket::isConnected() const
- }
-
-
-+SASLSocket::size_type SASLSocket::getBlockSize() const
-+{
-+ return m_wrapped->getBlockSize();
-+}
-+
-+
- void SASLSocket::receive(string& buffer)
- {
- const int n = receiveRaw(m_recvBuffer, sizeof(m_recvBuffer));
-@@ -77,7 +83,7 @@ void SASLSocket::receive(string& buffer)
- }
-
-
--int SASLSocket::receiveRaw(char* buffer, const int count)
-+SASLSocket::size_type SASLSocket::receiveRaw(char* buffer, const size_type count)
- {
- if (m_pendingLen != 0)
- {
-@@ -141,7 +147,7 @@ void SASLSocket::send(const string& buffer)
- }
-
-
--void SASLSocket::sendRaw(const char* buffer, const int count)
-+void SASLSocket::sendRaw(const char* buffer, const size_type count)
- {
- byte_t* output = 0;
- int outputLen = 0;
-diff --git a/src/utility/stream.cpp b/src/utility/stream.cpp
-index 483784c..ec30b7d 100644
---- a/src/utility/stream.cpp
-+++ b/src/utility/stream.cpp
-@@ -470,7 +470,7 @@ void outputStreamSocketAdapter::flush()
-
- stream::size_type outputStreamSocketAdapter::getBlockSize()
- {
-- return 16384; // 16 KB
-+ return m_socket.getBlockSize();
- }
-
-
-@@ -513,7 +513,7 @@ stream::size_type inputStreamSocketAdapter::skip
-
- stream::size_type inputStreamSocketAdapter::getBlockSize()
- {
-- return 16384; // 16 KB
-+ return m_socket.getBlockSize();
- }
-
-
-diff --git a/vmime/net/imap/IMAPConnection.hpp b/vmime/net/imap/IMAPConnection.hpp
-index 147c4df..820987b 100644
---- a/vmime/net/imap/IMAPConnection.hpp
-+++ b/vmime/net/imap/IMAPConnection.hpp
-@@ -96,6 +96,8 @@ public:
- bool isSecuredConnection() const;
- ref <connectionInfos> getConnectionInfos() const;
-
-+ ref <const socket> getSocket() const;
-+
- private:
-
- void authenticate();
-diff --git a/vmime/net/socket.hpp b/vmime/net/socket.hpp
-index 9b0319c..ec6a9d3 100644
---- a/vmime/net/socket.hpp
-+++ b/vmime/net/socket.hpp
-@@ -41,6 +41,11 @@ public:
-
- virtual ~socket() { }
-
-+ /** Type used for lengths in streams.
-+ */
-+ typedef int size_type;
-+
-+
- /** Connect to the specified address and port.
- *
- * @param address server address (this can be a full qualified domain name
-@@ -71,7 +76,7 @@ public:
- * @param count maximum number of bytes to receive (size of buffer)
- * @return number of bytes received/written into output buffer
- */
-- virtual int receiveRaw(char* buffer, const int count) = 0;
-+ virtual int receiveRaw(char* buffer, const size_type count) = 0;
-
- /** Send (text) data to the socket.
- *
-@@ -84,7 +89,14 @@ public:
- * @param buffer data to send
- * @param count number of bytes to send (size of buffer)
- */
-- virtual void sendRaw(const char* buffer, const int count) = 0;
-+ virtual void sendRaw(const char* buffer, const size_type count) = 0;
-+
-+ /** Return the preferred maximum block size when reading
-+ * from or writing to this stream.
-+ *
-+ * @return block size, in bytes
-+ */
-+ virtual size_type getBlockSize() const = 0;
-
- protected:
-
-diff --git a/vmime/net/tls/TLSSocket.hpp b/vmime/net/tls/TLSSocket.hpp
-index 5112550..7c38970 100644
---- a/vmime/net/tls/TLSSocket.hpp
-+++ b/vmime/net/tls/TLSSocket.hpp
-@@ -84,10 +84,12 @@ public:
- bool isConnected() const;
-
- void receive(string& buffer);
-- int receiveRaw(char* buffer, const int count);
-+ size_type receiveRaw(char* buffer, const size_type count);
-
- void send(const string& buffer);
-- void sendRaw(const char* buffer, const int count);
-+ void sendRaw(const char* buffer, const size_type count);
-+
-+ size_type getBlockSize() const;
-
- private:
-
-diff --git a/vmime/platforms/posix/posixSocket.hpp b/vmime/platforms/posix/posixSocket.hpp
-index 0d0dae6..9cd49d4 100644
---- a/vmime/platforms/posix/posixSocket.hpp
-+++ b/vmime/platforms/posix/posixSocket.hpp
-@@ -48,10 +48,12 @@ public:
- void disconnect();
-
- void receive(vmime::string& buffer);
-- int receiveRaw(char* buffer, const int count);
-+ size_type receiveRaw(char* buffer, const size_type count);
-
- void send(const vmime::string& buffer);
-- void sendRaw(const char* buffer, const int count);
-+ void sendRaw(const char* buffer, const size_type count);
-+
-+ size_type getBlockSize() const;
-
- protected:
-
-diff --git a/vmime/platforms/windows/windowsSocket.hpp b/vmime/platforms/windows/windowsSocket.hpp
-index 61475c3..2940157 100644
---- a/vmime/platforms/windows/windowsSocket.hpp
-+++ b/vmime/platforms/windows/windowsSocket.hpp
-@@ -50,10 +50,12 @@ public:
- void disconnect();
-
- void receive(vmime::string& buffer);
-- int receiveRaw(char* buffer, const int count);
-+ size_type receiveRaw(char* buffer, const size_type count);
-
- void send(const vmime::string& buffer);
-- void sendRaw(const char* buffer, const int count);
-+ void sendRaw(const char* buffer, const size_type count);
-+
-+ size_type getBlockSize() const;
-
- private:
-
-diff --git a/vmime/security/sasl/SASLSocket.hpp b/vmime/security/sasl/SASLSocket.hpp
-index 3ff27e3..0348331 100644
---- a/vmime/security/sasl/SASLSocket.hpp
-+++ b/vmime/security/sasl/SASLSocket.hpp
-@@ -53,10 +53,12 @@ public:
- bool isConnected() const;
-
- void receive(string& buffer);
-- int receiveRaw(char* buffer, const int count);
-+ size_type receiveRaw(char* buffer, const size_type count);
-
- void send(const string& buffer);
-- void sendRaw(const char* buffer, const int count);
-+ void sendRaw(const char* buffer, const size_type count);
-+
-+ size_type getBlockSize() const;
-
- private:
-
-
-commit 4e36e8816b57fc2f8b34be327f4b67a0366b6664
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Dec 1 13:23:26 2009 +0000
-
- Fixed missing function.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@511 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/tests/testUtils.cpp b/tests/testUtils.cpp
-index 456b8ad..ee17c92 100644
---- a/tests/testUtils.cpp
-+++ b/tests/testUtils.cpp
-@@ -51,6 +51,12 @@ bool testSocket::isConnected() const
- }
-
-
-+testSocket::size_type testSocket::getBlockSize() const
-+{
-+ return 16384;
-+}
-+
-+
- void testSocket::receive(vmime::string& buffer)
- {
- buffer = m_inBuffer;
-diff --git a/tests/testUtils.hpp b/tests/testUtils.hpp
-index 96daba8..227d1b3 100644
---- a/tests/testUtils.hpp
-+++ b/tests/testUtils.hpp
-@@ -216,6 +216,8 @@ public:
- int receiveRaw(char* buffer, const int count);
- void sendRaw(const char* buffer, const int count);
-
-+ size_type getBlockSize() const;
-+
- /** Send data to client.
- *
- * @buffer data to send
-
-commit fdc04f8dfd184c980b0a34d0297c41b5831edab0
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Dec 1 13:24:38 2009 +0000
-
- Added and moved tests for RFC-2231.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@512 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/tests/parser/parameterTest.cpp b/tests/parser/parameterTest.cpp
-index fb7a429..6d24438 100644
---- a/tests/parser/parameterTest.cpp
-+++ b/tests/parser/parameterTest.cpp
-@@ -32,7 +32,9 @@ VMIME_TEST_SUITE_BEGIN
-
- VMIME_TEST_LIST_BEGIN
- VMIME_TEST(testParse)
-+ VMIME_TEST(testParseRFC2231)
- VMIME_TEST(testGenerate)
-+ VMIME_TEST(testGenerateRFC2231)
- VMIME_TEST(testNonStandardEncodedParam)
- VMIME_TEST_LIST_END
-
-@@ -134,57 +136,60 @@ VMIME_TEST_SUITE_BEGIN
- VASSERT_EQ("7.1", 1, p7.getParameterCount());
- VASSERT_EQ("7.2", "param1", PARAM_NAME(p7, 0));
- VASSERT_EQ("7.3", "this is a slash: \"\\\"", PARAM_VALUE(p7, 0));
-+ }
-
-+ void testParseRFC2231()
-+ {
- // Extended parameter with charset specified in more than one
- // section (this is forbidden by RFC, but is should not fail)
-- parameterizedHeaderField p8;
-- p8.parse("X; param1*0*=charset1'language1'value1;\r\n"
-- " param1*1*=charset2'language2'value2;");
-+ parameterizedHeaderField p1;
-+ p1.parse("X; param1*0*=charset1'language1'value1;\r\n"
-+ " param1*1*=charset2'language2'value2;");
-
-- VASSERT_EQ("8.1", 1, p8.getParameterCount());
-- VASSERT_EQ("8.2", "param1", PARAM_NAME(p8, 0));
-- VASSERT_EQ("8.3", "charset1", PARAM_CHARSET(p8, 0));
-- VASSERT_EQ("8.4", "value1charset2'language2'value2", PARAM_BUFFER(p8, 0));
-+ VASSERT_EQ("1.1", 1, p1.getParameterCount());
-+ VASSERT_EQ("1.2", "param1", PARAM_NAME(p1, 0));
-+ VASSERT_EQ("1.3", "charset1", PARAM_CHARSET(p1, 0));
-+ VASSERT_EQ("1.4", "value1charset2'language2'value2", PARAM_BUFFER(p1, 0));
-
- // Charset not specified in the first section (that is not encoded),
- // but specified in the second one (legal)
-- parameterizedHeaderField p9;
-- p9.parse("X; param1*0=value1;\r\n"
-- " param1*1*=charset'language'value2;");
-+ parameterizedHeaderField p2;
-+ p2.parse("X; param1*0=value1;\r\n"
-+ " param1*1*=charset'language'value2;");
-
-- VASSERT_EQ("9.1", 1, p9.getParameterCount());
-- VASSERT_EQ("9.2", "param1", PARAM_NAME(p9, 0));
-- VASSERT_EQ("9.3", "charset", PARAM_CHARSET(p9, 0));
-- VASSERT_EQ("9.4", "value1value2", PARAM_BUFFER(p9, 0));
-+ VASSERT_EQ("2.1", 1, p2.getParameterCount());
-+ VASSERT_EQ("2.2", "param1", PARAM_NAME(p2, 0));
-+ VASSERT_EQ("2.3", "charset", PARAM_CHARSET(p2, 0));
-+ VASSERT_EQ("2.4", "value1value2", PARAM_BUFFER(p2, 0));
-
- // Characters prefixed with '%' in a simple (not extended) section
- // should not be decoded
-- parameterizedHeaderField p10;
-- p10.parse("X; param1=val%20ue1");
-+ parameterizedHeaderField p3;
-+ p3.parse("X; param1=val%20ue1");
-
-- VASSERT_EQ("10.1", 1, p10.getParameterCount());
-- VASSERT_EQ("10.2", "param1", PARAM_NAME(p10, 0));
-- VASSERT_EQ("10.3", "val%20ue1", PARAM_VALUE(p10, 0));
-+ VASSERT_EQ("3.1", 1, p3.getParameterCount());
-+ VASSERT_EQ("3.2", "param1", PARAM_NAME(p3, 0));
-+ VASSERT_EQ("3.3", "val%20ue1", PARAM_VALUE(p3, 0));
-
- // Multiple sections + charset specified and encoding
-- parameterizedHeaderField p11;
-- p11.parse("X; param1*0*=charset'language'value1a%20;"
-- " param1*1*=value1b%20;"
-- " param1*2=value1c");
-+ parameterizedHeaderField p4;
-+ p4.parse("X; param1*0*=charset'language'value1a%20;"
-+ " param1*1*=value1b%20;"
-+ " param1*2=value1c");
-
-- VASSERT_EQ("11.1", 1, p11.getParameterCount());
-- VASSERT_EQ("11.2", "param1", PARAM_NAME(p11, 0));
-- VASSERT_EQ("11.3", "charset", PARAM_CHARSET(p11, 0));
-- VASSERT_EQ("11.4", "value1a value1b value1c", PARAM_BUFFER(p11, 0));
-+ VASSERT_EQ("4.1", 1, p4.getParameterCount());
-+ VASSERT_EQ("4.2", "param1", PARAM_NAME(p4, 0));
-+ VASSERT_EQ("4.3", "charset", PARAM_CHARSET(p4, 0));
-+ VASSERT_EQ("4.4", "value1a value1b value1c", PARAM_BUFFER(p4, 0));
-
- // No charset specified: defaults to US-ASCII
-- parameterizedHeaderField p12;
-- p12.parse("X; param1*='language'value1");
-+ parameterizedHeaderField p5;
-+ p5.parse("X; param1*='language'value1");
-
-- VASSERT_EQ("12.1", 1, p12.getParameterCount());
-- VASSERT_EQ("12.2", "param1", PARAM_NAME(p12, 0));
-- VASSERT_EQ("12.3", "us-ascii", PARAM_CHARSET(p12, 0));
-- VASSERT_EQ("12.4", "value1", PARAM_BUFFER(p12, 0));
-+ VASSERT_EQ("5.1", 1, p5.getParameterCount());
-+ VASSERT_EQ("5.2", "param1", PARAM_NAME(p5, 0));
-+ VASSERT_EQ("5.3", "us-ascii", PARAM_CHARSET(p5, 0));
-+ VASSERT_EQ("5.4", "value1", PARAM_BUFFER(p5, 0));
- }
-
- void testGenerate()
-@@ -206,21 +211,24 @@ VMIME_TEST_SUITE_BEGIN
- p2b.appendParameter(vmime::create <vmime::parameter>("param1", "va\\lue\"1"));
-
- VASSERT_EQ("2b", "F: X; param1=\"va\\\\lue\\\"1\"", p2b.generate());
-+ }
-
-+ void testGenerateRFC2231()
-+ {
- // Extended parameter with charset specifier
-- parameterizedHeaderField p3;
-- p3.appendParameter(vmime::create <vmime::parameter>("param1",
-+ parameterizedHeaderField p1;
-+ p1.appendParameter(vmime::create <vmime::parameter>("param1",
- vmime::word("value 1\xe9", vmime::charset("charset"))));
-
-- VASSERT_EQ("3", "F: X; param1=\"value 1\";param1*=charset''value%201%E9", p3.generate());
-+ VASSERT_EQ("1", "F: X; param1=\"value 1\";param1*=charset''value%201%E9", p1.generate());
-
- // Value that spans on multiple lines
-- parameterizedHeaderField p4;
-- p4.appendParameter(vmime::create <vmime::parameter>("param1",
-+ parameterizedHeaderField p2;
-+ p2.appendParameter(vmime::create <vmime::parameter>("param1",
- vmime::word("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ",
- vmime::charset("charset"))));
-
-- VASSERT_EQ("4", "F: X; \r\n "
-+ VASSERT_EQ("2", "F: X; \r\n "
- "param1=abcdefghijklm;\r\n "
- "param1*0*=charset''abc;\r\n "
- "param1*1*=defghijkl;\r\n "
-@@ -228,7 +236,23 @@ VMIME_TEST_SUITE_BEGIN
- "param1*3*=vwxyzABCD;\r\n "
- "param1*4*=EFGHIJKLM;\r\n "
- "param1*5*=NOPQRSTUV;\r\n "
-- "param1*6*=WXYZ", p4.generate(25)); // max line length = 25
-+ "param1*6*=WXYZ", p2.generate(25)); // max line length = 25
-+
-+ // Non-ASCII parameter value
-+ parameterizedHeaderField p3;
-+ p3.appendParameter(vmime::create <vmime::parameter>("param1",
-+ vmime::word("δσσσσσσσσσσσσσσσσσσσσδσδα δσαδσδσαδσαδασδασ δσαδασδσα δσαδασδσα δασδασδασ δασαχφδδσα 2008.doc",
-+ vmime::charset("utf-8"))));
-+
-+ VASSERT_EQ("3", "F: X; \r\n "
-+ "param1=\" 2008.doc\";param1*0*=utf-8''%CE%B4%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83;\r\n "
-+ "param1*1*=%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83;\r\n "
-+ "param1*2*=%CE%B4%CF%83%CE%B4%CE%B1%20%CE%B4%CF%83%CE%B1%CE%B4%CF%83%CE%B4%CF;\r\n "
-+ "param1*3*=%83%CE%B1%CE%B4%CF%83%CE%B1%CE%B4%CE%B1%CF%83%CE%B4%CE%B1%CF%83%20;\r\n "
-+ "param1*4*=%CE%B4%CF%83%CE%B1%CE%B4%CE%B1%CF%83%CE%B4%CF%83%CE%B1%20%CE%B4%CF;\r\n "
-+ "param1*5*=%83%CE%B1%CE%B4%CE%B1%CF%83%CE%B4%CF%83%CE%B1%20%CE%B4%CE%B1%CF%83;\r\n "
-+ "param1*6*=%CE%B4%CE%B1%CF%83%CE%B4%CE%B1%CF%83%20%CE%B4%CE%B1%CF%83%CE%B1%CF;\r\n "
-+ "param1*7*=%87%CF%86%CE%B4%CE%B4%CF%83%CE%B1%202008.doc", p3.generate(80));
- }
-
- void testNonStandardEncodedParam()
-
-commit 6687ee18d8364bb3c5da17199abf55213d2fc665
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Dec 1 13:44:34 2009 +0000
-
- Added option to return ISO week-numbering instead of default calendar-numbering.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@513 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/utility/datetimeUtils.cpp b/src/utility/datetimeUtils.cpp
-index cf05a93..6ea5be6 100644
---- a/src/utility/datetimeUtils.cpp
-+++ b/src/utility/datetimeUtils.cpp
-@@ -256,7 +256,7 @@ int datetimeUtils::getDayOfWeek(const int year, const int month, const int day)
- }
-
-
--int datetimeUtils::getWeekOfYear(const int year, const int month, const int day)
-+int datetimeUtils::getWeekOfYear(const int year, const int month, const int day, const bool iso)
- {
- // Algorithm from http://personal.ecu.edu/mccartyr/ISOwdALG.txt
-
-@@ -322,7 +322,7 @@ int datetimeUtils::getWeekOfYear(const int year, const int month, const int day)
- WeekNumber -= 1;
- }
-
-- if (WeekNumber == 1 && month == 12)
-+ if (!iso && (WeekNumber == 1 && month == 12))
- WeekNumber = 53;
-
- return WeekNumber;
-diff --git a/tests/utility/datetimeUtilsTest.cpp b/tests/utility/datetimeUtilsTest.cpp
-index 4fd3e43..4671e75 100644
---- a/tests/utility/datetimeUtilsTest.cpp
-+++ b/tests/utility/datetimeUtilsTest.cpp
-@@ -143,10 +143,11 @@ VMIME_TEST_SUITE_BEGIN
- {
- VASSERT_EQ("1.1", 52, datetimeUtils::getWeekOfYear(2003, 12, 27));
- VASSERT_EQ("1.2", 52, datetimeUtils::getWeekOfYear(2003, 12, 28));
-- VASSERT_EQ("1.3", 1, datetimeUtils::getWeekOfYear(2003, 12, 29));
-- VASSERT_EQ("1.4", 1, datetimeUtils::getWeekOfYear(2004, 1, 4));
-- VASSERT_EQ("1.5", 2, datetimeUtils::getWeekOfYear(2004, 1, 5));
-- VASSERT_EQ("1.6", 2, datetimeUtils::getWeekOfYear(2004, 1, 11));
-+ VASSERT_EQ("1.3", 1, datetimeUtils::getWeekOfYear(2003, 12, 29, true));
-+ VASSERT_EQ("1.4", 53, datetimeUtils::getWeekOfYear(2003, 12, 29, false));
-+ VASSERT_EQ("1.5", 1, datetimeUtils::getWeekOfYear(2004, 1, 4));
-+ VASSERT_EQ("1.6", 2, datetimeUtils::getWeekOfYear(2004, 1, 5));
-+ VASSERT_EQ("1.7", 2, datetimeUtils::getWeekOfYear(2004, 1, 11));
-
- VASSERT_EQ("2.1", 52, datetimeUtils::getWeekOfYear(2004, 12, 26));
- VASSERT_EQ("2.2", 53, datetimeUtils::getWeekOfYear(2004, 12, 27));
-diff --git a/vmime/utility/datetimeUtils.hpp b/vmime/utility/datetimeUtils.hpp
-index b56533c..d5f89be 100644
---- a/vmime/utility/datetimeUtils.hpp
-+++ b/vmime/utility/datetimeUtils.hpp
-@@ -84,9 +84,11 @@ public:
- * @param year year in 4-digit format
- * @param month month (1-12), January is 1, December is 12 (see datetime::Months enum)
- * @param day month day (1-31)
-+ * @param iso if TRUE, use ISO week-numbering year (default is to use calendar year).
-+ * For more information, read here: http://en.wikipedia.org/wiki/ISO_8601#Week_dates
- * @return the week number (1 is the first week of the year)
- */
-- static int getWeekOfYear(const int year, const int month, const int day);
-+ static int getWeekOfYear(const int year, const int month, const int day, const bool iso = false);
- };
-
-
-
-commit 3b5ccb4334651cc9ba9b99259d44dc9e47d8e22a
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Dec 1 14:24:55 2009 +0000
-
- Fixed directory renaming.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@514 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/platforms/posix/posixFile.cpp b/src/platforms/posix/posixFile.cpp
-index 7ee9f19..b814b75 100644
---- a/src/platforms/posix/posixFile.cpp
-+++ b/src/platforms/posix/posixFile.cpp
-@@ -396,7 +396,11 @@ void posixFile::rename(const path& newName)
- const vmime::string newNativePath = posixFileSystemFactory::pathToStringImpl(newName);
-
- posixFile dest(newName);
-- dest.createFile();
-+
-+ if (isDirectory())
-+ dest.createDirectory();
-+ else
-+ dest.createFile();
-
- if (::rename(m_nativePath.c_str(), newNativePath.c_str()) == -1)
- posixFileSystemFactory::reportError(m_path, errno);
-diff --git a/tests/net/maildir/maildirStoreTest.cpp b/tests/net/maildir/maildirStoreTest.cpp
-index 5aad90b..5f8c703 100644
---- a/tests/net/maildir/maildirStoreTest.cpp
-+++ b/tests/net/maildir/maildirStoreTest.cpp
-@@ -322,12 +322,28 @@ public:
-
- void testRenameFolder_KMail()
- {
-- testRenameFolderImpl(TEST_MAILDIR_KMAIL, TEST_MAILDIRFILES_KMAIL);
-+ try
-+ {
-+ testRenameFolderImpl(TEST_MAILDIR_KMAIL, TEST_MAILDIRFILES_KMAIL);
-+ }
-+ catch (vmime::exception& e)
-+ {
-+ std::cerr << e;
-+ throw e;
-+ }
- }
-
- void testRenameFolder_Courier()
- {
-- testRenameFolderImpl(TEST_MAILDIR_COURIER, TEST_MAILDIRFILES_COURIER);
-+ try
-+ {
-+ testRenameFolderImpl(TEST_MAILDIR_COURIER, TEST_MAILDIRFILES_COURIER);
-+ }
-+ catch (vmime::exception& e)
-+ {
-+ std::cerr << e;
-+ throw e;
-+ }
- }
-
- void testRenameFolderImpl(const vmime::string* const dirs, const vmime::string* const files)
-diff --git a/tests/testUtils.cpp b/tests/testUtils.cpp
-index ee17c92..36455cf 100644
---- a/tests/testUtils.cpp
-+++ b/tests/testUtils.cpp
-@@ -187,3 +187,61 @@ vmime::ref <vmime::net::timeoutHandler> testTimeoutHandlerFactory::create()
- return vmime::create <testTimeoutHandler>();
- }
-
-+
-+
-+// Exception helper
-+std::ostream& operator<<(std::ostream& os, const vmime::exception& e)
-+{
-+ os << "* vmime::exceptions::" << e.name() << std::endl;
-+ os << " what = " << e.what() << std::endl;
-+
-+ // More information for special exceptions
-+ if (dynamic_cast <const vmime::exceptions::command_error*>(&e))
-+ {
-+ const vmime::exceptions::command_error& cee =
-+ dynamic_cast <const vmime::exceptions::command_error&>(e);
-+
-+ os << " command = " << cee.command() << std::endl;
-+ os << " response = " << cee.response() << std::endl;
-+ }
-+
-+ if (dynamic_cast <const vmime::exceptions::invalid_response*>(&e))
-+ {
-+ const vmime::exceptions::invalid_response& ir =
-+ dynamic_cast <const vmime::exceptions::invalid_response&>(e);
-+
-+ os << " response = " << ir.response() << std::endl;
-+ }
-+
-+ if (dynamic_cast <const vmime::exceptions::connection_greeting_error*>(&e))
-+ {
-+ const vmime::exceptions::connection_greeting_error& cgee =
-+ dynamic_cast <const vmime::exceptions::connection_greeting_error&>(e);
-+
-+ os << " response = " << cgee.response() << std::endl;
-+ }
-+
-+ if (dynamic_cast <const vmime::exceptions::authentication_error*>(&e))
-+ {
-+ const vmime::exceptions::authentication_error& aee =
-+ dynamic_cast <const vmime::exceptions::authentication_error&>(e);
-+
-+ os << " response = " << aee.response() << std::endl;
-+ }
-+
-+ if (dynamic_cast <const vmime::exceptions::filesystem_exception*>(&e))
-+ {
-+ const vmime::exceptions::filesystem_exception& fse =
-+ dynamic_cast <const vmime::exceptions::filesystem_exception&>(e);
-+
-+ os << " path = " << vmime::platform::getHandler()->
-+ getFileSystemFactory()->pathToString(fse.path()) << std::endl;
-+ }
-+
-+ if (e.other() != NULL)
-+ os << *e.other();
-+
-+ return os;
-+}
-+
-+
-diff --git a/tests/testUtils.hpp b/tests/testUtils.hpp
-index 227d1b3..9aee153 100644
---- a/tests/testUtils.hpp
-+++ b/tests/testUtils.hpp
-@@ -305,3 +305,7 @@ public:
- vmime::ref <vmime::net::timeoutHandler> create();
- };
-
-+
-+// Exception helper
-+std::ostream& operator<<(std::ostream& os, const vmime::exception& e);
-+
-
-commit 75b25e29e28fd00ae2e92c28baed98f62838e119
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Dec 2 11:49:00 2009 +0000
-
- Fixed compilation issue with Intel Compiler (thanks to Eric Trinh for report).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@515 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/vmime/propertySet.hpp b/vmime/propertySet.hpp
-index e5cbf1f..e5e91dd 100644
---- a/vmime/propertySet.hpp
-+++ b/vmime/propertySet.hpp
-@@ -432,7 +432,7 @@ public:
-
- #ifndef VMIME_INLINE_TEMPLATE_SPECIALIZATION
-
--template <> void propertySet::property::setValue(const string& value);
-+template <> void propertySet::property::setValue <string>(const string& value);
- template <> void propertySet::property::setValue(const bool& value);
-
- template <> string propertySet::property::getValue() const;
-
-commit e46c5fc23527db2409e872020f0e007f98e13c2d
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Dec 8 09:31:06 2009 +0000
-
- Initialize multi-threading for GNUTLS/GCrypt (thanks to Bartek Szurgot).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@516 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/net/tls/TLSSession.cpp b/src/net/tls/TLSSession.cpp
-index 1146d1b..d4eab3e 100644
---- a/src/net/tls/TLSSession.cpp
-+++ b/src/net/tls/TLSSession.cpp
-@@ -24,6 +24,13 @@
- #include <gnutls/gnutls.h>
- #include <gnutls/extra.h>
-
-+#include "vmime/config.hpp"
-+
-+#if VMIME_HAVE_PTHREAD
-+# include <gcrypt.h>
-+# include <errno.h>
-+#endif // VMIME_HAVE_PTHREAD
-+
- #include "vmime/net/tls/TLSSession.hpp"
-
- #include "vmime/exception.hpp"
-@@ -38,6 +45,14 @@
- #endif // VMIME_DEBUG && GNUTLS_DEBUG
-
-
-+#if VMIME_HAVE_PTHREAD && defined(GCRY_THREAD_OPTION_PTHREAD_IMPL)
-+extern "C"
-+{
-+ GCRY_THREAD_OPTION_PTHREAD_IMPL;
-+}
-+#endif // VMIME_HAVE_PTHREAD && defined(GCRY_THREAD_OPTION_PTHREAD_IMPL
-+
-+
- namespace vmime {
- namespace net {
- namespace tls {
-@@ -50,6 +65,10 @@ struct TLSGlobal
- {
- TLSGlobal()
- {
-+#if VMIME_HAVE_PTHREAD && defined(GCRY_THREAD_OPTION_PTHREAD_IMPL)
-+ gcry_control(GCRYCTL_SET_THREAD_CBS, &gcry_threads_pthread);
-+#endif // VMIME_HAVE_PTHREAD && defined(GCRY_THREAD_OPTION_PTHREAD_IMPL
-+
- gnutls_global_init();
- //gnutls_global_init_extra();
-
-
-commit 9e4d59d30924211495daf8c96fa8bb94537a9447
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Dec 8 10:03:34 2009 +0000
-
- Fixed not exception-safe constructor, which could lead to possible memory leak (thanks to Bartek Szurgot). Get rid of const-ness on factories.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@517 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/AUTHORS b/AUTHORS
-index 8391c18..f0b5e2d 100644
---- a/AUTHORS
-+++ b/AUTHORS
-@@ -19,6 +19,7 @@ VMIME CONTRIBUTORS
- - Georg Sauthoff <gsauthof@techfak.uni-bielefeld.de>
- - Pierre Thierry <nowhere.man@levallois.eu.org> (patches for STL algorithms)
- - Zarafa <http://developer.zarafa.com/VmimePatches>
-+ - Bartek Szurgot <vempirelord@wp.pl, http://baszerr.org>
-
- Please apologize if I have forgotten someone here. ;)
- See SVN Changelog for full list.
-diff --git a/src/net/maildir/format/courierMaildirFormat.cpp b/src/net/maildir/format/courierMaildirFormat.cpp
-index 6dbda80..721517e 100644
---- a/src/net/maildir/format/courierMaildirFormat.cpp
-+++ b/src/net/maildir/format/courierMaildirFormat.cpp
-@@ -49,7 +49,7 @@ const string courierMaildirFormat::getName() const
-
- void courierMaildirFormat::createFolder(const folder::path& path)
- {
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- if (!fsf->isValidPath(folderPathToFileSystemPath(path, ROOT_DIRECTORY)))
- throw exceptions::invalid_folder_name();
-@@ -80,7 +80,7 @@ void courierMaildirFormat::createFolder(const folder::path& path)
-
- void courierMaildirFormat::destroyFolder(const folder::path& path)
- {
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- // Recursively delete directories of subfolders
- const std::vector <folder::path> folders = listFolders(path, true);
-@@ -119,7 +119,7 @@ void courierMaildirFormat::renameFolder
- void courierMaildirFormat::renameFolderImpl
- (const folder::path& oldPath, const folder::path& newPath)
- {
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- const utility::file::path oldFSPath =
- folderPathToFileSystemPath(oldPath, ROOT_DIRECTORY);
-@@ -134,7 +134,7 @@ void courierMaildirFormat::renameFolderImpl
-
- bool courierMaildirFormat::folderExists(const folder::path& path) const
- {
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- ref <utility::file> rootDir = fsf->create
- (folderPathToFileSystemPath(path, ROOT_DIRECTORY));
-@@ -254,7 +254,7 @@ const std::vector <folder::path> courierMaildirFormat::listFolders
- bool courierMaildirFormat::listDirectories(const folder::path& root,
- std::vector <string>& dirs, const bool onlyTestForExistence) const
- {
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- ref <utility::file> rootDir = fsf->create
- (getContext()->getStore()->getFileSystemPath());
-@@ -496,7 +496,7 @@ const folder::path::component courierMaildirFormat::fromModifiedUTF7(const strin
-
- bool courierMaildirFormat::supports() const
- {
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- ref <utility::file> rootDir = fsf->create
- (getContext()->getStore()->getFileSystemPath());
-diff --git a/src/net/maildir/format/kmailMaildirFormat.cpp b/src/net/maildir/format/kmailMaildirFormat.cpp
-index 5fb75fe..a21d106 100644
---- a/src/net/maildir/format/kmailMaildirFormat.cpp
-+++ b/src/net/maildir/format/kmailMaildirFormat.cpp
-@@ -49,7 +49,7 @@ const string kmailMaildirFormat::getName() const
-
- void kmailMaildirFormat::createFolder(const folder::path& path)
- {
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- if (!fsf->isValidPath(folderPathToFileSystemPath(path, ROOT_DIRECTORY)))
- throw exceptions::invalid_folder_name();
-@@ -75,7 +75,7 @@ void kmailMaildirFormat::createFolder(const folder::path& path)
- void kmailMaildirFormat::destroyFolder(const folder::path& path)
- {
- // Delete 'folder' and '.folder.directory' directories
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- maildirUtils::recursiveFSDelete(fsf->create
- (folderPathToFileSystemPath(path, ROOT_DIRECTORY))); // root
-@@ -87,7 +87,7 @@ void kmailMaildirFormat::destroyFolder(const folder::path& path)
-
- bool kmailMaildirFormat::folderExists(const folder::path& path) const
- {
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- ref <utility::file> rootDir = fsf->create
- (folderPathToFileSystemPath(path, ROOT_DIRECTORY));
-@@ -177,7 +177,7 @@ const std::vector <folder::path> kmailMaildirFormat::listFolders
- void kmailMaildirFormat::listFoldersImpl
- (std::vector <folder::path>& list, const folder::path& root, const bool recursive) const
- {
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- ref <utility::file> rootDir = fsf->create(folderPathToFileSystemPath(root,
- root.isEmpty() ? ROOT_DIRECTORY : CONTAINER_DIRECTORY));
-@@ -226,7 +226,7 @@ bool kmailMaildirFormat::isSubfolderDirectory(const utility::file& file)
-
- void kmailMaildirFormat::renameFolder(const folder::path& oldPath, const folder::path& newPath)
- {
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- ref <utility::file> rootDir = fsf->create
- (folderPathToFileSystemPath(oldPath, ROOT_DIRECTORY));
-@@ -277,7 +277,7 @@ void kmailMaildirFormat::renameFolder(const folder::path& oldPath, const folder:
-
- bool kmailMaildirFormat::folderHasSubfolders(const folder::path& path) const
- {
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- ref <utility::file> rootDir = fsf->create
- (folderPathToFileSystemPath(path, CONTAINER_DIRECTORY));
-diff --git a/src/net/maildir/maildirFolder.cpp b/src/net/maildir/maildirFolder.cpp
-index 3e361ae..dd680c9 100644
---- a/src/net/maildir/maildirFolder.cpp
-+++ b/src/net/maildir/maildirFolder.cpp
-@@ -264,7 +264,7 @@ void maildirFolder::scanFolder()
- m_messageCount = 0;
- m_unreadMessageCount = 0;
-
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- utility::file::path newDirPath = store->getFormat()->folderPathToFileSystemPath
- (m_path, maildirFormat::NEW_DIRECTORY);
-@@ -760,7 +760,7 @@ void maildirFolder::setMessageFlagsImpl
- {
- ref <maildirStore> store = m_store.acquire();
-
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- utility::file::path curDirPath = store->getFormat()->
- folderPathToFileSystemPath(m_path, maildirFormat::CUR_DIRECTORY);
-@@ -832,7 +832,7 @@ void maildirFolder::addMessage(utility::inputStream& is, const int size,
- else if (m_mode == MODE_READ_ONLY)
- throw exceptions::illegal_state("Folder is read-only");
-
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- utility::file::path tmpDirPath = store->getFormat()->
- folderPathToFileSystemPath(m_path,maildirFormat::TMP_DIRECTORY);
-@@ -918,7 +918,7 @@ void maildirFolder::copyMessageImpl(const utility::file::path& tmpDirPath,
- utility::inputStream& is, const utility::stream::size_type size,
- utility::progressListener* progress)
- {
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- ref <utility::file> file = fsf->create(tmpDirPath / filename);
-
-@@ -1058,7 +1058,7 @@ void maildirFolder::copyMessagesImpl(const folder::path& dest, const std::vector
- {
- ref <maildirStore> store = m_store.acquire();
-
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- utility::file::path curDirPath = store->getFormat()->folderPathToFileSystemPath
- (m_path, maildirFormat::CUR_DIRECTORY);
-@@ -1200,7 +1200,7 @@ void maildirFolder::expunge()
- else if (m_mode == MODE_READ_ONLY)
- throw exceptions::illegal_state("Folder is read-only");
-
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- utility::file::path curDirPath = store->getFormat()->
- folderPathToFileSystemPath(m_path, maildirFormat::CUR_DIRECTORY);
-diff --git a/src/net/maildir/maildirMessage.cpp b/src/net/maildir/maildirMessage.cpp
-index ed87cdb..8999d84 100644
---- a/src/net/maildir/maildirMessage.cpp
-+++ b/src/net/maildir/maildirMessage.cpp
-@@ -346,7 +346,7 @@ void maildirMessage::extractImpl(utility::outputStream& os, utility::progressLis
- {
- ref <const maildirFolder> folder = m_folder.acquire();
-
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- const utility::file::path path = folder->getMessageFSPath(m_num);
- ref <utility::file> file = fsf->create(path);
-@@ -393,7 +393,7 @@ void maildirMessage::fetchPartHeader(ref <part> p)
-
- ref <maildirPart> mp = p.dynamicCast <maildirPart>();
-
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- const utility::file::path path = folder->getMessageFSPath(m_num);
- ref <utility::file> file = fsf->create(path);
-@@ -430,7 +430,7 @@ void maildirMessage::fetch(ref <maildirFolder> msgFolder, const int options)
- if (folder != msgFolder)
- throw exceptions::folder_not_found();
-
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- const utility::file::path path = folder->getMessageFSPath(m_num);
- ref <utility::file> file = fsf->create(path);
-diff --git a/src/net/maildir/maildirStore.cpp b/src/net/maildir/maildirStore.cpp
-index 3b77024..26f4593 100644
---- a/src/net/maildir/maildirStore.cpp
-+++ b/src/net/maildir/maildirStore.cpp
-@@ -132,7 +132,7 @@ void maildirStore::connect()
- throw exceptions::already_connected();
-
- // Get root directory
-- utility::fileSystemFactory* fsf = platform::getHandler()->getFileSystemFactory();
-+ ref <utility::fileSystemFactory> fsf = platform::getHandler()->getFileSystemFactory();
-
- m_fsPath = fsf->stringToPath(GET_PROPERTY(string, PROPERTY_SERVER_ROOTPATH));
-
-diff --git a/src/platforms/posix/posixHandler.cpp b/src/platforms/posix/posixHandler.cpp
-index f43972e..104bc40 100644
---- a/src/platforms/posix/posixHandler.cpp
-+++ b/src/platforms/posix/posixHandler.cpp
-@@ -55,18 +55,14 @@ posixHandler::posixHandler()
- m_socketFactory = vmime::create <posixSocketFactory>();
- #endif
- #if VMIME_HAVE_FILESYSTEM_FEATURES
-- m_fileSysFactory = new posixFileSystemFactory();
-- m_childProcFactory = new posixChildProcessFactory();
-+ m_fileSysFactory = vmime::create <posixFileSystemFactory>();
-+ m_childProcFactory = vmime::create <posixChildProcessFactory>();
- #endif
- }
-
-
- posixHandler::~posixHandler()
- {
--#if VMIME_HAVE_FILESYSTEM_FEATURES
-- delete (m_fileSysFactory);
-- delete (m_childProcFactory);
--#endif
- }
-
-
-@@ -173,9 +169,9 @@ unsigned int posixHandler::getProcessId() const
-
- #if VMIME_HAVE_MESSAGING_FEATURES
-
--ref <vmime::net::socketFactory> posixHandler::getSocketFactory() const
-+ref <vmime::net::socketFactory> posixHandler::getSocketFactory()
- {
-- return m_socketFactory.dynamicCast <vmime::net::socketFactory>();
-+ return m_socketFactory;
- }
-
- #endif
-@@ -183,15 +179,15 @@ ref <vmime::net::socketFactory> posixHandler::getSocketFactory() const
-
- #if VMIME_HAVE_FILESYSTEM_FEATURES
-
--vmime::utility::fileSystemFactory* posixHandler::getFileSystemFactory() const
-+ref <vmime::utility::fileSystemFactory> posixHandler::getFileSystemFactory()
- {
-- return (m_fileSysFactory);
-+ return m_fileSysFactory;
- }
-
-
--vmime::utility::childProcessFactory* posixHandler::getChildProcessFactory() const
-+ref <vmime::utility::childProcessFactory> posixHandler::getChildProcessFactory()
- {
-- return (m_childProcFactory);
-+ return m_childProcFactory;
- }
-
- #endif
-diff --git a/src/platforms/windows/windowsHandler.cpp b/src/platforms/windows/windowsHandler.cpp
-index 404d3cb..1a37c83 100644
---- a/src/platforms/windows/windowsHandler.cpp
-+++ b/src/platforms/windows/windowsHandler.cpp
-@@ -49,17 +49,13 @@ windowsHandler::windowsHandler()
- m_socketFactory = vmime::create <windowsSocketFactory>();
- #endif
- #if VMIME_HAVE_FILESYSTEM_FEATURES
-- m_fileSysFactory = new windowsFileSystemFactory();
-+ m_fileSysFactory = vmime::create <windowsFileSystemFactory>();
- #endif
- }
-
-
- windowsHandler::~windowsHandler()
- {
--#if VMIME_HAVE_FILESYSTEM_FEATURES
-- delete (m_fileSysFactory);
--#endif
--
- WSACleanup();
- }
-
-@@ -240,9 +236,9 @@ unsigned int windowsHandler::getProcessId() const
-
- #if VMIME_HAVE_MESSAGING_FEATURES
-
--ref <vmime::net::socketFactory> windowsHandler::getSocketFactory() const
-+ref <vmime::net::socketFactory> windowsHandler::getSocketFactory()
- {
-- return m_socketFactory.dynamicCast <vmime::net::socketFactory>();
-+ return m_socketFactory;
- }
-
- #endif
-@@ -250,13 +246,13 @@ ref <vmime::net::socketFactory> windowsHandler::getSocketFactory() const
-
- #if VMIME_HAVE_FILESYSTEM_FEATURES
-
--vmime::utility::fileSystemFactory* windowsHandler::getFileSystemFactory() const
-+ref <vmime::utility::fileSystemFactory> windowsHandler::getFileSystemFactory()
- {
-- return (m_fileSysFactory);
-+ return m_fileSysFactory;
- }
-
-
--vmime::utility::childProcessFactory* windowsHandler::getChildProcessFactory() const
-+ref <vmime::utility::childProcessFactory> windowsHandler::getChildProcessFactory()
- {
- // TODO: Not implemented
- return (NULL);
-diff --git a/tests/net/maildir/maildirStoreTest.cpp b/tests/net/maildir/maildirStoreTest.cpp
-index 5f8c703..3b1980e 100644
---- a/tests/net/maildir/maildirStoreTest.cpp
-+++ b/tests/net/maildir/maildirStoreTest.cpp
-@@ -501,7 +501,7 @@ private:
-
- const vmime::utility::url getStoreURL()
- {
-- vmime::utility::fileSystemFactory* fsf =
-+ vmime::ref <vmime::utility::fileSystemFactory> fsf =
- vmime::platform::getHandler()->getFileSystemFactory();
-
- vmime::utility::url url(std::string("maildir://localhost")
-@@ -512,7 +512,7 @@ private:
-
- void createMaildir(const vmime::string* const dirs, const vmime::string* const files)
- {
-- vmime::utility::fileSystemFactory* fsf =
-+ vmime::ref <vmime::utility::fileSystemFactory> fsf =
- vmime::platform::getHandler()->getFileSystemFactory();
-
- vmime::ref <vmime::utility::file> rootDir = fsf->create(m_tempPath);
-@@ -544,7 +544,7 @@ private:
-
- void destroyMaildir()
- {
-- vmime::utility::fileSystemFactory* fsf =
-+ vmime::ref <vmime::utility::fileSystemFactory> fsf =
- vmime::platform::getHandler()->getFileSystemFactory();
-
- recursiveDelete(fsf->create(m_tempPath));
-diff --git a/vmime/platform.hpp b/vmime/platform.hpp
-index d390571..0281554 100644
---- a/vmime/platform.hpp
-+++ b/vmime/platform.hpp
-@@ -108,7 +108,7 @@ public:
- *
- * @return socket factory
- */
-- virtual ref <net::socketFactory> getSocketFactory() const = 0;
-+ virtual ref <net::socketFactory> getSocketFactory() = 0;
- #endif
-
- #if VMIME_HAVE_FILESYSTEM_FEATURES
-@@ -116,14 +116,14 @@ public:
- *
- * @return file-system factory
- */
-- virtual utility::fileSystemFactory* getFileSystemFactory() const = 0;
-+ virtual ref <utility::fileSystemFactory> getFileSystemFactory() = 0;
-
- /** Return a pointer to a factory that creates child process objects,
- * which are used to spawn processes (run executable files).
- *
- * @return child process factory
- */
-- virtual utility::childProcessFactory* getChildProcessFactory() const = 0;
-+ virtual ref <utility::childProcessFactory> getChildProcessFactory() = 0;
- #endif
-
- };
-@@ -135,7 +135,7 @@ public:
- sm_handler = vmime::create <TYPE>();
- }
-
-- static ref <const handler> getHandler()
-+ static ref <handler> getHandler()
- {
- if (!sm_handler)
- throw exceptions::no_platform_handler();
-diff --git a/vmime/platforms/posix/posixHandler.hpp b/vmime/platforms/posix/posixHandler.hpp
-index 397a5dd..8e572a2 100644
---- a/vmime/platforms/posix/posixHandler.hpp
-+++ b/vmime/platforms/posix/posixHandler.hpp
-@@ -61,13 +61,13 @@ public:
- unsigned int getProcessId() const;
-
- #if VMIME_HAVE_MESSAGING_FEATURES
-- ref <vmime::net::socketFactory> getSocketFactory() const;
-+ ref <vmime::net::socketFactory> getSocketFactory();
- #endif
-
- #if VMIME_HAVE_FILESYSTEM_FEATURES
-- vmime::utility::fileSystemFactory* getFileSystemFactory() const;
-+ ref <vmime::utility::fileSystemFactory> getFileSystemFactory();
-
-- vmime::utility::childProcessFactory* getChildProcessFactory() const;
-+ ref <vmime::utility::childProcessFactory> getChildProcessFactory();
- #endif
-
- void wait() const;
-@@ -79,8 +79,8 @@ private:
- #endif
-
- #if VMIME_HAVE_FILESYSTEM_FEATURES
-- posixFileSystemFactory* m_fileSysFactory;
-- posixChildProcessFactory* m_childProcFactory;
-+ ref <posixFileSystemFactory> m_fileSysFactory;
-+ ref <posixChildProcessFactory> m_childProcFactory;
- #endif
- };
-
-diff --git a/vmime/platforms/windows/windowsHandler.hpp b/vmime/platforms/windows/windowsHandler.hpp
-index 701edf0..53df363 100644
---- a/vmime/platforms/windows/windowsHandler.hpp
-+++ b/vmime/platforms/windows/windowsHandler.hpp
-@@ -60,13 +60,13 @@ public:
- unsigned int getProcessId() const;
-
- #if VMIME_HAVE_MESSAGING_FEATURES
-- ref <vmime::net::socketFactory> getSocketFactory() const;
-+ ref <vmime::net::socketFactory> getSocketFactory();
- #endif
-
- #if VMIME_HAVE_FILESYSTEM_FEATURES
-- vmime::utility::fileSystemFactory* getFileSystemFactory() const;
-+ ref <vmime::utility::fileSystemFactory> getFileSystemFactory();
-
-- vmime::utility::childProcessFactory* getChildProcessFactory() const;
-+ ref <vmime::utility::childProcessFactory> getChildProcessFactory();
- #endif
-
- void wait() const;
-@@ -78,7 +78,7 @@ private:
- #endif
-
- #if VMIME_HAVE_FILESYSTEM_FEATURES
-- windowsFileSystemFactory* m_fileSysFactory;
-+ ref <windowsFileSystemFactory> m_fileSysFactory;
- #endif
- };
-
-diff --git a/vmime/utility/childProcess.hpp b/vmime/utility/childProcess.hpp
-index 33cb633..b5405f7 100644
---- a/vmime/utility/childProcess.hpp
-+++ b/vmime/utility/childProcess.hpp
-@@ -85,7 +85,7 @@ public:
- /** Create 'childProcess' objects.
- */
-
--class childProcessFactory
-+class childProcessFactory : public object
- {
- public:
-
-diff --git a/vmime/utility/file.hpp b/vmime/utility/file.hpp
-index 61ede80..f1d877e 100644
---- a/vmime/utility/file.hpp
-+++ b/vmime/utility/file.hpp
-@@ -214,7 +214,7 @@ private:
- /** Constructs 'file' objects.
- */
-
--class fileSystemFactory
-+class fileSystemFactory : public object
- {
- public:
-
-
-commit e2f7eb2eef7de7fd926e1d80e2a108869a839ec4
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Dec 8 10:21:33 2009 +0000
-
- Fixed non thread-safe getLocalCharset() function (thanks to Bartek Szurgot).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@518 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/platforms/posix/posixHandler.cpp b/src/platforms/posix/posixHandler.cpp
-index 104bc40..2c11307 100644
---- a/src/platforms/posix/posixHandler.cpp
-+++ b/src/platforms/posix/posixHandler.cpp
-@@ -36,6 +36,11 @@
- #include <netdb.h>
-
- #include <string.h>
-+#include <cassert>
-+
-+#if VMIME_HAVE_PTHREAD
-+# include <pthread.h>
-+#endif // VMIME_HAVE_PTHREAD
-
- /*
- #ifdef _POSIX_PRIORITY_SCHEDULING
-@@ -44,6 +49,43 @@
- */
-
-
-+#if VMIME_HAVE_PTHREAD
-+
-+namespace
-+{
-+ // This construction ensures mutex will be initialized in compile-time
-+ // and will be available any time in the runtime.
-+ pthread_mutex_t g_mutex = PTHREAD_MUTEX_INITIALIZER;
-+
-+ // Helper lock, to be exception safe all the time.
-+ class PLockHelper
-+ {
-+ public:
-+
-+ PLockHelper()
-+ {
-+ if (pthread_mutex_lock(&g_mutex) != 0)
-+ assert(!"unable to lock mutex - thread safety's void");
-+ }
-+
-+ ~PLockHelper()
-+ {
-+ if (pthread_mutex_unlock(&g_mutex) != 0)
-+ assert(!"unable to unlock mutex - application's dead...");
-+ }
-+
-+ private:
-+
-+ // Object cannot be copied
-+ PLockHelper(const PLockHelper&);
-+ const PLockHelper& operator=(const PLockHelper&);
-+ };
-+
-+} // unnamed namespace
-+
-+#endif // VMIME_HAVE_PTHREAD
-+
-+
- namespace vmime {
- namespace platforms {
- namespace posix {
-@@ -109,6 +151,8 @@ const vmime::datetime posixHandler::getCurrentLocalTime() const
-
- const vmime::charset posixHandler::getLocaleCharset() const
- {
-+ const PLockHelper lock;
-+
- const char* prevLocale = ::setlocale(LC_ALL, "");
- vmime::charset ch(::nl_langinfo(CODESET));
- ::setlocale(LC_ALL, prevLocale);
-
-commit d2f72cddc908788a539810ff428dbcc123be1dd3
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sun Dec 13 12:50:36 2009 +0000
-
- Makes 'To' optional, like 'Cc' and 'Bcc'. An exception is still thrown if there are no recipients at all (see bug #2912670).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@519 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/messageBuilder.cpp b/src/messageBuilder.cpp
-index a70372f..870d59e 100644
---- a/src/messageBuilder.cpp
-+++ b/src/messageBuilder.cpp
-@@ -54,11 +54,17 @@ ref <message> messageBuilder::construct() const
- if (m_from.isEmpty())
- throw exceptions::no_expeditor();
-
-- if (m_to.isEmpty() || m_to.getAddressAt(0)->isEmpty())
-+ if ((m_to.isEmpty() || m_to.getAddressAt(0)->isEmpty()) &&
-+ (m_cc.isEmpty() || m_cc.getAddressAt(0)->isEmpty()) &&
-+ (m_bcc.isEmpty() || m_bcc.getAddressAt(0)->isEmpty()))
-+ {
- throw exceptions::no_recipient();
-+ }
-
- msg->getHeader()->From()->setValue(m_from);
-- msg->getHeader()->To()->setValue(m_to);
-+
-+ if (!m_to.isEmpty())
-+ msg->getHeader()->To()->setValue(m_to);
-
- if (!m_cc.isEmpty())
- msg->getHeader()->Cc()->setValue(m_cc);
-
-commit eefa93eba21736bf9689317c35b0fd9ea6c30e69
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Jan 20 08:42:47 2010 +0000
-
- Fixed bug #2933667: CRLF filter broken.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@520 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/utility/filteredStream.cpp b/src/utility/filteredStream.cpp
-index 619f9da..c1b01ef 100644
---- a/src/utility/filteredStream.cpp
-+++ b/src/utility/filteredStream.cpp
-@@ -231,8 +231,8 @@ void CRLFToLFFilteredOutputStream::write
-
- if (previousChar == '\r')
- {
-- if (pos != data)
-- m_stream.write(start, pos - 1 - data); // do not write \r
-+ if (pos != start)
-+ m_stream.write(start, pos - 1 - start); // do not write \r
-
- m_stream.write("\n", 1);
-
-diff --git a/tests/utility/filteredStreamTest.cpp b/tests/utility/filteredStreamTest.cpp
-index ad26e6c..a2e6f3e 100644
---- a/tests/utility/filteredStreamTest.cpp
-+++ b/tests/utility/filteredStreamTest.cpp
-@@ -175,6 +175,7 @@ VMIME_TEST_SUITE_BEGIN
- testFilteredOutputStreamHelper<FILTER>("4", "foo\nbar", "foo", "\r\nbar");
- testFilteredOutputStreamHelper<FILTER>("5", "foo\nbar", "foo", "\r", "\nbar");
- testFilteredOutputStreamHelper<FILTER>("6", "foo\nbar", "foo", "\r", "\n", "bar");
-+ testFilteredOutputStreamHelper<FILTER>("7", "foo\nba\nr", "foo\r", "\nba\r\nr");
- }
-
- // stopSequenceFilteredInputStream
-
-commit 85ad52fef45592a0c3335afc3564b3485db07657
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Mon Feb 1 13:06:06 2010 +0000
-
- Fixed bug #2927077: account for multi-byte charsets in invalid sequence output.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@521 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/charsetConverter.cpp b/src/charsetConverter.cpp
-index ec74ae5..798adf0 100644
---- a/src/charsetConverter.cpp
-+++ b/src/charsetConverter.cpp
-@@ -121,7 +121,18 @@ void charsetConverter::convert(utility::inputStream& in, utility::outputStream&
-
- // Output a special character to indicate we don't known how to
- // convert the sequence at this position
-- out.write("?", 1);
-+ const char* invalidCharIn = "?";
-+ size_t invalidCharInLen = 1;
-+
-+ char invalidCharOutBuffer[16];
-+ char* invalidCharOutPtr = invalidCharOutBuffer;
-+ size_t invalidCharOutLen = 16;
-+
-+ if (iconv(cd, ICONV_HACK(&invalidCharIn), &invalidCharInLen,
-+ &invalidCharOutPtr, &invalidCharOutLen) != static_cast <size_t>(-1))
-+ {
-+ out.write(invalidCharOutBuffer, 16 - invalidCharOutLen);
-+ }
-
- // Skip a byte and leave unconverted bytes in the input buffer
- std::copy(const_cast <char*>(inPtr + 1), inBuffer + sizeof(inBuffer), inBuffer);
-
-commit 99869c3d4c41304034667400ac6a5c3edc07146d
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Mon Feb 1 13:26:12 2010 +0000
-
- Fixed bug #2927077: account for multi-byte charsets in invalid sequence output.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@522 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/charsetConverter.cpp b/src/charsetConverter.cpp
-index 798adf0..38b9e5e 100644
---- a/src/charsetConverter.cpp
-+++ b/src/charsetConverter.cpp
-@@ -53,6 +53,27 @@ extern "C"
- }
-
-
-+
-+// Output replacement char when an invalid sequence is encountered
-+template <typename OUTPUT_CLASS, typename ICONV_DESC>
-+void outputInvalidChar(OUTPUT_CLASS& out, ICONV_DESC cd)
-+{
-+ const char* invalidCharIn = "?";
-+ size_t invalidCharInLen = 1;
-+
-+ char invalidCharOutBuffer[16];
-+ char* invalidCharOutPtr = invalidCharOutBuffer;
-+ size_t invalidCharOutLen = 16;
-+
-+ if (iconv(cd, ICONV_HACK(&invalidCharIn), &invalidCharInLen,
-+ &invalidCharOutPtr, &invalidCharOutLen) != static_cast <size_t>(-1))
-+ {
-+ out.write(invalidCharOutBuffer, 16 - invalidCharOutLen);
-+ }
-+}
-+
-+
-+
- namespace vmime
- {
-
-@@ -121,18 +142,7 @@ void charsetConverter::convert(utility::inputStream& in, utility::outputStream&
-
- // Output a special character to indicate we don't known how to
- // convert the sequence at this position
-- const char* invalidCharIn = "?";
-- size_t invalidCharInLen = 1;
--
-- char invalidCharOutBuffer[16];
-- char* invalidCharOutPtr = invalidCharOutBuffer;
-- size_t invalidCharOutLen = 16;
--
-- if (iconv(cd, ICONV_HACK(&invalidCharIn), &invalidCharInLen,
-- &invalidCharOutPtr, &invalidCharOutLen) != static_cast <size_t>(-1))
-- {
-- out.write(invalidCharOutBuffer, 16 - invalidCharOutLen);
-- }
-+ outputInvalidChar(out, cd);
-
- // Skip a byte and leave unconverted bytes in the input buffer
- std::copy(const_cast <char*>(inPtr + 1), inBuffer + sizeof(inBuffer), inBuffer);
-@@ -246,7 +256,7 @@ void charsetFilteredOutputStream::write
- // character and skip one byte in the invalid sequence.
- if (m_unconvCount >= sizeof(m_unconvBuffer))
- {
-- m_stream.write("?", 1);
-+ outputInvalidChar(m_stream, cd);
-
- std::copy(m_unconvBuffer + 1,
- m_unconvBuffer + m_unconvCount, m_unconvBuffer);
-@@ -369,7 +379,7 @@ void charsetFilteredOutputStream::flush()
- // Skip a "blocking" character
- if (inputConverted == 0)
- {
-- m_stream.write("?", 1);
-+ outputInvalidChar(m_stream, cd);
-
- offset++;
- m_unconvCount--;
-
-commit fb9a3f5572922a285284af7b88bea90e69897345
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Mon Feb 1 16:33:31 2010 +0000
-
- Fixed memory leak.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@523 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/net/maildir/maildirFormat.cpp b/src/net/maildir/maildirFormat.cpp
-index 607ed61..7844542 100644
---- a/src/net/maildir/maildirFormat.cpp
-+++ b/src/net/maildir/maildirFormat.cpp
-@@ -52,7 +52,7 @@ maildirFormat::context::context(ref <maildirStore> store)
-
- ref <maildirStore> maildirFormat::context::getStore() const
- {
-- return m_store;
-+ return m_store.acquire().constCast <maildirStore>();
- }
-
-
-diff --git a/vmime/net/maildir/maildirFormat.hpp b/vmime/net/maildir/maildirFormat.hpp
-index a47c854..0940696 100644
---- a/vmime/net/maildir/maildirFormat.hpp
-+++ b/vmime/net/maildir/maildirFormat.hpp
-@@ -55,7 +55,7 @@ public:
-
- private:
-
-- ref <maildirStore> m_store;
-+ weak_ref <maildirStore> m_store;
- };
-
-
-
-commit 66bd70eb441da32d95ec103ebc26c9b53d90d28e
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Feb 3 10:45:17 2010 +0000
-
- Removed wide-char support.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@524 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/SConstruct b/SConstruct
-index 89b58f6..33bc2a3 100644
---- a/SConstruct
-+++ b/SConstruct
-@@ -530,14 +530,6 @@ opts.AddOptions(
- defaultSendmailPath
- ),
- EnumOption(
-- 'with_wide_char_support',
-- 'Support for wide characters (rarely used, should be set to "no")',
-- 'no',
-- allowed_values = ('yes', 'no'),
-- map = { },
-- ignorecase = 1
-- ),
-- EnumOption(
- 'byte_order',
- 'Byte order (Big Endian or Little Endian)',
- sys.byteorder,
-@@ -802,12 +794,6 @@ config_hpp.write('\n')
-
- config_hpp.write('// Options\n')
-
--config_hpp.write('// -- Wide characters support\n')
--if env['with_wide_char_support'] == 'yes':
-- config_hpp.write('#define VMIME_WIDE_CHAR_SUPPORT 1\n')
--else:
-- config_hpp.write('#define VMIME_WIDE_CHAR_SUPPORT 0\n')
--
- config_hpp.write('// -- File-system support\n')
- if env['with_filesystem'] == 'yes':
- config_hpp.write('#define VMIME_HAVE_FILESYSTEM_FEATURES 1\n')
-@@ -1916,8 +1902,6 @@ typedef signed ${VMIME_TYPE_INT32} vmime_int32;
- typedef unsigned ${VMIME_TYPE_INT32} vmime_uint32;
-
- // Options
--// -- Wide characters support
--#define VMIME_WIDE_CHAR_SUPPORT 0
- // -- File-system support
- #define VMIME_HAVE_FILESYSTEM_FEATURES 1
- // -- SASL support
-@@ -2261,8 +2245,6 @@ typedef unsigned int vmime_uint32;
-
-
- // Options
--// -- Wide characters support
--#define VMIME_WIDE_CHAR_SUPPORT 0
- // -- File-system support
- #define VMIME_HAVE_FILESYSTEM_FEATURES 1
- // -- SASL support
-diff --git a/src/base.cpp b/src/base.cpp
-index 2e47ca3..b895985 100644
---- a/src/base.cpp
-+++ b/src/base.cpp
-@@ -55,12 +55,6 @@ namespace vmime
- */
- const string NULL_STRING;
-
--#if VMIME_WIDE_CHAR_SUPPORT
-- /** "Null" (empty) wide-char string.
-- */
-- const wstring NULL_WSTRING;
--#endif
--
- /** "Null" (empty) text.
- */
- const text NULL_TEXT;
-diff --git a/src/text.cpp b/src/text.cpp
-index f9ded7c..89a541a 100644
---- a/src/text.cpp
-+++ b/src/text.cpp
-@@ -91,21 +91,6 @@ void text::generate(utility::outputStream& os, const string::size_type maxLineLe
- }
-
-
--#if VMIME_WIDE_CHAR_SUPPORT
--
--const wstring text::getDecodedText() const
--{
-- wstring out;
--
-- for (std::vector <ref <word> >::const_iterator i = m_words.begin() ; i != m_words.end() ; ++i)
-- out += (*i)->getDecodedText();
--
-- return (out);
--}
--
--#endif
--
--
- void text::copyFrom(const component& other)
- {
- const text& t = dynamic_cast <const text&>(other);
-diff --git a/src/word.cpp b/src/word.cpp
-index ea8244a..4f91108 100644
---- a/src/word.cpp
-+++ b/src/word.cpp
-@@ -621,20 +621,6 @@ void word::generate(utility::outputStream& os, const string::size_type maxLineLe
- }
-
-
--#if VMIME_WIDE_CHAR_SUPPORT
--
--const wstring word::getDecodedText() const
--{
-- wstring out;
--
-- charset::decode(m_buffer, out, m_charset);
--
-- return (out);
--}
--
--#endif
--
--
- word& word::operator=(const word& w)
- {
- m_buffer = w.m_buffer;
-diff --git a/vmime/base.hpp b/vmime/base.hpp
-index ce544e1..60e637d 100644
---- a/vmime/base.hpp
-+++ b/vmime/base.hpp
-@@ -48,9 +48,6 @@ namespace vmime
-
- // "Null" strings
- extern const string NULL_STRING;
--#if VMIME_WIDE_CHAR_SUPPORT
-- extern const wstring NULL_WSTRING;
--#endif
-
- extern const text NULL_TEXT;
- extern const word NULL_WORD;
-diff --git a/vmime/text.hpp b/vmime/text.hpp
-index 9760c48..15e11ae 100644
---- a/vmime/text.hpp
-+++ b/vmime/text.hpp
-@@ -129,10 +129,6 @@ public:
- */
- const std::vector <ref <word> > getWordList();
-
-- // Decoding
--#if VMIME_WIDE_CHAR_SUPPORT
-- const wstring getDecodedText() const;
--#endif
-
- /** Return the text converted into the specified charset.
- * The encoded-words are decoded and then converted in the
-diff --git a/vmime/types.hpp b/vmime/types.hpp
-index bdf627e..d1137e1 100644
---- a/vmime/types.hpp
-+++ b/vmime/types.hpp
-@@ -36,9 +36,6 @@
- namespace vmime
- {
- typedef std::string string;
--#if VMIME_WIDE_CHAR_SUPPORT
-- typedef std::wstring wstring;
--#endif
-
- typedef unsigned short port_t;
-
-diff --git a/vmime/word.hpp b/vmime/word.hpp
-index 78a88e8..ad848ec 100644
---- a/vmime/word.hpp
-+++ b/vmime/word.hpp
-@@ -91,10 +91,6 @@ public:
- bool operator==(const word& w) const;
- bool operator!=(const word& w) const;
-
--#if VMIME_WIDE_CHAR_SUPPORT
-- const wstring getDecodedText() const;
--#endif
--
- /** Return the contained text converted to the specified charset.
- *
- * @param dest output charset
-
-commit 221ae58cc1587a78a221988398f9377417b17e25
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Feb 3 10:56:12 2010 +0000
-
- Use homemade isSpace() instead of std::ispace() for portability.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@525 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/word.cpp b/src/word.cpp
-index 4f91108..f24d631 100644
---- a/src/word.cpp
-+++ b/src/word.cpp
-@@ -475,7 +475,7 @@ void word::generate(utility::outputStream& os, const string::size_type maxLineLe
-
- os << string(curLineStart, lastWSpos);
-
-- if (lastWSpos > curLineStart && std::isspace(*(lastWSpos - 1)))
-+ if (lastWSpos > curLineStart && parserHelpers::isSpace(*(lastWSpos - 1)))
- state->lastCharIsSpace = true;
- else
- state->lastCharIsSpace = false;
-
-commit af61f3bcc07eabd7cad06e9619882ce239cb419f
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Feb 3 11:01:40 2010 +0000
-
- Fixed compilation issue on Windows.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@526 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/platforms/windows/windowsFile.cpp b/src/platforms/windows/windowsFile.cpp
-index 82c5696..624612a 100644
---- a/src/platforms/windows/windowsFile.cpp
-+++ b/src/platforms/windows/windowsFile.cpp
-@@ -268,7 +268,7 @@ bool windowsFile::canWrite() const
- return true;
- }
-
--const windowsFile::length_type windowsFile::getLength()
-+windowsFile::length_type windowsFile::getLength()
- {
- HANDLE hFile = CreateFile(
- m_nativePath.c_str(),
-
-commit bc1016c7e1f18c1088809a2104b295563a2d253a
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Feb 10 09:12:25 2010 +0000
-
- Allow spaces to appear in mailbox display name without encoding or quoting. Encode or quote if CR or LF is present.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@527 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/mailbox.cpp b/src/mailbox.cpp
-index f6df516..036f003 100644
---- a/src/mailbox.cpp
-+++ b/src/mailbox.cpp
-@@ -369,7 +369,7 @@ void mailbox::generate(utility::outputStream& os, const string::size_type maxLin
- // We have to encode the name:
- // - if it contains characters in a charset different from "US-ASCII",
- // - and/or if it contains one or more of these special chars:
-- // SPACE TAB " ; , < > ( ) @ / ? . = :
-+ // CR LF TAB " ; , < > ( ) @ / ? . = :
-
- // Check whether there are words that are not "US-ASCII"
- // and/or contain the special chars.
-@@ -386,7 +386,8 @@ void mailbox::generate(utility::outputStream& os, const string::size_type maxLin
- {
- switch (*c)
- {
-- case ' ':
-+ case '\r':
-+ case '\n':
- case '\t':
- case ';':
- case ',':
-
-commit 65d0cd058e4806b1a783656e3239403edd628f5b
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Feb 10 09:41:36 2010 +0000
-
- Don't quote if no encoding is needed.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@528 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/word.cpp b/src/word.cpp
-index f24d631..667f1fb 100644
---- a/src/word.cpp
-+++ b/src/word.cpp
-@@ -357,7 +357,8 @@ void word::generate(utility::outputStream& os, const string::size_type maxLineLe
- // - the whole buffer is ASCII-only
- // - the buffer does not contain quoting character (")
- // - there is enough remaining space on the current line to hold the whole buffer
-- if ((flags & text::QUOTE_IF_POSSIBLE) &&
-+ if (!noEncoding &&
-+ (flags & text::QUOTE_IF_POSSIBLE) &&
- asciiCount == m_buffer.length() &&
- m_buffer.find('"') == string::npos &&
- (curLineLength + 2 /* 2 x " */ + m_buffer.length()) < maxLineLength)
-
-commit 5b770cf6cb94b90e72360314e31ea05ca8dfe396
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Feb 10 10:39:10 2010 +0000
-
- Fixed missing M4 file in dist tarball.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@529 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/SConstruct b/SConstruct
-index 33bc2a3..f6dc257 100644
---- a/SConstruct
-+++ b/SConstruct
-@@ -376,6 +376,7 @@ libvmimetest_sources = [
- ]
-
- libvmime_autotools = [
-+ 'm4/acx_pthread.m4',
- 'm4/iconv.m4',
- 'm4/lib-ld.m4',
- 'm4/lib-link.m4',
-
-commit ce3c3fffbdf366e9c6afc4216485f0f9e0ce13a2
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Fri Feb 12 22:00:49 2010 +0000
-
- Replaced 'Options' with 'Variables' to solve warnings about the former being deprecated.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@530 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/SConstruct b/SConstruct
-index f6dc257..d45aec0 100644
---- a/SConstruct
-+++ b/SConstruct
-@@ -459,15 +459,15 @@ if defaultSendmailPath == None:
-
-
- # Command line options
--opts = Options('options.cache')
-+opts = Variables('options.cache')
-
--opts.AddOptions(
-+opts.AddVariables(
- (
- 'prefix',
- 'Installation prefix directory',
- '/usr'
- ),
-- EnumOption(
-+ EnumVariable(
- 'debug',
- 'Debug version (useful for developers only)',
- 'no',
-@@ -475,7 +475,7 @@ opts.AddOptions(
- map = { },
- ignorecase = 1
- ),
-- EnumOption(
-+ EnumVariable(
- 'with_messaging',
- 'Messaging support (connection to mail store/transport servers)',
- 'yes',
-@@ -483,7 +483,7 @@ opts.AddOptions(
- map = { },
- ignorecase = 1
- ),
-- EnumOption(
-+ EnumVariable(
- 'with_filesystem',
- 'Enable file-system support (this is needed for "maildir" messaging support)',
- 'yes',
-@@ -509,7 +509,7 @@ opts.AddOptions(
- + 'Currently available platform handlers: posix.',
- '"posix"'
- ),
-- EnumOption(
-+ EnumVariable(
- 'with_sasl',
- 'Enable SASL support (requires GNU SASL library)',
- 'yes',
-@@ -517,7 +517,7 @@ opts.AddOptions(
- map = { },
- ignorecase = 1
- ),
-- EnumOption(
-+ EnumVariable(
- 'with_tls',
- 'Enable TLS support (requires GNU TLS library)',
- 'yes',
-@@ -530,7 +530,7 @@ opts.AddOptions(
- 'Specifies the path to sendmail.',
- defaultSendmailPath
- ),
-- EnumOption(
-+ EnumVariable(
- 'byte_order',
- 'Byte order (Big Endian or Little Endian)',
- sys.byteorder,
-@@ -538,7 +538,7 @@ opts.AddOptions(
- map = { },
- ignorecase = 1
- ),
-- EnumOption(
-+ EnumVariable(
- 'pf_8bit_type',
- 'The C-language 8-bit type for your platform',
- 'char',
-@@ -546,7 +546,7 @@ opts.AddOptions(
- map = { },
- ignorecase = 1
- ),
-- EnumOption(
-+ EnumVariable(
- 'pf_16bit_type',
- 'The C-language 16-bit type for your platform',
- 'short',
-@@ -554,7 +554,7 @@ opts.AddOptions(
- map = { },
- ignorecase = 1
- ),
-- EnumOption(
-+ EnumVariable(
- 'pf_32bit_type',
- 'The C-language 32-bit type for your platform',
- 'int',
-@@ -562,7 +562,7 @@ opts.AddOptions(
- map = { },
- ignorecase = 1
- ),
-- EnumOption(
-+ EnumVariable(
- 'build_tests',
- 'Build unit tests (run with "scons run-tests")',
- 'no',
-
-commit 6dcc7213c7881e312fcbc68742f33c38a425fe7e
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Fri Feb 12 22:11:03 2010 +0000
-
- Solved 'underquoted' warnings from m4 macros.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@531 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/m4/ost_posix.m4 b/m4/ost_posix.m4
-index 6572b1e..ab05e25 100644
---- a/m4/ost_posix.m4
-+++ b/m4/ost_posix.m4
-@@ -19,7 +19,7 @@ dnl distribute this file as part of a program that contains a configuration
- dnl script generated by Autoconf, you may include it under the same
- dnl distribution terms that you use for the rest of that program.
-
--AC_DEFUN(OST_SYS_POSIX,[
-+AC_DEFUN([OST_SYS_POSIX],[
- AC_REQUIRE([OST_PROG_CC_POSIX])
- AC_CACHE_CHECK(whether system meets Posix.1,
- ost_cv_sys_posix1,
-@@ -65,7 +65,7 @@ AC_DEFUN(OST_SYS_POSIX,[
- ])
- ])
-
--AC_DEFUN(OST_CC_FCNTL,[
-+AC_DEFUN([OST_CC_FCNTL],[
- AC_REQUIRE([OST_SYS_POSIX])
- AC_CHECK_HEADERS(fcntl.h sys/fcntl.h)
- AH_BOTTOM([
-diff --git a/m4/ost_prog.m4 b/m4/ost_prog.m4
-index c9e66f5..aaa82f3 100644
---- a/m4/ost_prog.m4
-+++ b/m4/ost_prog.m4
-@@ -19,18 +19,18 @@ dnl distribute this file as part of a program that contains a configuration
- dnl script generated by Autoconf, you may include it under the same
- dnl distribution terms that you use for the rest of that program.
-
--AC_DEFUN(OST_PROG_CC_POSIX,[
-+AC_DEFUN([OST_PROG_CC_POSIX],[
- AC_PROG_CC
- AC_PROG_CPP
- AC_ISC_POSIX]
- )
-
--AC_DEFUN(OST_PROG_COMMON,[
-+AC_DEFUN([OST_PROG_COMMON],[
- AC_REQUIRE([AC_PROG_INSTALL])
- AC_REQUIRE([AC_PROG_MAKE_SET])
- ])
-
--AC_DEFUN(OST_PROJ_LIBRARY,[
-+AC_DEFUN([OST_PROJ_LIBRARY],[
- AC_REQUIRE([AM_PROG_LIBTOOL])
- AC_REQUIRE([AC_PROG_RANLIB])
- if test ! -z "[$2]" ; then
-@@ -43,14 +43,14 @@ AC_DEFUN(OST_PROJ_LIBRARY,[
- fi
- ])
-
--AC_DEFUN(OST_PROG_LIBVER,[
-+AC_DEFUN([OST_PROG_LIBVER],[
- LT_MAJOR="`echo $LT_VERSION | sed s/:.*$//`"
- AC_SUBST(LT_RELEASE)
- AC_SUBST(LT_MAJOR)
- ])
-
-
--AC_DEFUN(OST_PROG_LIBRARY,[
-+AC_DEFUN([OST_PROG_LIBRARY],[
- AC_REQUIRE([AM_PROG_LIBTOOL])
- AC_REQUIRE([AC_PROG_RANLIB])
- if test ! -z "[$2]" ; then
-diff --git a/m4/ost_systime.m4 b/m4/ost_systime.m4
-index f48f207..145611e 100644
---- a/m4/ost_systime.m4
-+++ b/m4/ost_systime.m4
-@@ -19,7 +19,7 @@ dnl distribute this file as part of a program that contains a configuration
- dnl script generated by Autoconf, you may include it under the same
- dnl distribution terms that you use for the rest of that program.
-
--AC_DEFUN(OST_CC_SYSTIME,[
-+AC_DEFUN([OST_CC_SYSTIME],[
- AC_HEADER_TIME
- AC_CHECK_HEADERS(sys/time.h)
- AH_TOP([
-
-commit 0af45816e99b3d8e7a9902a35330095408c487ae
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Fri Feb 12 22:28:37 2010 +0000
-
- Updated gettext m4 macros to 0.17.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@532 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/m4/lib-link.m4 b/m4/lib-link.m4
-index ea0b0c4..e3d26fc 100644
---- a/m4/lib-link.m4
-+++ b/m4/lib-link.m4
-@@ -1,17 +1,19 @@
--# lib-link.m4 serial 6 (gettext-0.14.3)
--dnl Copyright (C) 2001-2005 Free Software Foundation, Inc.
-+# lib-link.m4 serial 13 (gettext-0.17)
-+dnl Copyright (C) 2001-2007 Free Software Foundation, Inc.
- dnl This file is free software; the Free Software Foundation
- dnl gives unlimited permission to copy and/or distribute it,
- dnl with or without modifications, as long as this notice is preserved.
-
- dnl From Bruno Haible.
-
--AC_PREREQ(2.50)
-+AC_PREREQ(2.54)
-
- dnl AC_LIB_LINKFLAGS(name [, dependencies]) searches for libname and
- dnl the libraries corresponding to explicit and implicit dependencies.
- dnl Sets and AC_SUBSTs the LIB${NAME} and LTLIB${NAME} variables and
- dnl augments the CPPFLAGS variable.
-+dnl Sets and AC_SUBSTs the LIB${NAME}_PREFIX variable to nonempty if libname
-+dnl was found in ${LIB${NAME}_PREFIX}/$acl_libdirstem.
- AC_DEFUN([AC_LIB_LINKFLAGS],
- [
- AC_REQUIRE([AC_LIB_PREPARE_PREFIX])
-@@ -24,13 +26,16 @@ AC_DEFUN([AC_LIB_LINKFLAGS],
- ac_cv_lib[]Name[]_libs="$LIB[]NAME"
- ac_cv_lib[]Name[]_ltlibs="$LTLIB[]NAME"
- ac_cv_lib[]Name[]_cppflags="$INC[]NAME"
-+ ac_cv_lib[]Name[]_prefix="$LIB[]NAME[]_PREFIX"
- ])
- LIB[]NAME="$ac_cv_lib[]Name[]_libs"
- LTLIB[]NAME="$ac_cv_lib[]Name[]_ltlibs"
- INC[]NAME="$ac_cv_lib[]Name[]_cppflags"
-+ LIB[]NAME[]_PREFIX="$ac_cv_lib[]Name[]_prefix"
- AC_LIB_APPENDTOVAR([CPPFLAGS], [$INC]NAME)
- AC_SUBST([LIB]NAME)
- AC_SUBST([LTLIB]NAME)
-+ AC_SUBST([LIB]NAME[_PREFIX])
- dnl Also set HAVE_LIB[]NAME so that AC_LIB_HAVE_LINKFLAGS can reuse the
- dnl results of this search when this library appears as a dependency.
- HAVE_LIB[]NAME=yes
-@@ -46,6 +51,8 @@ dnl sets and AC_SUBSTs HAVE_LIB${NAME}=yes and the LIB${NAME} and
- dnl LTLIB${NAME} variables and augments the CPPFLAGS variable, and
- dnl #defines HAVE_LIB${NAME} to 1. Otherwise, it sets and AC_SUBSTs
- dnl HAVE_LIB${NAME}=no and LIB${NAME} and LTLIB${NAME} to empty.
-+dnl Sets and AC_SUBSTs the LIB${NAME}_PREFIX variable to nonempty if libname
-+dnl was found in ${LIB${NAME}_PREFIX}/$acl_libdirstem.
- AC_DEFUN([AC_LIB_HAVE_LINKFLAGS],
- [
- AC_REQUIRE([AC_LIB_PREPARE_PREFIX])
-@@ -82,17 +89,23 @@ AC_DEFUN([AC_LIB_HAVE_LINKFLAGS],
- CPPFLAGS="$ac_save_CPPFLAGS"
- LIB[]NAME=
- LTLIB[]NAME=
-+ LIB[]NAME[]_PREFIX=
- fi
- AC_SUBST([HAVE_LIB]NAME)
- AC_SUBST([LIB]NAME)
- AC_SUBST([LTLIB]NAME)
-+ AC_SUBST([LIB]NAME[_PREFIX])
- undefine([Name])
- undefine([NAME])
- ])
-
- dnl Determine the platform dependent parameters needed to use rpath:
--dnl libext, shlibext, hardcode_libdir_flag_spec, hardcode_libdir_separator,
--dnl hardcode_direct, hardcode_minus_L.
-+dnl acl_libext,
-+dnl acl_shlibext,
-+dnl acl_hardcode_libdir_flag_spec,
-+dnl acl_hardcode_libdir_separator,
-+dnl acl_hardcode_direct,
-+dnl acl_hardcode_minus_L.
- AC_DEFUN([AC_LIB_RPATH],
- [
- dnl Tell automake >= 1.10 to complain if config.rpath is missing.
-@@ -109,12 +122,14 @@ AC_DEFUN([AC_LIB_RPATH],
- acl_cv_rpath=done
- ])
- wl="$acl_cv_wl"
-- libext="$acl_cv_libext"
-- shlibext="$acl_cv_shlibext"
-- hardcode_libdir_flag_spec="$acl_cv_hardcode_libdir_flag_spec"
-- hardcode_libdir_separator="$acl_cv_hardcode_libdir_separator"
-- hardcode_direct="$acl_cv_hardcode_direct"
-- hardcode_minus_L="$acl_cv_hardcode_minus_L"
-+ acl_libext="$acl_cv_libext"
-+ acl_shlibext="$acl_cv_shlibext"
-+ acl_libname_spec="$acl_cv_libname_spec"
-+ acl_library_names_spec="$acl_cv_library_names_spec"
-+ acl_hardcode_libdir_flag_spec="$acl_cv_hardcode_libdir_flag_spec"
-+ acl_hardcode_libdir_separator="$acl_cv_hardcode_libdir_separator"
-+ acl_hardcode_direct="$acl_cv_hardcode_direct"
-+ acl_hardcode_minus_L="$acl_cv_hardcode_minus_L"
- dnl Determine whether the user wants rpath handling at all.
- AC_ARG_ENABLE(rpath,
- [ --disable-rpath do not hardcode runtime library paths],
-@@ -124,19 +139,24 @@ AC_DEFUN([AC_LIB_RPATH],
- dnl AC_LIB_LINKFLAGS_BODY(name [, dependencies]) searches for libname and
- dnl the libraries corresponding to explicit and implicit dependencies.
- dnl Sets the LIB${NAME}, LTLIB${NAME} and INC${NAME} variables.
-+dnl Also, sets the LIB${NAME}_PREFIX variable to nonempty if libname was found
-+dnl in ${LIB${NAME}_PREFIX}/$acl_libdirstem.
- AC_DEFUN([AC_LIB_LINKFLAGS_BODY],
- [
-+ AC_REQUIRE([AC_LIB_PREPARE_MULTILIB])
- define([NAME],[translit([$1],[abcdefghijklmnopqrstuvwxyz./-],
- [ABCDEFGHIJKLMNOPQRSTUVWXYZ___])])
-+ dnl Autoconf >= 2.61 supports dots in --with options.
-+ define([N_A_M_E],[m4_if(m4_version_compare(m4_defn([m4_PACKAGE_VERSION]),[2.61]),[-1],[translit([$1],[.],[_])],[$1])])
- dnl By default, look in $includedir and $libdir.
- use_additional=yes
- AC_LIB_WITH_FINAL_PREFIX([
- eval additional_includedir=\"$includedir\"
- eval additional_libdir=\"$libdir\"
- ])
-- AC_LIB_ARG_WITH([lib$1-prefix],
--[ --with-lib$1-prefix[=DIR] search for lib$1 in DIR/include and DIR/lib
-- --without-lib$1-prefix don't search for lib$1 in includedir and libdir],
-+ AC_LIB_ARG_WITH([lib]N_A_M_E[-prefix],
-+[ --with-lib]N_A_M_E[-prefix[=DIR] search for lib$1 in DIR/include and DIR/lib
-+ --without-lib]N_A_M_E[-prefix don't search for lib$1 in includedir and libdir],
- [
- if test "X$withval" = "Xno"; then
- use_additional=no
-@@ -148,7 +168,7 @@ AC_DEFUN([AC_LIB_LINKFLAGS_BODY],
- ])
- else
- additional_includedir="$withval/include"
-- additional_libdir="$withval/lib"
-+ additional_libdir="$withval/$acl_libdirstem"
- fi
- fi
- ])
-@@ -157,6 +177,7 @@ AC_DEFUN([AC_LIB_LINKFLAGS_BODY],
- LIB[]NAME=
- LTLIB[]NAME=
- INC[]NAME=
-+ LIB[]NAME[]_PREFIX=
- rpathdirs=
- ltrpathdirs=
- names_already_handled=
-@@ -196,22 +217,55 @@ AC_DEFUN([AC_LIB_LINKFLAGS_BODY],
- found_la=
- found_so=
- found_a=
-+ eval libname=\"$acl_libname_spec\" # typically: libname=lib$name
-+ if test -n "$acl_shlibext"; then
-+ shrext=".$acl_shlibext" # typically: shrext=.so
-+ else
-+ shrext=
-+ fi
- if test $use_additional = yes; then
-- if test -n "$shlibext" && test -f "$additional_libdir/lib$name.$shlibext"; then
-- found_dir="$additional_libdir"
-- found_so="$additional_libdir/lib$name.$shlibext"
-- if test -f "$additional_libdir/lib$name.la"; then
-- found_la="$additional_libdir/lib$name.la"
-- fi
-- else
-- if test -f "$additional_libdir/lib$name.$libext"; then
-- found_dir="$additional_libdir"
-- found_a="$additional_libdir/lib$name.$libext"
-- if test -f "$additional_libdir/lib$name.la"; then
-- found_la="$additional_libdir/lib$name.la"
-+ dir="$additional_libdir"
-+ dnl The same code as in the loop below:
-+ dnl First look for a shared library.
-+ if test -n "$acl_shlibext"; then
-+ if test -f "$dir/$libname$shrext"; then
-+ found_dir="$dir"
-+ found_so="$dir/$libname$shrext"
-+ else
-+ if test "$acl_library_names_spec" = '$libname$shrext$versuffix'; then
-+ ver=`(cd "$dir" && \
-+ for f in "$libname$shrext".*; do echo "$f"; done \
-+ | sed -e "s,^$libname$shrext\\\\.,," \
-+ | sort -t '.' -n -r -k1,1 -k2,2 -k3,3 -k4,4 -k5,5 \
-+ | sed 1q ) 2>/dev/null`
-+ if test -n "$ver" && test -f "$dir/$libname$shrext.$ver"; then
-+ found_dir="$dir"
-+ found_so="$dir/$libname$shrext.$ver"
-+ fi
-+ else
-+ eval library_names=\"$acl_library_names_spec\"
-+ for f in $library_names; do
-+ if test -f "$dir/$f"; then
-+ found_dir="$dir"
-+ found_so="$dir/$f"
-+ break
-+ fi
-+ done
- fi
- fi
- fi
-+ dnl Then look for a static library.
-+ if test "X$found_dir" = "X"; then
-+ if test -f "$dir/$libname.$acl_libext"; then
-+ found_dir="$dir"
-+ found_a="$dir/$libname.$acl_libext"
-+ fi
-+ fi
-+ if test "X$found_dir" != "X"; then
-+ if test -f "$dir/$libname.la"; then
-+ found_la="$dir/$libname.la"
-+ fi
-+ fi
- fi
- if test "X$found_dir" = "X"; then
- for x in $LDFLAGS $LTLIB[]NAME; do
-@@ -219,21 +273,46 @@ AC_DEFUN([AC_LIB_LINKFLAGS_BODY],
- case "$x" in
- -L*)
- dir=`echo "X$x" | sed -e 's/^X-L//'`
-- if test -n "$shlibext" && test -f "$dir/lib$name.$shlibext"; then
-- found_dir="$dir"
-- found_so="$dir/lib$name.$shlibext"
-- if test -f "$dir/lib$name.la"; then
-- found_la="$dir/lib$name.la"
-- fi
-- else
-- if test -f "$dir/lib$name.$libext"; then
-+ dnl First look for a shared library.
-+ if test -n "$acl_shlibext"; then
-+ if test -f "$dir/$libname$shrext"; then
- found_dir="$dir"
-- found_a="$dir/lib$name.$libext"
-- if test -f "$dir/lib$name.la"; then
-- found_la="$dir/lib$name.la"
-+ found_so="$dir/$libname$shrext"
-+ else
-+ if test "$acl_library_names_spec" = '$libname$shrext$versuffix'; then
-+ ver=`(cd "$dir" && \
-+ for f in "$libname$shrext".*; do echo "$f"; done \
-+ | sed -e "s,^$libname$shrext\\\\.,," \
-+ | sort -t '.' -n -r -k1,1 -k2,2 -k3,3 -k4,4 -k5,5 \
-+ | sed 1q ) 2>/dev/null`
-+ if test -n "$ver" && test -f "$dir/$libname$shrext.$ver"; then
-+ found_dir="$dir"
-+ found_so="$dir/$libname$shrext.$ver"
-+ fi
-+ else
-+ eval library_names=\"$acl_library_names_spec\"
-+ for f in $library_names; do
-+ if test -f "$dir/$f"; then
-+ found_dir="$dir"
-+ found_so="$dir/$f"
-+ break
-+ fi
-+ done
- fi
- fi
- fi
-+ dnl Then look for a static library.
-+ if test "X$found_dir" = "X"; then
-+ if test -f "$dir/$libname.$acl_libext"; then
-+ found_dir="$dir"
-+ found_a="$dir/$libname.$acl_libext"
-+ fi
-+ fi
-+ if test "X$found_dir" != "X"; then
-+ if test -f "$dir/$libname.la"; then
-+ found_la="$dir/$libname.la"
-+ fi
-+ fi
- ;;
- esac
- if test "X$found_dir" != "X"; then
-@@ -248,7 +327,7 @@ AC_DEFUN([AC_LIB_LINKFLAGS_BODY],
- dnl Linking with a shared library. We attempt to hardcode its
- dnl directory into the executable's runpath, unless it's the
- dnl standard /usr/lib.
-- if test "$enable_rpath" = no || test "X$found_dir" = "X/usr/lib"; then
-+ if test "$enable_rpath" = no || test "X$found_dir" = "X/usr/$acl_libdirstem"; then
- dnl No hardcoding is needed.
- LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so"
- else
-@@ -267,12 +346,12 @@ AC_DEFUN([AC_LIB_LINKFLAGS_BODY],
- ltrpathdirs="$ltrpathdirs $found_dir"
- fi
- dnl The hardcoding into $LIBNAME is system dependent.
-- if test "$hardcode_direct" = yes; then
-+ if test "$acl_hardcode_direct" = yes; then
- dnl Using DIR/libNAME.so during linking hardcodes DIR into the
- dnl resulting binary.
- LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so"
- else
-- if test -n "$hardcode_libdir_flag_spec" && test "$hardcode_minus_L" = no; then
-+ if test -n "$acl_hardcode_libdir_flag_spec" && test "$acl_hardcode_minus_L" = no; then
- dnl Use an explicit option to hardcode DIR into the resulting
- dnl binary.
- LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so"
-@@ -303,13 +382,13 @@ AC_DEFUN([AC_LIB_LINKFLAGS_BODY],
- if test -z "$haveit"; then
- LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-L$found_dir"
- fi
-- if test "$hardcode_minus_L" != no; then
-+ if test "$acl_hardcode_minus_L" != no; then
- dnl FIXME: Not sure whether we should use
- dnl "-L$found_dir -l$name" or "-L$found_dir $found_so"
- dnl here.
- LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so"
- else
-- dnl We cannot use $hardcode_runpath_var and LD_RUN_PATH
-+ dnl We cannot use $acl_hardcode_runpath_var and LD_RUN_PATH
- dnl here, because this doesn't fit in flags passed to the
- dnl compiler. So give up. No hardcoding. This affects only
- dnl very old systems.
-@@ -334,8 +413,9 @@ AC_DEFUN([AC_LIB_LINKFLAGS_BODY],
- dnl Assume the include files are nearby.
- additional_includedir=
- case "$found_dir" in
-- */lib | */lib/)
-- basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e 's,/lib/*$,,'`
-+ */$acl_libdirstem | */$acl_libdirstem/)
-+ basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e "s,/$acl_libdirstem/"'*$,,'`
-+ LIB[]NAME[]_PREFIX="$basedir"
- additional_includedir="$basedir/include"
- ;;
- esac
-@@ -396,9 +476,9 @@ AC_DEFUN([AC_LIB_LINKFLAGS_BODY],
- dnl 3. if it's already present in $LDFLAGS or the already
- dnl constructed $LIBNAME,
- dnl 4. if it doesn't exist as a directory.
-- if test "X$additional_libdir" != "X/usr/lib"; then
-+ if test "X$additional_libdir" != "X/usr/$acl_libdirstem"; then
- haveit=
-- if test "X$additional_libdir" = "X/usr/local/lib"; then
-+ if test "X$additional_libdir" = "X/usr/local/$acl_libdirstem"; then
- if test -n "$GCC"; then
- case $host_os in
- linux* | gnu* | k*bsd*-gnu) haveit=yes;;
-@@ -497,18 +577,18 @@ AC_DEFUN([AC_LIB_LINKFLAGS_BODY],
- done
- done
- if test "X$rpathdirs" != "X"; then
-- if test -n "$hardcode_libdir_separator"; then
-+ if test -n "$acl_hardcode_libdir_separator"; then
- dnl Weird platform: only the last -rpath option counts, the user must
- dnl pass all path elements in one option. We can arrange that for a
- dnl single library, but not when more than one $LIBNAMEs are used.
- alldirs=
- for found_dir in $rpathdirs; do
-- alldirs="${alldirs}${alldirs:+$hardcode_libdir_separator}$found_dir"
-+ alldirs="${alldirs}${alldirs:+$acl_hardcode_libdir_separator}$found_dir"
- done
-- dnl Note: hardcode_libdir_flag_spec uses $libdir and $wl.
-+ dnl Note: acl_hardcode_libdir_flag_spec uses $libdir and $wl.
- acl_save_libdir="$libdir"
- libdir="$alldirs"
-- eval flag=\"$hardcode_libdir_flag_spec\"
-+ eval flag=\"$acl_hardcode_libdir_flag_spec\"
- libdir="$acl_save_libdir"
- LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$flag"
- else
-@@ -516,7 +596,7 @@ AC_DEFUN([AC_LIB_LINKFLAGS_BODY],
- for found_dir in $rpathdirs; do
- acl_save_libdir="$libdir"
- libdir="$found_dir"
-- eval flag=\"$hardcode_libdir_flag_spec\"
-+ eval flag=\"$acl_hardcode_libdir_flag_spec\"
- libdir="$acl_save_libdir"
- LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$flag"
- done
-@@ -551,3 +631,79 @@ AC_DEFUN([AC_LIB_APPENDTOVAR],
- fi
- done
- ])
-+
-+dnl For those cases where a variable contains several -L and -l options
-+dnl referring to unknown libraries and directories, this macro determines the
-+dnl necessary additional linker options for the runtime path.
-+dnl AC_LIB_LINKFLAGS_FROM_LIBS([LDADDVAR], [LIBSVALUE], [USE-LIBTOOL])
-+dnl sets LDADDVAR to linker options needed together with LIBSVALUE.
-+dnl If USE-LIBTOOL evaluates to non-empty, linking with libtool is assumed,
-+dnl otherwise linking without libtool is assumed.
-+AC_DEFUN([AC_LIB_LINKFLAGS_FROM_LIBS],
-+[
-+ AC_REQUIRE([AC_LIB_RPATH])
-+ AC_REQUIRE([AC_LIB_PREPARE_MULTILIB])
-+ $1=
-+ if test "$enable_rpath" != no; then
-+ if test -n "$acl_hardcode_libdir_flag_spec" && test "$acl_hardcode_minus_L" = no; then
-+ dnl Use an explicit option to hardcode directories into the resulting
-+ dnl binary.
-+ rpathdirs=
-+ next=
-+ for opt in $2; do
-+ if test -n "$next"; then
-+ dir="$next"
-+ dnl No need to hardcode the standard /usr/lib.
-+ if test "X$dir" != "X/usr/$acl_libdirstem"; then
-+ rpathdirs="$rpathdirs $dir"
-+ fi
-+ next=
-+ else
-+ case $opt in
-+ -L) next=yes ;;
-+ -L*) dir=`echo "X$opt" | sed -e 's,^X-L,,'`
-+ dnl No need to hardcode the standard /usr/lib.
-+ if test "X$dir" != "X/usr/$acl_libdirstem"; then
-+ rpathdirs="$rpathdirs $dir"
-+ fi
-+ next= ;;
-+ *) next= ;;
-+ esac
-+ fi
-+ done
-+ if test "X$rpathdirs" != "X"; then
-+ if test -n ""$3""; then
-+ dnl libtool is used for linking. Use -R options.
-+ for dir in $rpathdirs; do
-+ $1="${$1}${$1:+ }-R$dir"
-+ done
-+ else
-+ dnl The linker is used for linking directly.
-+ if test -n "$acl_hardcode_libdir_separator"; then
-+ dnl Weird platform: only the last -rpath option counts, the user
-+ dnl must pass all path elements in one option.
-+ alldirs=
-+ for dir in $rpathdirs; do
-+ alldirs="${alldirs}${alldirs:+$acl_hardcode_libdir_separator}$dir"
-+ done
-+ acl_save_libdir="$libdir"
-+ libdir="$alldirs"
-+ eval flag=\"$acl_hardcode_libdir_flag_spec\"
-+ libdir="$acl_save_libdir"
-+ $1="$flag"
-+ else
-+ dnl The -rpath options are cumulative.
-+ for dir in $rpathdirs; do
-+ acl_save_libdir="$libdir"
-+ libdir="$dir"
-+ eval flag=\"$acl_hardcode_libdir_flag_spec\"
-+ libdir="$acl_save_libdir"
-+ $1="${$1}${$1:+ }$flag"
-+ done
-+ fi
-+ fi
-+ fi
-+ fi
-+ fi
-+ AC_SUBST([$1])
-+])
-diff --git a/m4/lib-prefix.m4 b/m4/lib-prefix.m4
-index 0d895ca..a8684e1 100644
---- a/m4/lib-prefix.m4
-+++ b/m4/lib-prefix.m4
-@@ -1,4 +1,4 @@
--# lib-prefix.m4 serial 4 (gettext-0.14.2)
-+# lib-prefix.m4 serial 5 (gettext-0.15)
- dnl Copyright (C) 2001-2005 Free Software Foundation, Inc.
- dnl This file is free software; the Free Software Foundation
- dnl gives unlimited permission to copy and/or distribute it,
-@@ -24,6 +24,7 @@ AC_DEFUN([AC_LIB_PREFIX],
- AC_BEFORE([$0], [AC_LIB_LINKFLAGS])
- AC_REQUIRE([AC_PROG_CC])
- AC_REQUIRE([AC_CANONICAL_HOST])
-+ AC_REQUIRE([AC_LIB_PREPARE_MULTILIB])
- AC_REQUIRE([AC_LIB_PREPARE_PREFIX])
- dnl By default, look in $includedir and $libdir.
- use_additional=yes
-@@ -45,7 +46,7 @@ AC_DEFUN([AC_LIB_PREFIX],
- ])
- else
- additional_includedir="$withval/include"
-- additional_libdir="$withval/lib"
-+ additional_libdir="$withval/$acl_libdirstem"
- fi
- fi
- ])
-@@ -87,7 +88,7 @@ AC_DEFUN([AC_LIB_PREFIX],
- dnl 2. if it's already present in $LDFLAGS,
- dnl 3. if it's /usr/local/lib and we are using GCC on Linux,
- dnl 4. if it doesn't exist as a directory.
-- if test "X$additional_libdir" != "X/usr/lib"; then
-+ if test "X$additional_libdir" != "X/usr/$acl_libdirstem"; then
- haveit=
- for x in $LDFLAGS; do
- AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"])
-@@ -97,7 +98,7 @@ AC_DEFUN([AC_LIB_PREFIX],
- fi
- done
- if test -z "$haveit"; then
-- if test "X$additional_libdir" = "X/usr/local/lib"; then
-+ if test "X$additional_libdir" = "X/usr/local/$acl_libdirstem"; then
- if test -n "$GCC"; then
- case $host_os in
- linux*) haveit=yes;;
-@@ -151,3 +152,34 @@ AC_DEFUN([AC_LIB_WITH_FINAL_PREFIX],
- exec_prefix="$acl_save_exec_prefix"
- prefix="$acl_save_prefix"
- ])
-+
-+dnl AC_LIB_PREPARE_MULTILIB creates a variable acl_libdirstem, containing
-+dnl the basename of the libdir, either "lib" or "lib64".
-+AC_DEFUN([AC_LIB_PREPARE_MULTILIB],
-+[
-+ dnl There is no formal standard regarding lib and lib64. The current
-+ dnl practice is that on a system supporting 32-bit and 64-bit instruction
-+ dnl sets or ABIs, 64-bit libraries go under $prefix/lib64 and 32-bit
-+ dnl libraries go under $prefix/lib. We determine the compiler's default
-+ dnl mode by looking at the compiler's library search path. If at least
-+ dnl of its elements ends in /lib64 or points to a directory whose absolute
-+ dnl pathname ends in /lib64, we assume a 64-bit ABI. Otherwise we use the
-+ dnl default, namely "lib".
-+ acl_libdirstem=lib
-+ searchpath=`(LC_ALL=C $CC -print-search-dirs) 2>/dev/null | sed -n -e 's,^libraries: ,,p' | sed -e 's,^=,,'`
-+ if test -n "$searchpath"; then
-+ acl_save_IFS="${IFS= }"; IFS=":"
-+ for searchdir in $searchpath; do
-+ if test -d "$searchdir"; then
-+ case "$searchdir" in
-+ */lib64/ | */lib64 ) acl_libdirstem=lib64 ;;
-+ *) searchdir=`cd "$searchdir" && pwd`
-+ case "$searchdir" in
-+ */lib64 ) acl_libdirstem=lib64 ;;
-+ esac ;;
-+ esac
-+ fi
-+ done
-+ IFS="$acl_save_IFS"
-+ fi
-+])
-
-commit 508bfaf7f46e7c324e503794812bfee6fd422594
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Mon Feb 15 09:05:49 2010 +0000
-
- Fixed test for global constructor failing when cross building.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@533 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/SConstruct b/SConstruct
-index d45aec0..2452745 100644
---- a/SConstruct
-+++ b/SConstruct
-@@ -1364,7 +1364,7 @@ sh libtool --mode=link $CXX -o libtest.la -rpath / -version-info 0 mylib.lo >&5
- $CXX -c $CFLAGS $CPPFLAGS mytest.$ac_ext >&5
- sh libtool --mode=link $CXX -o mytest mytest.o libtest.la >&5 2>/dev/null
-
--if test -x mytest; then
-+if test -x mytest -a "$cross_compiling" != yes; then
- myresult=`./mytest`
- if test "X$myresult" = "XPASS"; then
- AC_MSG_RESULT(yes)
-
-commit 4ebf3f0343a54af998ac0f039820f790b4c5f255
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Feb 17 22:27:53 2010 +0000
-
- Fixed shebang for systems that don't have /bin/bash.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@534 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/bootstrap b/bootstrap
-index 457eaa8..01309ce 100755
---- a/bootstrap
-+++ b/bootstrap
-@@ -1,4 +1,5 @@
- #! /bin/bash
-+#! /usr/bin/env bash
- #
- # Bootstrap file for 'autotools' build
- #
-
-commit 253a55ef8991269e0b66bf6b54e1aed0b385cb6b
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sat Mar 6 12:48:39 2010 +0000
-
- Use 'glibtoolize' instead of 'libtoolize' on MacOSX.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@535 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/bootstrap b/bootstrap
-index 01309ce..1540429 100755
---- a/bootstrap
-+++ b/bootstrap
-@@ -13,6 +13,13 @@ rm -Rf autom4te.cache
- (mkdir autotools >& /dev/null)
- (cd autotools && rm -f config.guess config.sub missing mkinstalldirs compile ltmain.sh depcomp install-sh)
-
-+# Check for "glibtoolize" instead of "libtoolize" on OSX
-+LIBTOOLIZE=libtoolize
-+if which glibtoolize > /dev/null 2>&1; then
-+ LIBTOOLIZE=glibtoolize
-+fi
-+
-+
- DIE=0
-
- echo ""
-@@ -36,7 +43,7 @@ if test $DIE = 0 ; then
- fi
-
- if test $DIE = 0 ; then
-- echo -n "* Running libtoolize... " ; (libtoolize --copy --force --automake >& bootstrap.tmpout) \
-+ echo -n "* Running libtoolize... " ; ($LIBTOOLIZE --copy --force --automake >& bootstrap.tmpout) \
- && (echo "[OK]" ; cat bootstrap.tmpout ; rm -f bootstrap.tmpout) \
- || (echo "[NO]" ; cat bootstrap.tmpout ; rm -f bootstrap.tmpout ; not_a_command >& /dev/null) || DIE=1
- fi
-
-commit 5ccf29bc69f34dada3dca2f0bf7aac7b6714dffb
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Mar 10 13:29:33 2010 +0000
-
- Fixed bug #2966885: memory leak caused by strong ref (thanks to tuxx from SF).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@536 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/security/sasl/defaultSASLAuthenticator.cpp b/src/security/sasl/defaultSASLAuthenticator.cpp
-index 06ffc49..32192f7 100644
---- a/src/security/sasl/defaultSASLAuthenticator.cpp
-+++ b/src/security/sasl/defaultSASLAuthenticator.cpp
-@@ -96,7 +96,7 @@ const string defaultSASLAuthenticator::getAnonymousToken() const
-
- const string defaultSASLAuthenticator::getServiceName() const
- {
-- return m_saslSession->getServiceName();
-+ return m_saslSession.acquire()->getServiceName();
- }
-
-
-@@ -121,7 +121,7 @@ void defaultSASLAuthenticator::setSASLSession(ref <SASLSession> sess)
-
- ref <SASLSession> defaultSASLAuthenticator::getSASLSession() const
- {
-- return m_saslSession;
-+ return m_saslSession.acquire();
- }
-
-
-diff --git a/vmime/security/sasl/defaultSASLAuthenticator.hpp b/vmime/security/sasl/defaultSASLAuthenticator.hpp
-index a896b65..7595de7 100644
---- a/vmime/security/sasl/defaultSASLAuthenticator.hpp
-+++ b/vmime/security/sasl/defaultSASLAuthenticator.hpp
-@@ -67,10 +67,8 @@ private:
-
- defaultAuthenticator m_default;
-
--
- weak_ref <net::service> m_service;
--
-- ref <SASLSession> m_saslSession;
-+ weak_ref <SASLSession> m_saslSession;
- ref <SASLMechanism> m_saslMech;
- };
-
-
-commit af7be2b3da767f2723879fd78dbbcf991f069715
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Mar 10 15:54:23 2010 +0000
-
- Fixed compilation issue with 'const'.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@537 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/security/sasl/defaultSASLAuthenticator.cpp b/src/security/sasl/defaultSASLAuthenticator.cpp
-index 32192f7..4eae4e3 100644
---- a/src/security/sasl/defaultSASLAuthenticator.cpp
-+++ b/src/security/sasl/defaultSASLAuthenticator.cpp
-@@ -121,7 +121,7 @@ void defaultSASLAuthenticator::setSASLSession(ref <SASLSession> sess)
-
- ref <SASLSession> defaultSASLAuthenticator::getSASLSession() const
- {
-- return m_saslSession.acquire();
-+ return m_saslSession.acquire().constCast <SASLSession>();
- }
-
-
-
-commit 2a62318173c8285202bbddbba3fb1e77a1dc9d3a
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Mar 16 08:39:45 2010 +0000
-
- Return false instead of throwing an exception if file does not exist in isDirectory(), isFile(), canRead() and canWrite().
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@538 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/platforms/posix/posixFile.cpp b/src/platforms/posix/posixFile.cpp
-index b814b75..ec529eb 100644
---- a/src/platforms/posix/posixFile.cpp
-+++ b/src/platforms/posix/posixFile.cpp
-@@ -306,6 +306,9 @@ bool posixFile::isFile() const
-
- if (::stat(m_nativePath.c_str(), &buf) == -1)
- {
-+ if (errno == ENOENT)
-+ return false;
-+
- posixFileSystemFactory::reportError(m_path, errno);
- return false;
- }
-@@ -320,6 +323,9 @@ bool posixFile::isDirectory() const
-
- if (::stat(m_nativePath.c_str(), &buf) == -1)
- {
-+ if (errno == ENOENT)
-+ return false;
-+
- posixFileSystemFactory::reportError(m_path, errno);
- return false;
- }
-@@ -334,6 +340,9 @@ bool posixFile::canRead() const
-
- if (::stat(m_nativePath.c_str(), &buf) == -1)
- {
-+ if (errno == ENOENT)
-+ return false;
-+
- posixFileSystemFactory::reportError(m_path, errno);
- return false;
- }
-@@ -349,6 +358,9 @@ bool posixFile::canWrite() const
-
- if (::stat(m_nativePath.c_str(), &buf) == -1)
- {
-+ if (errno == ENOENT)
-+ return false;
-+
- posixFileSystemFactory::reportError(m_path, errno);
- return false;
- }
-
-commit 298f8712f6e2bb6e0f1b321906eb691793554f05
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Mar 16 11:54:11 2010 +0000
-
- Fixed calls to 'empty' instead of 'clear' (thanks to John van der Kamp, from Zarafa).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@539 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/mailbox.cpp b/src/mailbox.cpp
-index 036f003..5cb0139 100644
---- a/src/mailbox.cpp
-+++ b/src/mailbox.cpp
-@@ -311,7 +311,7 @@ void mailbox::parse(const string& buffer, const string::size_type position,
- // (email address is mandatory, whereas name is optional).
- if (address.empty() && !name.empty())
- {
-- m_email.empty();
-+ m_email.clear();
- m_email.reserve(name.size());
- m_name.removeAllWords();
-
-@@ -324,7 +324,7 @@ void mailbox::parse(const string& buffer, const string::size_type position,
- else
- {
- text::decodeAndUnfold(name, &m_name);
-- m_email.empty();
-+ m_email.clear();
- m_email.reserve(address.size());
-
- for (string::size_type i = 0 ; i < address.size() ; ++i)
-
-commit ec603c6c52734c44467f17dfded90a38e3516d3a
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Mar 16 15:55:47 2010 +0000
-
- Migrated config script for newer versions of SCons.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@540 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/SConstruct b/SConstruct
-index 2452745..384c90f 100644
---- a/SConstruct
-+++ b/SConstruct
-@@ -436,7 +436,7 @@ libvmime_dist_files += libvmime_autotools
- # Set options #
- #################
-
--EnsureSConsVersion(0, 94)
-+EnsureSConsVersion(0, 98, 1)
-
- SetOption('implicit_cache', 1)
-
-@@ -578,7 +578,10 @@ opts.AddVariables(
- # Configuration Environment #
- ###############################
-
--env = Environment(options = opts)
-+try:
-+ env = Environment(variables = opts)
-+except TypeError:
-+ env = Environment(options = opts)
-
- env.Append(ENV = os.environ)
- env.Append(ENV = {'PATH' : os.environ['PATH']})
-@@ -953,7 +956,7 @@ Default(libVmime)
- # Tests
- if env['build_tests'] == 'yes':
- if env['debug'] == 'yes':
-- env = env.Copy()
-+ env = env.Clone()
- env.Append(LIBS = ['cppunit', 'dl', packageVersionedGenericName + '-debug', 'pthread'])
- env.Append(LIBPATH=['.'])
- Default(
-
-commit 586397b44f047e1c3be7936cf5538f32769c6e47
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Thu Apr 8 18:28:22 2010 +0000
-
- Fixed parsing of non-significant whitespaces in field values.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@541 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/parameterizedHeaderField.cpp b/src/parameterizedHeaderField.cpp
-index 090d5b4..464990e 100644
---- a/src/parameterizedHeaderField.cpp
-+++ b/src/parameterizedHeaderField.cpp
-@@ -85,12 +85,32 @@ void parameterizedHeaderField::parse(const string& buffer, const string::size_ty
- const string::value_type* const pstart = buffer.data() + position;
- const string::value_type* p = pstart;
-
-- const string::size_type start = position;
-+ // Skip non-significant whitespaces
-+ string::size_type valueStart = position;
-
-- while (p < pend && *p != ';') ++p;
-+ while (p < pend && parserHelpers::isSpace(*p))
-+ {
-+ ++p;
-+ ++valueStart;
-+ }
-+
-+ // Advance up to ';', if any
-+ string::size_type valueLength = 0;
-+
-+ while (p < pend && *p != ';') // FIXME: support ";" inside quoted or RFC-2047-encoded text
-+ {
-+ ++p;
-+ ++valueLength;
-+ }
-+
-+ // Trim whitespaces at the end of the value
-+ while (valueLength > 0 && parserHelpers::isSpace(buffer[valueStart + valueLength - 1]))
-+ --valueLength;
-
-- getValue()->parse(buffer, start, position + (p - pstart));
-+ // Parse value
-+ getValue()->parse(buffer, valueStart, valueStart + valueLength);
-
-+ // Reset parameters
- removeAllParameters();
-
- // If there is one or more parameters following...
-diff --git a/tests/parser/parameterTest.cpp b/tests/parser/parameterTest.cpp
-index 6d24438..803bb59 100644
---- a/tests/parser/parameterTest.cpp
-+++ b/tests/parser/parameterTest.cpp
-@@ -36,6 +36,7 @@ VMIME_TEST_SUITE_BEGIN
- VMIME_TEST(testGenerate)
- VMIME_TEST(testGenerateRFC2231)
- VMIME_TEST(testNonStandardEncodedParam)
-+ VMIME_TEST(testParseNonSignificantWS)
- VMIME_TEST_LIST_END
-
-
-@@ -53,6 +54,7 @@ VMIME_TEST_SUITE_BEGIN
- };
-
-
-+#define FIELD_VALUE(f) (f.getValue()->generate())
- #define PARAM_VALUE(p, n) (p.getParameterAt(n)->getValue().generate())
- #define PARAM_NAME(p, n) (p.getParameterAt(n)->getName())
- #define PARAM_CHARSET(p, n) \
-@@ -278,5 +280,22 @@ VMIME_TEST_SUITE_BEGIN
- VASSERT_EQ("2.3", "Logo VMime.png", PARAM_VALUE(p2, 0));
- }
-
-+ // Parse parameters with non-significant whitespaces
-+ void testParseNonSignificantWS()
-+ {
-+ parameterizedHeaderField p1;
-+ p1.parse(" \t X \r\n");
-+
-+ VASSERT_EQ("1.1", "X", FIELD_VALUE(p1));
-+
-+ parameterizedHeaderField p2;
-+ p2.parse(" X ; param1 = value1 \r\n");
-+
-+ VASSERT_EQ("2.1", 1, p2.getParameterCount());
-+ VASSERT_EQ("2.2", "X", FIELD_VALUE(p2));
-+ VASSERT_EQ("2.3", "param1", PARAM_NAME(p2, 0));
-+ VASSERT_EQ("2.4", "value1", PARAM_VALUE(p2, 0));
-+ }
-+
- VMIME_TEST_SUITE_END
-
-
-commit 29a45062173bede8d485af035c92e00b894172f7
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sat Apr 10 06:43:40 2010 +0000
-
- Fixed duplicate shebang.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@542 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/bootstrap b/bootstrap
-index 1540429..9c9c3d3 100755
---- a/bootstrap
-+++ b/bootstrap
-@@ -1,4 +1,3 @@
--#! /bin/bash
- #! /usr/bin/env bash
- #
- # Bootstrap file for 'autotools' build
-
-commit a198fe0e65788519507e527e6b0a52d25bd970a1
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Apr 13 09:51:30 2010 +0000
-
- Register non-standard encoding names.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@543 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/utility/encoder/encoderFactory.cpp b/src/utility/encoder/encoderFactory.cpp
-index 428788d..2237178 100644
---- a/src/utility/encoder/encoderFactory.cpp
-+++ b/src/utility/encoder/encoderFactory.cpp
-@@ -46,6 +46,10 @@ encoderFactory::encoderFactory()
- registerName <sevenBitEncoder>("7bit");
- registerName <eightBitEncoder>("8bit");
- registerName <binaryEncoder>("binary");
-+
-+ // Also register some non-standard encoding names
-+ registerName <sevenBitEncoder>("7-bit");
-+ registerName <eightBitEncoder>("8-bit");
- }
-
-
-
-commit 596b8882088f0c12f7c4ae1848b24cd521112131
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue May 4 10:07:56 2010 +0000
-
- Fixed typo.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@544 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/SConstruct b/SConstruct
-index 384c90f..d05f8bc 100644
---- a/SConstruct
-+++ b/SConstruct
-@@ -1071,7 +1071,7 @@ def generateAutotools(target, source, env):
- # Generate pkg-config file for shared and static library
- vmime_pc_in = open(packageVersionedGenericName + ".pc.in", 'w')
- vmime_pc_in.write("# File automatically generated by SConstruct ('scons autotools')\n")
-- vmime_pc_in.write("# DOT NOT EDIT!\n")
-+ vmime_pc_in.write("# DO NOT EDIT!\n")
- vmime_pc_in.write("\n")
- vmime_pc_in.write("prefix=@prefix@\n")
- vmime_pc_in.write("exec_prefix=@exec_prefix@\n")
-@@ -1091,7 +1091,7 @@ def generateAutotools(target, source, env):
- Makefile_am = open("Makefile.am", 'w')
- Makefile_am.write("""
- # File automatically generated by SConstruct ('scons autotools')
--# DOT NOT EDIT!
-+# DO NOT EDIT!
-
- BINDING =
- INCLUDE = vmime
-@@ -1123,7 +1123,7 @@ docdir = $(datadir)/doc/$(GENERIC_LIBRARY_NAME)
- Makefile_am = open("vmime/Makefile.am", 'w')
- Makefile_am.write("""
- # File automatically generated by SConstruct ('scons autotools')
--# DOT NOT EDIT!
-+# DO NOT EDIT!
- """)
-
- #Makefile_am.write(packageVersionedName + "includedir = $(prefix)/include/@GENERIC_VERSIONED_LIBRARY_NAME@/@GENERIC_LIBRARY_NAME@\n")
-@@ -1145,7 +1145,7 @@ docdir = $(datadir)/doc/$(GENERIC_LIBRARY_NAME)
- Makefile_am = open("src/Makefile.am", 'w')
- Makefile_am.write("""
- # File automatically generated by SConstruct ('scons autotools')
--# DOT NOT EDIT!
-+# DO NOT EDIT!
-
- AUTOMAKE_OPTIONS = no-dependencies foreign
- INTERNALS =
-@@ -1235,7 +1235,7 @@ noinst_HEADERS = $(INTERNALS)
- # configure.in
-
- # File automatically generated by SConstruct ('scons autotools')
--# DOT NOT EDIT!
-+# DO NOT EDIT!
-
- # Init
- """)
-
-commit 926e5c458c5e1c2950c29043e1f7464d26d20c6b
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue May 4 10:49:10 2010 +0000
-
- Use STARTTLS for additional connections (thanks to Andrei).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@545 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/net/imap/IMAPConnection.cpp b/src/net/imap/IMAPConnection.cpp
-index 6e5a265..825a002 100644
---- a/src/net/imap/IMAPConnection.cpp
-+++ b/src/net/imap/IMAPConnection.cpp
-@@ -156,7 +156,7 @@ void IMAPConnection::connect()
- const bool tlsRequired = HAS_PROPERTY(PROPERTY_CONNECTION_TLS_REQUIRED)
- && GET_PROPERTY(bool, PROPERTY_CONNECTION_TLS_REQUIRED);
-
-- if (!store->isSecuredConnection() && tls) // only if not IMAPS
-+ if (!store->isIMAPS() && tls) // only if not IMAPS
- {
- try
- {
-
-commit 9577cf0e03906b13210de550ee806f92fc45a373
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Fri May 14 16:56:20 2010 +0000
-
- Fixed parsing of header field value with no data on the first line (folding).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@546 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/headerField.cpp b/src/headerField.cpp
-index 52fe7e8..cdde8ec 100644
---- a/src/headerField.cpp
-+++ b/src/headerField.cpp
-@@ -146,6 +146,12 @@ ref <headerField> headerField::parseNext(const string& buffer, const string::siz
- {
- c = buffer[pos];
-
-+ // Check for folded line
-+ if (c == '\r' && pos + 2 < end && buffer[pos + 1] == '\n' &&
-+ (buffer[pos + 2] == ' ' || buffer[pos + 2] == '\t'))
-+ {
-+ pos += 3;
-+ }
- // Check for end of contents
- if (c == '\r' && pos + 1 < end && buffer[pos + 1] == '\n')
- {
-
-commit 25cb2c1432f4912106ab70dc1cea00fee21b91c0
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue May 18 13:52:27 2010 +0000
-
- Added helper function to construct parsed message from net message. Splitted IMAP source files.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@547 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/ChangeLog b/ChangeLog
-index 4031746..b824b4c 100644
---- a/ChangeLog
-+++ b/ChangeLog
-@@ -2,6 +2,11 @@
- VERSION 0.9.1svn
- ================
-
-+2010-05-18 Vincent Richard <vincent@vincent-richard.net>
-+
-+ * net/*: added helper function vmime::net::message::getParsedMessage()
-+ to construct a RFC-822 parsed message from a net message.
-+
- 2009-09-06 Vincent Richard <vincent@vincent-richard.net>
-
- * Relicensed VMime under the GNU GPL license version 3. Dual licensing
-diff --git a/SConstruct b/SConstruct
-index d05f8bc..99b2190 100644
---- a/SConstruct
-+++ b/SConstruct
-@@ -261,6 +261,9 @@ libvmime_messaging_proto_sources = [
- 'net/imap/IMAPMessage.cpp', 'net/imap/IMAPMessage.hpp',
- 'net/imap/IMAPTag.cpp', 'net/imap/IMAPTag.hpp',
- 'net/imap/IMAPUtils.cpp', 'net/imap/IMAPUtils.hpp',
-+ 'net/imap/IMAPMessagePartContentHandler.cpp', 'net/imap/IMAPMessagePartContentHandler.hpp',
-+ 'net/imap/IMAPStructure.cpp', 'net/imap/IMAPStructure.hpp',
-+ 'net/imap/IMAPPart.cpp', 'net/imap/IMAPPart.hpp',
- 'net/imap/IMAPParser.hpp',
- ]
- ],
-diff --git a/src/bodyPart.cpp b/src/bodyPart.cpp
-index 20bb102..7d60461 100644
---- a/src/bodyPart.cpp
-+++ b/src/bodyPart.cpp
-@@ -37,6 +37,15 @@ bodyPart::bodyPart()
- }
-
-
-+bodyPart::bodyPart(weak_ref <vmime::bodyPart> parentPart)
-+ : m_header(vmime::create <header>()),
-+ m_body(vmime::create <body>()),
-+ m_parent(parentPart)
-+{
-+ m_body->setParentPart(thisRef().dynamicCast <bodyPart>());
-+}
-+
-+
- void bodyPart::parse(const string& buffer, const string::size_type position,
- const string::size_type end, string::size_type* newPosition)
- {
-diff --git a/src/headerField.cpp b/src/headerField.cpp
-index cdde8ec..d1d4236 100644
---- a/src/headerField.cpp
-+++ b/src/headerField.cpp
-@@ -300,7 +300,8 @@ const std::vector <ref <const component> > headerField::getChildComponents() con
- {
- std::vector <ref <const component> > list;
-
-- list.push_back(m_value);
-+ if (m_value)
-+ list.push_back(m_value);
-
- return (list);
- }
-diff --git a/src/net/imap/IMAPMessage.cpp b/src/net/imap/IMAPMessage.cpp
-index 29c2aea..adfef01 100644
---- a/src/net/imap/IMAPMessage.cpp
-+++ b/src/net/imap/IMAPMessage.cpp
-@@ -27,6 +27,9 @@
- #include "vmime/net/imap/IMAPStore.hpp"
- #include "vmime/net/imap/IMAPConnection.hpp"
- #include "vmime/net/imap/IMAPUtils.hpp"
-+#include "vmime/net/imap/IMAPStructure.hpp"
-+#include "vmime/net/imap/IMAPPart.hpp"
-+#include "vmime/net/imap/IMAPMessagePartContentHandler.hpp"
-
- #include <sstream>
- #include <iterator>
-@@ -38,198 +41,6 @@ namespace net {
- namespace imap {
-
-
--//
--// IMAPpart
--//
--
--class IMAPstructure;
--
--class IMAPpart : public part
--{
--private:
--
-- friend class vmime::creator;
--
-- IMAPpart(ref <IMAPpart> parent, const int number, const IMAPParser::body_type_mpart* mpart);
-- IMAPpart(ref <IMAPpart> parent, const int number, const IMAPParser::body_type_1part* part);
--
--public:
--
-- ref <const structure> getStructure() const;
-- ref <structure> getStructure();
--
-- ref <const IMAPpart> getParent() const { return m_parent.acquire(); }
--
-- const mediaType& getType() const { return (m_mediaType); }
-- int getSize() const { return (m_size); }
-- int getNumber() const { return (m_number); }
--
-- ref <const header> getHeader() const
-- {
-- if (m_header == NULL)
-- throw exceptions::unfetched_object();
-- else
-- return m_header;
-- }
--
--
-- static ref <IMAPpart> create
-- (ref <IMAPpart> parent, const int number, const IMAPParser::body* body)
-- {
-- if (body->body_type_mpart())
-- {
-- ref <IMAPpart> part = vmime::create <IMAPpart>(parent, number, body->body_type_mpart());
-- part->m_structure = vmime::create <IMAPstructure>(part, body->body_type_mpart()->list());
--
-- return part;
-- }
-- else
-- {
-- return vmime::create <IMAPpart>(parent, number, body->body_type_1part());
-- }
-- }
--
--
-- header& getOrCreateHeader()
-- {
-- if (m_header != NULL)
-- return (*m_header);
-- else
-- return (*(m_header = vmime::create <header>()));
-- }
--
--private:
--
-- ref <IMAPstructure> m_structure;
-- weak_ref <IMAPpart> m_parent;
-- ref <header> m_header;
--
-- int m_number;
-- int m_size;
-- mediaType m_mediaType;
--};
--
--
--
--//
--// IMAPstructure
--//
--
--class IMAPstructure : public structure
--{
--public:
--
-- IMAPstructure()
-- {
-- }
--
-- IMAPstructure(const IMAPParser::body* body)
-- {
-- m_parts.push_back(IMAPpart::create(NULL, 0, body));
-- }
--
-- IMAPstructure(ref <IMAPpart> parent, const std::vector <IMAPParser::body*>& list)
-- {
-- int number = 0;
--
-- for (std::vector <IMAPParser::body*>::const_iterator
-- it = list.begin() ; it != list.end() ; ++it, ++number)
-- {
-- m_parts.push_back(IMAPpart::create(parent, number, *it));
-- }
-- }
--
--
-- ref <const part> getPartAt(const int x) const
-- {
-- return m_parts[x];
-- }
--
-- ref <part> getPartAt(const int x)
-- {
-- return m_parts[x];
-- }
--
-- int getPartCount() const
-- {
-- return m_parts.size();
-- }
--
--
-- static ref <IMAPstructure> emptyStructure()
-- {
-- return (m_emptyStructure);
-- }
--
--private:
--
-- static ref <IMAPstructure> m_emptyStructure;
--
-- std::vector <ref <IMAPpart> > m_parts;
--};
--
--
--ref <IMAPstructure> IMAPstructure::m_emptyStructure = vmime::create <IMAPstructure>();
--
--
--
--IMAPpart::IMAPpart(ref <IMAPpart> parent, const int number, const IMAPParser::body_type_mpart* mpart)
-- : m_parent(parent), m_header(NULL), m_number(number), m_size(0)
--{
-- m_mediaType = vmime::mediaType
-- ("multipart", mpart->media_subtype()->value());
--}
--
--
--IMAPpart::IMAPpart(ref <IMAPpart> parent, const int number, const IMAPParser::body_type_1part* part)
-- : m_parent(parent), m_header(NULL), m_number(number), m_size(0)
--{
-- if (part->body_type_text())
-- {
-- m_mediaType = vmime::mediaType
-- ("text", part->body_type_text()->
-- media_text()->media_subtype()->value());
--
-- m_size = part->body_type_text()->body_fields()->body_fld_octets()->value();
-- }
-- else if (part->body_type_msg())
-- {
-- m_mediaType = vmime::mediaType
-- ("message", part->body_type_msg()->
-- media_message()->media_subtype()->value());
-- }
-- else
-- {
-- m_mediaType = vmime::mediaType
-- (part->body_type_basic()->media_basic()->media_type()->value(),
-- part->body_type_basic()->media_basic()->media_subtype()->value());
--
-- m_size = part->body_type_basic()->body_fields()->body_fld_octets()->value();
-- }
--
-- m_structure = NULL;
--}
--
--
--ref <const structure> IMAPpart::getStructure() const
--{
-- if (m_structure != NULL)
-- return (m_structure);
-- else
-- return (IMAPstructure::emptyStructure());
--}
--
--
--ref <structure> IMAPpart::getStructure()
--{
-- if (m_structure != NULL)
-- return (m_structure);
-- else
-- return (IMAPstructure::emptyStructure());
--}
--
--
--
- #ifndef VMIME_BUILDING_DOC
-
- //
-@@ -400,7 +211,22 @@ void IMAPMessage::fetchPartHeader(ref <part> p)
-
- extract(p, ossAdapter, NULL, 0, -1, true, true);
-
-- p.dynamicCast <IMAPpart>()->getOrCreateHeader().parse(oss.str());
-+ p.dynamicCast <IMAPPart>()->getOrCreateHeader().parse(oss.str());
-+}
-+
-+
-+void IMAPMessage::fetchPartHeaderForStructure(ref <structure> str)
-+{
-+ for (int i = 0, n = str->getPartCount() ; i < n ; ++i)
-+ {
-+ ref <class part> part = str->getPartAt(i);
-+
-+ // Fetch header of current part
-+ fetchPartHeader(part);
-+
-+ // Fetch header of sub-parts
-+ fetchPartHeaderForStructure(part->getStructure());
-+ }
- }
-
-
-@@ -418,7 +244,7 @@ void IMAPMessage::extract(ref <const part> p, utility::outputStream& os,
-
- if (p != NULL)
- {
-- ref <const IMAPpart> currentPart = p.dynamicCast <const IMAPpart>();
-+ ref <const IMAPPart> currentPart = p.dynamicCast <const IMAPPart>();
- std::vector <int> numbers;
-
- numbers.push_back(currentPart->getNumber());
-@@ -446,8 +272,17 @@ void IMAPMessage::extract(ref <const part> p, utility::outputStream& os,
- command << "FETCH " << m_num << " BODY";
- if (peek) command << ".PEEK";
- command << "[";
-- command << section.str();
-- if (headerOnly) command << ".MIME"; // "MIME" not "HEADER" for parts
-+
-+ if (section.str().empty() && headerOnly)
-+ {
-+ command << "HEADER";
-+ }
-+ else
-+ {
-+ command << section.str();
-+ if (headerOnly) command << ".MIME"; // "MIME" not "HEADER" for parts
-+ }
-+
- command << "]";
-
- if (start != 0 || length != -1)
-@@ -621,7 +456,7 @@ void IMAPMessage::processFetchResponse
- }
- case IMAPParser::msg_att_item::BODY_STRUCTURE:
- {
-- m_structure = vmime::create <IMAPstructure>((*it)->body());
-+ m_structure = vmime::create <IMAPStructure>((*it)->body());
- break;
- }
- case IMAPParser::msg_att_item::RFC822_HEADER:
-@@ -796,6 +631,80 @@ void IMAPMessage::setFlags(const int flags, const int mode)
- }
-
-
-+void IMAPMessage::constructParsedMessage(ref <bodyPart> parentPart, ref <structure> str, int level)
-+{
-+ if (level == 0)
-+ {
-+ ref <class part> part = str->getPartAt(0);
-+
-+ // Copy header
-+ ref <const header> hdr = part->getHeader();
-+ parentPart->getHeader()->copyFrom(*hdr);
-+
-+ // Initialize body
-+ parentPart->getBody()->setContents
-+ (vmime::create <IMAPMessagePartContentHandler>
-+ (thisRef().dynamicCast <IMAPMessage>(),
-+ part, parentPart->getBody()->getEncoding()));
-+
-+ constructParsedMessage(parentPart, part->getStructure(), 1);
-+ }
-+ else
-+ {
-+ for (int i = 0, n = str->getPartCount() ; i < n ; ++i)
-+ {
-+ ref <class part> part = str->getPartAt(i);
-+
-+ ref <bodyPart> childPart = vmime::create <bodyPart>();
-+
-+ // Copy header
-+ ref <const header> hdr = part->getHeader();
-+ childPart->getHeader()->copyFrom(*hdr);
-+
-+ // Initialize body
-+ childPart->getBody()->setContents
-+ (vmime::create <IMAPMessagePartContentHandler>
-+ (thisRef().dynamicCast <IMAPMessage>(),
-+ part, childPart->getBody()->getEncoding()));
-+
-+ // Add child part
-+ parentPart->getBody()->appendPart(childPart);
-+
-+ // Construct sub parts
-+ constructParsedMessage(childPart, part->getStructure(), ++level);
-+ }
-+ }
-+}
-+
-+
-+ref <vmime::message> IMAPMessage::getParsedMessage()
-+{
-+ // Fetch structure
-+ ref <structure> structure = NULL;
-+
-+ try
-+ {
-+ structure = getStructure();
-+ }
-+ catch (exceptions::unfetched_object&)
-+ {
-+ fetch(m_folder.acquire(), IMAPFolder::FETCH_STRUCTURE);
-+ structure = getStructure();
-+ }
-+
-+ // Fetch header for each part
-+ fetchPartHeaderForStructure(structure);
-+
-+ // Construct message from structure
-+ ref <vmime::message> msg = vmime::create <vmime::message>();
-+
-+ constructParsedMessage(msg, structure);
-+
-+ return msg;
-+}
-+
-+
- } // imap
- } // net
- } // vmime
-+
-diff --git a/src/net/imap/IMAPMessagePartContentHandler.cpp b/src/net/imap/IMAPMessagePartContentHandler.cpp
-new file mode 100644
-index 0000000..12d387c
---- /dev/null
-+++ b/src/net/imap/IMAPMessagePartContentHandler.cpp
-@@ -0,0 +1,179 @@
-+//
-+// VMime library (http://www.vmime.org)
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
-+//
-+// 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 3 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.,
-+// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
-+//
-+// Linking this library statically or dynamically with other modules is making
-+// a combined work based on this library. Thus, the terms and conditions of
-+// the GNU General Public License cover the whole combination.
-+//
-+
-+#include "vmime/net/imap/imapmessagepartcontenthandler.hpp"
-+
-+
-+namespace vmime {
-+namespace net {
-+namespace imap {
-+
-+
-+IMAPMessagePartContentHandler::IMAPMessagePartContentHandler
-+ (ref <IMAPMessage> msg, ref <class part> part, const vmime::encoding& encoding)
-+ : m_message(msg), m_part(part), m_encoding(encoding)
-+{
-+}
-+
-+
-+ref <contentHandler> IMAPMessagePartContentHandler::clone() const
-+{
-+ return create <IMAPMessagePartContentHandler>
-+ (m_message.acquire().constCast <IMAPMessage>(),
-+ m_part.acquire().constCast <part>(),
-+ m_encoding);
-+}
-+
-+
-+void IMAPMessagePartContentHandler::generate
-+ (utility::outputStream& os, const vmime::encoding& enc, const string::size_type maxLineLength) const
-+{
-+ ref <IMAPMessage> msg = m_message.acquire().constCast <IMAPMessage>();
-+ ref <part> part = m_part.acquire().constCast <class part>();
-+
-+ // Data is already encoded
-+ if (isEncoded())
-+ {
-+ // The data is already encoded but the encoding specified for
-+ // the generation is different from the current one. We need
-+ // to re-encode data: decode from input buffer to temporary
-+ // buffer, and then re-encode to output stream...
-+ if (m_encoding != enc)
-+ {
-+ // Extract part contents to temporary buffer
-+ std::ostringstream oss;
-+ utility::outputStreamAdapter tmp(oss);
-+
-+ msg->extractPart(part, tmp, NULL);
-+
-+ // Decode to another temporary buffer
-+ utility::inputStreamStringProxyAdapter in(oss.str());
-+
-+ std::ostringstream oss2;
-+ utility::outputStreamAdapter tmp2(oss2);
-+
-+ ref <utility::encoder::encoder> theDecoder = m_encoding.getEncoder();
-+ theDecoder->decode(in, tmp2);
-+
-+ // Reencode to output stream
-+ string str = oss2.str();
-+ utility::inputStreamStringAdapter tempIn(str);
-+
-+ ref <utility::encoder::encoder> theEncoder = enc.getEncoder();
-+ theEncoder->getProperties()["maxlinelength"] = maxLineLength;
-+ theEncoder->encode(tempIn, os);
-+ }
-+ // No encoding to perform
-+ else
-+ {
-+ msg->extractPart(part, os);
-+ }
-+ }
-+ // Need to encode data before
-+ else
-+ {
-+ // Extract part contents to temporary buffer
-+ std::ostringstream oss;
-+ utility::outputStreamAdapter tmp(oss);
-+
-+ msg->extractPart(part, tmp, NULL);
-+
-+ // Encode temporary buffer to output stream
-+ ref <utility::encoder::encoder> theEncoder = enc.getEncoder();
-+ theEncoder->getProperties()["maxlinelength"] = maxLineLength;
-+
-+ utility::inputStreamStringAdapter is(oss.str());
-+
-+ theEncoder->encode(is, os);
-+ }
-+}
-+
-+
-+void IMAPMessagePartContentHandler::extract
-+ (utility::outputStream& os, utility::progressListener* progress) const
-+{
-+ ref <IMAPMessage> msg = m_message.acquire().constCast <IMAPMessage>();
-+ ref <part> part = m_part.acquire().constCast <class part>();
-+
-+ // No decoding to perform
-+ if (!isEncoded())
-+ {
-+ msg->extractPart(part, os, progress);
-+ }
-+ // Need to decode data
-+ else
-+ {
-+ // Extract part contents to temporary buffer
-+ std::ostringstream oss;
-+ utility::outputStreamAdapter tmp(oss);
-+
-+ msg->extractPart(part, tmp, NULL);
-+
-+ // Encode temporary buffer to output stream
-+ utility::inputStreamStringAdapter is(oss.str());
-+ utility::progressListenerSizeAdapter plsa(progress, getLength());
-+
-+ ref <utility::encoder::encoder> theDecoder = m_encoding.getEncoder();
-+ theDecoder->decode(is, os, &plsa);
-+ }
-+}
-+
-+
-+void IMAPMessagePartContentHandler::extractRaw
-+ (utility::outputStream& os, utility::progressListener* progress) const
-+{
-+ ref <IMAPMessage> msg = m_message.acquire().constCast <IMAPMessage>();
-+ ref <part> part = m_part.acquire().constCast <class part>();
-+
-+ msg->extractPart(part, os, progress);
-+}
-+
-+
-+string::size_type IMAPMessagePartContentHandler::getLength() const
-+{
-+ return m_part.acquire()->getSize();
-+}
-+
-+
-+bool IMAPMessagePartContentHandler::isEncoded() const
-+{
-+ return m_encoding != NO_ENCODING;
-+}
-+
-+
-+const vmime::encoding& IMAPMessagePartContentHandler::getEncoding() const
-+{
-+ return m_encoding;
-+}
-+
-+
-+bool IMAPMessagePartContentHandler::isEmpty() const
-+{
-+ return getLength() == 0;
-+}
-+
-+
-+} // imap
-+} // net
-+} // vmime
-+
-diff --git a/src/net/imap/IMAPPart.cpp b/src/net/imap/IMAPPart.cpp
-new file mode 100644
-index 0000000..32021e8
---- /dev/null
-+++ b/src/net/imap/IMAPPart.cpp
-@@ -0,0 +1,152 @@
-+//
-+// VMime library (http://www.vmime.org)
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
-+//
-+// 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 3 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.,
-+// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
-+//
-+// Linking this library statically or dynamically with other modules is making
-+// a combined work based on this library. Thus, the terms and conditions of
-+// the GNU General Public License cover the whole combination.
-+//
-+
-+#include "vmime/net/imap/IMAPPart.hpp"
-+#include "vmime/net/imap/IMAPStructure.hpp"
-+
-+
-+namespace vmime {
-+namespace net {
-+namespace imap {
-+
-+
-+IMAPPart::IMAPPart(ref <IMAPPart> parent, const int number, const IMAPParser::body_type_mpart* mpart)
-+ : m_parent(parent), m_header(NULL), m_number(number), m_size(0)
-+{
-+ m_mediaType = vmime::mediaType
-+ ("multipart", mpart->media_subtype()->value());
-+}
-+
-+
-+IMAPPart::IMAPPart(ref <IMAPPart> parent, const int number, const IMAPParser::body_type_1part* part)
-+ : m_parent(parent), m_header(NULL), m_number(number), m_size(0)
-+{
-+ if (part->body_type_text())
-+ {
-+ m_mediaType = vmime::mediaType
-+ ("text", part->body_type_text()->
-+ media_text()->media_subtype()->value());
-+
-+ m_size = part->body_type_text()->body_fields()->body_fld_octets()->value();
-+ }
-+ else if (part->body_type_msg())
-+ {
-+ m_mediaType = vmime::mediaType
-+ ("message", part->body_type_msg()->
-+ media_message()->media_subtype()->value());
-+ }
-+ else
-+ {
-+ m_mediaType = vmime::mediaType
-+ (part->body_type_basic()->media_basic()->media_type()->value(),
-+ part->body_type_basic()->media_basic()->media_subtype()->value());
-+
-+ m_size = part->body_type_basic()->body_fields()->body_fld_octets()->value();
-+ }
-+
-+ m_structure = NULL;
-+}
-+
-+
-+ref <const structure> IMAPPart::getStructure() const
-+{
-+ if (m_structure != NULL)
-+ return m_structure;
-+ else
-+ return IMAPStructure::emptyStructure();
-+}
-+
-+
-+ref <structure> IMAPPart::getStructure()
-+{
-+ if (m_structure != NULL)
-+ return m_structure;
-+ else
-+ return IMAPStructure::emptyStructure();
-+}
-+
-+
-+ref <const IMAPPart> IMAPPart::getParent() const
-+{
-+ return m_parent.acquire();
-+}
-+
-+
-+const mediaType& IMAPPart::getType() const
-+{
-+ return m_mediaType;
-+}
-+
-+
-+int IMAPPart::getSize() const
-+{
-+ return m_size;
-+}
-+
-+
-+int IMAPPart::getNumber() const
-+{
-+ return m_number;
-+}
-+
-+
-+ref <const header> IMAPPart::getHeader() const
-+{
-+ if (m_header == NULL)
-+ throw exceptions::unfetched_object();
-+ else
-+ return m_header;
-+}
-+
-+
-+// static
-+ref <IMAPPart> IMAPPart::create
-+ (ref <IMAPPart> parent, const int number, const IMAPParser::body* body)
-+{
-+ if (body->body_type_mpart())
-+ {
-+ ref <IMAPPart> part = vmime::create <IMAPPart>(parent, number, body->body_type_mpart());
-+ part->m_structure = vmime::create <IMAPStructure>(part, body->body_type_mpart()->list());
-+
-+ return part;
-+ }
-+ else
-+ {
-+ return vmime::create <IMAPPart>(parent, number, body->body_type_1part());
-+ }
-+}
-+
-+
-+header& IMAPPart::getOrCreateHeader()
-+{
-+ if (m_header != NULL)
-+ return *m_header;
-+ else
-+ return *(m_header = vmime::create <header>());
-+}
-+
-+
-+} // imap
-+} // net
-+} // vmime
-+
-diff --git a/src/net/imap/IMAPStructure.cpp b/src/net/imap/IMAPStructure.cpp
-new file mode 100644
-index 0000000..357febe
---- /dev/null
-+++ b/src/net/imap/IMAPStructure.cpp
-@@ -0,0 +1,85 @@
-+//
-+// VMime library (http://www.vmime.org)
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
-+//
-+// 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 3 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.,
-+// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
-+//
-+// Linking this library statically or dynamically with other modules is making
-+// a combined work based on this library. Thus, the terms and conditions of
-+// the GNU General Public License cover the whole combination.
-+//
-+
-+#include "vmime/net/imap/IMAPStructure.hpp"
-+#include "vmime/net/imap/IMAPPart.hpp"
-+
-+
-+namespace vmime {
-+namespace net {
-+namespace imap {
-+
-+
-+IMAPStructure::IMAPStructure()
-+{
-+}
-+
-+
-+IMAPStructure::IMAPStructure(const IMAPParser::body* body)
-+{
-+ m_parts.push_back(IMAPPart::create(NULL, 0, body));
-+}
-+
-+
-+IMAPStructure::IMAPStructure(ref <IMAPPart> parent, const std::vector <IMAPParser::body*>& list)
-+{
-+ int number = 0;
-+
-+ for (std::vector <IMAPParser::body*>::const_iterator
-+ it = list.begin() ; it != list.end() ; ++it, ++number)
-+ {
-+ m_parts.push_back(IMAPPart::create(parent, number, *it));
-+ }
-+}
-+
-+
-+ref <const part> IMAPStructure::getPartAt(const int x) const
-+{
-+ return m_parts[x];
-+}
-+
-+
-+ref <part> IMAPStructure::getPartAt(const int x)
-+{
-+ return m_parts[x];
-+}
-+
-+
-+int IMAPStructure::getPartCount() const
-+{
-+ return m_parts.size();
-+}
-+
-+
-+// static
-+ref <IMAPStructure> IMAPStructure::emptyStructure()
-+{
-+ static ref <IMAPStructure> emptyStructure = vmime::create <IMAPStructure>();
-+ return emptyStructure;
-+}
-+
-+
-+} // imap
-+} // net
-+} // vmime
-+
-diff --git a/src/net/maildir/maildirMessage.cpp b/src/net/maildir/maildirMessage.cpp
-index 8999d84..51cd1ba 100644
---- a/src/net/maildir/maildirMessage.cpp
-+++ b/src/net/maildir/maildirMessage.cpp
-@@ -524,6 +524,20 @@ ref <header> maildirMessage::getOrCreateHeader()
- }
-
-
-+ref <vmime::message> maildirMessage::getParsedMessage()
-+{
-+ std::ostringstream oss;
-+ utility::outputStreamAdapter os(oss);
-+
-+ extract(os);
-+
-+ vmime::ref <vmime::message> msg = vmime::create <vmime::message>();
-+ msg->parse(oss.str());
-+
-+ return msg;
-+}
-+
-+
- } // maildir
- } // net
- } // vmime
-diff --git a/src/net/pop3/POP3Message.cpp b/src/net/pop3/POP3Message.cpp
-index b38951b..50f4f87 100644
---- a/src/net/pop3/POP3Message.cpp
-+++ b/src/net/pop3/POP3Message.cpp
-@@ -218,6 +218,20 @@ void POP3Message::setFlags(const int /* flags */, const int /* mode */)
- }
-
-
-+ref <vmime::message> POP3Message::getParsedMessage()
-+{
-+ std::ostringstream oss;
-+ utility::outputStreamAdapter os(oss);
-+
-+ extract(os);
-+
-+ vmime::ref <vmime::message> msg = vmime::create <vmime::message>();
-+ msg->parse(oss.str());
-+
-+ return msg;
-+}
-+
-+
- } // pop3
- } // net
- } // vmime
-diff --git a/vmime/bodyPart.hpp b/vmime/bodyPart.hpp
-index 47c11cb..aa0f040 100644
---- a/vmime/bodyPart.hpp
-+++ b/vmime/bodyPart.hpp
-@@ -46,6 +46,7 @@ class bodyPart : public component
- public:
-
- bodyPart();
-+ bodyPart(weak_ref <vmime::bodyPart> parentPart);
-
- /** Return the header section of this part.
- *
-diff --git a/vmime/contentHandler.hpp b/vmime/contentHandler.hpp
-index aa485f5..38e4e24 100644
---- a/vmime/contentHandler.hpp
-+++ b/vmime/contentHandler.hpp
-@@ -87,7 +87,8 @@ public:
- virtual void extractRaw(utility::outputStream& os, utility::progressListener* progress = NULL) const = 0;
-
- /** Returns the actual length of data. WARNING: this can return 0 if no
-- * length was specified when setting data of this object.
-+ * length was specified when setting data of this object, or if the
-+ * length is not known).
- *
- * @return length of data
- */
-diff --git a/vmime/net/imap/IMAPMessage.hpp b/vmime/net/imap/IMAPMessage.hpp
-index 690e5e2..edbf69f 100644
---- a/vmime/net/imap/IMAPMessage.hpp
-+++ b/vmime/net/imap/IMAPMessage.hpp
-@@ -28,6 +28,8 @@
- #include "vmime/net/message.hpp"
- #include "vmime/net/folder.hpp"
-
-+#include "vmime/net/imap/IMAPParser.hpp"
-+
-
- namespace vmime {
- namespace net {
-@@ -75,12 +77,29 @@ public:
-
- void fetchPartHeader(ref <part> p);
-
-+ ref <vmime::message> getParsedMessage();
-+
- private:
-
- void fetch(ref <IMAPFolder> folder, const int options);
-
- void processFetchResponse(const int options, const IMAPParser::msg_att* msgAtt);
-
-+ /** Recursively fetch part header for all parts in the structure.
-+ *
-+ * @param str structure for which to fetch parts headers
-+ */
-+ void fetchPartHeaderForStructure(ref <structure> str);
-+
-+ /** Recursively contruct parsed message from structure.
-+ * Called by getParsedMessage().
-+ *
-+ * @param parentPart root body part (the message)
-+ * @param str structure for which to construct part
-+ * @param level current nesting level (0 is root)
-+ */
-+ void constructParsedMessage(ref <bodyPart> parentPart, ref <structure> str, int level = 0);
-+
- void extract(ref <const part> p, utility::outputStream& os, utility::progressListener* progress, const int start, const int length, const bool headerOnly, const bool peek) const;
-
-
-diff --git a/vmime/net/imap/IMAPMessagePartContentHandler.hpp b/vmime/net/imap/IMAPMessagePartContentHandler.hpp
-new file mode 100644
-index 0000000..0c4641e
---- /dev/null
-+++ b/vmime/net/imap/IMAPMessagePartContentHandler.hpp
-@@ -0,0 +1,73 @@
-+//
-+// VMime library (http://www.vmime.org)
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
-+//
-+// 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 3 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.,
-+// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
-+//
-+// Linking this library statically or dynamically with other modules is making
-+// a combined work based on this library. Thus, the terms and conditions of
-+// the GNU General Public License cover the whole combination.
-+//
-+
-+#ifndef VMIME_NET_IMAP_IMAPMESSAGEPARTCONTENTHANDLER_HPP_INCLUDED
-+#define VMIME_NET_IMAP_IMAPMESSAGEPARTCONTENTHANDLER_HPP_INCLUDED
-+
-+
-+#include "vmime/contentHandler.hpp"
-+#include "vmime/net/imap/IMAPMessage.hpp"
-+
-+
-+namespace vmime {
-+namespace net {
-+namespace imap {
-+
-+
-+class IMAPMessagePartContentHandler : public contentHandler
-+{
-+public:
-+
-+ IMAPMessagePartContentHandler(ref <IMAPMessage> msg, ref <class part> part, const vmime::encoding& encoding);
-+
-+ ref <contentHandler> clone() const;
-+
-+ void generate(utility::outputStream& os, const vmime::encoding& enc, const string::size_type maxLineLength = lineLengthLimits::infinite) const;
-+
-+ void extract(utility::outputStream& os, utility::progressListener* progress = NULL) const;
-+ void extractRaw(utility::outputStream& os, utility::progressListener* progress = NULL) const;
-+
-+ string::size_type getLength() const;
-+
-+ bool isEncoded() const;
-+
-+ const vmime::encoding& getEncoding() const;
-+
-+ bool isEmpty() const;
-+
-+private:
-+
-+ weak_ref <IMAPMessage> m_message;
-+ weak_ref <part> m_part;
-+
-+ vmime::encoding m_encoding;
-+};
-+
-+
-+} // imap
-+} // net
-+} // vmime
-+
-+
-+#endif // VMIME_NET_IMAP_IMAPMESSAGEPARTCONTENTHANDLER_HPP_INCLUDED
-+
-diff --git a/vmime/net/imap/IMAPPart.hpp b/vmime/net/imap/IMAPPart.hpp
-new file mode 100644
-index 0000000..d84db1b
---- /dev/null
-+++ b/vmime/net/imap/IMAPPart.hpp
-@@ -0,0 +1,88 @@
-+//
-+// VMime library (http://www.vmime.org)
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
-+//
-+// 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 3 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.,
-+// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
-+//
-+// Linking this library statically or dynamically with other modules is making
-+// a combined work based on this library. Thus, the terms and conditions of
-+// the GNU General Public License cover the whole combination.
-+//
-+
-+#ifndef VMIME_NET_IMAP_IMAPPART_HPP_INCLUDED
-+#define VMIME_NET_IMAP_IMAPPART_HPP_INCLUDED
-+
-+
-+#include "vmime/net/message.hpp"
-+
-+#include "vmime/net/imap/IMAPParser.hpp"
-+
-+
-+namespace vmime {
-+namespace net {
-+namespace imap {
-+
-+
-+class IMAPStructure;
-+
-+
-+class IMAPPart : public part
-+{
-+private:
-+
-+ friend class vmime::creator;
-+
-+ IMAPPart(ref <IMAPPart> parent, const int number, const IMAPParser::body_type_mpart* mpart);
-+ IMAPPart(ref <IMAPPart> parent, const int number, const IMAPParser::body_type_1part* part);
-+
-+public:
-+
-+ ref <const structure> getStructure() const;
-+ ref <structure> getStructure();
-+
-+ ref <const IMAPPart> getParent() const;
-+
-+ const mediaType& getType() const;
-+ int getSize() const;
-+ int getNumber() const;
-+
-+ ref <const header> getHeader() const;
-+
-+
-+ static ref <IMAPPart> create
-+ (ref <IMAPPart> parent, const int number, const IMAPParser::body* body);
-+
-+
-+ header& getOrCreateHeader();
-+
-+private:
-+
-+ ref <IMAPStructure> m_structure;
-+ weak_ref <IMAPPart> m_parent;
-+ ref <header> m_header;
-+
-+ int m_number;
-+ int m_size;
-+ mediaType m_mediaType;
-+};
-+
-+
-+} // imap
-+} // net
-+} // vmime
-+
-+
-+#endif // VMIME_NET_IMAP_IMAPPART_HPP_INCLUDED
-+
-diff --git a/vmime/net/imap/IMAPStructure.hpp b/vmime/net/imap/IMAPStructure.hpp
-new file mode 100644
-index 0000000..e43676c
---- /dev/null
-+++ b/vmime/net/imap/IMAPStructure.hpp
-@@ -0,0 +1,67 @@
-+//
-+// VMime library (http://www.vmime.org)
-+// Copyright (C) 2002-2009 Vincent Richard <vincent@vincent-richard.net>
-+//
-+// 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 3 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.,
-+// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
-+//
-+// Linking this library statically or dynamically with other modules is making
-+// a combined work based on this library. Thus, the terms and conditions of
-+// the GNU General Public License cover the whole combination.
-+//
-+
-+#ifndef VMIME_NET_IMAP_IMAPSTRUCTURE_HPP_INCLUDED
-+#define VMIME_NET_IMAP_IMAPSTRUCTURE_HPP_INCLUDED
-+
-+
-+#include "vmime/net/message.hpp"
-+
-+#include "vmime/net/imap/IMAPParser.hpp"
-+
-+
-+namespace vmime {
-+namespace net {
-+namespace imap {
-+
-+
-+class IMAPPart;
-+
-+
-+class IMAPStructure : public structure
-+{
-+public:
-+
-+ IMAPStructure();
-+ IMAPStructure(const IMAPParser::body* body);
-+ IMAPStructure(ref <IMAPPart> parent, const std::vector <IMAPParser::body*>& list);
-+
-+ ref <const part> getPartAt(const int x) const;
-+ ref <part> getPartAt(const int x);
-+ int getPartCount() const;
-+
-+ static ref <IMAPStructure> emptyStructure();
-+
-+private:
-+
-+ std::vector <ref <IMAPPart> > m_parts;
-+};
-+
-+
-+} // imap
-+} // net
-+} // vmime
-+
-+
-+#endif // VMIME_NET_IMAP_IMAPSTRUCTURE_HPP_INCLUDED
-+
-diff --git a/vmime/net/maildir/maildirMessage.hpp b/vmime/net/maildir/maildirMessage.hpp
-index ba3c88e..cd66d43 100644
---- a/vmime/net/maildir/maildirMessage.hpp
-+++ b/vmime/net/maildir/maildirMessage.hpp
-@@ -75,6 +75,8 @@ public:
-
- void fetchPartHeader(ref <part> p);
-
-+ ref <vmime::message> getParsedMessage();
-+
- private:
-
- void fetch(ref <maildirFolder> folder, const int options);
-diff --git a/vmime/net/message.hpp b/vmime/net/message.hpp
-index a0cc1da..b6ebef8 100644
---- a/vmime/net/message.hpp
-+++ b/vmime/net/message.hpp
-@@ -31,6 +31,8 @@
- #include "vmime/utility/progressListener.hpp"
- #include "vmime/utility/stream.hpp"
-
-+#include "vmime/message.hpp"
-+
-
- namespace vmime {
- namespace net {
-@@ -286,6 +288,16 @@ public:
- * @param p the part for which to fetch the header
- */
- virtual void fetchPartHeader(ref <part> p) = 0;
-+
-+ /** Get the RFC-822 message for this abstract message.
-+ * Warning: This may require getting some data (ie: structure and headers) from
-+ * the server, which is done automatically. Actual message contents (ie: body)
-+ * will not be fetched if possible (IMAP allows it, whereas POP3 will require
-+ * to fetch the whole message).
-+ *
-+ * @return a RFC-822-parsed message
-+ */
-+ virtual ref <vmime::message> getParsedMessage() = 0;
- };
-
-
-diff --git a/vmime/net/pop3/POP3Message.hpp b/vmime/net/pop3/POP3Message.hpp
-index 5dbea3f..337cc5d 100644
---- a/vmime/net/pop3/POP3Message.hpp
-+++ b/vmime/net/pop3/POP3Message.hpp
-@@ -77,6 +77,8 @@ public:
-
- void fetchPartHeader(ref <part> p);
-
-+ ref <vmime::message> getParsedMessage();
-+
- private:
-
- void fetch(ref <POP3Folder> folder, const int options);
-
-commit 6a967daa852e3ef6f277e8bbcf50e07770d04661
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Thu May 20 09:57:51 2010 +0000
-
- Fixed type size.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@548 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/security/digest/sha1/sha1MessageDigest.cpp b/src/security/digest/sha1/sha1MessageDigest.cpp
-index 6d99e3f..e4bcea4 100644
---- a/src/security/digest/sha1/sha1MessageDigest.cpp
-+++ b/src/security/digest/sha1/sha1MessageDigest.cpp
-@@ -135,7 +135,7 @@ void sha1MessageDigest::update(const byte_t* buffer, const unsigned long len)
-
- void sha1MessageDigest::finalize()
- {
-- unsigned long i, j;
-+ unsigned int i, j;
- unsigned char finalcount[8];
-
- for (i = 0 ; i < 8 ; i++)
-@@ -162,8 +162,8 @@ void sha1MessageDigest::finalize()
- i = j = 0;
-
- std::memset(m_buffer, 0, 64);
-- std::memset(m_state, 0, 5 * sizeof(unsigned long));
-- std::memset(m_count, 0, 2 * sizeof(unsigned long));
-+ std::memset(m_state, 0, 5 * sizeof(unsigned int));
-+ std::memset(m_count, 0, 2 * sizeof(unsigned int));
- std::memset(&finalcount, 0, 8);
- }
-
-@@ -192,17 +192,17 @@ void sha1MessageDigest::finalize(const byte_t* buffer,
- * This is the core of the algorithm.
- */
- void sha1MessageDigest::transform
-- (unsigned long state[5], const unsigned char buffer[64])
-+ (unsigned int state[5], const unsigned char buffer[64])
- {
-- unsigned long a, b, c, d, e;
-+ unsigned int a, b, c, d, e;
-
- typedef union
- {
- unsigned char c[64];
-- unsigned long l[16];
-+ unsigned int l[16];
- } CHAR64LONG16;
-
-- assert(sizeof(unsigned long) == 4);
-+ assert(sizeof(unsigned int) == 4);
-
- CHAR64LONG16* block;
- static unsigned char workspace[64];
-diff --git a/vmime/security/digest/sha1/sha1MessageDigest.hpp b/vmime/security/digest/sha1/sha1MessageDigest.hpp
-index 906009a..c8da349 100644
---- a/vmime/security/digest/sha1/sha1MessageDigest.hpp
-+++ b/vmime/security/digest/sha1/sha1MessageDigest.hpp
-@@ -59,10 +59,10 @@ protected:
-
- void init();
-
-- static void transform(unsigned long state[5], const byte_t buffer[64]);
-+ static void transform(unsigned int state[5], const byte_t buffer[64]);
-
-- unsigned long m_state[5];
-- unsigned long m_count[2];
-+ unsigned int m_state[5];
-+ unsigned int m_count[2];
- byte_t m_buffer[64];
-
- byte_t m_digest[20];
-
-commit 90f9e6fb020975996377f09e0569a17b8feaaf71
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Thu May 20 10:00:19 2010 +0000
-
- Fixed unit tests build on OSX.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@549 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/SConstruct b/SConstruct
-index 99b2190..fb01edf 100644
---- a/SConstruct
-+++ b/SConstruct
-@@ -962,6 +962,10 @@ if env['build_tests'] == 'yes':
- env = env.Clone()
- env.Append(LIBS = ['cppunit', 'dl', packageVersionedGenericName + '-debug', 'pthread'])
- env.Append(LIBPATH=['.'])
-+
-+ if sys.platform == "mac" or sys.platform == "darwin":
-+ env.Append(LIBS = ['iconv', 'gcrypt'])
-+
- Default(
- env.Program(
- target = 'run-tests',
-
-commit 8bdccea503ad998f029a13e3963877c416a6bc0c
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Thu May 20 15:28:51 2010 +0000
-
- Fixed case-sensitive include.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@550 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/net/imap/IMAPMessagePartContentHandler.cpp b/src/net/imap/IMAPMessagePartContentHandler.cpp
-index 12d387c..a226b68 100644
---- a/src/net/imap/IMAPMessagePartContentHandler.cpp
-+++ b/src/net/imap/IMAPMessagePartContentHandler.cpp
-@@ -21,7 +21,7 @@
- // the GNU General Public License cover the whole combination.
- //
-
--#include "vmime/net/imap/imapmessagepartcontenthandler.hpp"
-+#include "vmime/net/imap/IMAPMessagePartContentHandler.hpp"
-
-
- namespace vmime {
-
-commit ab5050b777359913f1e73b396dcc44da71870b29
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Fri May 21 06:01:33 2010 +0000
-
- Fixed missing #include.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@551 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/net/tls/TLSSession.cpp b/src/net/tls/TLSSession.cpp
-index d4eab3e..cb5351a 100644
---- a/src/net/tls/TLSSession.cpp
-+++ b/src/net/tls/TLSSession.cpp
-@@ -27,6 +27,7 @@
- #include "vmime/config.hpp"
-
- #if VMIME_HAVE_PTHREAD
-+# include <pthread.h>
- # include <gcrypt.h>
- # include <errno.h>
- #endif // VMIME_HAVE_PTHREAD
-
-commit bb65b540ddce6793cfb1d16bb3c07730ccd7a791
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Fri May 21 07:41:15 2010 +0000
-
- Always encode special charsets.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@552 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/utility/stringUtils.cpp b/src/utility/stringUtils.cpp
-index abae8f9..7f61a7d 100644
---- a/src/utility/stringUtils.cpp
-+++ b/src/utility/stringUtils.cpp
-@@ -151,6 +151,24 @@ string::size_type stringUtils::countASCIIchars
- }
-
-
-+string::size_type stringUtils::findFirstNonASCIIchar
-+ (const string::const_iterator begin, const string::const_iterator end)
-+{
-+ string::size_type pos = string::npos;
-+
-+ for (string::const_iterator i = begin ; i != end ; ++i)
-+ {
-+ if (!parserHelpers::isAscii(*i))
-+ {
-+ pos = i - begin;
-+ break;
-+ }
-+ }
-+
-+ return pos;
-+}
-+
-+
- const string stringUtils::unquote(const string& str)
- {
- if (str.length() < 2)
-diff --git a/src/word.cpp b/src/word.cpp
-index 667f1fb..9d0177f 100644
---- a/src/word.cpp
-+++ b/src/word.cpp
-@@ -336,30 +336,22 @@ void word::generate(utility::outputStream& os, const string::size_type maxLineLe
- if (state == NULL)
- state = &defaultGeneratorState;
-
-- // Calculate the number of ASCII chars to check whether encoding is needed
-- // and _which_ encoding to use.
-- const string::size_type asciiCount =
-- utility::stringUtils::countASCIIchars(m_buffer.begin(), m_buffer.end());
-+ // Find out if encoding is forced or required by contents + charset
-+ bool encodingNeeded = (flags & text::FORCE_ENCODING) != 0;
-
-- bool noEncoding = (flags & text::FORCE_NO_ENCODING) ||
-- (!(flags & text::FORCE_ENCODING) && asciiCount == m_buffer.length());
--
-- if (!(flags & text::FORCE_NO_ENCODING) &&
-- m_buffer.find_first_of("\n\r") != string::npos)
-- {
-- // Force encoding when there are only ASCII chars, but there is
-- // also at least one of '\n' or '\r' (header fields)
-- noEncoding = false;
-- }
-+ if (encodingNeeded == false)
-+ encodingNeeded = wordEncoder::isEncodingNeeded(m_buffer, m_charset);
-+ else if ((flags & text::FORCE_NO_ENCODING) != 0)
-+ encodingNeeded = false;
-
- // If possible and requested (with flag), quote the buffer (no folding is performed).
- // Quoting is possible if and only if:
-- // - the whole buffer is ASCII-only
-+ // - the buffer does not need to be encoded
- // - the buffer does not contain quoting character (")
- // - there is enough remaining space on the current line to hold the whole buffer
-- if (!noEncoding &&
-+ if (!encodingNeeded &&
- (flags & text::QUOTE_IF_POSSIBLE) &&
-- asciiCount == m_buffer.length() &&
-+ !encodingNeeded &&
- m_buffer.find('"') == string::npos &&
- (curLineLength + 2 /* 2 x " */ + m_buffer.length()) < maxLineLength)
- {
-@@ -367,7 +359,7 @@ void word::generate(utility::outputStream& os, const string::size_type maxLineLe
- curLineLength += 2 + m_buffer.length();
- }
- // We will fold lines without encoding them.
-- else if (noEncoding)
-+ else if (!encodingNeeded)
- {
- string::const_iterator lastWSpos = m_buffer.end(); // last white-space position
- string::const_iterator curLineStart = m_buffer.begin(); // current line start
-diff --git a/src/wordEncoder.cpp b/src/wordEncoder.cpp
-index 154b4ef..cc8292f 100644
---- a/src/wordEncoder.cpp
-+++ b/src/wordEncoder.cpp
-@@ -260,17 +260,75 @@ wordEncoder::Encoding wordEncoder::getEncoding() const
- }
-
-
-+// Explicitly force encoding for some charsets
-+struct CharsetEncodingEntry
-+{
-+ CharsetEncodingEntry(const std::string& charset_, const wordEncoder::Encoding encoding_)
-+ : charset(charset_), encoding(encoding_)
-+ {
-+ }
-+
-+ std::string charset;
-+ wordEncoder::Encoding encoding;
-+};
-+
-+CharsetEncodingEntry g_charsetEncodingMap[] =
-+{
-+ // Use QP encoding for ISO-8859-x charsets
-+ CharsetEncodingEntry("iso-8859", wordEncoder::ENCODING_QP),
-+ CharsetEncodingEntry("iso8859", wordEncoder::ENCODING_QP),
-+
-+ // RFC-1468 states:
-+ // " ISO-2022-JP may also be used in MIME Part 2 headers. The "B"
-+ // encoding should be used with ISO-2022-JP text. "
-+ // Use Base64 encoding for all ISO-2022 charsets.
-+ CharsetEncodingEntry("iso-2022", wordEncoder::ENCODING_B64),
-+ CharsetEncodingEntry("iso2022", wordEncoder::ENCODING_B64),
-+
-+ // Last entry is not used
-+ CharsetEncodingEntry("", wordEncoder::ENCODING_AUTO)
-+};
-+
-+
-+// static
-+bool wordEncoder::isEncodingNeeded(const string& buffer, const charset& charset)
-+{
-+ // Special treatment for some charsets
-+ const string cset = utility::stringUtils::toLower(charset.getName());
-+
-+ for (unsigned int i = 0 ; i < (sizeof(g_charsetEncodingMap) / sizeof(g_charsetEncodingMap[0])) - 1 ; ++i)
-+ {
-+ if (cset.find(g_charsetEncodingMap[i].charset) != string::npos)
-+ {
-+ if (g_charsetEncodingMap[i].encoding != wordEncoder::ENCODING_AUTO)
-+ return true;
-+ }
-+ }
-+
-+ // No encoding is needed if the buffer only contains ASCII chars
-+ if (utility::stringUtils::findFirstNonASCIIchar(buffer.begin(), buffer.end()) != string::npos)
-+ return true;
-+
-+ // Force encoding when there are only ASCII chars, but there is
-+ // also at least one of '\n' or '\r' (header fields)
-+ if (buffer.find_first_of("\n\r") != string::npos)
-+ return true;
-+
-+ return false;
-+}
-+
-+
- // static
- wordEncoder::Encoding wordEncoder::guessBestEncoding
- (const string& buffer, const charset& charset)
- {
-- // If the charset is ISO-8859-x, set to QP encoding
-+ // Special treatment for some charsets
- const string cset = utility::stringUtils::toLower(charset.getName());
-
-- if (cset.find("iso-8859") != string::npos ||
-- cset.find("iso8859") != string::npos)
-+ for (unsigned int i = 0 ; i < (sizeof(g_charsetEncodingMap) / sizeof(g_charsetEncodingMap[0])) - 1 ; ++i)
- {
-- return ENCODING_QP;
-+ if (cset.find(g_charsetEncodingMap[i].charset) != string::npos)
-+ return g_charsetEncodingMap[i].encoding;
- }
-
- // Use Base64 if more than 40% non-ASCII, or Quoted-Printable else (default)
-diff --git a/tests/parser/textTest.cpp b/tests/parser/textTest.cpp
-index 5c9b521..4a7e394 100644
---- a/tests/parser/textTest.cpp
-+++ b/tests/parser/textTest.cpp
-@@ -44,6 +44,8 @@ VMIME_TEST_SUITE_BEGIN
- VMIME_TEST(testWordGenerateSpace)
- VMIME_TEST(testWordGenerateSpace2)
- VMIME_TEST(testWordGenerateMultiBytes)
-+ VMIME_TEST(testWordGenerateQuote)
-+ VMIME_TEST(testWordGenerateSpecialCharsets)
- VMIME_TEST_LIST_END
-
-
-@@ -335,9 +337,38 @@ VMIME_TEST_SUITE_BEGIN
- VASSERT_EQ("1", "=?utf-8?Q?aaa?==?utf-8?Q?=C3=A9?==?utf-8?Q?zzz?=",
- cleanGeneratedWords(vmime::word("aaa\xc3\xa9zzz", vmime::charset("utf-8")).generate(16)));
-
-- VASSERT_EQ("1", "=?utf-8?Q?aaa=C3=A9?==?utf-8?Q?zzz?=",
-+ VASSERT_EQ("2", "=?utf-8?Q?aaa=C3=A9?==?utf-8?Q?zzz?=",
- cleanGeneratedWords(vmime::word("aaa\xc3\xa9zzz", vmime::charset("utf-8")).generate(17)));
- }
-
-+ void testWordGenerateQuote()
-+ {
-+ std::string str;
-+ vmime::utility::outputStreamStringAdapter os(str);
-+
-+ // ASCII-only text is quotable
-+ str.clear();
-+ vmime::word("Quoted text").generate(os, 1000, 0, NULL, vmime::text::QUOTE_IF_POSSIBLE, NULL);
-+ VASSERT_EQ("1", "\"Quoted text\"", cleanGeneratedWords(str));
-+
-+ // Text with CR/LF is not quotable
-+ str.clear();
-+ vmime::word("Non-quotable\ntext", "us-ascii").generate(os, 1000, 0, NULL, vmime::text::QUOTE_IF_POSSIBLE, NULL);
-+ VASSERT_EQ("2", "=?us-ascii?Q?Non-quotable=0Atext?=", cleanGeneratedWords(str));
-+
-+ // Text with non-ASCII chars is not quotable
-+ str.clear();
-+ vmime::word("Non-quotable text \xc3\xa9").generate(os, 1000, 0, NULL, vmime::text::QUOTE_IF_POSSIBLE, NULL);
-+ VASSERT_EQ("3", "=?UTF-8?Q?Non-quotable_text_=C3=A9?=", cleanGeneratedWords(str));
-+ }
-+
-+ void testWordGenerateSpecialCharsets()
-+ {
-+ // ISO-2022-JP only uses 7-bit chars but should be encoded in Base64
-+ VASSERT_EQ("1", "=?iso-2022-jp?B?XlskQiVRITwlPSVKJWshJiU9JVUlSCUmJSclIl5bKEI=?=",
-+ cleanGeneratedWords(vmime::word("^[$B%Q!<%=%J%k!&%=%U%H%&%'%\"^[(B",
-+ vmime::charset("iso-2022-jp")).generate(100)));
-+ }
-+
- VMIME_TEST_SUITE_END
-
-diff --git a/vmime/utility/stringUtils.hpp b/vmime/utility/stringUtils.hpp
-index b6589db..a8270d3 100644
---- a/vmime/utility/stringUtils.hpp
-+++ b/vmime/utility/stringUtils.hpp
-@@ -104,6 +104,14 @@ public:
- */
- static string::size_type countASCIIchars(const string::const_iterator begin, const string::const_iterator end);
-
-+ /** Returns the position of the first non 7-bit US-ASCII character in a string.
-+ *
-+ * @param begin start position
-+ * @param end end position
-+ * @return position since begin, or string::npos
-+ */
-+ static string::size_type findFirstNonASCIIchar(const string::const_iterator begin, const string::const_iterator end);
-+
- /** Convert the specified value to a string value.
- *
- * @param value to convert
-diff --git a/vmime/wordEncoder.hpp b/vmime/wordEncoder.hpp
-index 17ca808..1a492ea 100644
---- a/vmime/wordEncoder.hpp
-+++ b/vmime/wordEncoder.hpp
-@@ -73,12 +73,23 @@ public:
- */
- Encoding getEncoding() const;
-
--private:
-+ /** Test whether RFC-2047 encoding is needed.
-+ *
-+ * @param buffer buffer to analyze
-+ * @param charset charset of the buffer
-+ * @return true if encoding is needed, false otherwise.
-+ */
-+ static bool isEncodingNeeded(const string& buffer, const charset& charset);
-
-+ /** Guess the best RFC-2047 encoding to use for the specified buffer.
-+ *
-+ * @param buffer buffer to analyze
-+ * @param charset charset of the buffer
-+ * @return RFC-2047 encoding
-+ */
- static Encoding guessBestEncoding(const string& buffer, const charset& charset);
-
-- void guessBestEncoding();
--
-+private:
-
- string m_buffer;
- string::size_type m_pos;
-
-commit 2c3a4bcc74a56df6362657cb8fad4ab21bde287c
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Fri May 21 09:32:42 2010 +0000
-
- Rewritten doc.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@553 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/vmime/component.hpp b/vmime/component.hpp
-index f30a76c..b38127f 100644
---- a/vmime/component.hpp
-+++ b/vmime/component.hpp
-@@ -32,8 +32,8 @@ namespace vmime
- {
-
-
--/** This abstract class is the base for all the classes in the library.
-- * It defines the methods for parsing and generating all the components.
-+/** This abstract class is the base class for all the components of a message.
-+ * It defines methods for parsing and generating a component.
- */
-
- class component : public object
-
-commit 36aed261bed5604ce6ed4b39c3938db8712b2004
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sun May 23 16:14:41 2010 +0000
-
- FileSystemFactory is now a ref.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@554 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/examples/example3.cpp b/examples/example3.cpp
-index cb3e6ae..4fa482d 100644
---- a/examples/example3.cpp
-+++ b/examples/example3.cpp
-@@ -73,7 +73,7 @@ int main()
-
- // -- embed an image (the returned "CID" (content identifier) is used to reference
- // -- the image into HTML content).
-- vmime::utility::fileSystemFactory* fs =
-+ vmime::ref <vmime::utility::fileSystemFactory> fs =
- vmime::platform::getHandler()->getFileSystemFactory();
-
- vmime::ref <vmime::utility::file> imageFile =
-
-commit e959b4b3c3ff5228b33dc74c6f6305eeadc1f068
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sun May 23 16:18:00 2010 +0000
-
- Improved automatic encoding selection. Added helper functions on body for setting contents, type, charset and encoding.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@555 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/body.cpp b/src/body.cpp
-index 3f5ff0f..13dff6b 100644
---- a/src/body.cpp
-+++ b/src/body.cpp
-@@ -213,8 +213,26 @@ void body::parse(const string& buffer, const string::size_type position,
- // Treat the contents as 'simple' data
- else
- {
-+ encoding enc;
-+
-+ try
-+ {
-+ const ref <const headerField> cef =
-+ m_header.acquire()->findField(fields::CONTENT_TRANSFER_ENCODING);
-+
-+ enc = *cef->getValue().dynamicCast <const encoding>();
-+ }
-+ catch (exceptions::no_such_field&)
-+ {
-+ // Defaults to "7bit" (RFC-1521)
-+ enc = vmime::encoding(encodingTypes::SEVEN_BIT);
-+
-+ // Set header field
-+ m_header.acquire()->ContentTransferEncoding()->setValue(enc);
-+ }
-+
- // Extract the (encoded) contents
-- m_contents = vmime::create <stringContentHandler>(buffer, position, end, getEncoding());
-+ m_contents = vmime::create <stringContentHandler>(buffer, position, end, enc);
- }
-
- setParsedBounds(position, end);
-@@ -406,6 +424,22 @@ bool body::isValidBoundary(const string& boundary)
- // Quick-access functions
- //
-
-+
-+void body::setContentType(const mediaType& type, const charset& chset)
-+{
-+ ref <contentTypeField> ctf = m_header.acquire()->ContentType().dynamicCast <contentTypeField>();
-+
-+ ctf->setValue(type);
-+ ctf->setCharset(chset);
-+}
-+
-+
-+void body::setContentType(const mediaType& type)
-+{
-+ m_header.acquire()->ContentType()->setValue(type);
-+}
-+
-+
- const mediaType body::getContentType() const
- {
- try
-@@ -423,6 +457,25 @@ const mediaType body::getContentType() const
- }
-
-
-+void body::setCharset(const charset& chset)
-+{
-+ // If a Content-Type field exists, set charset
-+ try
-+ {
-+ ref <contentTypeField> ctf =
-+ m_header.acquire()->findField(fields::CONTENT_TYPE).dynamicCast <contentTypeField>();
-+
-+ ctf->setCharset(chset);
-+ }
-+ // Else, create a new Content-Type field of default type "text/plain"
-+ // and set charset on it
-+ catch (exceptions::no_such_field&)
-+ {
-+ setContentType(mediaType(mediaTypes::TEXT, mediaTypes::TEXT_PLAIN), chset);
-+ }
-+}
-+
-+
- const charset body::getCharset() const
- {
- try
-@@ -445,6 +498,12 @@ const charset body::getCharset() const
- }
-
-
-+void body::setEncoding(const encoding& enc)
-+{
-+ m_header.acquire()->ContentTransferEncoding()->setValue(enc);
-+}
-+
-+
- const encoding body::getEncoding() const
- {
- try
-@@ -456,8 +515,15 @@ const encoding body::getEncoding() const
- }
- catch (exceptions::no_such_field&)
- {
-- // Defaults to "7bit" (RFC-1521)
-- return (vmime::encoding(encodingTypes::SEVEN_BIT));
-+ if (m_contents->isEncoded())
-+ {
-+ return m_contents->getEncoding();
-+ }
-+ else
-+ {
-+ // Defaults to "7bit" (RFC-1521)
-+ return vmime::encoding(encodingTypes::SEVEN_BIT);
-+ }
- }
- }
-
-@@ -551,6 +617,32 @@ void body::setContents(ref <const contentHandler> contents)
- }
-
-
-+void body::setContents(ref <const contentHandler> contents, const mediaType& type)
-+{
-+ m_contents = contents;
-+
-+ setContentType(type);
-+}
-+
-+
-+void body::setContents(ref <const contentHandler> contents, const mediaType& type, const charset& chset)
-+{
-+ m_contents = contents;
-+
-+ setContentType(type, chset);
-+}
-+
-+
-+void body::setContents(ref <const contentHandler> contents, const mediaType& type,
-+ const charset& chset, const encoding& enc)
-+{
-+ m_contents = contents;
-+
-+ setContentType(type, chset);
-+ setEncoding(enc);
-+}
-+
-+
- void body::initNewPart(ref <bodyPart> part)
- {
- part->m_parent = m_part;
-diff --git a/src/charset.cpp b/src/charset.cpp
-index e3c11da..e043186 100644
---- a/src/charset.cpp
-+++ b/src/charset.cpp
-@@ -24,6 +24,7 @@
- #include "vmime/charset.hpp"
- #include "vmime/exception.hpp"
- #include "vmime/platform.hpp"
-+#include "vmime/encoding.hpp"
-
- #include "vmime/utility/stringUtils.hpp"
-
-@@ -140,4 +141,53 @@ const std::vector <ref <const component> > charset::getChildComponents() const
- }
-
-
-+
-+// Explicitly force encoding for some charsets
-+struct CharsetEncodingEntry
-+{
-+ CharsetEncodingEntry(const string& charset_, const string& encoding_)
-+ : charset(charset_), encoding(encoding_)
-+ {
-+ }
-+
-+ const string charset;
-+ const string encoding;
-+};
-+
-+CharsetEncodingEntry g_charsetEncodingMap[] =
-+{
-+ // Use QP encoding for ISO-8859-x charsets
-+ CharsetEncodingEntry("iso-8859", encodingTypes::QUOTED_PRINTABLE),
-+ CharsetEncodingEntry("iso8859", encodingTypes::QUOTED_PRINTABLE),
-+
-+ // RFC-1468 states:
-+ // " ISO-2022-JP may also be used in MIME Part 2 headers. The "B"
-+ // encoding should be used with ISO-2022-JP text. "
-+ // Use Base64 encoding for all ISO-2022 charsets.
-+ CharsetEncodingEntry("iso-2022", encodingTypes::BASE64),
-+ CharsetEncodingEntry("iso2022", encodingTypes::BASE64),
-+
-+ // Last entry is not used
-+ CharsetEncodingEntry("", "")
-+};
-+
-+
-+bool charset::getRecommendedEncoding(encoding& enc) const
-+{
-+ // Special treatment for some charsets
-+ const string cset = utility::stringUtils::toLower(getName());
-+
-+ for (unsigned int i = 0 ; i < (sizeof(g_charsetEncodingMap) / sizeof(g_charsetEncodingMap[0])) - 1 ; ++i)
-+ {
-+ if (cset.find(g_charsetEncodingMap[i].charset) != string::npos)
-+ {
-+ enc = g_charsetEncodingMap[i].encoding;
-+ return true;
-+ }
-+ }
-+
-+ return false;
-+}
-+
-+
- } // vmime
-diff --git a/src/emptyContentHandler.cpp b/src/emptyContentHandler.cpp
-index 5245341..48dc351 100644
---- a/src/emptyContentHandler.cpp
-+++ b/src/emptyContentHandler.cpp
-@@ -96,4 +96,10 @@ const vmime::encoding& emptyContentHandler::getEncoding() const
- }
-
-
-+bool emptyContentHandler::isBuffered() const
-+{
-+ return true;
-+}
-+
-+
- } // vmime
-diff --git a/src/encoding.cpp b/src/encoding.cpp
-index 58ce71d..0919d44 100644
---- a/src/encoding.cpp
-+++ b/src/encoding.cpp
-@@ -110,7 +110,7 @@ bool encoding::operator!=(const encoding& value) const
- }
-
-
--const encoding encoding::decide
-+const encoding encoding::decideImpl
- (const string::const_iterator begin, const string::const_iterator end)
- {
- const string::difference_type length = end - begin;
-@@ -164,10 +164,40 @@ const encoding encoding::decide
- }
-
-
--const encoding encoding::decide(ref <const contentHandler> /* data */)
-+const encoding encoding::decide
-+ (ref <const contentHandler> data, const EncodingUsage usage)
- {
-- // TODO: a better solution to do that?
-- return (encoding(encodingTypes::BASE64));
-+ if (usage == USAGE_TEXT && data->isBuffered() &&
-+ data->getLength() > 0 && data->getLength() < 32768)
-+ {
-+ // Extract data into temporary buffer
-+ string buffer;
-+ utility::outputStreamStringAdapter os(buffer);
-+
-+ data->extract(os);
-+ os.flush();
-+
-+ return decideImpl(buffer.begin(), buffer.end());
-+ }
-+ else
-+ {
-+ return encoding(encodingTypes::BASE64);
-+ }
-+}
-+
-+
-+const encoding encoding::decide(ref <const contentHandler> data,
-+ const charset& chset, const EncodingUsage usage)
-+{
-+ if (usage == USAGE_TEXT)
-+ {
-+ encoding recEncoding;
-+
-+ if (chset.getRecommendedEncoding(recEncoding))
-+ return recEncoding;
-+ }
-+
-+ return decide(data, usage);
- }
-
-
-diff --git a/src/htmlTextPart.cpp b/src/htmlTextPart.cpp
-index 7713034..c845b57 100644
---- a/src/htmlTextPart.cpp
-+++ b/src/htmlTextPart.cpp
-@@ -69,27 +69,20 @@ void htmlTextPart::generateIn(ref <bodyPart> /* message */, ref <bodyPart> paren
- ref <bodyPart> part = vmime::create <bodyPart>();
- parent->getBody()->appendPart(part);
-
-- // -- Set header fields
-- part->getHeader()->ContentType()->setValue
-- (mediaType(mediaTypes::TEXT, mediaTypes::TEXT_PLAIN));
-- part->getHeader()->ContentType().dynamicCast <contentTypeField>()->setCharset(m_charset);
-- part->getHeader()->ContentTransferEncoding()->setValue(encoding(encodingTypes::QUOTED_PRINTABLE));
--
- // -- Set contents
-- part->getBody()->setContents(m_plainText);
-+ part->getBody()->setContents(m_plainText,
-+ mediaType(mediaTypes::TEXT, mediaTypes::TEXT_PLAIN), m_charset,
-+ encoding::decide(m_plainText, m_charset, encoding::USAGE_TEXT));
- }
-
- // HTML text
- // -- Create a new part
- ref <bodyPart> htmlPart = vmime::create <bodyPart>();
-
-- // -- Set header fields
-- htmlPart->getHeader()->ContentType()->setValue(mediaType(mediaTypes::TEXT, mediaTypes::TEXT_HTML));
-- htmlPart->getHeader()->ContentType().dynamicCast <contentTypeField>()->setCharset(m_charset);
-- htmlPart->getHeader()->ContentTransferEncoding()->setValue(encoding(encodingTypes::QUOTED_PRINTABLE));
--
- // -- Set contents
-- htmlPart->getBody()->setContents(m_text);
-+ htmlPart->getBody()->setContents(m_text,
-+ mediaType(mediaTypes::TEXT, mediaTypes::TEXT_HTML), m_charset,
-+ encoding::decide(m_text, m_charset, encoding::USAGE_TEXT));
-
- // Handle the case we have embedded objects
- if (!m_objects.empty())
-diff --git a/src/net/imap/IMAPMessagePartContentHandler.cpp b/src/net/imap/IMAPMessagePartContentHandler.cpp
-index a226b68..4e6ba97 100644
---- a/src/net/imap/IMAPMessagePartContentHandler.cpp
-+++ b/src/net/imap/IMAPMessagePartContentHandler.cpp
-@@ -173,6 +173,12 @@ bool IMAPMessagePartContentHandler::isEmpty() const
- }
-
-
-+bool IMAPMessagePartContentHandler::isBuffered() const
-+{
-+ return true;
-+}
-+
-+
- } // imap
- } // net
- } // vmime
-diff --git a/src/plainTextPart.cpp b/src/plainTextPart.cpp
-index 7a674e7..15bcb5e 100644
---- a/src/plainTextPart.cpp
-+++ b/src/plainTextPart.cpp
-@@ -63,13 +63,10 @@ void plainTextPart::generateIn(ref <bodyPart> /* message */, ref <bodyPart> pare
- ref <bodyPart> part = vmime::create <bodyPart>();
- parent->getBody()->appendPart(part);
-
-- // Set header fields
-- part->getHeader()->ContentType()->setValue(mediaType(mediaTypes::TEXT, mediaTypes::TEXT_PLAIN));
-- part->getHeader()->ContentType().dynamicCast <contentTypeField>()->setCharset(m_charset);
-- part->getHeader()->ContentTransferEncoding()->setValue(encoding(encodingTypes::QUOTED_PRINTABLE));
--
- // Set contents
-- part->getBody()->setContents(m_text);
-+ part->getBody()->setContents(m_text,
-+ mediaType(mediaTypes::TEXT, mediaTypes::TEXT_PLAIN), m_charset,
-+ encoding::decide(m_text, m_charset, encoding::USAGE_TEXT));
- }
-
-
-diff --git a/src/streamContentHandler.cpp b/src/streamContentHandler.cpp
-index 9edf4aa..2ebd073 100644
---- a/src/streamContentHandler.cpp
-+++ b/src/streamContentHandler.cpp
-@@ -201,4 +201,11 @@ const vmime::encoding& streamContentHandler::getEncoding() const
- }
-
-
-+bool streamContentHandler::isBuffered() const
-+{
-+ // FIXME: some streams can be resetted
-+ return false;
-+}
-+
-+
- } // vmime
-diff --git a/src/stringContentHandler.cpp b/src/stringContentHandler.cpp
-index 248fca4..4e85a6c 100644
---- a/src/stringContentHandler.cpp
-+++ b/src/stringContentHandler.cpp
-@@ -202,4 +202,10 @@ const vmime::encoding& stringContentHandler::getEncoding() const
- }
-
-
-+bool stringContentHandler::isBuffered() const
-+{
-+ return true;
-+}
-+
-+
- } // vmime
-diff --git a/src/wordEncoder.cpp b/src/wordEncoder.cpp
-index cc8292f..22994ed 100644
---- a/src/wordEncoder.cpp
-+++ b/src/wordEncoder.cpp
-@@ -26,6 +26,8 @@
- #include "vmime/exception.hpp"
- #include "vmime/charsetConverter.hpp"
-
-+#include "vmime/encoding.hpp"
-+
- #include "vmime/utility/encoder/b64Encoder.hpp"
- #include "vmime/utility/encoder/qpEncoder.hpp"
-
-@@ -260,50 +262,14 @@ wordEncoder::Encoding wordEncoder::getEncoding() const
- }
-
-
--// Explicitly force encoding for some charsets
--struct CharsetEncodingEntry
--{
-- CharsetEncodingEntry(const std::string& charset_, const wordEncoder::Encoding encoding_)
-- : charset(charset_), encoding(encoding_)
-- {
-- }
--
-- std::string charset;
-- wordEncoder::Encoding encoding;
--};
--
--CharsetEncodingEntry g_charsetEncodingMap[] =
--{
-- // Use QP encoding for ISO-8859-x charsets
-- CharsetEncodingEntry("iso-8859", wordEncoder::ENCODING_QP),
-- CharsetEncodingEntry("iso8859", wordEncoder::ENCODING_QP),
--
-- // RFC-1468 states:
-- // " ISO-2022-JP may also be used in MIME Part 2 headers. The "B"
-- // encoding should be used with ISO-2022-JP text. "
-- // Use Base64 encoding for all ISO-2022 charsets.
-- CharsetEncodingEntry("iso-2022", wordEncoder::ENCODING_B64),
-- CharsetEncodingEntry("iso2022", wordEncoder::ENCODING_B64),
--
-- // Last entry is not used
-- CharsetEncodingEntry("", wordEncoder::ENCODING_AUTO)
--};
--
--
- // static
- bool wordEncoder::isEncodingNeeded(const string& buffer, const charset& charset)
- {
-- // Special treatment for some charsets
-- const string cset = utility::stringUtils::toLower(charset.getName());
-+ // Charset-specific encoding
-+ encoding recEncoding;
-
-- for (unsigned int i = 0 ; i < (sizeof(g_charsetEncodingMap) / sizeof(g_charsetEncodingMap[0])) - 1 ; ++i)
-- {
-- if (cset.find(g_charsetEncodingMap[i].charset) != string::npos)
-- {
-- if (g_charsetEncodingMap[i].encoding != wordEncoder::ENCODING_AUTO)
-- return true;
-- }
-- }
-+ if (charset.getRecommendedEncoding(recEncoding))
-+ return true;
-
- // No encoding is needed if the buffer only contains ASCII chars
- if (utility::stringUtils::findFirstNonASCIIchar(buffer.begin(), buffer.end()) != string::npos)
-@@ -322,13 +288,15 @@ bool wordEncoder::isEncodingNeeded(const string& buffer, const charset& charset)
- wordEncoder::Encoding wordEncoder::guessBestEncoding
- (const string& buffer, const charset& charset)
- {
-- // Special treatment for some charsets
-- const string cset = utility::stringUtils::toLower(charset.getName());
-+ // Charset-specific encoding
-+ encoding recEncoding;
-
-- for (unsigned int i = 0 ; i < (sizeof(g_charsetEncodingMap) / sizeof(g_charsetEncodingMap[0])) - 1 ; ++i)
-+ if (charset.getRecommendedEncoding(recEncoding))
- {
-- if (cset.find(g_charsetEncodingMap[i].charset) != string::npos)
-- return g_charsetEncodingMap[i].encoding;
-+ if (recEncoding == encoding(encodingTypes::QUOTED_PRINTABLE))
-+ return ENCODING_QP;
-+ else
-+ return ENCODING_B64;
- }
-
- // Use Base64 if more than 40% non-ASCII, or Quoted-Printable else (default)
-diff --git a/vmime/body.hpp b/vmime/body.hpp
-index 80c1bb5..9e83d6b 100644
---- a/vmime/body.hpp
-+++ b/vmime/body.hpp
-@@ -184,6 +184,45 @@ public:
- */
- void setContents(ref <const contentHandler> contents);
-
-+ /** Set the body contents and type.
-+ *
-+ * @param contents new body contents
-+ * @param type type of contents
-+ */
-+ void setContents(ref <const contentHandler> contents, const mediaType& type);
-+
-+ /** Set the body contents, type and charset.
-+ *
-+ * @param contents new body contents
-+ * @param type type of contents
-+ * @param charset charset of contents
-+ */
-+ void setContents(ref <const contentHandler> contents, const mediaType& type, const charset& chset);
-+
-+ /** Set the body contents, type, charset and encoding.
-+ *
-+ * @param contents new body contents
-+ * @param type type of contents
-+ * @param charset charset of contents
-+ * @param encoding contents encoding
-+ */
-+ void setContents(ref <const contentHandler> contents, const mediaType& type,
-+ const charset& chset, const encoding& enc);
-+
-+ /** Set the MIME type and charset of contents.
-+ * If a charset is defined, it will not be modified.
-+ *
-+ * @param type MIME media type of contents
-+ * @param chset charset of contents
-+ */
-+ void setContentType(const mediaType& type, const charset& chset);
-+
-+ /** Set the MIME type of contents.
-+ *
-+ * @param type MIME media type of contents
-+ */
-+ void setContentType(const mediaType& type);
-+
- /** Return the media type of the data contained in the body contents.
- * This is a shortcut for getHeader()->ContentType()->getValue()
- * on the parent part.
-@@ -192,6 +231,13 @@ public:
- */
- const mediaType getContentType() const;
-
-+ /** Set the charset of contents.
-+ * If the type is not set, it will be set to default "text/plain" type.
-+ *
-+ * @param chset charset of contents
-+ */
-+ void setCharset(const charset& chset);
-+
- /** Return the charset of the data contained in the body contents.
- * This is a shortcut for getHeader()->ContentType()->getCharset()
- * on the parent part.
-@@ -200,6 +246,13 @@ public:
- */
- const charset getCharset() const;
-
-+ /** Set the output encoding of contents.
-+ * Contents will be encoded (or re-encoded) when this node is being generated.
-+ *
-+ * @param enc encoding of contents
-+ */
-+ void setEncoding(const encoding& enc);
-+
- /** Return the encoding used to encode the body contents.
- * This is a shortcut for getHeader()->ContentTransferEncoding()->getValue()
- * on the parent part.
-diff --git a/vmime/charset.hpp b/vmime/charset.hpp
-index 1d25b74..b2e241c 100644
---- a/vmime/charset.hpp
-+++ b/vmime/charset.hpp
-@@ -33,6 +33,9 @@ namespace vmime
- {
-
-
-+class encoding; // forward reference
-+
-+
- /** Charset description (basic type).
- */
-
-@@ -59,6 +62,16 @@ public:
-
- const std::vector <ref <const component> > getChildComponents() const;
-
-+ /** Gets the recommended encoding for this charset.
-+ * Note: there may be no recommended encoding.
-+ *
-+ * @param enc output parameter that will hold recommended encoding
-+ * @return true if an encoding is recommended (the encoding is stored
-+ * in the enc parameter), false otherwise (in this case, the enc
-+ * parameter is not modified)
-+ */
-+ bool getRecommendedEncoding(encoding& enc) const;
-+
- /** Returns the default charset used on the system.
- *
- * This function simply calls <code>platformHandler::getLocaleCharset()</code>
-diff --git a/vmime/contentHandler.hpp b/vmime/contentHandler.hpp
-index 38e4e24..0374cbe 100644
---- a/vmime/contentHandler.hpp
-+++ b/vmime/contentHandler.hpp
-@@ -111,6 +111,13 @@ public:
- * @return true if no data is managed by this object, false otherwise
- */
- virtual bool isEmpty() const = 0;
-+
-+ /** Indicates whether the extract() method can be called multiple times.
-+ *
-+ * @return true if the data can be extracted multiple times, or false
-+ * if not (ie. streamed data from socket)
-+ */
-+ virtual bool isBuffered() const = 0;
- };
-
-
-diff --git a/vmime/emptyContentHandler.hpp b/vmime/emptyContentHandler.hpp
-index 727c065..7b1e7eb 100644
---- a/vmime/emptyContentHandler.hpp
-+++ b/vmime/emptyContentHandler.hpp
-@@ -52,6 +52,8 @@ public:
- const vmime::encoding& getEncoding() const;
-
- bool isEmpty() const;
-+
-+ bool isBuffered() const;
- };
-
-
-diff --git a/vmime/encoding.hpp b/vmime/encoding.hpp
-index fa72dfb..ba78081 100644
---- a/vmime/encoding.hpp
-+++ b/vmime/encoding.hpp
-@@ -45,6 +45,13 @@ class encoding : public headerFieldValue
- {
- public:
-
-+ enum EncodingUsage
-+ {
-+ USAGE_TEXT, /**< Use for body text. */
-+ USAGE_BINARY_DATA /**< Use for attachment, image... */
-+ };
-+
-+
- encoding();
- explicit encoding(const string& name);
- encoding(const encoding& enc);
-@@ -75,20 +82,21 @@ public:
-
- /** Decide which encoding to use based on the specified data.
- *
-- * \deprecated Use the new decide() method which takes a contentHandler parameter.
-- *
-- * @param begin start iterator in buffer
-- * @param end end iterator in buffer
-+ * @param data data used to determine encoding
-+ * @param usage context of use of data
- * @return suitable encoding for specified data
- */
-- static const encoding decide(const string::const_iterator begin, const string::const_iterator end);
-+ static const encoding decide(ref <const contentHandler> data, const EncodingUsage usage = USAGE_BINARY_DATA);
-
-- /** Decide which encoding to use based on the specified data.
-+ /** Decide which encoding to use based on the specified data and charset.
- *
- * @param data data used to determine encoding
-- * @return suitable encoding for specified data
-+ * @param charset charset of data
-+ * @param usage context of use of data
-+ * @return suitable encoding for specified data and charset
- */
-- static const encoding decide(ref <const contentHandler> data);
-+ static const encoding decide(ref <const contentHandler> data, const charset& chset, const EncodingUsage usage = USAGE_BINARY_DATA);
-+
-
- ref <component> clone() const;
- void copyFrom(const component& other);
-@@ -106,6 +114,17 @@ private:
-
- string m_name;
-
-+ /** Decide which encoding to use based on the specified data.
-+ *
-+ * Please note: this will read the whole buffer, so it should be used only
-+ * for small amount of data (eg. text), and not large binary attachments.
-+ *
-+ * @param begin start iterator in buffer
-+ * @param end end iterator in buffer
-+ * @return suitable encoding for specified data
-+ */
-+ static const encoding decideImpl(const string::const_iterator begin, const string::const_iterator end);
-+
- public:
-
- using component::parse;
-diff --git a/vmime/net/imap/IMAPMessagePartContentHandler.hpp b/vmime/net/imap/IMAPMessagePartContentHandler.hpp
-index 0c4641e..75a03af 100644
---- a/vmime/net/imap/IMAPMessagePartContentHandler.hpp
-+++ b/vmime/net/imap/IMAPMessagePartContentHandler.hpp
-@@ -55,6 +55,8 @@ public:
-
- bool isEmpty() const;
-
-+ bool isBuffered() const;
-+
- private:
-
- weak_ref <IMAPMessage> m_message;
-diff --git a/vmime/streamContentHandler.hpp b/vmime/streamContentHandler.hpp
-index aa62b2f..703fb72 100644
---- a/vmime/streamContentHandler.hpp
-+++ b/vmime/streamContentHandler.hpp
-@@ -62,6 +62,8 @@ public:
-
- bool isEmpty() const;
-
-+ bool isBuffered() const;
-+
- private:
-
- // Equals to NO_ENCODING if data is not encoded, otherwise this
-diff --git a/vmime/stringContentHandler.hpp b/vmime/stringContentHandler.hpp
-index 8d36889..a73ae67 100644
---- a/vmime/stringContentHandler.hpp
-+++ b/vmime/stringContentHandler.hpp
-@@ -80,6 +80,8 @@ public:
-
- bool isEmpty() const;
-
-+ bool isBuffered() const;
-+
- private:
-
- // Equals to NO_ENCODING if data is not encoded, otherwise this
-
-commit 59511165232b856605940976978f977e439a476a
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Jun 23 20:42:25 2010 +0000
-
- Do not generate 7-bit value for parameter if RFC-2231 extended value is generated (thanks to Eugene A. Shatokhin).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@556 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/parameter.cpp b/src/parameter.cpp
-index 6cd8d1f..53adaca 100644
---- a/src/parameter.cpp
-+++ b/src/parameter.cpp
-@@ -257,11 +257,23 @@ void parameter::generate(utility::outputStream& os, const string::size_type maxL
-
- // For compatibility with implementations that do not understand RFC-2231,
- // also generate a normal "7bit/us-ascii" parameter
-+
-+ // [By Eugene A. Shatokhin]
-+ // Note that if both the normal "7bit/us-ascii" value and the extended
-+ // value are present, the latter can be ignored by mail processing systems.
-+ // This may lead to annoying problems, for example, with strange names of
-+ // attachments with all but 7-bit ascii characters removed, etc. To avoid
-+ // this, I would suggest not to create "7bit/us-ascii" value if the extended
-+ // value is to be generated.
-+
-+ // A stream for a temporary storage
-+ std::ostringstream sevenBitBuffer;
-+
- string::size_type pos = curLinePos;
-
- if (pos + name.length() + 10 + value.length() > maxLineLength)
- {
-- os << NEW_LINE_SEQUENCE;
-+ sevenBitBuffer << NEW_LINE_SEQUENCE;
- pos = NEW_LINE_SEQUENCE_LENGTH;
- }
-
-@@ -301,12 +313,12 @@ void parameter::generate(utility::outputStream& os, const string::size_type maxL
-
- if (needQuoting)
- {
-- os << name << "=\"";
-+ sevenBitBuffer << name << "=\"";
- pos += name.length() + 2;
- }
- else
- {
-- os << name << "=";
-+ sevenBitBuffer << name << "=";
- pos += name.length() + 1;
- }
-
-@@ -318,12 +330,12 @@ void parameter::generate(utility::outputStream& os, const string::size_type maxL
-
- if (/* needQuoting && */ (c == '"' || c == '\\')) // 'needQuoting' is implicit
- {
-- os << '\\' << value[i]; // escape 'x' with '\x'
-+ sevenBitBuffer << '\\' << value[i]; // escape 'x' with '\x'
- pos += 2;
- }
- else if (parserHelpers::isAscii(c))
- {
-- os << value[i];
-+ sevenBitBuffer << value[i];
- ++pos;
- }
- else
-@@ -334,17 +346,31 @@ void parameter::generate(utility::outputStream& os, const string::size_type maxL
-
- if (needQuoting)
- {
-- os << '"';
-+ sevenBitBuffer << '"';
- ++pos;
- }
-
-+#if VMIME_ALWAYS_GENERATE_7BIT_PARAMETER
-+ os << sevenBitBuffer;
-+#endif // !VMIME_ALWAYS_GENERATE_7BIT_PARAMETER
-+
- // Also generate an extended parameter if the value contains 8-bit characters
- // or is too long for a single line
- if (extended || cutValue)
- {
-+
-+#if VMIME_ALWAYS_GENERATE_7BIT_PARAMETER
-+
- os << ';';
- ++pos;
-
-+#else // !VMIME_ALWAYS_GENERATE_7BIT_PARAMETER
-+
-+ // The data output to 'sevenBitBuffer' will be discarded in this case
-+ pos = curLinePos;
-+
-+#endif // VMIME_ALWAYS_GENERATE_7BIT_PARAMETER
-+
- /* RFC-2231
- * ========
- *
-@@ -477,6 +503,17 @@ void parameter::generate(utility::outputStream& os, const string::size_type maxL
- }
- }
- }
-+#if !VMIME_ALWAYS_GENERATE_7BIT_PARAMETER
-+ else
-+ {
-+ // The value does not contain 8-bit characters and
-+ // is short enough for a single line.
-+ // "7bit/us-ascii" will suffice in this case.
-+
-+ // Output what has been stored in temporary buffer so far
-+ os << sevenBitBuffer.str();
-+ }
-+#endif // !VMIME_ALWAYS_GENERATE_7BIT_PARAMETER
-
- if (newLinePos)
- *newLinePos = pos;
-
-commit 3ce1428c7f6d9704ddc0346b664e6fa9dc0aa0ff
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Sat Jul 17 07:00:49 2010 +0000
-
- Take account of charset recommended encoding (thanks to John van der Kamp, Zarafa).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@557 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/text.cpp b/src/text.cpp
-index 89a541a..a2fe060 100644
---- a/src/text.cpp
-+++ b/src/text.cpp
-@@ -24,6 +24,7 @@
- #include "vmime/text.hpp"
-
- #include "vmime/parserHelpers.hpp"
-+#include "vmime/encoding.hpp"
-
-
- namespace vmime
-@@ -248,26 +249,36 @@ ref <text> text::newFromString(const string& in, const charset& ch)
-
- void text::createFromString(const string& in, const charset& ch)
- {
-- bool is8bit = false; // is the current word 8-bit?
-- bool prevIs8bit = false; // is previous word 8-bit?
-- unsigned int count = 0; // total number of words
-+ string::size_type asciiCount = 0;
-+ string::size_type asciiPercent = 0;
-
- removeAllWords();
-
-- const string::size_type asciiCount =
-- utility::stringUtils::countASCIIchars(in.begin(), in.end());
-+ // Check whether there is a recommended encoding for this charset.
-+ // If so, the whole buffer will be encoded. Else, the number of
-+ // 7-bit (ASCII) bytes in the input will be used to determine if
-+ // we need to encode the whole buffer.
-+ encoding recommendedEnc;
-+ const bool alwaysEncode = ch.getRecommendedEncoding(recommendedEnc);
-
-- const string::size_type asciiPercent =
-- (in.length() == 0 ? 100 : (100 * asciiCount) / in.length());
-+ if (!alwaysEncode)
-+ {
-+ asciiCount = utility::stringUtils::countASCIIchars(in.begin(), in.end());
-+ asciiPercent = (in.length() == 0 ? 100 : (100 * asciiCount) / in.length());
-+ }
-
- // If there are "too much" non-ASCII chars, encode everything
-- if (asciiPercent < 60) // less than 60% ASCII chars
-+ if (alwaysEncode || asciiPercent < 60) // less than 60% ASCII chars
- {
- appendWord(vmime::create <word>(in, ch));
- }
- // Else, only encode words which need it
- else
- {
-+ bool is8bit = false; // is the current word 8-bit?
-+ bool prevIs8bit = false; // is previous word 8-bit?
-+ unsigned int count = 0; // total number of words
-+
- for (string::size_type end = in.size(), pos = 0, start = 0 ; ; )
- {
- if (pos == end || parserHelpers::isSpace(in[pos]))
-
-commit fa4f3f1ce3a8e5105c205c039fe62ad0b2657fc5
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Jul 21 12:21:07 2010 +0000
-
- Added section about deleting messages from store.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@558 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/doc/book/net.tex b/doc/book/net.tex
-index 08b7df5..3056861 100644
---- a/doc/book/net.tex
-+++ b/doc/book/net.tex
-@@ -614,6 +614,27 @@ Suppose we have a message with the following structure:
- The previous example will extract the header and body of the \emph{image/jpeg}
- part.
-
-+\subsection{Deleting messages} % ---------------------------------------------
-+
-+The following example will delete the second and the third message from the
-+store.
-+
-+\begin{lstlisting}[caption={Deleting messages}]
-+vmime::ref <vmime::net::folder> folder = store->getDefaultFolder();
-+
-+folder->deleteMessage(3);
-+folder->deleteMessage(2);
-+
-+// This is equivalent
-+std::vector <int> nums;
-+nums.push_back(2);
-+nums.push_back(3);
-+folder->deleteMessages(nums);
-+
-+// This is also equivalent
-+folder->deleteMessages(/* from */ 2, /* to */ 3);
-+\end{lstlisting}
-+
- \subsection{Events} % --------------------------------------------------------
-
- As a result of executing some operation (or from time to time, even if no
-
-commit d6feb9c5503726f99d7aecaa8dedd359950c6e1c
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Thu Aug 5 10:30:22 2010 +0000
-
- Connection time out.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@559 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/net/imap/IMAPConnection.cpp b/src/net/imap/IMAPConnection.cpp
-index 825a002..e2b60ed 100644
---- a/src/net/imap/IMAPConnection.cpp
-+++ b/src/net/imap/IMAPConnection.cpp
-@@ -99,7 +99,7 @@ void IMAPConnection::connect()
- m_timeoutHandler = store->getTimeoutHandlerFactory()->create();
-
- // Create and connect the socket
-- m_socket = store->getSocketFactory()->create();
-+ m_socket = store->getSocketFactory()->create(m_timeoutHandler);
-
- #if VMIME_HAVE_TLS_SUPPORT
- if (store->isIMAPS()) // dedicated port/IMAPS
-diff --git a/src/net/pop3/POP3Store.cpp b/src/net/pop3/POP3Store.cpp
-index e5e8ba7..9d554c6 100644
---- a/src/net/pop3/POP3Store.cpp
-+++ b/src/net/pop3/POP3Store.cpp
-@@ -138,7 +138,7 @@ void POP3Store::connect()
- m_timeoutHandler = getTimeoutHandlerFactory()->create();
-
- // Create and connect the socket
-- m_socket = getSocketFactory()->create();
-+ m_socket = getSocketFactory()->create(m_timeoutHandler);
-
- #if VMIME_HAVE_TLS_SUPPORT
- if (m_isPOP3S) // dedicated port/POP3S
-diff --git a/src/net/smtp/SMTPTransport.cpp b/src/net/smtp/SMTPTransport.cpp
-index 917a56c..71f166b 100644
---- a/src/net/smtp/SMTPTransport.cpp
-+++ b/src/net/smtp/SMTPTransport.cpp
-@@ -100,7 +100,7 @@ void SMTPTransport::connect()
- m_timeoutHandler = getTimeoutHandlerFactory()->create();
-
- // Create and connect the socket
-- m_socket = getSocketFactory()->create();
-+ m_socket = getSocketFactory()->create(m_timeoutHandler);
-
- #if VMIME_HAVE_TLS_SUPPORT
- if (m_isSMTPS) // dedicated port/SMTPS
-diff --git a/src/platforms/posix/posixSocket.cpp b/src/platforms/posix/posixSocket.cpp
-index 807ec47..b8bb8b1 100644
---- a/src/platforms/posix/posixSocket.cpp
-+++ b/src/platforms/posix/posixSocket.cpp
-@@ -49,8 +49,8 @@ namespace posix {
- // posixSocket
- //
-
--posixSocket::posixSocket()
-- : m_desc(-1)
-+posixSocket::posixSocket(ref <vmime::net::timeoutHandler> th)
-+ : m_timeoutHandler(th), m_desc(-1)
- {
- }
-
-@@ -105,11 +105,115 @@ void posixSocket::connect(const vmime::string& address, const vmime::port_t port
- if (sock < 0)
- continue; // try next
-
-- if (::connect(sock, res->ai_addr, res->ai_addrlen) < 0)
-+ if (m_timeoutHandler != NULL)
- {
-- ::close(sock);
-- sock = -1;
-- continue; // try next
-+ ::fcntl(sock, F_SETFL, ::fcntl(sock, F_GETFL) | O_NONBLOCK);
-+
-+ if (::connect(sock, res->ai_addr, res->ai_addrlen) < 0)
-+ {
-+ switch (errno)
-+ {
-+ case 0:
-+ case EINPROGRESS:
-+ case EINTR:
-+#if defined(EAGAIN)
-+ case EAGAIN:
-+#endif // EAGAIN
-+#if defined(EWOULDBLOCK) && (!defined(EAGAIN) || (EWOULDBLOCK != EAGAIN))
-+ case EWOULDBLOCK:
-+#endif // EWOULDBLOCK
-+
-+ // Connection in progress
-+ break;
-+
-+ default:
-+
-+ ::close(sock);
-+ sock = -1;
-+ continue; // try next
-+ }
-+
-+ // Wait for socket to be connected.
-+ // We will check for time out every second.
-+ fd_set fds;
-+ FD_ZERO(&fds);
-+ FD_SET(sock, &fds);
-+
-+ fd_set fdsError;
-+ FD_ZERO(&fdsError);
-+ FD_SET(sock, &fdsError);
-+
-+ struct timeval tm;
-+ tm.tv_sec = 1;
-+ tm.tv_usec = 0;
-+
-+ m_timeoutHandler->resetTimeOut();
-+
-+ bool connected = false;
-+
-+ do
-+ {
-+ const int ret = select(sock + 1, NULL, &fds, &fdsError, &tm);
-+
-+ // Success
-+ if (ret > 0)
-+ {
-+ connected = true;
-+ break;
-+ }
-+ // Error
-+ else if (ret < -1)
-+ {
-+ if (errno != EINTR)
-+ {
-+ // Cancel connection
-+ break;
-+ }
-+ }
-+ // 1-second timeout
-+ else if (ret == 0)
-+ {
-+ if (m_timeoutHandler->isTimeOut())
-+ {
-+ if (!m_timeoutHandler->handleTimeOut())
-+ {
-+ // Cancel connection
-+ break;
-+ }
-+ else
-+ {
-+ // Reset timeout and keep waiting for connection
-+ m_timeoutHandler->resetTimeOut();
-+ }
-+ }
-+ else
-+ {
-+ // Keep waiting for connection
-+ }
-+ }
-+
-+ ::sched_yield();
-+
-+ } while (true);
-+
-+ if (!connected)
-+ {
-+ ::close(sock);
-+ sock = -1;
-+ continue; // try next
-+ }
-+
-+ break;
-+ }
-+ }
-+ else
-+ {
-+ if (::connect(sock, res->ai_addr, res->ai_addrlen) < 0)
-+ {
-+ ::close(sock);
-+ sock = -1;
-+ continue; // try next
-+ }
- }
- }
-
-@@ -325,7 +429,14 @@ void posixSocket::throwSocketError(const int err)
-
- ref <vmime::net::socket> posixSocketFactory::create()
- {
-- return vmime::create <posixSocket>();
-+ ref <vmime::net::timeoutHandler> th = NULL;
-+ return vmime::create <posixSocket>(th);
-+}
-+
-+
-+ref <vmime::net::socket> posixSocketFactory::create(ref <vmime::net::timeoutHandler> th)
-+{
-+ return vmime::create <posixSocket>(th);
- }
-
-
-diff --git a/tests/testUtils.hpp b/tests/testUtils.hpp
-index 9aee153..aee50dc 100644
---- a/tests/testUtils.hpp
-+++ b/tests/testUtils.hpp
-@@ -260,6 +260,11 @@ public:
- {
- return vmime::create <T>();
- }
-+
-+ vmime::ref <vmime::net::socket> create(vmime::ref <vmime::net::timeoutHandler> /* th */)
-+ {
-+ return vmime::create <T>();
-+ }
- };
-
-
-diff --git a/vmime/net/socket.hpp b/vmime/net/socket.hpp
-index ec6a9d3..b394649 100644
---- a/vmime/net/socket.hpp
-+++ b/vmime/net/socket.hpp
-@@ -27,6 +27,8 @@
-
- #include "vmime/base.hpp"
-
-+#include "vmime/net/timeoutHandler.hpp"
-+
-
- namespace vmime {
- namespace net {
-@@ -117,7 +119,18 @@ public:
-
- virtual ~socketFactory() { }
-
-+ /** Creates a socket without timeout handler.
-+ *
-+ * @return a new socket
-+ */
- virtual ref <socket> create() = 0;
-+
-+ /** Creates a socket with the specified timeout handler.
-+ *
-+ * @param th timeout handler
-+ * @return a new socket
-+ */
-+ virtual ref <socket> create(ref <timeoutHandler> th) = 0;
- };
-
-
-diff --git a/vmime/platforms/posix/posixSocket.hpp b/vmime/platforms/posix/posixSocket.hpp
-index 9cd49d4..7e0c2d3 100644
---- a/vmime/platforms/posix/posixSocket.hpp
-+++ b/vmime/platforms/posix/posixSocket.hpp
-@@ -40,7 +40,7 @@ class posixSocket : public vmime::net::socket
- {
- public:
-
-- posixSocket();
-+ posixSocket(ref <vmime::net::timeoutHandler> th);
- ~posixSocket();
-
- void connect(const vmime::string& address, const vmime::port_t port);
-@@ -61,6 +61,8 @@ protected:
-
- private:
-
-+ ref <vmime::net::timeoutHandler> m_timeoutHandler;
-+
- char m_buffer[65536];
- int m_desc;
- };
-@@ -72,6 +74,7 @@ class posixSocketFactory : public vmime::net::socketFactory
- public:
-
- ref <vmime::net::socket> create();
-+ ref <vmime::net::socket> create(ref <vmime::net::timeoutHandler> th);
- };
-
-
-
-commit 5bd1361b6024c687f06318af32cab5c7502bbc55
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Mon Aug 16 10:21:03 2010 +0000
-
- Added stubs for timeout handler (#3045770).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@560 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/platforms/windows/windowsSocket.cpp b/src/platforms/windows/windowsSocket.cpp
-index 3ff9ad5..430c8ea 100644
---- a/src/platforms/windows/windowsSocket.cpp
-+++ b/src/platforms/windows/windowsSocket.cpp
-@@ -38,8 +38,8 @@ namespace windows {
- // posixSocket
- //
-
--windowsSocket::windowsSocket()
-- : m_desc(-1)
-+windowsSocket::windowsSocket(ref <vmime::net::timeoutHandler> th)
-+ : m_timeoutHandler(th), m_desc(-1)
- {
- WSAData wsaData;
- WSAStartup(MAKEWORD(1, 1), &wsaData);
-@@ -179,9 +179,14 @@ void windowsSocket::sendRaw(const char* buffer, const size_type count)
-
- ref <vmime::net::socket> windowsSocketFactory::create()
- {
-- return vmime::create <windowsSocket>();
-+ ref <vmime::net::timeoutHandler> th = NULL;
-+ return vmime::create <windowsSocket>(th);
- }
-
-+ref <vmime::net::socket> windowsSocketFactory::create(ref <vmime::net::timeoutHandler> th)
-+{
-+ return vmime::create <windowsSocket>(th);
-+}
-
- } // posix
- } // platforms
-diff --git a/vmime/platforms/windows/windowsSocket.hpp b/vmime/platforms/windows/windowsSocket.hpp
-index 2940157..1c89aeb 100644
---- a/vmime/platforms/windows/windowsSocket.hpp
-+++ b/vmime/platforms/windows/windowsSocket.hpp
-@@ -41,6 +41,7 @@ class windowsSocket : public vmime::net::socket
- {
- public:
- windowsSocket();
-+ windowsSocket(ref <vmime::net::timeoutHandler> th);
- ~windowsSocket();
-
- public:
-@@ -59,6 +60,8 @@ public:
-
- private:
-
-+ ref <vmime::net::timeoutHandler> m_timeoutHandler;
-+
- char m_buffer[65536];
- SOCKET m_desc;
- };
-@@ -70,6 +73,7 @@ class windowsSocketFactory : public vmime::net::socketFactory
- public:
-
- ref <vmime::net::socket> create();
-+ ref <vmime::net::socket> create(ref <vmime::net::timeoutHandler> th);
- };
-
-
-
-commit e2f160f70bdc0298609007ea451d2b19e8938a0c
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Aug 17 21:47:25 2010 +0000
-
- Encode TSpecials in RFC-2231 encoded chunks.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@561 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/parameter.cpp b/src/parameter.cpp
-index 53adaca..d923e68 100644
---- a/src/parameter.cpp
-+++ b/src/parameter.cpp
-@@ -432,9 +432,21 @@ void parameter::generate(utility::outputStream& os, const string::size_type maxL
- case '\t':
- case '\r':
- case '\n':
-+ case '%':
- case '"':
- case ';':
- case ',':
-+ case '(':
-+ case ')':
-+ case '<':
-+ case '>':
-+ case '@':
-+ case ':':
-+ case '/':
-+ case '[':
-+ case ']':
-+ case '?':
-+ case '=':
-
- encode = true;
- break;
-diff --git a/tests/parser/parameterTest.cpp b/tests/parser/parameterTest.cpp
-index 803bb59..72f9e9b 100644
---- a/tests/parser/parameterTest.cpp
-+++ b/tests/parser/parameterTest.cpp
-@@ -37,6 +37,8 @@ VMIME_TEST_SUITE_BEGIN
- VMIME_TEST(testGenerateRFC2231)
- VMIME_TEST(testNonStandardEncodedParam)
- VMIME_TEST(testParseNonSignificantWS)
-+ VMIME_TEST(testEncodeTSpecials)
-+ VMIME_TEST(testEncodeTSpecialsInRFC2231)
- VMIME_TEST_LIST_END
-
-
-@@ -222,7 +224,11 @@ VMIME_TEST_SUITE_BEGIN
- p1.appendParameter(vmime::create <vmime::parameter>("param1",
- vmime::word("value 1\xe9", vmime::charset("charset"))));
-
-+#if VMIME_ALWAYS_GENERATE_7BIT_PARAMETER
- VASSERT_EQ("1", "F: X; param1=\"value 1\";param1*=charset''value%201%E9", p1.generate());
-+#else
-+ VASSERT_EQ("1", "F: X; param1*=charset''value%201%E9", p1.generate());
-+#endif
-
- // Value that spans on multiple lines
- parameterizedHeaderField p2;
-@@ -230,6 +236,7 @@ VMIME_TEST_SUITE_BEGIN
- vmime::word("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ",
- vmime::charset("charset"))));
-
-+#if VMIME_ALWAYS_GENERATE_7BIT_PARAMETER
- VASSERT_EQ("2", "F: X; \r\n "
- "param1=abcdefghijklm;\r\n "
- "param1*0*=charset''abc;\r\n "
-@@ -239,6 +246,16 @@ VMIME_TEST_SUITE_BEGIN
- "param1*4*=EFGHIJKLM;\r\n "
- "param1*5*=NOPQRSTUV;\r\n "
- "param1*6*=WXYZ", p2.generate(25)); // max line length = 25
-+#else
-+ VASSERT_EQ("2", "F: X; \r\n "
-+ "param1*0*=charset''abc;\r\n "
-+ "param1*1*=defghijkl;\r\n "
-+ "param1*2*=mnopqrstu;\r\n "
-+ "param1*3*=vwxyzABCD;\r\n "
-+ "param1*4*=EFGHIJKLM;\r\n "
-+ "param1*5*=NOPQRSTUV;\r\n "
-+ "param1*6*=WXYZ", p2.generate(25)); // max line length = 25
-+#endif
-
- // Non-ASCII parameter value
- parameterizedHeaderField p3;
-@@ -246,6 +263,7 @@ VMIME_TEST_SUITE_BEGIN
- vmime::word("δσσσσσσσσσσσσσσσσσσσσδσδα δσαδσδσαδσαδασδασ δσαδασδσα δσαδασδσα δασδασδασ δασαχφδδσα 2008.doc",
- vmime::charset("utf-8"))));
-
-+#if VMIME_ALWAYS_GENERATE_7BIT_PARAMETER
- VASSERT_EQ("3", "F: X; \r\n "
- "param1=\" 2008.doc\";param1*0*=utf-8''%CE%B4%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83;\r\n "
- "param1*1*=%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83;\r\n "
-@@ -255,6 +273,16 @@ VMIME_TEST_SUITE_BEGIN
- "param1*5*=%83%CE%B1%CE%B4%CE%B1%CF%83%CE%B4%CF%83%CE%B1%20%CE%B4%CE%B1%CF%83;\r\n "
- "param1*6*=%CE%B4%CE%B1%CF%83%CE%B4%CE%B1%CF%83%20%CE%B4%CE%B1%CF%83%CE%B1%CF;\r\n "
- "param1*7*=%87%CF%86%CE%B4%CE%B4%CF%83%CE%B1%202008.doc", p3.generate(80));
-+#else
-+ VASSERT_EQ("3", "F: X; param1*0*=utf-8''%CE%B4%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83;\r\n "
-+ "param1*1*=%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83%CF%83;\r\n "
-+ "param1*2*=%CE%B4%CF%83%CE%B4%CE%B1%20%CE%B4%CF%83%CE%B1%CE%B4%CF%83%CE%B4%CF;\r\n "
-+ "param1*3*=%83%CE%B1%CE%B4%CF%83%CE%B1%CE%B4%CE%B1%CF%83%CE%B4%CE%B1%CF%83%20;\r\n "
-+ "param1*4*=%CE%B4%CF%83%CE%B1%CE%B4%CE%B1%CF%83%CE%B4%CF%83%CE%B1%20%CE%B4%CF;\r\n "
-+ "param1*5*=%83%CE%B1%CE%B4%CE%B1%CF%83%CE%B4%CF%83%CE%B1%20%CE%B4%CE%B1%CF%83;\r\n "
-+ "param1*6*=%CE%B4%CE%B1%CF%83%CE%B4%CE%B1%CF%83%20%CE%B4%CE%B1%CF%83%CE%B1%CF;\r\n "
-+ "param1*7*=%87%CF%86%CE%B4%CE%B4%CF%83%CE%B1%202008.doc", p3.generate(80));
-+#endif
- }
-
- void testNonStandardEncodedParam()
-@@ -297,5 +325,32 @@ VMIME_TEST_SUITE_BEGIN
- VASSERT_EQ("2.4", "value1", PARAM_VALUE(p2, 0));
- }
-
-+ // Encode "tspecials"
-+ void testEncodeTSpecials()
-+ {
-+ VASSERT_EQ(" 1", "p=\"val(ue\"", vmime::create <vmime::parameter>("p", "val(ue")->generate());
-+ VASSERT_EQ(" 2", "p=\"val)ue\"", vmime::create <vmime::parameter>("p", "val)ue")->generate());
-+ VASSERT_EQ(" 3", "p=\"val<ue\"", vmime::create <vmime::parameter>("p", "val<ue")->generate());
-+ VASSERT_EQ(" 4", "p=\"val>ue\"", vmime::create <vmime::parameter>("p", "val>ue")->generate());
-+ VASSERT_EQ(" 5", "p=\"val@ue\"", vmime::create <vmime::parameter>("p", "val@ue")->generate());
-+ VASSERT_EQ(" 6", "p=\"val,ue\"", vmime::create <vmime::parameter>("p", "val,ue")->generate());
-+ VASSERT_EQ(" 7", "p=\"val;ue\"", vmime::create <vmime::parameter>("p", "val;ue")->generate());
-+ VASSERT_EQ(" 8", "p=\"val:ue\"", vmime::create <vmime::parameter>("p", "val:ue")->generate());
-+ VASSERT_EQ(" 9", "p=\"val/ue\"", vmime::create <vmime::parameter>("p", "val/ue")->generate());
-+ VASSERT_EQ("10", "p=\"val[ue\"", vmime::create <vmime::parameter>("p", "val[ue")->generate());
-+ VASSERT_EQ("11", "p=\"val]ue\"", vmime::create <vmime::parameter>("p", "val]ue")->generate());
-+ VASSERT_EQ("12", "p=\"val?ue\"", vmime::create <vmime::parameter>("p", "val?ue")->generate());
-+ VASSERT_EQ("13", "p=\"val=ue\"", vmime::create <vmime::parameter>("p", "val=ue")->generate());
-+ VASSERT_EQ("14", "p=\"val ue\"", vmime::create <vmime::parameter>("p", "val ue")->generate());
-+ VASSERT_EQ("15", "p=\"val\tue\"", vmime::create <vmime::parameter>("p", "val\tue")->generate());
-+ }
-+
-+ // http://sourceforge.net/projects/vmime/forums/forum/237356/topic/3812278
-+ void testEncodeTSpecialsInRFC2231()
-+ {
-+ VASSERT_EQ("1", "filename*=UTF-8''my_file_name_%C3%B6%C3%A4%C3%BC_%281%29.txt",
-+ vmime::create <vmime::parameter>("filename", "my_file_name_\xc3\xb6\xc3\xa4\xc3\xbc_(1).txt")->generate());
-+ }
-+
- VMIME_TEST_SUITE_END
-
-
-commit 593591674556159fa2ff19b9c421254770a6e8ac
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Thu Aug 19 07:50:15 2010 +0000
-
- Fixed pointer-type argument for gnutls_credentials_set (thanks to Mike Smellie).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@562 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/net/tls/TLSSession.cpp b/src/net/tls/TLSSession.cpp
-index cb5351a..010c007 100644
---- a/src/net/tls/TLSSession.cpp
-+++ b/src/net/tls/TLSSession.cpp
-@@ -199,10 +199,10 @@ TLSSession::TLSSession(ref <security::cert::certificateVerifier> cv)
-
- // Initialize credentials
- gnutls_credentials_set(*m_gnutlsSession,
-- GNUTLS_CRD_ANON, &g_gnutlsGlobal.anonCred);
-+ GNUTLS_CRD_ANON, g_gnutlsGlobal.anonCred);
-
- gnutls_credentials_set(*m_gnutlsSession,
-- GNUTLS_CRD_CERTIFICATE, &g_gnutlsGlobal.certCred);
-+ GNUTLS_CRD_CERTIFICATE, g_gnutlsGlobal.certCred);
- }
-
-
-
-commit b7ec3accd3fa1b6dc7d7724aab968f860fe1930b
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Mon Sep 6 20:20:45 2010 +0000
-
- Fixed extraction of root part body.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@563 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/net/imap/IMAPMessage.cpp b/src/net/imap/IMAPMessage.cpp
-index adfef01..bbdba69 100644
---- a/src/net/imap/IMAPMessage.cpp
-+++ b/src/net/imap/IMAPMessage.cpp
-@@ -273,9 +273,12 @@ void IMAPMessage::extract(ref <const part> p, utility::outputStream& os,
- if (peek) command << ".PEEK";
- command << "[";
-
-- if (section.str().empty() && headerOnly)
-+ if (section.str().empty())
- {
-- command << "HEADER";
-+ if (headerOnly)
-+ command << "HEADER";
-+ else
-+ command << "TEXT";
- }
- else
- {
-
-commit 98843499d10a458f7029b054ceb3cda944e52e88
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Sep 7 07:44:15 2010 +0000
-
- Support filenames with charset (thanks to John van der Kamp, Zarafa).
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@564 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/parameter.cpp b/src/parameter.cpp
-index d923e68..91a7e5c 100644
---- a/src/parameter.cpp
-+++ b/src/parameter.cpp
-@@ -25,6 +25,7 @@
- #include "vmime/parserHelpers.hpp"
-
- #include "vmime/text.hpp"
-+#include "vmime/encoding.hpp"
-
-
- namespace vmime
-@@ -322,7 +323,13 @@ void parameter::generate(utility::outputStream& os, const string::size_type maxL
- pos += name.length() + 1;
- }
-
-- bool extended = false;
-+ // Check whether there is a recommended encoding for this charset.
-+ // If so, the whole buffer will be encoded. Else, the number of
-+ // 7-bit (ASCII) bytes in the input will be used to determine if
-+ // we need to encode the whole buffer.
-+ encoding recommendedEnc;
-+ const bool alwaysEncode = m_value.getCharset().getRecommendedEncoding(recommendedEnc);
-+ bool extended = alwaysEncode;
-
- for (string::size_type i = 0 ; (i < value.length()) && (pos < maxLineLength - 4) ; ++i)
- {
-@@ -454,7 +461,8 @@ void parameter::generate(utility::outputStream& os, const string::size_type maxL
- default:
-
- encode = (!parserHelpers::isPrint(c) ||
-- !parserHelpers::isAscii(c));
-+ !parserHelpers::isAscii(c) ||
-+ alwaysEncode);
-
- break;
- }
-
-commit a5a7e03fd144e6c46e5418f8bdd0e3f754bd980f
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Sep 7 10:46:24 2010 +0000
-
- Added an option to recognize inline objects as attachments.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@565 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/attachmentHelper.cpp b/src/attachmentHelper.cpp
-index 65e8c88..c23ee95 100644
---- a/src/attachmentHelper.cpp
-+++ b/src/attachmentHelper.cpp
-@@ -36,7 +36,8 @@ namespace vmime
-
-
- // static
--bool attachmentHelper::isBodyPartAnAttachment(ref <const bodyPart> part)
-+bool attachmentHelper::isBodyPartAnAttachment
-+ (ref <const bodyPart> part, const unsigned int options)
- {
- try
- {
-@@ -49,54 +50,63 @@ bool attachmentHelper::isBodyPartAnAttachment(ref <const bodyPart> part)
- if (disp.getName() != contentDispositionTypes::INLINE)
- return true;
-
-- // If the Content-Disposition is 'inline' and there is no
-- // Content-Id or Content-Location field, it may be an attachment
-- if (!part->getHeader()->hasField(vmime::fields::CONTENT_ID) &&
-- !part->getHeader()->hasField(vmime::fields::CONTENT_LOCATION))
-+ if ((options & INLINE_OBJECTS) == 0)
- {
-- // If this is the root part, it might not be an attachment
-- if (part->getParentPart() == NULL)
-- return false;
-+ // If the Content-Disposition is 'inline' and there is no
-+ // Content-Id or Content-Location field, it may be an attachment
-+ if (!part->getHeader()->hasField(vmime::fields::CONTENT_ID) &&
-+ !part->getHeader()->hasField(vmime::fields::CONTENT_LOCATION))
-+ {
-+ // If this is the root part, it might not be an attachment
-+ if (part->getParentPart() == NULL)
-+ return false;
-
-- return true;
-+ return true;
-+ }
-+
-+ return false;
- }
- }
- catch (exceptions::no_such_field&)
- {
-- // No "Content-disposition" field: assume "attachment" if
-- // type is not "text/..." or "multipart/...".
-- mediaType type;
-+ // Will try using Content-Type
-+ }
-
-- try
-- {
-- const contentTypeField& ctf = dynamic_cast<contentTypeField&>
-- (*part->getHeader()->findField(fields::CONTENT_TYPE));
-+ // Assume "attachment" if type is not "text/..." or "multipart/...".
-+ mediaType type;
-
-- type = *ctf.getValue().dynamicCast <const mediaType>();
-- }
-- catch (exceptions::no_such_field&)
-- {
-- // If this is the root part and no Content-Type field is present,
-- // then this may not be a MIME message, so do not assume it is
-- // an attachment
-- if (part->getParentPart() == NULL)
-- return false;
-+ try
-+ {
-+ const contentTypeField& ctf = dynamic_cast<contentTypeField&>
-+ (*part->getHeader()->findField(fields::CONTENT_TYPE));
-
-- // No "Content-type" field: assume "application/octet-stream".
-- type = mediaType(mediaTypes::APPLICATION,
-- mediaTypes::APPLICATION_OCTET_STREAM);
-- }
-+ type = *ctf.getValue().dynamicCast <const mediaType>();
-+ }
-+ catch (exceptions::no_such_field&)
-+ {
-+ // If this is the root part and no Content-Type field is present,
-+ // then this may not be a MIME message, so do not assume it is
-+ // an attachment
-+ if (part->getParentPart() == NULL)
-+ return false;
-+
-+ // No "Content-type" field: assume "application/octet-stream".
-+ type = mediaType(mediaTypes::APPLICATION,
-+ mediaTypes::APPLICATION_OCTET_STREAM);
-+ }
-
-- if (type.getType() != mediaTypes::TEXT &&
-- type.getType() != mediaTypes::MULTIPART)
-+ if (type.getType() != mediaTypes::TEXT &&
-+ type.getType() != mediaTypes::MULTIPART)
-+ {
-+ if ((options & INLINE_OBJECTS) == 0)
- {
- // If a "Content-Id" field is present, it might be an
- // embedded object (MHTML messages)
- if (part->getHeader()->hasField(vmime::fields::CONTENT_ID))
- return false;
--
-- return true;
- }
-+
-+ return true;
- }
-
- return false;
-@@ -104,10 +114,10 @@ bool attachmentHelper::isBodyPartAnAttachment(ref <const bodyPart> part)
-
-
- // static
--ref <const attachment>
-- attachmentHelper::getBodyPartAttachment(ref <const bodyPart> part)
-+ref <const attachment> attachmentHelper::getBodyPartAttachment
-+ (ref <const bodyPart> part, const unsigned int options)
- {
-- if (!isBodyPartAnAttachment(part))
-+ if (!isBodyPartAnAttachment(part, options))
- return NULL;
-
- mediaType type;
-@@ -140,22 +150,24 @@ ref <const attachment>
-
- // static
- const std::vector <ref <const attachment> >
-- attachmentHelper::findAttachmentsInMessage(ref <const message> msg)
-+ attachmentHelper::findAttachmentsInMessage
-+ (ref <const message> msg, const unsigned int options)
- {
-- return findAttachmentsInBodyPart(msg);
-+ return findAttachmentsInBodyPart(msg, options);
- }
-
-
- // static
- const std::vector <ref <const attachment> >
-- attachmentHelper::findAttachmentsInBodyPart(ref <const bodyPart> part)
-+ attachmentHelper::findAttachmentsInBodyPart
-+ (ref <const bodyPart> part, const unsigned int options)
- {
- std::vector <ref <const attachment> > atts;
-
- // Test this part
-- if (isBodyPartAnAttachment(part))
-+ if (isBodyPartAnAttachment(part, options))
- {
-- atts.push_back(getBodyPartAttachment(part));
-+ atts.push_back(getBodyPartAttachment(part, options));
- }
- // Find in sub-parts
- else
-@@ -165,7 +177,7 @@ const std::vector <ref <const attachment> >
- for (int i = 0 ; i < bdy->getPartCount() ; ++i)
- {
- std::vector <ref <const attachment> > partAtts =
-- findAttachmentsInBodyPart(bdy->getPartAt(i));
-+ findAttachmentsInBodyPart(bdy->getPartAt(i), options);
-
- std::copy(partAtts.begin(), partAtts.end(), std::back_inserter(atts));
- }
-diff --git a/vmime/attachmentHelper.hpp b/vmime/attachmentHelper.hpp
-index 3ce86c8..a383367 100644
---- a/vmime/attachmentHelper.hpp
-+++ b/vmime/attachmentHelper.hpp
-@@ -30,10 +30,6 @@
- #include "vmime/attachment.hpp"
- #include "vmime/message.hpp"
-
--#if VMIME_HAVE_MESSAGING_FEATURES
-- #include "vmime/net/message.hpp"
--#endif
--
-
- namespace vmime
- {
-@@ -45,31 +41,57 @@ class attachmentHelper
- {
- public:
-
-+ /** Options for use with the following functions:
-+ * findAttachmentsInMessage,
-+ * getBodyPartAttachment,
-+ * and isBodyPartAnAttachment.
-+ */
-+ enum FindOptions
-+ {
-+ INLINE_OBJECTS = (1 << 0) /**< Recognize and return inline objects. The aim is to
-+ consider MHTML objects (parts with a "Content-Id" or
-+ a "Content-Location", such as inline images) as attachments. */
-+ };
-+
- /** Test whether a body part is an attachment.
- *
- * @param part message part to test
-+ * @param options search options (see FindOptions)
- * @return true if the part is an attachment, false otherwise
- */
-- static bool isBodyPartAnAttachment(ref <const bodyPart> part);
-+ static bool isBodyPartAnAttachment(ref <const bodyPart> part, const unsigned int options = 0);
-
- /** Return attachment information in the specified body part.
- * If the specified body part does not contain attachment
- * information (ie. is not an attachment), NULL is returned.
- *
- * @param part message part in which to search
-+ * @param options search options (see FindOptions)
- * @return attachment found in the part, or NULL
- */
- static ref <const attachment>
-- getBodyPartAttachment(ref <const bodyPart> part);
-+ getBodyPartAttachment(ref <const bodyPart> part, const unsigned int options = 0);
-+
-+ /** Find all attachments contained in the specified part
-+ * and all its children parts.
-+ * This is simply a recursive call to getBodyPartAttachment().
-+ *
-+ * @param part part in which to search
-+ * @param options search options (see FindOptions)
-+ * @return a list of attachments found
-+ */
-+ static const std::vector <ref <const attachment> >
-+ findAttachmentsInBodyPart(ref <const bodyPart> part, const unsigned int options = 0);
-
- /** Find all attachments contained in the specified message.
- * This is simply a recursive call to getBodyPartAttachment().
- *
- * @param msg message in which to search
-+ * @param options search options (see FindOptions)
- * @return a list of attachments found
- */
- static const std::vector <ref <const attachment> >
-- findAttachmentsInMessage(ref <const message> msg);
-+ findAttachmentsInMessage(ref <const message> msg, const unsigned int options = 0);
-
- /** Add an attachment to the specified message.
- *
-@@ -87,9 +109,6 @@ public:
-
- protected:
-
-- static const std::vector <ref <const attachment> >
-- findAttachmentsInBodyPart(ref <const bodyPart> part);
--
- static ref <bodyPart> findBodyPart
- (ref <bodyPart> part, const mediaType& type);
- };
-
-commit 81d279e1f26e9938489ed0a64f26a0873e86b7ee
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Oct 12 09:45:16 2010 +0000
-
- Encode quotation marks in QP/RFC-2047.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@566 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/utility/encoder/qpEncoder.cpp b/src/utility/encoder/qpEncoder.cpp
-index c3a8c6d..e20be9f 100644
---- a/src/utility/encoder/qpEncoder.cpp
-+++ b/src/utility/encoder/qpEncoder.cpp
-@@ -236,6 +236,7 @@ utility::stream::size_type qpEncoder::encode(utility::inputStream& in,
- case '>':
- case '[':
- case ']':
-+ case '"':
- {
- if (rfc2047)
- {
-diff --git a/tests/parser/textTest.cpp b/tests/parser/textTest.cpp
-index 4a7e394..b455d91 100644
---- a/tests/parser/textTest.cpp
-+++ b/tests/parser/textTest.cpp
-@@ -46,6 +46,7 @@ VMIME_TEST_SUITE_BEGIN
- VMIME_TEST(testWordGenerateMultiBytes)
- VMIME_TEST(testWordGenerateQuote)
- VMIME_TEST(testWordGenerateSpecialCharsets)
-+ VMIME_TEST(testWordGenerateSpecials)
- VMIME_TEST_LIST_END
-
-
-@@ -370,5 +371,12 @@ VMIME_TEST_SUITE_BEGIN
- vmime::charset("iso-2022-jp")).generate(100)));
- }
-
-+ void testWordGenerateSpecials()
-+ {
-+ // In RFC-2047, quotation marks (ASCII 22h) should be encoded
-+ VASSERT_EQ("1", "=?UTF-8?Q?=22=C3=9Cml=C3=A4ute=22?=",
-+ vmime::word("\x22\xC3\x9Cml\xC3\xA4ute\x22", vmime::charset("UTF-8")).generate());
-+ }
-+
- VMIME_TEST_SUITE_END
-
-diff --git a/tests/utility/encoderTest.cpp b/tests/utility/encoderTest.cpp
-index 4e2c9a7..f2d42b6 100644
---- a/tests/utility/encoderTest.cpp
-+++ b/tests/utility/encoderTest.cpp
-@@ -33,15 +33,19 @@ VMIME_TEST_SUITE_BEGIN
- VMIME_TEST_LIST_BEGIN
- VMIME_TEST(testBase64)
- VMIME_TEST(testQuotedPrintable)
-+ VMIME_TEST(testQuotedPrintable_RFC2047)
- VMIME_TEST_LIST_END
-
-
- // Encoding helper function
-- static const vmime::string encode(const vmime::string& name, const vmime::string& in, int maxLineLength = 0)
-+ static const vmime::string encode(const vmime::string& name, const vmime::string& in,
-+ int maxLineLength = 0, const vmime::propertySet props = vmime::propertySet())
- {
- vmime::ref <vmime::utility::encoder::encoder> enc =
- vmime::utility::encoder::encoderFactory::getInstance()->create(name);
-
-+ enc->getProperties() = props;
-+
- if (maxLineLength != 0)
- enc->getProperties()["maxlinelength"] = maxLineLength;
-
-@@ -284,6 +288,37 @@ VMIME_TEST_SUITE_BEGIN
- }
- }
-
-+ void testQuotedPrintable_RFC2047()
-+ {
-+ /*
-+ * The RFC (http://tools.ietf.org/html/rfc2047#section-5) says:
-+ *
-+ * In this case the set of characters that may be used in a "Q"-encoded
-+ * 'encoded-word' is restricted to: <upper and lower case ASCII
-+ * letters, decimal digits, "!", "*", "+", "-", "/", "=", and "_"
-+ * (underscore, ASCII 95.)>. An 'encoded-word' that appears within a
-+ * 'phrase' MUST be separated from any adjacent 'word', 'text' or
-+ * 'special' by 'linear-white-space'.
-+ */
-+
-+ vmime::propertySet encProps;
-+ encProps["rfc2047"] = true;
-+
-+ // Ensure 'especials' are encoded
-+ VASSERT_EQ("especials.1", "=2C", encode("quoted-printable", ",", 10, encProps));
-+ VASSERT_EQ("especials.2", "=3B", encode("quoted-printable", ";", 10, encProps));
-+ VASSERT_EQ("especials.3", "=3A", encode("quoted-printable", ":", 10, encProps));
-+ VASSERT_EQ("especials.4", "=5F", encode("quoted-printable", "_", 10, encProps));
-+ VASSERT_EQ("especials.5", "=40", encode("quoted-printable", "@", 10, encProps));
-+ VASSERT_EQ("especials.6", "=28", encode("quoted-printable", "(", 10, encProps));
-+ VASSERT_EQ("especials.7", "=29", encode("quoted-printable", ")", 10, encProps));
-+ VASSERT_EQ("especials.8", "=3C", encode("quoted-printable", "<", 10, encProps));
-+ VASSERT_EQ("especials.9", "=3E", encode("quoted-printable", ">", 10, encProps));
-+ VASSERT_EQ("especials.10", "=5B", encode("quoted-printable", "[", 10, encProps));
-+ VASSERT_EQ("especials.11", "=5D", encode("quoted-printable", "]", 10, encProps));
-+ VASSERT_EQ("especials.12", "=22", encode("quoted-printable", "\"", 10, encProps));
-+ }
-+
- // TODO: UUEncode
-
- VMIME_TEST_SUITE_END
-
-commit fb268637f2f06d710f0ef475d71a8d4034a28e6c
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Oct 12 17:10:58 2010 +0000
-
- Better RFC-2047 encoding.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@567 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/utility/encoder/qpEncoder.cpp b/src/utility/encoder/qpEncoder.cpp
-index e20be9f..aa95022 100644
---- a/src/utility/encoder/qpEncoder.cpp
-+++ b/src/utility/encoder/qpEncoder.cpp
-@@ -51,10 +51,52 @@ const std::vector <string> qpEncoder::getAvailableProperties() const
-
-
-
--// Encoding table
-+// Hex-encoding table
- const unsigned char qpEncoder::sm_hexDigits[] = "0123456789ABCDEF";
-
--// Decoding table
-+
-+// RFC-2047 encoding table: we always encode RFC-2047 using the restricted
-+// charset, that is the one used for 'phrase' in From/To/Cc/... headers.
-+//
-+// " The set of characters that may be used in a "Q"-encoded 'encoded-word'
-+// is restricted to: <upper and lower case ASCII letters, decimal digits,
-+// "!", "*", "+", "-", "/", "=", and "_" (underscore, ASCII 95.)>. "
-+//
-+// Two special cases:
-+// - encode space (32) as underscore (95)
-+// - encode underscore as hex (=5F)
-+//
-+// This is a quick lookup table:
-+// '1' means "encode", '0' means "no encoding"
-+//
-+const unsigned char qpEncoder::sm_RFC2047EncodeTable[] =
-+{
-+ /* 0 NUL */ 1, /* 1 SOH */ 1, /* 2 STX */ 1, /* 3 ETX */ 1, /* 4 EOT */ 1, /* 5 ENQ */ 1,
-+ /* 6 ACK */ 1, /* 7 BEL */ 1, /* 8 BS */ 1, /* 9 TAB */ 1, /* 10 LF */ 1, /* 11 VT */ 1,
-+ /* 12 FF */ 1, /* 13 CR */ 1, /* 14 SO */ 1, /* 15 SI */ 1, /* 16 DLE */ 1, /* 17 DC1 */ 1,
-+ /* 18 DC2 */ 1, /* 19 DC3 */ 1, /* 20 DC4 */ 1, /* 21 NAK */ 1, /* 22 SYN */ 1, /* 23 ETB */ 1,
-+ /* 24 CAN */ 1, /* 25 EM */ 1, /* 26 SUB */ 1, /* 27 ESC */ 1, /* 28 FS */ 1, /* 29 GS */ 1,
-+ /* 30 RS */ 1, /* 31 US */ 1, /* 32 SPACE*/ 1, /* 33 ! */ 0, /* 34 " */ 1, /* 35 # */ 1,
-+ /* 36 $ */ 1, /* 37 % */ 1, /* 38 & */ 1, /* 39 ' */ 1, /* 40 ( */ 1, /* 41 ) */ 1,
-+ /* 42 * */ 0, /* 43 + */ 0, /* 44 , */ 1, /* 45 - */ 0, /* 46 . */ 1, /* 47 / */ 0,
-+ /* 48 0 */ 0, /* 49 1 */ 0, /* 50 2 */ 0, /* 51 3 */ 0, /* 52 4 */ 0, /* 53 5 */ 0,
-+ /* 54 6 */ 0, /* 55 7 */ 0, /* 56 8 */ 0, /* 57 9 */ 0, /* 58 : */ 1, /* 59 ; */ 1,
-+ /* 60 < */ 1, /* 61 = */ 1, /* 62 > */ 1, /* 63 ? */ 1, /* 64 @ */ 1, /* 65 A */ 0,
-+ /* 66 B */ 0, /* 67 C */ 0, /* 68 D */ 0, /* 69 E */ 0, /* 70 F */ 0, /* 71 G */ 0,
-+ /* 72 H */ 0, /* 73 I */ 0, /* 74 J */ 0, /* 75 K */ 0, /* 76 L */ 0, /* 77 M */ 0,
-+ /* 78 N */ 0, /* 79 O */ 0, /* 80 P */ 0, /* 81 Q */ 0, /* 82 R */ 0, /* 83 S */ 0,
-+ /* 84 T */ 0, /* 85 U */ 0, /* 86 V */ 0, /* 87 W */ 0, /* 88 X */ 0, /* 89 Y */ 0,
-+ /* 90 Z */ 0, /* 91 [ */ 1, /* 92 " */ 1, /* 93 ] */ 1, /* 94 ^ */ 1, /* 95 _ */ 1,
-+ /* 96 ` */ 1, /* 97 a */ 0, /* 98 b */ 0, /* 99 c */ 0, /* 100 d */ 0, /* 101 e */ 0,
-+ /* 102 f */ 0, /* 103 g */ 0, /* 104 h */ 0, /* 105 i */ 0, /* 106 j */ 0, /* 107 k */ 0,
-+ /* 108 l */ 0, /* 109 m */ 0, /* 110 n */ 0, /* 111 o */ 0, /* 112 p */ 0, /* 113 q */ 0,
-+ /* 114 r */ 0, /* 115 s */ 0, /* 116 t */ 0, /* 117 u */ 0, /* 118 v */ 0, /* 119 w */ 0,
-+ /* 120 x */ 0, /* 121 y */ 0, /* 122 z */ 0, /* 123 { */ 1, /* 124 | */ 1, /* 125 } */ 1,
-+ /* 126 ~ */ 1, /* 127 DEL */ 1
-+};
-+
-+
-+// Hex-decoding table
- const unsigned char qpEncoder::sm_hexDecodeTable[256] =
- {
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-@@ -76,6 +118,36 @@ const unsigned char qpEncoder::sm_hexDecodeTable[256] =
- };
-
-
-+// static
-+bool qpEncoder::RFC2047_isEncodingNeededForChar(const unsigned char c)
-+{
-+ return (c >= 128 || sm_RFC2047EncodeTable[c] != 0);
-+}
-+
-+
-+// static
-+int qpEncoder::RFC2047_getEncodedLength(const unsigned char c)
-+{
-+ if (c >= 128 || sm_RFC2047EncodeTable[c] != 0)
-+ {
-+ if (c == 32) // space
-+ {
-+ // Encoded as "_"
-+ return 1;
-+ }
-+ else
-+ {
-+ // Hex encoding
-+ return 3;
-+ }
-+ }
-+ else
-+ {
-+ return 1; // no encoding
-+ }
-+}
-+
-+
- #ifndef VMIME_BUILDING_DOC
-
- #define QP_ENCODE_HEX(x) \
-@@ -83,7 +155,7 @@ const unsigned char qpEncoder::sm_hexDecodeTable[256] =
- outBuffer[outBufferPos + 1] = sm_hexDigits[x >> 4]; \
- outBuffer[outBufferPos + 2] = sm_hexDigits[x & 0xF]; \
- outBufferPos += 3; \
-- curCol += 3;
-+ curCol += 3
-
- #define QP_WRITE(s, x, l) s.write(reinterpret_cast <utility::stream::value_type*>(x), l)
-
-@@ -145,34 +217,51 @@ utility::stream::size_type qpEncoder::encode(utility::inputStream& in,
- // Get the next char and encode it
- const unsigned char c = static_cast <unsigned char>(buffer[bufferPos++]);
-
-- switch (c)
-- {
-- case '.':
-+ if (rfc2047)
- {
-- if (!rfc2047 && curCol == 0)
-+ if (c >= 128 || sm_RFC2047EncodeTable[c] != 0)
- {
-- // If a '.' appears at the beginning of a line, we encode it to
-- // to avoid problems with SMTP servers... ("\r\n.\r\n" means the
-- // end of data transmission).
-- QP_ENCODE_HEX('.')
-- continue;
-+ if (c == 32) // space
-+ {
-+ // RFC-2047, Page 5, 4.2. The "Q" encoding:
-+ // << The 8-bit hexadecimal value 20 (e.g., ISO-8859-1 SPACE) may be
-+ // represented as "_" (underscore, ASCII 95.). >>
-+ outBuffer[outBufferPos++] = '_';
-+ ++curCol;
-+ }
-+ else
-+ {
-+ // Other characters: '=' + hexadecimal encoding
-+ QP_ENCODE_HEX(c);
-+ }
-+ }
-+ else
-+ {
-+ // No encoding
-+ outBuffer[outBufferPos++] = c;
-+ ++curCol;
- }
--
-- outBuffer[outBufferPos++] = '.';
-- ++curCol;
-- break;
- }
-- case ' ':
-+ else
- {
-- // RFC-2047, Page 5, 4.2. The "Q" encoding:
-- // << The 8-bit hexadecimal value 20 (e.g., ISO-8859-1 SPACE) may be
-- // represented as "_" (underscore, ASCII 95.). >>
-- if (rfc2047)
-+ switch (c)
- {
-- outBuffer[outBufferPos++] = '_';
-+ case 46: // .
-+ {
-+ if (curCol == 0)
-+ {
-+ // If a '.' appears at the beginning of a line, we encode it to
-+ // to avoid problems with SMTP servers... ("\r\n.\r\n" means the
-+ // end of data transmission).
-+ QP_ENCODE_HEX('.');
-+ continue;
-+ }
-+
-+ outBuffer[outBufferPos++] = '.';
- ++curCol;
-+ break;
- }
-- else
-+ case 32: // space
- {
- // Need to get more data?
- if (bufferPos >= bufferLength)
-@@ -192,100 +281,74 @@ utility::stream::size_type qpEncoder::encode(utility::inputStream& in,
- outBuffer[outBufferPos++] = ' ';
- ++curCol;
- }
-- }
-
-- break;
-- }
-- case '\t':
-- {
-- QP_ENCODE_HEX(c)
-- break;
-- }
-- case '\r':
-- case '\n':
-- {
-- // Text mode (where using CRLF or LF or ... does not
-- // care for a new line...)
-- if (text)
-- {
-- outBuffer[outBufferPos++] = c;
-- ++curCol;
-+ break;
- }
-- // Binary mode (where CR and LF bytes are important!)
-- else
-+ case 9: // TAB
- {
-- QP_ENCODE_HEX(c)
-- }
--
-- break;
-- }
-- case '=':
-- {
-- QP_ENCODE_HEX('=')
-- break;
-- }
-- // RFC-2047 'especials' characters
-- case ',':
-- case ';':
-- case ':':
-- case '_':
-- case '@':
-- case '(':
-- case ')':
-- case '<':
-- case '>':
-- case '[':
-- case ']':
-- case '"':
-- {
-- if (rfc2047)
-- {
-- QP_ENCODE_HEX(c)
-+ QP_ENCODE_HEX(c);
-+ break;
- }
-- else
-+ case 13: // CR
-+ case 10: // LF
- {
-- outBuffer[outBufferPos++] = c;
-- ++curCol;
-- }
-+ // Text mode (where using CRLF or LF or ... does not
-+ // care for a new line...)
-+ if (text)
-+ {
-+ outBuffer[outBufferPos++] = c;
-+ ++curCol;
-+ }
-+ // Binary mode (where CR and LF bytes are important!)
-+ else
-+ {
-+ QP_ENCODE_HEX(c);
-+ }
-
-- break;
-- }
-- /*
-- Rule #2: (Literal representation) Octets with decimal values of 33
-- through 60 inclusive, and 62 through 126, inclusive, MAY be
-- represented as the ASCII characters which correspond to those
-- octets (EXCLAMATION POINT through LESS THAN, and GREATER THAN
-- through TILDE, respectively).
-- */
-- default:
-- {
-- //if ((c >= 33 && c <= 60) || (c >= 62 && c <= 126))
-- if (c >= 33 && c <= 126 && c != 61 && c != 63)
-- {
-- outBuffer[outBufferPos++] = c;
-- ++curCol;
-+ break;
- }
-- // Other characters: '=' + hexadecimal encoding
-- else
-+ case 61: // =
- {
-- QP_ENCODE_HEX(c)
-+ QP_ENCODE_HEX('=');
-+ break;
- }
-+ /*
-+ Rule #2: (Literal representation) Octets with decimal values of 33
-+ through 60 inclusive, and 62 through 126, inclusive, MAY be
-+ represented as the ASCII characters which correspond to those
-+ octets (EXCLAMATION POINT through LESS THAN, and GREATER THAN
-+ through TILDE, respectively).
-+ */
-+ default:
-+
-+ //if ((c >= 33 && c <= 60) || (c >= 62 && c <= 126))
-+ if (c >= 33 && c <= 126 && c != 61 && c != 63)
-+ {
-+ outBuffer[outBufferPos++] = c;
-+ ++curCol;
-+ }
-+ // Other characters: '=' + hexadecimal encoding
-+ else
-+ {
-+ QP_ENCODE_HEX(c);
-+ }
-
-- break;
-- }
-+ break;
-
-- }
-+ } // switch (c)
-
-- // Soft line break : "=\r\n"
-- if (cutLines && curCol >= maxLineLength - 1)
-- {
-- outBuffer[outBufferPos] = '=';
-- outBuffer[outBufferPos + 1] = '\r';
-- outBuffer[outBufferPos + 2] = '\n';
-+ // Soft line break : "=\r\n"
-+ if (cutLines && curCol >= maxLineLength - 1)
-+ {
-+ outBuffer[outBufferPos] = '=';
-+ outBuffer[outBufferPos + 1] = '\r';
-+ outBuffer[outBufferPos + 2] = '\n';
-
-- outBufferPos += 3;
-- curCol = 0;
-- }
-+ outBufferPos += 3;
-+ curCol = 0;
-+ }
-+
-+ } // !rfc2047
-
- ++inTotal;
-
-diff --git a/src/wordEncoder.cpp b/src/wordEncoder.cpp
-index 22994ed..67bd7a1 100644
---- a/src/wordEncoder.cpp
-+++ b/src/wordEncoder.cpp
-@@ -150,29 +150,9 @@ const string wordEncoder::getNextChunk(const string::size_type maxLength)
- while ((inputCount == 0 || outputCount < maxLength) && (inputCount < remaining))
- {
- const unsigned char c = m_buffer[m_pos + inputCount];
-- bool encoded = true;
--
-- switch (c)
-- {
-- case ',':
-- case ';':
-- case ':':
-- case '_':
-- case '=':
--
-- encoded = true;
-- break;
--
-- default:
--
-- if (c >= 33 && c <= 126 && c != 61)
-- encoded = false;
--
-- break;
-- }
-
- inputCount++;
-- outputCount += (encoded ? 3 : 1);
-+ outputCount += utility::encoder::qpEncoder::RFC2047_getEncodedLength(c);
- }
-
- // Encode chunk
-@@ -217,28 +197,7 @@ const string wordEncoder::getNextChunk(const string::size_type maxLength)
- for (string::size_type i = 0, n = encodeBytes.length() ; i < n ; ++i)
- {
- const unsigned char c = encodeBytes[i];
-- bool encoded = true;
--
-- switch (c)
-- {
-- case ',':
-- case ';':
-- case ':':
-- case '_':
-- case '=':
--
-- encoded = true;
-- break;
--
-- default:
--
-- if (c >= 33 && c <= 126 && c != 61)
-- encoded = false;
--
-- break;
-- }
--
-- outputCount += (encoded ? 3 : 1);
-+ outputCount += utility::encoder::qpEncoder::RFC2047_getEncodedLength(c);
- }
- }
-
-diff --git a/vmime/utility/encoder/qpEncoder.hpp b/vmime/utility/encoder/qpEncoder.hpp
-index 098b4c8..a969126 100644
---- a/vmime/utility/encoder/qpEncoder.hpp
-+++ b/vmime/utility/encoder/qpEncoder.hpp
-@@ -47,10 +47,14 @@ public:
-
- const std::vector <string> getAvailableProperties() const;
-
-+ static bool RFC2047_isEncodingNeededForChar(const unsigned char c);
-+ static int RFC2047_getEncodedLength(const unsigned char c);
-+
- protected:
-
- static const unsigned char sm_hexDigits[17];
- static const unsigned char sm_hexDecodeTable[256];
-+ static const unsigned char sm_RFC2047EncodeTable[128];
- };
-
-
-
-commit 3c46d1a864399d924a4a7c8a0cfdd348ecfd5fbc
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Oct 12 20:01:34 2010 +0000
-
- Fixed missing whitespace in text parsing.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@568 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/text.cpp b/src/text.cpp
-index a2fe060..2454456 100644
---- a/src/text.cpp
-+++ b/src/text.cpp
-@@ -299,6 +299,12 @@ void text::createFromString(const string& in, const charset& ch)
- }
- else
- {
-+ if (count)
-+ {
-+ ref <word> w = getWordAt(getWordCount() - 1);
-+ w->getBuffer() += ' ';
-+ }
-+
- appendWord(vmime::create <word>(chunk, ch));
-
- prevIs8bit = true;
-@@ -314,6 +320,12 @@ void text::createFromString(const string& in, const charset& ch)
- }
- else
- {
-+ if (count)
-+ {
-+ ref <word> w = getWordAt(getWordCount() - 1);
-+ w->getBuffer() += ' ';
-+ }
-+
- appendWord(vmime::create <word>
- (chunk, charset(charsets::US_ASCII)));
-
-diff --git a/tests/parser/textTest.cpp b/tests/parser/textTest.cpp
-index b455d91..c60da5a 100644
---- a/tests/parser/textTest.cpp
-+++ b/tests/parser/textTest.cpp
-@@ -47,6 +47,9 @@ VMIME_TEST_SUITE_BEGIN
- VMIME_TEST(testWordGenerateQuote)
- VMIME_TEST(testWordGenerateSpecialCharsets)
- VMIME_TEST(testWordGenerateSpecials)
-+
-+ VMIME_TEST(testWhitespace)
-+ VMIME_TEST(testWhitespaceMBox)
- VMIME_TEST_LIST_END
-
-
-@@ -141,9 +144,9 @@ VMIME_TEST_SUITE_BEGIN
- t2.createFromString(s2, c2);
-
- VASSERT_EQ("2.1", 3, t2.getWordCount());
-- VASSERT_EQ("2.2", "some ASCII characters and special chars:", t2.getWordAt(0)->getBuffer());
-+ VASSERT_EQ("2.2", "some ASCII characters and special chars: ", t2.getWordAt(0)->getBuffer());
- VASSERT_EQ("2.3", vmime::charset(vmime::charsets::US_ASCII), t2.getWordAt(0)->getCharset());
-- VASSERT_EQ("2.4", "\xf1\xf2\xf3\xf4", t2.getWordAt(1)->getBuffer());
-+ VASSERT_EQ("2.4", "\xf1\xf2\xf3\xf4 ", t2.getWordAt(1)->getBuffer());
- VASSERT_EQ("2.5", c2, t2.getWordAt(1)->getCharset());
- VASSERT_EQ("2.6", "and then more ASCII chars.", t2.getWordAt(2)->getBuffer());
- VASSERT_EQ("2.7", vmime::charset(vmime::charsets::US_ASCII), t2.getWordAt(2)->getCharset());
-@@ -378,5 +381,52 @@ VMIME_TEST_SUITE_BEGIN
- vmime::word("\x22\xC3\x9Cml\xC3\xA4ute\x22", vmime::charset("UTF-8")).generate());
- }
-
-+ void testWhitespace()
-+ {
-+ // Create
-+ vmime::text text;
-+ text.createFromString("Achim Br\xc3\xa4ndt", vmime::charsets::UTF_8);
-+
-+ VASSERT_EQ("1", 2, text.getWordCount());
-+ VASSERT_EQ("2", "Achim ", text.getWordAt(0)->getBuffer());
-+ VASSERT_EQ("3", "us-ascii", text.getWordAt(0)->getCharset());
-+ VASSERT_EQ("4", "Br\xc3\xa4ndt", text.getWordAt(1)->getBuffer());
-+ VASSERT_EQ("5", "utf-8", text.getWordAt(1)->getCharset());
-+
-+ // Generate
-+ VASSERT_EQ("6", "Achim =?utf-8?Q?Br=C3=A4ndt?=", text.generate());
-+
-+ // Parse
-+ text.parse("=?us-ascii?Q?Achim_?= =?utf-8?Q?Br=C3=A4ndt?=");
-+
-+ VASSERT_EQ("7", 2, text.getWordCount());
-+ VASSERT_EQ("8", "Achim ", text.getWordAt(0)->getBuffer());
-+ VASSERT_EQ("9", "us-ascii", text.getWordAt(0)->getCharset());
-+ VASSERT_EQ("10", "Br\xc3\xa4ndt", text.getWordAt(1)->getBuffer());
-+ VASSERT_EQ("11", "utf-8", text.getWordAt(1)->getCharset());
-+ }
-+
-+ void testWhitespaceMBox()
-+ {
-+ // Space MUST be encoded inside a word
-+ vmime::mailbox mbox(vmime::text("Achim Br\xc3\xa4ndt", vmime::charsets::UTF_8), "me@vmime.org");
-+ VASSERT_EQ("generate1", "=?us-ascii?Q?Achim_?= =?utf-8?Q?Br=C3=A4ndt?= <me@vmime.org>", mbox.generate());
-+
-+ vmime::text txt;
-+ txt.appendWord(vmime::create <vmime::word>("Achim ", "us-ascii"));
-+ txt.appendWord(vmime::create <vmime::word>("Br\xc3\xa4ndt", "utf-8"));
-+ mbox = vmime::mailbox(txt, "me@vmime.org");
-+ VASSERT_EQ("generate2", "=?us-ascii?Q?Achim_?= =?utf-8?Q?Br=C3=A4ndt?= <me@vmime.org>", mbox.generate());
-+
-+ mbox.parse("=?us-ascii?Q?Achim?= =?utf-8?Q?Br=C3=A4ndt?= <me@vmime.org>");
-+ VASSERT_EQ("parse.name.count", 2, mbox.getName().getWordCount());
-+ VASSERT_EQ("parse.name.word1.buffer", "Achim", mbox.getName().getWordAt(0)->getBuffer());
-+ VASSERT_EQ("parse.name.word1.charset", "us-ascii", mbox.getName().getWordAt(0)->getCharset());
-+ VASSERT_EQ("parse.name.word2.buffer", "Br\xc3\xa4ndt", mbox.getName().getWordAt(1)->getBuffer());
-+ VASSERT_EQ("parse.name.word2.charset", "utf-8", mbox.getName().getWordAt(1)->getCharset());
-+
-+ VASSERT_EQ("parse.email", "me@vmime.org", mbox.getEmail());
-+ }
-+
- VMIME_TEST_SUITE_END
-
-
-commit 5c4011ca61000a4ae09705d360d6b85ea9128dc3
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Mon Oct 18 14:20:34 2010 +0000
-
- Fold non-encoded lines in the case there is no whitespace in them.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@569 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/word.cpp b/src/word.cpp
-index 9d0177f..db720dc 100644
---- a/src/word.cpp
-+++ b/src/word.cpp
-@@ -351,7 +351,6 @@ void word::generate(utility::outputStream& os, const string::size_type maxLineLe
- // - there is enough remaining space on the current line to hold the whole buffer
- if (!encodingNeeded &&
- (flags & text::QUOTE_IF_POSSIBLE) &&
-- !encodingNeeded &&
- m_buffer.find('"') == string::npos &&
- (curLineLength + 2 /* 2 x " */ + m_buffer.length()) < maxLineLength)
- {
-@@ -361,6 +360,40 @@ void word::generate(utility::outputStream& os, const string::size_type maxLineLe
- // We will fold lines without encoding them.
- else if (!encodingNeeded)
- {
-+ // Here, we could have the following conditions:
-+ //
-+ // * a maximum line length of N bytes
-+ // * a buffer containing N+1 bytes, with no whitespace
-+ //
-+ // Look in the buffer for any run (ie. whitespace-separated sequence) which
-+ // is longer than the maximum line length. If there is one, then force encoding,
-+ // so that no generated line is longer than the maximum line length.
-+ string::size_type maxRunLength = 0;
-+ string::size_type curRunLength = 0;
-+
-+ for (string::const_iterator p = m_buffer.begin(), end = m_buffer.end() ; p != end ; ++p)
-+ {
-+ if (parserHelpers::isSpace(*p))
-+ {
-+ maxRunLength = std::max(maxRunLength, curRunLength);
-+ curRunLength = 0;
-+ }
-+ else
-+ {
-+ curRunLength++;
-+ }
-+ }
-+
-+ maxRunLength = std::max(maxRunLength, curRunLength);
-+
-+ if (maxRunLength >= maxLineLength - 3)
-+ {
-+ // Generate with encoding forced
-+ generate(os, maxLineLength, curLinePos, newLinePos, flags | text::FORCE_ENCODING, state);
-+ return;
-+ }
-+
-+ // Output runs, and fold line when a whitespace is encountered
- string::const_iterator lastWSpos = m_buffer.end(); // last white-space position
- string::const_iterator curLineStart = m_buffer.begin(); // current line start
-
-diff --git a/tests/parser/textTest.cpp b/tests/parser/textTest.cpp
-index c60da5a..b84f376 100644
---- a/tests/parser/textTest.cpp
-+++ b/tests/parser/textTest.cpp
-@@ -50,6 +50,8 @@ VMIME_TEST_SUITE_BEGIN
-
- VMIME_TEST(testWhitespace)
- VMIME_TEST(testWhitespaceMBox)
-+
-+ VMIME_TEST(testFoldingAscii)
- VMIME_TEST_LIST_END
-
-
-@@ -428,5 +430,17 @@ VMIME_TEST_SUITE_BEGIN
- VASSERT_EQ("parse.email", "me@vmime.org", mbox.getEmail());
- }
-
-+ void testFoldingAscii()
-+ {
-+ // In this test, no encoding is needed, but line should be folded anyway
-+ vmime::word w("01234567890123456789012345678901234567890123456789"
-+ "01234567890123456789012345678901234567890123456789", vmime::charset("us-ascii"));
-+
-+ VASSERT_EQ("fold.ascii",
-+ "=?us-ascii?Q?01234567890123456789012345678901234?=\r\n"
-+ " =?us-ascii?Q?5678901234567890123456789012345678?=\r\n"
-+ " =?us-ascii?Q?9012345678901234567890123456789?=", w.generate(50));
-+ }
-+
- VMIME_TEST_SUITE_END
-
-
-commit efeffacbf9ef683edb4c6cd92b9582df67b8fca4
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Oct 19 13:28:43 2010 +0000
-
- Added support for DRAFT flag.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@570 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/AUTHORS b/AUTHORS
-index f0b5e2d..6acebd0 100644
---- a/AUTHORS
-+++ b/AUTHORS
-@@ -20,6 +20,7 @@ VMIME CONTRIBUTORS
- - Pierre Thierry <nowhere.man@levallois.eu.org> (patches for STL algorithms)
- - Zarafa <http://developer.zarafa.com/VmimePatches>
- - Bartek Szurgot <vempirelord@wp.pl, http://baszerr.org>
-+ - Achim Brändt <http://sourceforge.net/users/a-brandt/>
-
- Please apologize if I have forgotten someone here. ;)
- See SVN Changelog for full list.
-diff --git a/src/net/imap/IMAPMessage.cpp b/src/net/imap/IMAPMessage.cpp
-index bbdba69..bc661ed 100644
---- a/src/net/imap/IMAPMessage.cpp
-+++ b/src/net/imap/IMAPMessage.cpp
-@@ -555,6 +555,7 @@ void IMAPMessage::setFlags(const int flags, const int mode)
- if (flags & FLAG_MARKED) flagList.push_back("\\Flagged");
- if (flags & FLAG_DELETED) flagList.push_back("\\Deleted");
- if (flags & FLAG_SEEN) flagList.push_back("\\Seen");
-+ if (flags & FLAG_DRAFT) flagList.push_back("\\Draft");
-
- if (!flagList.empty())
- {
-diff --git a/src/net/imap/IMAPUtils.cpp b/src/net/imap/IMAPUtils.cpp
-index c4651ed..0d6fc47 100644
---- a/src/net/imap/IMAPUtils.cpp
-+++ b/src/net/imap/IMAPUtils.cpp
-@@ -419,10 +419,12 @@ int IMAPUtils::messageFlagsFromFlags(const IMAPParser::flag_list* list)
- case IMAPParser::flag::SEEN:
- flags |= message::FLAG_SEEN;
- break;
-+ case IMAPParser::flag::DRAFT:
-+ flags |= message::FLAG_DRAFT;
-+ break;
-
- default:
- //case IMAPParser::flag::UNKNOWN:
-- //case IMAPParser::flag::DRAFT:
- break;
- }
- }
-@@ -439,6 +441,7 @@ const string IMAPUtils::messageFlagList(const int flags)
- if (flags & message::FLAG_MARKED) flagList.push_back("\\Flagged");
- if (flags & message::FLAG_DELETED) flagList.push_back("\\Deleted");
- if (flags & message::FLAG_SEEN) flagList.push_back("\\Seen");
-+ if (flags & message::FLAG_DRAFT) flagList.push_back("\\Draft");
-
- if (!flagList.empty())
- {
-diff --git a/src/net/maildir/maildirUtils.cpp b/src/net/maildir/maildirUtils.cpp
-index 19887b2..3430d1f 100644
---- a/src/net/maildir/maildirUtils.cpp
-+++ b/src/net/maildir/maildirUtils.cpp
-@@ -102,6 +102,7 @@ int maildirUtils::extractFlags(const utility::file::path::component& comp)
- case 'T': case 't': flags |= message::FLAG_DELETED; break;
- case 'F': case 'f': flags |= message::FLAG_MARKED; break;
- case 'P': case 'p': flags |= message::FLAG_PASSED; break;
-+ case 'D': case 'd': flags |= message::FLAG_DRAFT; break;
- }
- }
-
-@@ -121,6 +122,7 @@ const utility::file::path::component maildirUtils::buildFlags(const int flags)
- if (flags & message::FLAG_REPLIED) str += "R";
- if (flags & message::FLAG_SEEN) str += "S";
- if (flags & message::FLAG_DELETED) str += "T";
-+ if (flags & message::FLAG_DRAFT) str += "D";
-
- return (utility::file::path::component(str));
- }
-diff --git a/vmime/net/message.hpp b/vmime/net/message.hpp
-index b6ebef8..1fbd008 100644
---- a/vmime/net/message.hpp
-+++ b/vmime/net/message.hpp
-@@ -227,6 +227,7 @@ public:
- FLAG_REPLIED = (1 << 3), /**< User replied to this message. */
- FLAG_MARKED = (1 << 4), /**< Used-defined flag. */
- FLAG_PASSED = (1 << 5), /**< Message has been resent/forwarded/bounced. */
-+ FLAG_DRAFT = (1 << 6), /**< Message is marked as a 'draft'. */
-
- FLAG_UNDEFINED = 9999 /**< Used internally (this should not be returned
- by the flags() function). */
-
-commit c853ee3020480e91878813730d6beb2b29bf2323
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Tue Oct 19 14:25:44 2010 +0000
-
- Fixed wrong name.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@571 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/AUTHORS b/AUTHORS
-index 6acebd0..4164052 100644
---- a/AUTHORS
-+++ b/AUTHORS
-@@ -20,7 +20,7 @@ VMIME CONTRIBUTORS
- - Pierre Thierry <nowhere.man@levallois.eu.org> (patches for STL algorithms)
- - Zarafa <http://developer.zarafa.com/VmimePatches>
- - Bartek Szurgot <vempirelord@wp.pl, http://baszerr.org>
-- - Achim Brändt <http://sourceforge.net/users/a-brandt/>
-+ - Achim Brandt <http://sourceforge.net/users/a-brandt/>
-
- Please apologize if I have forgotten someone here. ;)
- See SVN Changelog for full list.
-
-commit accc75399541bcaff0a8c7c4bd282370be9ca494
-Author: vincent-richard <vincent-richard@5301114d-f842-0410-bbdd-996ee0417009>
-Date: Wed Oct 20 09:37:39 2010 +0000
-
- Return failed email address in exception for RCPT TO.
-
- git-svn-id: https://vmime.svn.sourceforge.net/svnroot/vmime/trunk@572 5301114d-f842-0410-bbdd-996ee0417009
-
-diff --git a/src/net/smtp/SMTPTransport.cpp b/src/net/smtp/SMTPTransport.cpp
-index 71f166b..204daae 100644
---- a/src/net/smtp/SMTPTransport.cpp
-+++ b/src/net/smtp/SMTPTransport.cpp
-@@ -583,7 +583,7 @@ void SMTPTransport::send(const mailbox& expeditor, const mailboxList& recipients
- if ((resp = readResponse())->getCode() != 250)
- {
- internalDisconnect();
-- throw exceptions::command_error("RCPT TO", resp->getText());
-+ throw exceptions::command_error("RCPT TO", resp->getText(), mbox.getEmail());
- }
- }
-
diff --git a/src/vmime.mk b/src/vmime.mk
index 4513c94..b104135 100644
--- a/src/vmime.mk
+++ b/src/vmime.mk
@@ -4,8 +4,8 @@
# VMime
PKG := vmime
$(PKG)_IGNORE :=
-$(PKG)_VERSION := 0.9.0
-$(PKG)_CHECKSUM := 02215e1d8ea758f486c32e7bff63a04f71a9b736
+$(PKG)_VERSION := 0.9.1
+$(PKG)_CHECKSUM := 3e8dd8855e423db438d465777efeb523c4abb5f3
$(PKG)_SUBDIR := libvmime-$($(PKG)_VERSION)
$(PKG)_FILE := libvmime-$($(PKG)_VERSION).tar.bz2
$(PKG)_WEBSITE := http://vmime.sourceforge.net/