// Base64Encoder.h
//
// Copyright (C) 2000, 2001, 2002, 2003, 2004, 2005 Matthew Flood
// See file AUTHORS for contact information
//
// This file is part of RudeConfig.
//
// RudeConfig is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2, or (at your option)
// any later version.
// 
// RudeConfig 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 RudeConfig; (see COPYING) if not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
// 02111-1307, USA.
//------------------------------------------------------------------------

#ifndef INCLUDED_BASE64ENCODER_H

#define INCLUDED_BASE64ENCODER_H



namespace rude{
namespace config{

class Base64Encoder{

private:
      static char c_encode(char uc);
      static unsigned char c_decode(char c);
      static bool IsBase64(char c);

public:

		// datalength does not need to include the NULL terminator for strings
		//
		// a NULL terminator is appended to result to make it string friendly
		// but outlength does not include the
		// appended NULL terminator in length calculation
		//
		// CALLER RESPONSIBLE FOR DELETING RETURNED char * if it is not NULL.
		//
		static char * encode(const char *data, int datalength, int &outlength);


		// datalength does not need to include the NULL terminator for strings
		// NULL Terminator is appended to result, but outlength does not include the
		// appended NULL terminator in length calculation
		//
		// CALLER RESPONSIBLE FOR DELETING RETURNED char * if it is not NULL.
		//
		static char * decode(const char *data, int datalength, int &outlength);

};
}}

#endif





syntax highlighted by Code2HTML, v. 0.9.1