/*
Copyright (C) 2006-2007 Scott Ellis
Copyright (C) 2007-2011 Jan Holub

This is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.

This 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
Library General Public License for more details.

You should have received a copy of the GNU Library General Public
License along with this file; see the file license.txt.  If
not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.  
*/

#include "stdafx.h"

int iCodePage = CP_ACP;

bool a2w(const char *as, wchar_t *buff, int bufflen)
{
	if (as) MultiByteToWideChar(iCodePage, 0, as, -1, buff, bufflen);
	return true;
}

bool w2a(const wchar_t *ws, char *buff, int bufflen) 
{
	if (ws) WideCharToMultiByte(iCodePage, 0, ws, -1, buff, bufflen, 0, 0);
	return true;
}

bool utf2w(const char *us, wchar_t *buff, int bufflen) 
{
	if (us) MultiByteToWideChar(CP_UTF8, 0, us, -1, buff, bufflen);
	return true;
}

bool w2utf(const wchar_t *ws, char *buff, int bufflen) 
{
	if (ws) WideCharToMultiByte(CP_UTF8, 0, ws, -1, buff, bufflen, 0, 0);
	return true;
}

bool a2utf(const char *as, char *buff, int bufflen) 
{
	if (!as) return false;

	wchar_t *ws = a2w(as);
	if (ws) WideCharToMultiByte(CP_UTF8, 0, ws, -1, buff, bufflen, 0, 0);
	mir_free(ws);
	return true;
}

bool utf2a(const char *us, char *buff, int bufflen)
{
	if (!us) return false;

	wchar_t *ws = utf2w(us);
	if (ws) WideCharToMultiByte(iCodePage, 0, ws, -1, buff, bufflen, 0, 0);
	mir_free(ws);
	return true;
}


bool t2w(const TCHAR *ts, wchar_t *buff, int bufflen) 
{
	wcsncpy(buff, ts, bufflen);
	return true;
}

bool w2t(const wchar_t *ws, TCHAR *buff, int bufflen)
{
	wcsncpy(buff, ws, bufflen);
	return true;
}

bool t2a(const TCHAR *ts, char *buff, int bufflen) 
{
	return w2a(ts, buff, bufflen);
}

bool a2t(const char *as, TCHAR *buff, int bufflen) 
{
	return a2w(as, buff, bufflen);
}

bool t2utf(const TCHAR *ts, char *buff, int bufflen)
{
	return w2utf(ts, buff, bufflen);
}

bool utf2t(const char *us, TCHAR *buff, int bufflen) 
{
	return utf2w(us, buff, bufflen);
}

wchar_t *utf2w(const char *us)
{
	if (us)
	{
		int size = MultiByteToWideChar(CP_UTF8, 0, us, -1, 0, 0);
		wchar_t *buff = (wchar_t *)mir_alloc(size * sizeof(wchar_t));
		MultiByteToWideChar(CP_UTF8, 0, us, -1, buff, size);
		return buff;
	} 
	else
	{
		return 0;
	}
}

char *w2utf(const wchar_t *ws) 
{
	if (ws)
	{
		int size = WideCharToMultiByte(CP_UTF8, 0, ws, -1, 0, 0, 0, 0);
		char *buff = (char *)mir_alloc(size);
		WideCharToMultiByte(CP_UTF8, 0, ws, -1, buff, size, 0, 0);
		return buff;
	} 
	else 
	{
		return 0;
	}
}

wchar_t *a2w(const char *as)
{
	int size = MultiByteToWideChar(iCodePage, 0, as, -1, 0, 0);
	wchar_t *buff = (wchar_t *)mir_alloc(size * sizeof(wchar_t));
	MultiByteToWideChar(iCodePage, 0, as, -1, buff, size);
	return buff;
}

char *w2a(const wchar_t *ws)
{
	int size = WideCharToMultiByte(iCodePage, 0, ws, -1, 0, 0, 0, 0);
	char *buff = (char *)mir_alloc(size);
	WideCharToMultiByte(iCodePage, 0, ws, -1, buff, size, 0, 0);
	return buff;
}

char *utf2a(const char *utfs)
{
	wchar_t *ws = utf2w(utfs);
	char *ret = w2a(ws);
	mir_free(ws);
	return ret;
}

char *a2utf(const char *as) 
{
	wchar_t *ws = a2w(as);
	char *ret = w2utf(ws);
	mir_free(ws);
	return ret;
}

TCHAR *w2t(const wchar_t *ws)
{
	return mir_wstrdup(ws);
}

wchar_t *t2w(const TCHAR *ts)
{
	return mir_tstrdup(ts);
}


char *t2a(const TCHAR *ts)
{
	return w2a(ts);
}

TCHAR *a2t(const char *as) 
{
	return a2w(as);
}

TCHAR *utf2t(const char *utfs)
{
	return utf2w(utfs);
}

char *t2utf(const TCHAR *ts)
{
	return w2utf(ts);
}

TCHAR *myfgets(TCHAR *Buf, int MaxCount, FILE *File)
{
	_fgetts(Buf, MaxCount, File);
	for (size_t i = mir_tstrlen(Buf) - 1; ; i--)
	{
		if (Buf[i] == '\n' || Buf[i] == ' ')
			Buf[i] = 0;
		else
			break;
	}

	CharLower(Buf);
	return Buf;
}