shithub: aacdec

Download patch

ref: 8cfe7d4f44a76d1430ceaa2d99e87aa0d3cb88cc
parent: 2108cdfee01328b35c50d8f260870c661d5d2711
author: aforanna <aforanna>
date: Mon Nov 1 14:44:33 EST 2004

Cfaac moved to faac folder

binary files a/common/Cfaac/AudioCoding.bmp /dev/null differ
--- a/common/Cfaac/CRegistry.cpp
+++ /dev/null
@@ -1,361 +1,0 @@
-/*
-CRegistry class
-Copyright (C) 2002-2004 Antonio Foranna
-
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation.
-	
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
-		
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-			
-The author can be contacted at:
[email protected]
-*/
-
-#include "CRegistry.h"
-
-//************************************************************************************************
-
-CRegistry::CRegistry()
-{
-	regKey=NULL;
-	path=NULL;
-}
-//------------------------------------------------------------------------------------------------
-
-CRegistry::~CRegistry()
-{
-	Close();
-}
-//************************************************************************************************
-/*
-void CRegistry::ShowLastError(char *Caption)
-{
-LPVOID MsgBuf;
-	if(FormatMessage( 
-		FORMAT_MESSAGE_ALLOCATE_BUFFER | 
-		FORMAT_MESSAGE_FROM_SYSTEM | 
-		FORMAT_MESSAGE_IGNORE_INSERTS,
-		NULL,
-		GetLastError(),
-		MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language
-		(LPTSTR) &MsgBuf,
-		0,
-		NULL 
-	))
-		MessageBox(NULL, (LPCTSTR)MsgBuf, Caption, MB_OK|MB_ICONSTOP);
-	if(MsgBuf)
-		LocalFree(MsgBuf);
-}*/
-//************************************************************************************************
-
-#define setPath(SubKey) \
-{ \
-	if(path) \
-		free(path); \
-	path=strdup(SubKey); \
-}
-
-BOOL CRegistry::Open(HKEY hKey, char *SubKey)
-{
-	if(regKey)
-		RegCloseKey(regKey);
-	if(RegOpenKeyEx(hKey, SubKey, 0, KEY_ALL_ACCESS, &regKey)==ERROR_SUCCESS)
-	{
-		setPath(SubKey);
-		return TRUE;
-	}
-	else // can't open the key -> error
-	{
-		regKey=0;
-		setPath("");
-		return FALSE;
-	}
-}
-//************************************************************************************************
-
-BOOL CRegistry::OpenCreate(HKEY hKey, char *SubKey)
-{
-	if(regKey)
-		RegCloseKey(regKey);
-	if(RegOpenKeyEx(hKey, SubKey, 0, KEY_ALL_ACCESS, &regKey)==ERROR_SUCCESS)
-	{
-		setPath(SubKey);
-		return TRUE;
-	}
-	else // open failed -> create the key
-	{
-	DWORD disp;
-		RegCreateKeyEx(hKey, SubKey, 0, NULL, REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS, NULL, &regKey, &disp);
-		if(disp==REG_CREATED_NEW_KEY) 
-		{
-			setPath(SubKey);
-			return TRUE;
-		}
-		else // can't create the key -> error
-		{
-			regKey=0;
-			setPath("");
-			return FALSE;
-		}
-	}
-}
-//************************************************************************************************
-
-void CRegistry::Close()
-{
-	if(regKey)
-		RegCloseKey(regKey);
-	regKey=NULL;
-	if(path) 
-		free(path); 
-	path=NULL;
-}
-//************************************************************************************************
-//************************************************************************************************
-//************************************************************************************************
-
-void CRegistry::DeleteVal(char *SubKey)
-{
-	RegDeleteValue(regKey,SubKey);
-}
-//************************************************************************************************
-
-void CRegistry::DeleteKey(char *SubKey)
-{
-	RegDeleteKey(regKey,SubKey);
-}
-
-//************************************************************************************************
-//************************************************************************************************
-//************************************************************************************************
-
-void CRegistry::SetBool(char *keyStr, bool val)
-{
-bool tempVal;
-DWORD len=sizeof(bool);
-	if(RegQueryValueEx(regKey, keyStr, NULL, NULL, (BYTE *)&tempVal, &len )!=ERROR_SUCCESS ||
-		tempVal!=val)
-		RegSetValueEx(regKey, keyStr, 0, REG_BINARY, (BYTE *)&val, sizeof(bool));
-}
-//************************************************************************************************
-
-void CRegistry::SetByte(char *keyStr, BYTE val)
-{
-DWORD	t=val;
-DWORD	tempVal;
-DWORD	len;
-	if(RegQueryValueEx(regKey, keyStr, NULL, NULL, (BYTE *)&tempVal, &len )!=ERROR_SUCCESS ||
-		tempVal!=val)
-		RegSetValueEx(regKey, keyStr, 0, REG_DWORD, (BYTE *)&t, sizeof(DWORD));
-}
-//************************************************************************************************
-
-void CRegistry::SetWord(char *keyStr, WORD val)
-{
-DWORD	t=val;
-DWORD	tempVal;
-DWORD	len;
-	if(RegQueryValueEx(regKey, keyStr, NULL, NULL, (BYTE *)&tempVal, &len )!=ERROR_SUCCESS ||
-		tempVal!=val)
-		RegSetValueEx(regKey, keyStr, 0, REG_DWORD, (BYTE *)&t, sizeof(DWORD));
-}
-//************************************************************************************************
-
-void CRegistry::SetDword(char *keyStr, DWORD val)
-{
-DWORD tempVal;
-DWORD len;
-	if(RegQueryValueEx(regKey, keyStr, NULL, NULL, (BYTE *)&tempVal, &len )!=ERROR_SUCCESS ||
-		tempVal!=val)
-		RegSetValueEx(regKey, keyStr, 0, REG_DWORD, (BYTE *)&val, sizeof(DWORD));
-}
-//************************************************************************************************
-
-void CRegistry::SetFloat(char *keyStr, float val)
-{
-float tempVal;
-DWORD len;
-	if(RegQueryValueEx(regKey, keyStr, NULL, NULL, (BYTE *)&tempVal, &len )!=ERROR_SUCCESS ||
-		tempVal!=val)
-		RegSetValueEx(regKey, keyStr, 0, REG_BINARY, (BYTE *)&val, sizeof(float));
-}
-//************************************************************************************************
-
-void CRegistry::SetStr(char *keyStr, char *valStr)
-{
-DWORD len;
-DWORD slen=strlen(valStr)+1;
-
-	if(!valStr || !*valStr)
-		return;
-
-	if(RegQueryValueEx(regKey, keyStr, NULL, NULL, NULL, &len )!=ERROR_SUCCESS ||
-		len!=slen)
-		RegSetValueEx(regKey, keyStr, 0, REG_SZ, (BYTE *)valStr, slen);
-	else
-	{
-	char *tempVal=new char[slen];
-		if(RegQueryValueEx(regKey, keyStr, NULL, NULL, (BYTE *)tempVal, &len )!=ERROR_SUCCESS ||
-			strcmpi(tempVal,valStr))
-			RegSetValueEx(regKey, keyStr, 0, REG_SZ, (BYTE *)valStr, slen);
-		delete tempVal;
-	}
-}
-//************************************************************************************************
-
-void CRegistry::SetValN(char *keyStr, BYTE *addr,  DWORD size)
-{
-DWORD len;
-	if(!addr || !size)
-		return;
-
-	if(RegQueryValueEx(regKey, keyStr, NULL, NULL, NULL, &len )!=ERROR_SUCCESS ||
-		len!=size)
-		RegSetValueEx(regKey, keyStr, 0, REG_BINARY, addr, size);
-	else
-	{
-	BYTE *tempVal=new BYTE[size];
-		if(RegQueryValueEx(regKey, keyStr, NULL, NULL, (BYTE *)tempVal, &len )!=ERROR_SUCCESS ||
-			memcmp(tempVal,addr,len))
-			RegSetValueEx(regKey, keyStr, 0, REG_BINARY, addr, size);
-		delete tempVal;
-	}
-}
-
-
-
-//************************************************************************************************
-//************************************************************************************************
-//************************************************************************************************
-
-
-
-bool CRegistry::GetSetBool(char *keyStr, bool val)
-{
-bool tempVal;
-DWORD len=sizeof(bool);
-
-	if(RegQueryValueEx(regKey, keyStr, NULL, NULL, (BYTE *)&tempVal, &len )!=ERROR_SUCCESS)
-	{
-		RegSetValueEx(regKey, keyStr, 0, REG_BINARY, (BYTE *)&val, sizeof(bool));
-		return val;
-	}
-	return tempVal;
-}
-//************************************************************************************************
-
-BYTE CRegistry::GetSetByte(char *keyStr, BYTE val)
-{
-DWORD tempVal;
-DWORD len=sizeof(DWORD);
-
-	if(RegQueryValueEx(regKey, keyStr, NULL, NULL, (BYTE *)&tempVal, &len )!=ERROR_SUCCESS)
-	{
-		tempVal=val;
-		RegSetValueEx(regKey, keyStr, 0, REG_DWORD, (BYTE *)&tempVal, sizeof(DWORD));
-		return val;
-	}
-	return (BYTE)tempVal;
-}
-//************************************************************************************************
-
-WORD CRegistry::GetSetWord(char *keyStr, WORD val)
-{
-DWORD tempVal;
-DWORD len=sizeof(DWORD);
-
-	if(RegQueryValueEx(regKey, keyStr, NULL, NULL, (BYTE *)&tempVal, &len )!=ERROR_SUCCESS)
-	{
-		tempVal=val;
-		RegSetValueEx(regKey, keyStr, 0, REG_DWORD, (BYTE *)&tempVal, sizeof(DWORD));
-		return val;
-	}
-	return (WORD)tempVal;
-}
-//************************************************************************************************
-
-DWORD CRegistry::GetSetDword(char *keyStr, DWORD val)
-{
-DWORD tempVal;
-DWORD len=sizeof(DWORD);
-
-	if(RegQueryValueEx(regKey, keyStr, NULL, NULL, (BYTE *)&tempVal, &len )!=ERROR_SUCCESS)
-	{
-		RegSetValueEx(regKey, keyStr, 0, REG_DWORD, (BYTE *)&val, sizeof(DWORD));
-		return val;
-	}
-	return (DWORD)tempVal;
-}
-//************************************************************************************************
-
-float CRegistry::GetSetFloat(char *keyStr, float val)
-{
-float tempVal;
-DWORD len=sizeof(float);
-
-	if(RegQueryValueEx(regKey, keyStr, NULL, NULL, (BYTE *)&tempVal, &len )!=ERROR_SUCCESS)
-	{
-		RegSetValueEx(regKey, keyStr, 0, REG_BINARY, (BYTE *)&val, sizeof(float));
-		return val;
-	}
-	return tempVal;
-}
-//************************************************************************************************
-
-char *CRegistry::GetSetStr(char *keyStr, char *String)
-{
-long	retVal;
-DWORD	Len;
-char	*dest=NULL;
-	
-	if((retVal=RegQueryValueEx(regKey , keyStr , NULL , NULL, NULL, &Len))==ERROR_SUCCESS)
-		if(dest=(char *)malloc(Len+1))
-			retVal=RegQueryValueEx(regKey , keyStr , NULL , NULL, (BYTE *)dest , &Len);
-	if(retVal!=ERROR_SUCCESS)
-	{
-		if(dest)
-			free(dest);
-		if(!String)
-			return NULL;
-
-		Len=strlen(String)+1;
-		if(!(dest=strdup(String)))
-			return NULL;
-		RegSetValueEx(regKey , keyStr , NULL , REG_SZ , (BYTE *)dest , Len);
-	}
-	return dest;
-}
-// -----------------------------------------------------------------------------------------------
-
-int CRegistry::GetSetValN(char *keyStr, BYTE *defData, DWORD defSize, BYTE **dest)
-{
-long	retVal;
-DWORD	size;
-
-	dest=NULL;
-	if((retVal=RegQueryValueEx(regKey , keyStr , NULL , NULL, NULL, &size))==ERROR_SUCCESS)
-		if(*dest=(BYTE *)malloc(size+1))
-			retVal=RegQueryValueEx(regKey , keyStr , NULL , NULL, (BYTE *)*dest , &size);
-	if(retVal!=ERROR_SUCCESS)
-	{
-		if(dest)
-			free(dest);
-		if(!defData)
-			return 0;
-
-		size=defSize;
-		if(!(*dest=(BYTE *)malloc(size)))
-			return 0;
-		memcpy(*dest,defData,size);
-		RegSetValueEx(regKey , keyStr , NULL , REG_BINARY , (BYTE *)*dest , size);
-	}
-	return size;
-}
--- a/common/Cfaac/CRegistry.h
+++ /dev/null
@@ -1,64 +1,0 @@
-/*
-CRegistry class
-Copyright (C) 2002-2004 Antonio Foranna
-
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation.
-	
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
-		
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-			
-The author can be contacted at:
[email protected]
-*/
-
-//---------------------------------------------------------------------------
-#ifndef CRegistryH
-#define CRegistryH
-//---------------------------------------------------------------------------
-
-#include <windows.h>
-#include <stdlib.h>
-#include <string.h>
-//#include <memory.h>
-
-class CRegistry 
-{
-public:
-			CRegistry();
-			~CRegistry();
-
-	BOOL	Open(HKEY hKey, char *SubKey);
-	BOOL	OpenCreate(HKEY hKey, char *SubKey);
-	void	Close();
-	void	DeleteVal(char *SubKey);
-	void	DeleteKey(char *SubKey);
-
-	void	SetBool(char *keyStr , bool val);
-	void	SetByte(char *keyStr , BYTE val);
-	void	SetWord(char *keyStr , WORD val);
-	void	SetDword(char *keyStr , DWORD val);
-	void	SetFloat(char *keyStr , float val);
-	void	SetStr(char *keyStr , char *valStr);
-	void	SetValN(char *keyStr , BYTE *addr,  DWORD size);
-
-	bool	GetSetBool(char *keyStr, bool var);
-	BYTE	GetSetByte(char *keyStr, BYTE var);
-	WORD	GetSetWord(char *keyStr, WORD var);
-	DWORD	GetSetDword(char *keyStr, DWORD var);
-	float	GetSetFloat(char *keyStr, float var);
-	char	*GetSetStr(char *keyStr, char *String);
-	int		GetSetValN(char *keyStr, BYTE *defData, DWORD defSize, BYTE **dest);
-
-	HKEY	regKey;
-	char	*path;
-};
-
-#endif
--- a/common/Cfaac/CTag.cpp
+++ /dev/null
@@ -1,346 +1,0 @@
-/*
-CTag - Class to read/write id3v2/mp4 tags
-Copyright (C) 2004 Antonio Foranna
-
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation.
-	
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
-		
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-			
-The author can be contacted at:
[email protected]
-*/
-
-#include <stdlib.h>
-#include <mp4.h>
-#include <faac.h>
-#include "CTag.h"
-
-
-
-// *********************************************************************************************
-//										CMP4Tag
-// *********************************************************************************************
-
-CMP4Tag::CMP4Tag()
-{
-//	memset(this,0,sizeof(*this));
-	copyright=NULL;
-	artist=title=album=year=genre=writer=comment=NULL;
-	trackno=ntracks=discno=ndiscs=0;
-	compilation=0;
-	artFilename=NULL;
-	art.pictureType=0; // = other
-	memset(&art,0,sizeof(art));
-}
-// *********************************************************************************************
-
-void CMP4Tag::FreeTag()
-{
-	FREE_ARRAY(artist);
-	FREE_ARRAY(title);
-	FREE_ARRAY(album);
-	FREE_ARRAY(year);
-	FREE_ARRAY(genre);
-	FREE_ARRAY(writer);
-	FREE_ARRAY(comment);
-	FREE_ARRAY(artFilename);
-	FREE_ARRAY(art.data);
-	FREE_ARRAY(art.description);
-	FREE_ARRAY(art.mimeType);
-	FREE_ARRAY(art.format);
-}
-// ***********************************************************************************************
-
-int CMP4Tag::check_image_header(const char *buf)
-{
-	if(!strncmp(buf, "\x89\x50\x4E\x47\x0D\x0A\x1A\x0A", 8))
-		return 1; /* PNG */
-	if(!strncmp(buf, "\xFF\xD8\xFF\xE0", 4) &&
-		!strncmp(buf + 6, "JFIF\0",	5))
-		return 2; /* JPEG */
-	if(!strncmp(buf, "GIF87a", 6)	|| !strncmp(buf, "GIF89a", 6))
-		return 3; /* GIF */
-
-	return 0;
-}
-// -----------------------------------------------------------------------------------------------
-
-int CMP4Tag::ReadCoverArtFile(char *pCoverArtFile, char **artData)
-{
-FILE *artFile;
-
-	if(!pCoverArtFile || !*pCoverArtFile)
-		return 0;
-
-	if(!(artFile=fopen(pCoverArtFile, "rb")))
-	{
-	char buf[25+MAX_PATH+1];
-		sprintf(buf,"ReadCoverArtFile: can't open \"%s\"",pCoverArtFile);
-		MessageBox(NULL,buf,NULL,MB_OK);
-		return 0;
-	}
-
-int r;
-char *art;
-int	artSize=0;
-
-	fseek(artFile, 0, SEEK_END);
-	artSize=ftell(artFile);
-	fseek(artFile, 0, SEEK_SET);
-
-	if(!(art=(char *)malloc(artSize)))
-	{
-		fclose(artFile);
-		MessageBox(NULL,"ReadCoverArtFile: Memory allocation error!", NULL, MB_OK);
-		return 0;
-	}
-
-	r=fread(art, 1, artSize, artFile);
-	if(r!=artSize)
-	{
-		free(art);
-		fclose(artFile);
-		MessageBox(NULL,"ReadCoverArtFile: Error reading cover art file!", NULL, MB_OK);
-		return 0;
-	}
-	else
-		if(artSize<12 || !check_image_header(art))
-		{
-			// the above expression checks the image signature
-			free(art);
-			fclose(artFile);
-			MessageBox(NULL,"ReadCoverArtFile: Unsupported cover image file format!", NULL, MB_OK);
-			return 0;
-		}
-
-	FREE_ARRAY(*artData);
-	*artData=art;
-	fclose(artFile);
-	return artSize;
-}
-// *********************************************************************************************
-
-int CMP4Tag::WriteMP4Tag(MP4FileHandle MP4File)
-{
-char	buf[512], *faac_id_string, *faac_copyright_string;
-
-	if(MP4File==NULL)
-	{
-		MessageBox(NULL,"WriteMp4Tag: can't open file!",NULL,MB_OK);
-		return 1;
-	}
-
-	sprintf(buf, "FAAC v%s", (faacEncGetVersion(&faac_id_string, &faac_copyright_string)==FAAC_CFG_VERSION) ? faac_id_string : " wrong libfaac version");
-	MP4SetMetadataTool(MP4File, buf);
-
-	if(artist) MP4SetMetadataArtist(MP4File, artist);
-	if(writer) MP4SetMetadataWriter(MP4File, writer);
-	if(title) MP4SetMetadataName(MP4File, title);
-	if(album) MP4SetMetadataAlbum(MP4File, album);
-	if(trackno>0) MP4SetMetadataTrack(MP4File, trackno, ntracks);
-	if(discno>0) MP4SetMetadataDisk(MP4File, discno, ndiscs);
-	if(compilation) MP4SetMetadataCompilation(MP4File, compilation);
-	if(year) MP4SetMetadataYear(MP4File, year);
-	if(genre) MP4SetMetadataGenre(MP4File, genre);
-	if(comment) MP4SetMetadataComment(MP4File, comment);
-	if(art.size=ReadCoverArtFile(artFilename,&art.data))
-	{
-		MP4SetMetadataCoverArt(MP4File, (unsigned __int8 *)art.data, art.size);
-		FREE_ARRAY(art.data);
-	}
-	return 0;
-}
-// *********************************************************************************************
-
-int CMP4Tag::ReadMp4Tag(char *Filename)						 
-{
-MP4FileHandle MP4File;
-
-	if(!(MP4File=MP4Read(Filename, 0)))
-	{
-	char buf[25+MAX_PATH+1];
-		sprintf(buf,"ReadMp4Tag: can't open \"%s\"",Filename);
-		MessageBox(NULL,buf,NULL,MB_OK);
-		return 1;
-	}
-
-	FREE_ARRAY(copyright);
-	MP4GetMetadataTool(MP4File, &copyright);
-
-	FREE_ARRAY(artist);
-	MP4GetMetadataArtist(MP4File, &artist);
-	FREE_ARRAY(writer);
-	MP4GetMetadataWriter(MP4File, &writer);
-	FREE_ARRAY(title);
-	MP4GetMetadataName(MP4File, &title);
-	FREE_ARRAY(album);
-	MP4GetMetadataAlbum(MP4File, &album);
-	MP4GetMetadataTrack(MP4File, (unsigned __int16 *)&trackno, (unsigned __int16 *)&ntracks);
-	MP4GetMetadataDisk(MP4File, (unsigned __int16 *)&discno, (unsigned __int16 *)&ndiscs);
-	MP4GetMetadataCompilation(MP4File, (unsigned __int8 *)&compilation);
-	FREE_ARRAY(year);
-	MP4GetMetadataYear(MP4File, &year);
-	FREE_ARRAY(genre);
-	MP4GetMetadataGenre(MP4File, &genre);
-	FREE_ARRAY(comment);
-	MP4GetMetadataComment(MP4File, &comment);
-	FREE_ARRAY(art.data);
-	MP4GetMetadataCoverArt(MP4File, (unsigned __int8 **)&art.data, (u_int32_t *)&art.size);
-
-	MP4Close(MP4File);
-/*
-	FILE *f=fopen("D:\\prova.jpg","wb");
-		fwrite(artFile,1,artSize,f);
-		fclose(f);*/
-	return 0;
-}
-// *********************************************************************************************
-
-#define DEL_FIELD(id3Tag,ID3FID) \
-{ \
-ID3_Frame *Frame=id3Tag.Find(ID3FID); \
-	if(Frame!=NULL) \
-		id3Tag.RemoveFrame(Frame); \
-}
-// -----------------------------------------------------------------------------------------------
-
-#define ADD_FIELD(id3Tag,ID3FID,ID3FN,data) \
-{ \
-ID3_Frame *NewFrame=new ID3_Frame(ID3FID); \
-	NewFrame->Field(ID3FN)=data; \
-	DEL_FIELD(id3Tag,ID3FID); \
-	id3Tag.AttachFrame(NewFrame); \
-}
-// -----------------------------------------------------------------------------------------------
-
-int CMP4Tag::WriteAacTag(char *Filename)
-{
-char	buf[512], *faac_id_string, *faac_copyright_string;
-ID3_Tag id3Tag;
-FILE *file;
-
-	if((file=fopen(Filename,"r"))==NULL)
-	{
-	char buf[25+MAX_PATH+1];
-		sprintf(buf,"WriteAacTag: can't open \"%s\"",Filename);
-		MessageBox(NULL,buf,NULL,MB_OK);
-		return 1;
-	}
-	else
-		fclose(file);
-	id3Tag.Link(Filename);
-
-	sprintf(buf, "FAAC v%s", (faacEncGetVersion(&faac_id_string, &faac_copyright_string)==FAAC_CFG_VERSION) ? faac_id_string : " wrong libfaac version");
-	ADD_FIELD(id3Tag,ID3FID_ENCODEDBY,ID3FN_TEXT,buf);
-
-	ADD_FIELD(id3Tag,ID3FID_LEADARTIST,ID3FN_TEXT,artist);
-	ADD_FIELD(id3Tag,ID3FID_COMPOSER,ID3FN_TEXT,writer);
-	ADD_FIELD(id3Tag,ID3FID_TITLE,ID3FN_TEXT,title);
-	ADD_FIELD(id3Tag,ID3FID_ALBUM,ID3FN_TEXT,album);
-	sprintf(buf,"%d",trackno);
-	ADD_FIELD(id3Tag,ID3FID_TRACKNUM,ID3FN_TEXT,buf);
-	ADD_FIELD(id3Tag,ID3FID_YEAR,ID3FN_TEXT,year);
-	ADD_FIELD(id3Tag,ID3FID_CONTENTTYPE,ID3FN_TEXT,genre);
-	ADD_FIELD(id3Tag,ID3FID_COMMENT,ID3FN_TEXT,comment);
-	art.size=ReadCoverArtFile(artFilename,&art.data);
-	if(art.size)
-	{
-	ID3_Frame *NewFrame=new ID3_Frame(ID3FID_PICTURE);
-	char name[_MAX_FNAME], ext[_MAX_EXT];
-		_splitpath(artFilename,NULL,NULL,name,ext);
-
-		NewFrame->Field(ID3FN_DESCRIPTION)=name;
-	char buf[15];
-		sprintf(buf,"image/%s",check_image_header(art.data)==2 ? "jpeg" : strlwr(ext+1));
-		NewFrame->Field(ID3FN_MIMETYPE)=buf;
-//		NewFrame->Field(ID3FN_IMAGEFORMAT)=;
-		NewFrame->Field(ID3FN_PICTURETYPE)=(DWORD)art.pictureType;
-		NewFrame->Field(ID3FN_DATA).Set((BYTE *)art.data,art.size);
-		id3Tag.AttachFrame(NewFrame);
-	}
-
-	// setup all our rendering parameters
-    id3Tag.SetUnsync(false);
-    id3Tag.SetExtendedHeader(true);
-    id3Tag.SetCompression(true);
-    id3Tag.SetPadding(true);
- 
-	// write any changes to the file
-    id3Tag.Update();
-
-	FREE_ARRAY(art.data);
-	return 0;
-}
-// *********************************************************************************************
-
-#define GET_FIELD_STR(id3Tag,ID3FID,ID3FN,data) \
-{ \
-	Frame=id3Tag.Find(ID3FID); \
-	if(Frame!=NULL) \
-	{ \
-	DWORD size=Frame->Field(ID3FN).Size(); \
-		FREE_ARRAY(data); \
-		if(data=(char *)malloc(size+1)) \
-			Frame->Field(ID3FN).Get(data,size+1); \
-	} \
-	else \
-		FREE_ARRAY(data); \
-}
-// -----------------------------------------------------------------------------------------------
-
-int CMP4Tag::ReadAacTag(char *Filename)
-{
-char	*buf=NULL;
-ID3_Tag id3Tag;
-ID3_Frame *Frame;
-
-	if(!id3Tag.Link(Filename))
-	{
-	char buf[25+MAX_PATH+1];
-		sprintf(buf,"ReadAacTag: can't open \"%s\"",Filename);
-		MessageBox(NULL,buf,NULL,MB_OK);
-		return 1;
-	}
-
-	GET_FIELD_STR(id3Tag,ID3FID_ENCODEDBY,ID3FN_TEXT,copyright);
-
-	GET_FIELD_STR(id3Tag,ID3FID_LEADARTIST,ID3FN_TEXT,artist);
-	GET_FIELD_STR(id3Tag,ID3FID_COMPOSER,ID3FN_TEXT,writer);
-	GET_FIELD_STR(id3Tag,ID3FID_TITLE,ID3FN_TEXT,title);
-	GET_FIELD_STR(id3Tag,ID3FID_ALBUM,ID3FN_TEXT,album);
-
-	GET_FIELD_STR(id3Tag,ID3FID_TRACKNUM,ID3FN_TEXT,buf);
-	if(buf)
-		trackno=atoi(buf);
-	FREE_ARRAY(buf);
-	GET_FIELD_STR(id3Tag,ID3FID_YEAR,ID3FN_TEXT,year);
-	GET_FIELD_STR(id3Tag,ID3FID_CONTENTTYPE,ID3FN_TEXT,genre);
-	GET_FIELD_STR(id3Tag,ID3FID_COMMENT,ID3FN_TEXT,comment);
-
-	if(Frame=id3Tag.Find(ID3FID_PICTURE))
-	{
-		art.size=Frame->Field(ID3FN_DATA).Size();
-		FREE_ARRAY(art.data);
-		if(art.data=(char *)malloc(art.size))
-			memcpy(art.data,Frame->Field(ID3FN_DATA).GetBinary(),art.size);
-
-		GET_FIELD_STR(id3Tag,ID3FID_PICTURE,ID3FN_MIMETYPE,art.mimeType);
-		GET_FIELD_STR(id3Tag,ID3FID_PICTURE,ID3FN_DESCRIPTION,art.description);
-		GET_FIELD_STR(id3Tag,ID3FID_PICTURE,ID3FN_IMAGEFORMAT,art.format);
-		art.pictureType=Frame->Field(ID3FN_PICTURETYPE).Get();
-/*
-	FILE *f=fopen("D:\\prova.jpg","wb");
-		fwrite(artFile,1,artSize,f);
-		fclose(f);*/
-	}
-	return 0;
-}
\ No newline at end of file
--- a/common/Cfaac/CTag.h
+++ /dev/null
@@ -1,86 +1,0 @@
-/*
-CTag - Class to read/write id3v2/mp4 tags
-Copyright (C) 2004 Antonio Foranna
-
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation.
-	
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
-		
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-			
-The author can be contacted at:
[email protected]
-*/
-
-#ifndef _CTag_H
-#define _CTag_H
-
-// *********************************************************************************************
-
-#include <mp4.h>
-#include <id3/tag.h>	// id3 tag
-#include "CRegistry.h"
-#include "Defines.h"
-
-// *********************************************************************************************
-
-#define REG_TAGON "Tag On"
-#define REG_TAGIMPORT "Tag import"
-#define REG_ARTIST "Tag Artist"
-#define REG_TITLE "Tag Title"
-#define REG_ALBUM "Tag Album"
-#define REG_YEAR "Tag Year"
-#define REG_GENRE "Tag Genre"
-#define REG_WRITER "Tag Writer"
-#define REG_COMMENT "Tag Comment"
-#define REG_TRACK "Tag Track"
-#define REG_NTRACKS "Tag Tracks"
-#define REG_DISK "Tag Disk"
-#define REG_NDISKS "Tag Disks"
-#define REG_COMPILATION "Tag Compilation"
-#define REG_ARTFILE "Tag Art file"
-
-// *********************************************************************************************
-
-typedef struct
-{
-	char	*data;
-	DWORD	size;
-	DWORD	pictureType; // front, back, icon, ...
-	char	*mimeType, // jpg, png, gif
-			*format, // ???
-			*description; // text description
-} id3Picture;
-
-class CMP4Tag
-{
-private:
-	int check_image_header(const char *buf);
-	int ReadCoverArtFile(char *pCoverArtFile, char **artBuf);
-
-public:
-	CMP4Tag();
-	virtual ~CMP4Tag() { FreeTag(); }
-
-	virtual void FreeTag();
-	virtual int WriteMP4Tag(MP4FileHandle MP4File);
-	virtual int WriteAacTag(char *Filename);
-	virtual int ReadMp4Tag(char *Filename);
-	virtual int ReadAacTag(char *Filename);
-
-	char	*copyright; // used in Cfaad
-	char	*artist, *title, *album, *year, *genre, *writer, *comment;
-	WORD	trackno,ntracks, discno,ndiscs;
-	BYTE	compilation;
-	char	*artFilename;
-	id3Picture art; // used in ReadAacTag(). Remark: field not stored into registry
-};
-
-#endif
\ No newline at end of file
--- a/common/Cfaac/Cfaac.cpp
+++ /dev/null
@@ -1,719 +1,0 @@
-/*
-CFAAC - set of classes to import/export .aac/.mp4 files
-Copyright (C) 2004 Antonio Foranna
-
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation.
-	
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
-		
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-			
-The author can be contacted at:
[email protected]
-*/
-
-#include "Cfaac.h"
-
-
-
-// *********************************************************************************************
-//										CMyEncCfg
-// *********************************************************************************************
-
-void CMyEncCfg::getCfg(CMyEncCfg *cfg)
-{ 
-CRegistry reg;
-
-	if(reg.OpenCreate(HKEY_CURRENT_USER, REGISTRY_PROGRAM_NAME "\\FAAC"))
-	{
-		cfg->AutoCfg=reg.GetSetBool(REG_AUTO,DEF_AUTO);
-		cfg->SaveMP4=reg.GetSetByte(REG_WRITEMP4,DEF_WRITEMP4);
-		cfg->EncCfg.mpegVersion=reg.GetSetDword(REG_MPEGVER,DEF_MPEGVER); 
-		cfg->EncCfg.aacObjectType=reg.GetSetDword(REG_PROFILE,DEF_PROFILE); 
-		cfg->EncCfg.allowMidside=reg.GetSetDword(REG_MIDSIDE,DEF_MIDSIDE); 
-		cfg->EncCfg.useTns=reg.GetSetDword(REG_TNS,DEF_TNS); 
-		cfg->EncCfg.useLfe=reg.GetSetDword(REG_LFE,DEF_LFE);
-		cfg->UseQuality=reg.GetSetBool(REG_USEQUALTY,DEF_USEQUALTY);
-		cfg->EncCfg.quantqual=reg.GetSetDword(REG_QUALITY,DEF_QUALITY); 
-		cfg->EncCfg.bitRate=reg.GetSetDword(REG_BITRATE,DEF_BITRATE); 
-		cfg->EncCfg.bandWidth=reg.GetSetDword(REG_BANDWIDTH,DEF_BANDWIDTH); 
-		cfg->EncCfg.outputFormat=reg.GetSetDword(REG_HEADER,DEF_HEADER); 
-
-		FREE_ARRAY(cfg->OutDir);
-		cfg->OutDir=reg.GetSetStr(REG_OutFolder,"");
-
-		cfg->TagOn=reg.GetSetByte(REG_TAGON,0);
-#ifdef USE_IMPORT_TAG
-		cfg->TagImport=reg.GetSetByte(REG_TAGIMPORT,0);
-	#ifdef USE_PATHEXT
-		FREE_ARRAY(cfg->TagSrcPath);
-		FREE_ARRAY(cfg->TagSrcExt);
-		cfg->TagSrcPath=reg.GetSetStr(REG_InFolder,"");
-		cfg->TagSrcExt=reg.GetSetStr(REG_SrcExt,"");
-	#endif
-#endif
-		cfg->Tag.artist=reg.GetSetStr(REG_ARTIST,"");
-		cfg->Tag.title=reg.GetSetStr(REG_TITLE,"");
-		cfg->Tag.album=reg.GetSetStr(REG_ALBUM,"");
-		cfg->Tag.year=reg.GetSetStr(REG_YEAR,"");
-		cfg->Tag.genre=reg.GetSetStr(REG_GENRE,"");
-		cfg->Tag.writer=reg.GetSetStr(REG_WRITER,"");
-		cfg->Tag.comment=reg.GetSetStr(REG_COMMENT,"");
-		cfg->Tag.trackno=reg.GetSetWord(REG_TRACK,0);
-		cfg->Tag.ntracks=reg.GetSetWord(REG_NTRACKS,0);
-		cfg->Tag.discno=reg.GetSetWord(REG_DISK,0);
-		cfg->Tag.ndiscs=reg.GetSetWord(REG_NDISKS,0);
-		cfg->Tag.compilation=reg.GetSetByte(REG_COMPILATION,0);
-		cfg->Tag.artFilename=reg.GetSetStr(REG_ARTFILE,"");
-	}
-	else
-		MessageBox(0,"Can't open registry!",0,MB_OK|MB_ICONSTOP);
-}
-// -----------------------------------------------------------------------------------------------
-
-void CMyEncCfg::setCfg(CMyEncCfg *cfg)
-{ 
-CRegistry reg;
-
-	if(reg.OpenCreate(HKEY_CURRENT_USER, REGISTRY_PROGRAM_NAME "\\FAAC"))
-	{
-		reg.SetBool(REG_AUTO,cfg->AutoCfg);
-		reg.SetByte(REG_WRITEMP4,cfg->SaveMP4);
-		reg.SetDword(REG_MPEGVER,cfg->EncCfg.mpegVersion);
-		reg.SetDword(REG_PROFILE,cfg->EncCfg.aacObjectType);
-		reg.SetDword(REG_MIDSIDE,cfg->EncCfg.allowMidside);
-		reg.SetDword(REG_TNS,cfg->EncCfg.useTns);
-		reg.SetDword(REG_LFE,cfg->EncCfg.useLfe);
-		reg.SetBool(REG_USEQUALTY,cfg->UseQuality);
-		reg.SetDword(REG_QUALITY,cfg->EncCfg.quantqual);
-		reg.SetDword(REG_BITRATE,cfg->EncCfg.bitRate);
-		reg.SetDword(REG_BANDWIDTH,cfg->EncCfg.bandWidth);
-		reg.SetDword(REG_HEADER,cfg->EncCfg.outputFormat);
-
-		reg.SetStr(REG_OutFolder,cfg->OutDir);
-
-		reg.SetByte(REG_TAGON,cfg->TagOn);
-#ifdef USE_IMPORT_TAG
-		reg.SetByte(REG_TAGIMPORT,cfg->TagImport);
-	#ifdef USE_PATHEXT
-		reg.SetStr(REG_InFolder,cfg->TagSrcPath);
-		reg.SetStr(REG_SrcExt,cfg->TagSrcExt);
-	#endif
-#endif
-		reg.SetStr(REG_ARTIST,cfg->Tag.artist);
-		reg.SetStr(REG_TITLE,cfg->Tag.title);
-		reg.SetStr(REG_ALBUM,cfg->Tag.album);
-		reg.SetStr(REG_YEAR,cfg->Tag.year);
-		reg.SetStr(REG_GENRE,cfg->Tag.genre);
-		reg.SetStr(REG_WRITER,cfg->Tag.writer);
-		reg.SetStr(REG_COMMENT,cfg->Tag.comment);
-		reg.SetWord(REG_TRACK,cfg->Tag.trackno);
-		reg.SetWord(REG_NTRACKS,cfg->Tag.ntracks);
-		reg.SetWord(REG_DISK,cfg->Tag.discno);
-		reg.SetWord(REG_NDISKS,cfg->Tag.ndiscs);
-		reg.SetByte(REG_COMPILATION,cfg->Tag.compilation);
-		reg.SetStr(REG_ARTFILE,cfg->Tag.artFilename);
-	}
-	else
-		MessageBox(0,"Can't open registry!",0,MB_OK|MB_ICONSTOP);
-}
-
-// *********************************************************************************************
-//											Cfaac
-// *********************************************************************************************
-
-
-
-Cfaac::Cfaac(HANDLE hOut)
-{
-	if(hOut)
-	{
-		hOutput=hOut;
-		return;
-	}
-
-    if(!(hOutput=GlobalAlloc(GMEM_MOVEABLE|GMEM_SHARE|GMEM_ZEROINIT,sizeof(MYOUTPUT))))
-	{
-		MessageBox(0, "Memory allocation error: hOutput", APP_NAME " plugin", MB_OK|MB_ICONSTOP); \
-		return;
-	}
-//	dontAskGetFilename=false;
-}
-// -----------------------------------------------------------------------------------------------
-
-Cfaac::~Cfaac()
-{
-	if(!hOutput)
-		return;
-
-MYOUTPUT *mo;
-
-	GLOBALLOCK(mo,hOutput,MYOUTPUT,return);
-	
-	if(mo->WrittenSamples)
-	{
-	int	BytesWritten;
-		if(mo->bytes_into_buffer>0)
-			memset(mo->bufIn+mo->bytes_into_buffer, 0, (mo->samplesInput*(mo->BitsPerSample>>3))-mo->bytes_into_buffer);
-		do
-		{
-			if((BytesWritten=processData(hOutput,mo->bufIn,mo->bytes_into_buffer))<0)
-				MessageBox(0, "~Cfaac: processData", APP_NAME " plugin", MB_OK|MB_ICONSTOP);
-			mo->bytes_into_buffer=0;
-		}while(BytesWritten>0);
-	}
-
-	if(mo->aacFile)
-	{
-		fclose(mo->aacFile);
-		mo->aacFile=0;
-
-	CMyEncCfg cfg(false);
-		if(cfg.TagOn && mo->OutFilename)
-		{
-		int error=0;
-#ifdef USE_IMPORT_TAG
-			if(cfg.TagImport && mo->InFilename)
-			{
-			int l=strlen(mo->InFilename);
-				if(	!strcmpi(mo->InFilename+l-4,".mp4") ||
-					!strcmpi(mo->InFilename+l-4,".m4a") ||
-					!strcmpi(mo->InFilename+l-4,".m4b"))
-					error=cfg.Tag.ReadMp4Tag(mo->InFilename);
-				else
-					error=cfg.Tag.ReadAacTag(mo->InFilename);
-			}
-#endif
-			if(!error)
-				cfg.Tag.WriteAacTag(mo->OutFilename);
-		}
-	}
-	else
-	{
-		MP4Close(mo->MP4File);
-		mo->MP4File=0;
-	}
-	
-	if(mo->hEncoder)
-		faacEncClose(mo->hEncoder);
-	
-	FREE_ARRAY(mo->bitbuf)
-	FREE_ARRAY(mo->buf32bit)
-	FREE_ARRAY(mo->bufIn)
-
-	FREE_ARRAY(mo->OutFilename)
-	FREE_ARRAY(mo->InFilename)
-
-	GlobalUnlock(hOutput);
-	GlobalFree(hOutput);
-}
-
-// *********************************************************************************************
-//									Utilities
-// *********************************************************************************************
-
-char *Cfaac::getSourceFilename(char *path, char *src, char *ext)
-{
-char	*dst, chExt,
-		*pname, *pext;
-
-
-	if(!src)
-		return NULL;
-	if(!path)
-		path="";
-	if(!ext)
-		ext="";
-	pname=pext=src+strlen(src);
-
-	while(pname!=src && *pname!='\\' && *pname!='/')
-		pname--;
-	if(*pname=='\\' || *pname=='/')
-		pname++;
-	while(pext!=src && *pext!='.')
-		pext--;
-	chExt=*pext;
-	if(chExt=='.')
-		*pext='\0';
-
-	if(*path)
-	{
-	int l;
-		if(!(dst=(char *)malloc(strlen(path)+strlen(pname)+strlen(ext)+3))) // '\0','\\','.'
-			return dst;
-		l=strlen(path);
-		if(l>0 && path[l-1]=='\\')
-			sprintf(dst,"%s%s.%s",path,pname,ext);
-		else
-			sprintf(dst,"%s\\%s.%s",path,pname,ext);
-	}
-	else
-	{
-		if(!(dst=(char *)malloc(strlen(pname)+strlen(ext)+2)))
-			return dst;
-		sprintf(dst,"%s.%s",pname,ext);
-	}
-	*pext=chExt;
-
-	if(!strcmpi(src,dst))
-	{
-//		if(!dontAskGetFilename)
-		{
-		char buf[MAX_PATH+100];
-			sprintf(buf,"%s\nSource file=Destination file...aborting!\n\n\tSuppress this warning?",dst);
-//			if(MessageBox(NULL,buf,NULL,MB_YESNO)==IDYES)
-//				dontAskGetFilename=true;
-		}
-		FREE_ARRAY(dst);
-		return NULL;
-	}
-
-	return dst;
-}
-// *********************************************************************************************
-
-#define SWAP32(x) (((x & 0xff) << 24) | ((x & 0xff00) << 8) \
-	| ((x & 0xff0000) >> 8) | ((x & 0xff000000) >> 24))
-#define SWAP16(x) (((x & 0xff) << 8) | ((x & 0xff00) >> 8))
-
-void Cfaac::To32bit(int32_t *buf, BYTE *bufi, int size, BYTE samplebytes, BYTE bigendian)
-{
-int i;
-
-	switch(samplebytes)
-	{
-	case 1:
-		// this is endian clean
-		for (i = 0; i < size; i++)
-			buf[i] = (bufi[i] - 128) * 65536;
-		break;
-		
-	case 2:
-#ifdef WORDS_BIGENDIAN
-		if (!bigendian)
-#else
-			if (bigendian)
-#endif
-			{
-				// swap bytes
-				for (i = 0; i < size; i++)
-				{
-					int16_t s = ((int16_t *)bufi)[i];
-					
-					s = SWAP16(s);
-					
-					buf[i] = ((u_int32_t)s) << 8;
-				}
-			}
-			else
-			{
-				// no swap
-				for (i = 0; i < size; i++)
-				{
-					int s = ((int16_t *)bufi)[i];
-					
-					buf[i] = s << 8;
-				}
-			}
-			break;
-			
-	case 3:
-		if (!bigendian)
-		{
-			for (i = 0; i < size; i++)
-			{
-				int s = bufi[3 * i] | (bufi[3 * i + 1] << 8) | (bufi[3 * i + 2] << 16);
-				
-				// fix sign
-				if (s & 0x800000)
-					s |= 0xff000000;
-				
-				buf[i] = s;
-			}
-		}
-		else // big endian input
-		{
-			for (i = 0; i < size; i++)
-			{
-				int s = (bufi[3 * i] << 16) | (bufi[3 * i + 1] << 8) | bufi[3 * i + 2];
-				
-				// fix sign
-				if (s & 0x800000)
-					s |= 0xff000000;
-				
-				buf[i] = s;
-			}
-		}
-		break;
-		
-	case 4:		
-#ifdef WORDS_BIGENDIAN
-		if (!bigendian)
-#else
-			if (bigendian)
-#endif
-			{
-				// swap bytes
-				for (i = 0; i < size; i++)
-				{
-					int s = bufi[i];
-					
-					buf[i] = SWAP32(s);
-				}
-			}
-			else
-				memcpy(buf,bufi,size*sizeof(u_int32_t));
-		/*
-		int exponent, mantissa;
-		float *bufo=(float *)buf;
-			
-			for (i = 0; i < size; i++)
-			{
-				exponent=bufi[(i<<2)+3]<<1;
-				if(bufi[i*4+2] & 0x80)
-					exponent|=0x01;
-				exponent-=126;
-				mantissa=(DWORD)bufi[(i<<2)+2]<<16;
-				mantissa|=(DWORD)bufi[(i<<2)+1]<<8;
-				mantissa|=bufi[(i<<2)];
-				bufo[i]=(float)ldexp(mantissa,exponent);
-			}*/
-			break;
-	}
-}
-
-// *********************************************************************************************
-//									Main functions
-// *********************************************************************************************
-
-void Cfaac::DisplayError(char *ProcName, char *str)
-{
-char buf[100]="";
-
-	if(str && *str)
-	{
-		if(ProcName && *ProcName)
-			sprintf(buf,"%s: ", ProcName);
-		strcat(buf,str);
-		MessageBox(0, buf, APP_NAME " plugin", MB_OK|MB_ICONSTOP);
-	}
-
-MYOUTPUT *mo;
-	GLOBALLOCK(mo,hOutput,MYOUTPUT,return);
-	mo->bytes_into_buffer=-1;
-	GlobalUnlock(hOutput);
-	GlobalUnlock(hOutput);
-}
-// *********************************************************************************************
-
-HANDLE Cfaac::Init(LPSTR InFileName, LPSTR OutFileName,long lSamprate,WORD wBitsPerSample,WORD wChannels,long FileSize)
-{
-MYOUTPUT	*mo;
-CMyEncCfg	cfg(false);
-DWORD		samplesInput,
-			maxBytesOutput;
-
-//	if(wBitsPerSample!=8 && wBitsPerSample!=16) // 32 bit audio from cooledit is in unsupported format
-//		return 0;
-	if(wChannels>48)	// FAAC supports max 48 tracks!
-		return NULL;
-
-	GLOBALLOCK(mo,hOutput,MYOUTPUT,return NULL);
-
-	// open the encoder library
-	if(!(mo->hEncoder=faacEncOpen(lSamprate, wChannels, &samplesInput, &maxBytesOutput)))
-		return ERROR_Init("Can't open library");
-
-	if(!(mo->bitbuf=(unsigned char *)malloc(maxBytesOutput*sizeof(unsigned char))))
-		return ERROR_Init("Memory allocation error: output buffer");
-
-	if(!(mo->bufIn=(BYTE *)malloc(samplesInput*sizeof(int32_t))))
-		return ERROR_Init("Memory allocation error: input buffer");
-
-	if(!(mo->buf32bit=(int32_t *)malloc(samplesInput*sizeof(int32_t))))
-		return ERROR_Init("Memory allocation error: 32 bit buffer");
-
-	if(cfg.SaveMP4)// || cfg.Tag.On)
-	{
-	int ExtPos=0, // append new ext
-		fnLen=lstrlen(OutFileName);
-//		if(OutFileName[lstrlen(OutFileName)-4]=='.')
-		if(	fnLen>=4 &&
-			(!strcmpi(OutFileName+fnLen-4,".aac") ||
-			!strcmpi(OutFileName+fnLen-4,".mp4") ||
-			!strcmpi(OutFileName+fnLen-4,".m4a") ||
-			!strcmpi(OutFileName+fnLen-4,".m4b"))) // no aac/mp4 ext => append new ext
-			if(	(cfg.SaveMP4==1 && strcmpi(OutFileName+fnLen-4,".mp4")) ||
-				(cfg.SaveMP4==2 && strcmpi(OutFileName+fnLen-4,".m4a")) ||
-				(cfg.SaveMP4==3 && strcmpi(OutFileName+fnLen-4,".m4b")))
-				ExtPos=4; // wrong ext => replace it
-			else
-				ExtPos=-1; // correct ext => no action
-		if(ExtPos!=-1)
-		{
-			switch(cfg.SaveMP4)
-			{
-			case 1:	strcpy(OutFileName+fnLen-ExtPos,".mp4"); break;
-			case 2: strcpy(OutFileName+fnLen-ExtPos,".m4a"); break;
-			case 3: strcpy(OutFileName+fnLen-ExtPos,".m4b"); break;
-			}
-		FILE *f=fopen(OutFileName,"rb");
-			if(f)
-			{
-			char buf[MAX_PATH+20];
-				sprintf(buf,"Overwrite \"%s\" ?",OutFileName);
-				fclose(f);
-				if(MessageBox(NULL,buf,"File already exists!",MB_YESNO|MB_ICONQUESTION)==IDNO)
-					return ERROR_Init(0);//"User abort");
-			}
-		}
-	}
-	mo->WriteMP4=	!strcmpi(OutFileName+lstrlen(OutFileName)-4,".mp4") ||
-					!strcmpi(OutFileName+lstrlen(OutFileName)-4,".m4a") ||
-					!strcmpi(OutFileName+lstrlen(OutFileName)-4,".m4b");
-
-faacEncConfigurationPtr CurFormat=faacEncGetCurrentConfiguration(mo->hEncoder);
-	CurFormat->inputFormat=FAAC_INPUT_32BIT;
-/*	switch(wBitsPerSample)
-	{
-	case 16:
-		CurFormat->inputFormat=FAAC_INPUT_16BIT;
-		break;
-	case 24:
-		CurFormat->inputFormat=FAAC_INPUT_24BIT;
-		break;
-	case 32:
-		CurFormat->inputFormat=FAAC_INPUT_32BIT;
-		break;
-	default:
-		CurFormat->inputFormat=FAAC_INPUT_NULL;
-		break;
-	}*/
-	if(!cfg.AutoCfg)
-	{
-	faacEncConfigurationPtr myFormat=&cfg.EncCfg;
-
-		if(cfg.UseQuality)
-		{
-			CurFormat->quantqual=myFormat->quantqual;
-			CurFormat->bitRate=0;//myFormat->bitRate;
-		}
-		else
-		{
-			CurFormat->bitRate=(myFormat->bitRate*1000)/wChannels;
-			CurFormat->quantqual=100;
-		}
-
-		switch(CurFormat->bandWidth)
-		{
-		case 0: // Auto
-			break;
-		case 0xffffffff: // Full
-			CurFormat->bandWidth=lSamprate/2;
-			break;
-		default:
-			CurFormat->bandWidth=myFormat->bandWidth;
-			break;
-		}
-		CurFormat->mpegVersion=myFormat->mpegVersion;
-		CurFormat->outputFormat=myFormat->outputFormat;
-		CurFormat->mpegVersion=myFormat->mpegVersion;
-		CurFormat->aacObjectType=myFormat->aacObjectType;
-		CurFormat->allowMidside=myFormat->allowMidside;
-//		CurFormat->useTns=myFormat->useTns;
-		CurFormat->useTns=false;
-	}
-	else
-	{
-		CurFormat->mpegVersion=DEF_MPEGVER;
-		CurFormat->aacObjectType=DEF_PROFILE;
-		CurFormat->allowMidside=DEF_MIDSIDE;
-//		CurFormat->useTns=DEF_TNS;
-		CurFormat->useTns=false;
-		CurFormat->useLfe=DEF_LFE;
-		CurFormat->quantqual=DEF_QUALITY;
-		CurFormat->bitRate=DEF_BITRATE;
-		CurFormat->bandWidth=DEF_BANDWIDTH;
-		CurFormat->outputFormat=DEF_HEADER;
-	}
-	if(mo->WriteMP4)
-		CurFormat->outputFormat=RAW;
-	CurFormat->useLfe=wChannels>=6 ? 1 : 0;
-	if(!faacEncSetConfiguration(mo->hEncoder, CurFormat))
-		return ERROR_Init("Unsupported parameters!");
-
-//	mo->src_size=lSize;
-//	mi->dst_name=strdup(OutFileName);
-	mo->Samprate=lSamprate;
-	mo->BitsPerSample=wBitsPerSample;
-	mo->Channels=wChannels;
-	mo->samplesInput=samplesInput;
-	mo->samplesInputSize=samplesInput*(mo->BitsPerSample>>3);
-
-	mo->maxBytesOutput=maxBytesOutput;
-
-    if(mo->WriteMP4) // Create MP4 file --------------------------------------------------------------------------
-	{
-    BYTE *ASC=0;
-    DWORD ASCLength=0;
-
-        if((mo->MP4File=MP4Create(OutFileName, 0, 0, 0))==MP4_INVALID_FILE_HANDLE)
-			return ERROR_Init("Can't create file");
-        MP4SetTimeScale(mo->MP4File, 90000);
-        mo->MP4track=MP4AddAudioTrack(mo->MP4File, lSamprate, MP4_INVALID_DURATION, MP4_MPEG4_AUDIO_TYPE);
-        MP4SetAudioProfileLevel(mo->MP4File, 0x0F);
-        faacEncGetDecoderSpecificInfo(mo->hEncoder, &ASC, &ASCLength);
-        MP4SetTrackESConfiguration(mo->MP4File, mo->MP4track, (unsigned __int8 *)ASC, ASCLength);
-		mo->frameSize=samplesInput/wChannels;
-		mo->ofs=mo->frameSize;
-
-		if(cfg.TagOn)
-		{
-		int error=0;
-#ifdef USE_IMPORT_TAG
-			if(cfg.TagImport && InFileName)
-			{
-			int l=strlen(InFileName);
-				if(	!strcmpi(InFileName+l-4,".mp4") ||
-					!strcmpi(InFileName+l-4,".m4a") ||
-					!strcmpi(InFileName+l-4,".m4b"))
-					error=cfg.Tag.ReadMp4Tag(InFileName);
-				else
-					error=cfg.Tag.ReadAacTag(InFileName);
-			}
-#endif
-			if(!error)
-				cfg.Tag.WriteMP4Tag(mo->MP4File);
-		}
-	}
-	else // Create AAC file -----------------------------------------------------------------------------
-	{
-		// open the aac output file 
-		if(!(mo->aacFile=fopen(OutFileName, "wb")))
-			return ERROR_Init("Can't create file");
-
-		// use bufferized stream
-		setvbuf(mo->aacFile,NULL,_IOFBF,32767);
-
-		mo->InFilename=strdup(InFileName);
-		mo->OutFilename=strdup(OutFileName);
-	}
-
-	showInfo(mo);
-
-	GlobalUnlock(hOutput);
-    return hOutput;
-}
-// *********************************************************************************************
-
-int Cfaac::processData(HANDLE hOutput, BYTE *bufIn, DWORD len)
-{
-	if(!hOutput)
-		return -1;
-
-int bytesWritten=0;
-int bytesEncoded;
-MYOUTPUT far *mo;
-
-	GLOBALLOCK(mo,hOutput,MYOUTPUT,return 0);
-
-int32_t *buf=mo->buf32bit;
-
-	if((int)len<mo->samplesInputSize)
-	{
-		mo->samplesInput=(len<<3)/mo->BitsPerSample;
-		mo->samplesInputSize=mo->samplesInput*(mo->BitsPerSample>>3);
-	}
-//	if(mo->BitsPerSample==8 || mo->BitsPerSample==32)
-		To32bit(buf,bufIn,mo->samplesInput,mo->BitsPerSample>>3,false);
-
-	// call the actual encoding routine
-	if((bytesEncoded=faacEncEncode(mo->hEncoder, (int32_t *)buf, mo->samplesInput, mo->bitbuf, mo->maxBytesOutput))<0)
-		return ERROR_processData("faacEncEncode()");
-
-	// write bitstream to aac file 
-	if(mo->aacFile)
-	{
-		if(bytesEncoded>0)
-		{
-			if((bytesWritten=fwrite(mo->bitbuf, 1, bytesEncoded, mo->aacFile))!=bytesEncoded)
-				return ERROR_processData("Write failed!");
-			mo->WrittenSamples=1; // needed into destructor
-		}
-	}
-	else
-	// write bitstream to mp4 file
-	{
-	MP4Duration dur,
-				SamplesLeft;
-		if(len>0)
-		{
-			mo->srcSize+=len;
-			dur=mo->frameSize;
-		}
-		else
-		{
-			mo->TotalSamples=(mo->srcSize<<3)/(mo->BitsPerSample*mo->Channels);
-			SamplesLeft=(mo->TotalSamples-mo->WrittenSamples)+mo->frameSize;
-			dur=SamplesLeft>mo->frameSize ? mo->frameSize : SamplesLeft;
-		}
-		if(bytesEncoded>0)
-		{
-			if(!(bytesWritten=MP4WriteSample(mo->MP4File, mo->MP4track, (unsigned __int8 *)mo->bitbuf, (DWORD)bytesEncoded, dur, mo->ofs, true) ? bytesEncoded : -1))
-				return ERROR_processData("MP4WriteSample()");
-			mo->ofs=0;
-			mo->WrittenSamples+=dur;
-		}
-	}
-
-	showProgress(mo);
-
-	GlobalUnlock(hOutput);
-	return bytesWritten;
-}
-// -----------------------------------------------------------------------------------------------
-
-int Cfaac::processDataBufferized(HANDLE hOutput, BYTE *bufIn, long lBytes)
-{
-	if(!hOutput)
-		return -1;
-
-int	bytesWritten=0, tot=0;
-MYOUTPUT far *mo;
-
-	GLOBALLOCK(mo,hOutput,MYOUTPUT,return 0);
-
-	if(mo->bytes_into_buffer>=0)
-		do
-		{
-			if(mo->bytes_into_buffer+lBytes<mo->samplesInputSize)
-			{
-				memmove(mo->bufIn+mo->bytes_into_buffer, bufIn, lBytes);
-				mo->bytes_into_buffer+=lBytes;
-				lBytes=0;
-			}
-			else
-			{
-			int	shift=mo->samplesInputSize-mo->bytes_into_buffer;
-				memmove(mo->bufIn+mo->bytes_into_buffer, bufIn, shift);
-				mo->bytes_into_buffer+=shift;
-				bufIn+=shift;
-				lBytes-=shift;
-
-				tot+=bytesWritten=processData(hOutput,mo->bufIn,mo->bytes_into_buffer);
-				if(bytesWritten<0)
-					return ERROR_processData(0);
-				mo->bytes_into_buffer=0;
-			}
-		}while(lBytes);
-
-	GlobalUnlock(hOutput);
-	return tot;
-}
--- a/common/Cfaac/Cfaac.h
+++ /dev/null
@@ -1,184 +1,0 @@
-/*
-CFAAC - set of classes to import/export .aac/.mp4 files
-Copyright (C) 2004 Antonio Foranna
-
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation.
-	
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
-		
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-			
-The author can be contacted at:
[email protected]
-*/
-
-#ifndef _Cfaac_H
-#define _Cfaac_H
-
-// *********************************************************************************************
-
-#include <mp4.h>		// int32_t, ...
-#include <faad.h>		// FAAD2 version
-#ifdef MAIN
-	#undef MAIN
-#endif
-#ifdef SSR
-	#undef SSR
-#endif
-#ifdef LTP
-	#undef LTP
-#endif
-#include <faac.h>
-#include <win32_ver.h>	// mpeg4ip version
-#include "CRegistry.h"
-#include "CTag.h"
-#include "Defines.h"	// my defines
-
-// *********************************************************************************************
-
-#ifdef	ADTS
-#undef	ADTS
-#define ADTS 1
-#endif
-
-// *********************************************************************************************
-
-#define REG_AUTO "Auto"
-#define DEF_AUTO true
-#define REG_WRITEMP4 "Write MP4"
-#define DEF_WRITEMP4 0
-#define REG_MPEGVER "MPEG version"
-#define DEF_MPEGVER MPEG4
-#define REG_PROFILE "Profile"
-#define DEF_PROFILE LOW
-#define REG_MIDSIDE "MidSide"
-#define DEF_MIDSIDE true
-#define REG_TNS "TNS"
-#define DEF_TNS true
-#define REG_LFE "LFE"
-#define DEF_LFE false
-#define REG_USEQUALTY "Use quality"
-#define DEF_USEQUALTY true
-#define REG_QUALITY "Quality"
-#define DEF_QUALITY 100
-#define REG_BITRATE "BitRate"
-#define DEF_BITRATE 0 /* quality on */
-#define REG_BANDWIDTH "BandWidth"
-#define DEF_BANDWIDTH 0
-#define REG_HEADER "Header"
-#define DEF_HEADER ADTS
-
-#define REG_OutFolder "Output folder"
-#define REG_InFolder "Source folder"
-#define REG_SrcExt "Source extensions"
-
-// *********************************************************************************************
-
-class CMyEncCfg
-{
-private:
-
-	bool SaveCfgOnDestroy;
-
-public:
-
-	CMyEncCfg(bool SaveOnDestroy=true) { OutDir=TagSrcPath=TagSrcExt=NULL; getCfg(this); SaveCfgOnDestroy=SaveOnDestroy; }
-	virtual ~CMyEncCfg() { if(SaveCfgOnDestroy) setCfg(this); FreeCfg(this); }
-
-	void FreeCfg(CMyEncCfg *cfg) { Tag.FreeTag(); FREE_ARRAY(OutDir); FREE_ARRAY(TagSrcPath); FREE_ARRAY(TagSrcExt); }
-	void getCfg(CMyEncCfg *cfg);
-	void setCfg(CMyEncCfg *cfg);
-
-	bool					AutoCfg,
-							UseQuality;
-	BYTE					SaveMP4;
-	char					*OutDir;
-	faacEncConfiguration	EncCfg;
-	CMP4Tag					Tag;
-	BYTE					TagOn;
-	BYTE					TagImport;
-	char					*TagSrcPath,
-							*TagSrcExt;
-};
-// -----------------------------------------------------------------------------------------------
-
-typedef struct output_tag  // any special vars associated with output file
-{
-// MP4
-MP4FileHandle 	MP4File;
-MP4TrackId		MP4track;
-MP4Duration		TotalSamples,
-				WrittenSamples,
-				encoded_samples;
-DWORD			frameSize,
-				ofs;
-
-// AAC
-FILE			*aacFile;
-char			*InFilename,
-				*OutFilename;
-
-// GLOBAL
-long			Samprate;
-WORD			BitsPerSample;
-WORD			Channels;
-DWORD			srcSize;
-//char			*dst_name;		// name of compressed file
-
-faacEncHandle	hEncoder;
-int32_t			*buf32bit;
-BYTE			*bufIn;
-unsigned char	*bitbuf;
-long			bytes_into_buffer;
-DWORD			maxBytesOutput;
-long			samplesInput,
-				samplesInputSize;
-bool			WriteMP4;
-} MYOUTPUT;
-
-
-
-// *********************************************************************************************
-
-
-
-class Cfaac
-{
-private:
-	virtual void DisplayError(char *ProcName, char *str);
-	virtual HANDLE ERROR_Init(char *str) { DisplayError("Init", str); return NULL; }
-	virtual int ERROR_processData(char *str) { DisplayError("processData", str); return -1; }
-	virtual void showInfo(MYOUTPUT *mi) {}
-	virtual void showProgress(MYOUTPUT *mi) {}
-	void To32bit(int32_t *buf, BYTE *bufi, int size, BYTE samplebytes, BYTE bigendian);
-
-public:
-    Cfaac(HANDLE hOutput=NULL);
-    virtual ~Cfaac();
-
-	virtual char *getSourceFilename(char *path, char *src, char *ext);
-
-	virtual HANDLE Init(LPSTR InFilename,LPSTR OutFilename,long lSamprate,WORD wBitsPerSample,WORD wChannels,long FileSize);
-    virtual int processData(HANDLE hOutput, BYTE *bufIn, DWORD len);
-	virtual int processDataBufferized(HANDLE hOutput, BYTE *bufIn, long lBytes);
-/*
-// AAC
-	bool            BlockSeeking;
-
-// GLOBAL
-	long            newpos_ms;
-	BOOL            IsSeekable;
-	MYINPUT			*mi;
-*/
-	HANDLE			hOutput;
-//	bool			dontAskGetFilename;
-};
-
-#endif
--- a/common/Cfaac/Cfaad.cpp
+++ /dev/null
@@ -1,807 +1,0 @@
-/*
-CFAAC - set of classes to import/export .aac/.mp4 files
-Copyright (C) 2004 Antonio Foranna
-
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation.
-	
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
-		
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-			
-The author can be contacted at:
[email protected]
-*/
-
-#include "Cfaad.h"
-
-
-
-// *********************************************************************************************
-
-
-
-Cfaad::Cfaad(HANDLE hIn)
-{
-	ShowDlg4RawAAC=NULL;
-	pCfg=NULL;
-
-	if(hIn)
-	{
-		hInput=hIn;
-		return;
-	}
-
-MYINPUT *mi;
-
-	if(!(hInput=GlobalAlloc(GMEM_MOVEABLE|GMEM_SHARE|GMEM_ZEROINIT,sizeof(MYINPUT))))
-		MessageBox(0, "Memory allocation error: hInput", APP_NAME " plugin", MB_OK|MB_ICONSTOP); \
-	if(!(mi=(MYINPUT *)GlobalLock(hInput)))
-		MessageBox(0, "GlobalLock(hInput)", APP_NAME " plugin", MB_OK|MB_ICONSTOP); \
-/*
-	mi->mp4File=0;
-	mi->aacFile=0;
-    mi->hDecoder=0;
-    mi->buffer=0;
-	mi->bytes_read=0;*/
-	mi->BitsPerSample=16;
-	mi->FindBitrate=FALSE;
-	newpos_ms=-1;
-	mi->seek_table=NULL;
-	mi->seek_table_length=0;
-	mi->LockSeeking=false;
-	GlobalUnlock(hInput);
-}
-// -----------------------------------------------------------------------------------------------
-
-Cfaad::~Cfaad()
-{
-MYINPUT *mi;
-
-	if(!hInput)
-		return;
-
-	GLOBALLOCK(mi,hInput,MYINPUT,return);
-
-	if(mi->mp4File)
-		MP4Close(mi->mp4File);
-	if(mi->aacFile)
-		fclose(mi->aacFile);
-	if(mi->hDecoder)
-		faacDecClose(mi->hDecoder);
-	FREE_ARRAY(mi->buffer);
-	FREE_ARRAY(mi->seek_table);
-
-	GlobalUnlock(hInput);
-	GlobalFree(hInput);
-}
-
-// *********************************************************************************************
-//									Utilities
-// *********************************************************************************************
-
-int Cfaad::GetAACTrack(MP4FileHandle infile)
-{
-// find AAC track
-int i, rc;
-int numTracks = MP4GetNumberOfTracks(infile, NULL, 0);
-
-	for (i = 0; i < numTracks; i++)
-    {
-    MP4TrackId trackId = MP4FindTrackId(infile, i, NULL, 0);
-    const char* trackType = MP4GetTrackType(infile, trackId);
-
-        if (!strcmp(trackType, MP4_AUDIO_TRACK_TYPE))
-        {
-        unsigned char *buff = NULL;
-        unsigned __int32 buff_size = 0;
-        mp4AudioSpecificConfig mp4ASC;
-
-			MP4GetTrackESConfiguration(infile, trackId, (unsigned __int8 **)&buff, &buff_size);
-
-            if (buff)
-            {
-                rc = AudioSpecificConfig(buff, buff_size, &mp4ASC);
-                free(buff);
-
-                if (rc < 0)
-                    return -1;
-                return trackId;
-            }
-        }
-    }
-
-    // can't decode this
-    return -1;
-}
-// *********************************************************************************************
-
-int Cfaad::IsMP4(LPSTR lpstrFilename)
-{
-DWORD	mp4file = 0;
-FILE	*hMP4File = fopen(lpstrFilename, "rb");
-BYTE	header[8];
-    if(!hMP4File)
-		return -1;
-    fread(header, 1, 8, hMP4File);
-    fclose(hMP4File);
-    if(header[4]=='f' && header[5]=='t' && header[6]=='y' && header[7]=='p')
-		return 1;
-
-	return 0;
-}
-// *********************************************************************************************
-long Cfaad::id3v2_TagSize(unsigned char *buffer)
-{
-	if(StringComp((const char *)buffer, "ID3", 3) == 0)
-	{
-	unsigned long tagsize;
-
-	// high bit is not used
-		tagsize =	(buffer[6] << 21) | (buffer[7] << 14) |
-					(buffer[8] <<  7) | (buffer[9] <<  0);
-		tagsize += 10;
-		return tagsize;
-	}
-	return 0;
-}
-/*
-long Cfaad::id3v2_TagSize(aac_buffer *b)
-{
-DWORD    tagsize = 0;
-    if (!memcmp(b->buffer, "ID3", 3))
-    {
-        // high bit is not used
-        tagsize = (b->buffer[6] << 21) | (b->buffer[7] << 14) |
-            (b->buffer[8] <<  7) | (b->buffer[9] <<  0);
-
-        tagsize += 10;
-        advance_buffer(b, tagsize);
-        fill_buffer(b);
-    }
-	return tagsize;
-}
-// *********************************************************************************************
-
-int Cfaad::fill_buffer(aac_buffer *b)
-{
-    int bread;
-
-    if (b->bytes_consumed > 0)
-    {
-        if (b->bytes_into_buffer)
-        {
-            memmove((void*)b->buffer, (void*)(b->buffer + b->bytes_consumed),
-                b->bytes_into_buffer*sizeof(unsigned char));
-        }
-
-        if (!b->at_eof)
-        {
-            bread = fread((void*)(b->buffer + b->bytes_into_buffer), 1,
-                b->bytes_consumed, b->infile);
-
-            if (bread != b->bytes_consumed)
-                b->at_eof = 1;
-
-            b->bytes_into_buffer += bread;
-        }
-
-        b->bytes_consumed = 0;
-
-        if (b->bytes_into_buffer > 3)
-        {
-            if (memcmp(b->buffer, "TAG", 3) == 0)
-                b->bytes_into_buffer = 0;
-        }
-        if (b->bytes_into_buffer > 11)
-        {
-            if (memcmp(b->buffer, "LYRICSBEGIN", 11) == 0)
-                b->bytes_into_buffer = 0;
-        }
-        if (b->bytes_into_buffer > 8)
-        {
-            if (memcmp(b->buffer, "APETAGEX", 8) == 0)
-                b->bytes_into_buffer = 0;
-        }
-    }
-
-    return 1;
-}
-// *********************************************************************************************
-
-void Cfaad::advance_buffer(aac_buffer *b, int bytes)
-{
-    b->file_offset += bytes;
-    b->bytes_consumed = bytes;
-    b->bytes_into_buffer -= bytes;
-}
-// *********************************************************************************************
-
-static int adts_sample_rates[] = {96000,88200,64000,48000,44100,32000,24000,22050,16000,12000,11025,8000,7350,0,0,0};
-
-int Cfaad::adts_parse(aac_buffer *b, int *bitrate, float *length)
-{
-    int frames, frame_length;
-    int t_framelength = 0;
-    int samplerate;
-    float frames_per_sec, bytes_per_frame;
-
-    // Read all frames to ensure correct time and bitrate
-    for (frames = 0; ; frames++)
-    {
-        fill_buffer(b);
-
-        if (b->bytes_into_buffer > 7)
-        {
-            // check syncword 
-            if (!((b->buffer[0] == 0xFF)&&((b->buffer[1] & 0xF6) == 0xF0)))
-                break;
-
-            if (frames == 0)
-                samplerate = adts_sample_rates[(b->buffer[2]&0x3c)>>2];
-
-            frame_length = ((((unsigned int)b->buffer[3] & 0x3)) << 11)
-                | (((unsigned int)b->buffer[4]) << 3) | (b->buffer[5] >> 5);
-
-            t_framelength += frame_length;
-
-            if (frame_length > b->bytes_into_buffer)
-                break;
-
-            advance_buffer(b, frame_length);
-        } else {
-            break;
-        }
-    }
-
-    frames_per_sec = (float)samplerate/1024.0f;
-    if (frames != 0)
-        bytes_per_frame = (float)t_framelength/(float)(frames*1000);
-    else
-        bytes_per_frame = 0;
-    *bitrate = (int)(8. * bytes_per_frame * frames_per_sec + 0.5);
-    if (frames_per_sec != 0)
-        *length = (float)frames/frames_per_sec;
-    else
-        *length = 1;
-
-    return 1;
-}
-// *********************************************************************************************
-
-// get AAC infos for printing 
-void Cfaad::GetAACInfos(aac_buffer *b, DWORD *header_type, float *song_length, int *pbitrate, long filesize)
-{
-int		bitrate=0;
-float	length=0;
-int		bread;
-long	tagsize=id3v2_TagSize(b);
-
-	*header_type = 0;
-	b->file_offset=tagsize;
-
-    if ((b->buffer[0] == 0xFF) && ((b->buffer[1] & 0xF6) == 0xF0))
-    {
-        adts_parse(b, &bitrate, &length);
-        fseek(b->infile, tagsize, SEEK_SET);
-
-        bread = fread(b->buffer, 1, FAAD_MIN_STREAMSIZE*MAX_CHANNELS, b->infile);
-        if (bread != FAAD_MIN_STREAMSIZE*MAX_CHANNELS)
-            b->at_eof = 1;
-        else
-            b->at_eof = 0;
-        b->bytes_into_buffer = bread;
-        b->bytes_consumed = 0;
-        b->file_offset = tagsize;
-
-        *header_type = 1;
-    } else if (memcmp(b->buffer, "ADIF", 4) == 0) {
-        int skip_size = (b->buffer[4] & 0x80) ? 9 : 0;
-        bitrate = ((unsigned int)(b->buffer[4 + skip_size] & 0x0F)<<19) |
-            ((unsigned int)b->buffer[5 + skip_size]<<11) |
-            ((unsigned int)b->buffer[6 + skip_size]<<3) |
-            ((unsigned int)b->buffer[7 + skip_size] & 0xE0);
-
-        length = (float)filesize;
-        if (length != 0)
-        {
-            length = ((float)length*8.f)/((float)bitrate) + 0.5f;
-        }
-
-        bitrate = (int)((float)bitrate/1000.0f + 0.5f);
-
-        *header_type = 2;
-    }
-
-    *song_length = length;
-	*pbitrate=bitrate;
-}
-
-void Cfaad::GetAACInfos(char *Filename, aac_buffer *b, DWORD *header_type, float *song_length, int *pbitrate)
-{
-	if(!(b->infile=fopen(Filename,"rb")))
-	{
-		MessageBox(NULL,"Error opening file",NULL,MB_OK);
-		return;
-	}
-	fseek(b->infile, 0, SEEK_END);
-long	src_size=ftell(b->infile);
-	fseek(b->infile, 0, SEEK_SET);
-	if(!(b->buffer=(BYTE *)malloc(FAAD_STREAMSIZE)))
-	{
-		MessageBox(NULL,"Memory allocation error: b->buffer",NULL,MB_OK);
-		return;
-	}
-
-int	tread=src_size<FAAD_STREAMSIZE ? src_size : FAAD_STREAMSIZE;
-	b->bytes_into_buffer=fread(b->buffer, 1, tread, b->infile);
-	if(b->bytes_into_buffer!=tread)
-	{
-		MessageBox(NULL,"Read failed!",NULL,MB_OK);
-		return;
-	}
-	b->bytes_consumed=0;
-	b->file_offset=0;
-	b->at_eof=(b->bytes_into_buffer!=tread) ? 1 : 0;
-
-	*header_type = 0;
-	b->file_offset=0;
-
-	GetAACInfos(b,header_type,song_length,pbitrate,src_size);
-
-	free(b->buffer);
-	fclose(b->infile);
-}
-*/
-// *********************************************************************************************
-//									Main functions
-// *********************************************************************************************
-
-void CMyDecCfg::getCfg(CMyDecCfg *cfg) 
-{ 
-CRegistry reg;
-
-if(reg.OpenCreate(HKEY_CURRENT_USER, REGISTRY_PROGRAM_NAME "\\FAAD"))
-	{
-		cfg->DefaultCfg=reg.GetSetBool(REG_DEFAULT,true);
-		cfg->DecCfg.defObjectType=reg.GetSetByte(REG_PROFILE,LC);
-		cfg->DecCfg.defSampleRate=reg.GetSetDword(REG_SAMPLERATE,44100);
-		cfg->DecCfg.outputFormat=reg.GetSetByte(REG_BPS,FAAD_FMT_16BIT);
-		cfg->DecCfg.downMatrix=reg.GetSetByte(REG_DOWNMATRIX,0);
-		cfg->DecCfg.useOldADTSFormat=reg.GetSetByte(REG_OLDADTS,0);
-		cfg->DecCfg.dontUpSampleImplicitSBR=reg.GetSetByte(REG_DONTUPSAMPLESBR,1);
-//		cfg->Channels=reg.GetSetByte("Channels",2);
-	}
-	else
-		MessageBox(0,"Can't open registry!",0,MB_OK|MB_ICONSTOP);
-}
-// -----------------------------------------------------------------------------------------------
-
-void CMyDecCfg::setCfg(CMyDecCfg *cfg)
-{ 
-CRegistry reg;
-
-	if(reg.OpenCreate(HKEY_CURRENT_USER, REGISTRY_PROGRAM_NAME "\\FAAD"))
-	{
-		reg.SetBool(REG_DEFAULT,cfg->DefaultCfg);
-		reg.SetByte(REG_PROFILE,cfg->DecCfg.defObjectType);
-		reg.SetDword(REG_SAMPLERATE,cfg->DecCfg.defSampleRate);
-		reg.SetByte(REG_BPS,cfg->DecCfg.outputFormat);
-		reg.SetByte(REG_DOWNMATRIX,cfg->DecCfg.downMatrix);
-		reg.SetByte(REG_OLDADTS,cfg->DecCfg.useOldADTSFormat);
-		reg.SetByte(REG_DONTUPSAMPLESBR,cfg->DecCfg.dontUpSampleImplicitSBR);
-//		reg.SetByte("Channels",cfg->Channels);
-	}
-	else
-		MessageBox(0,"Can't open registry!",0,MB_OK|MB_ICONSTOP);
-}
-// *********************************************************************************************
-
-void Cfaad::setFaadCfg(faacDecHandle hDecoder, CMyDecCfg Cfg)
-{
-faacDecConfigurationPtr	config=faacDecGetCurrentConfiguration(hDecoder);
-
-	if(!Cfg.DefaultCfg)
-	{
-		config->defObjectType=Cfg.DecCfg.defObjectType;
-		config->outputFormat=Cfg.DecCfg.outputFormat;
-		config->defSampleRate=Cfg.DecCfg.defSampleRate;
-		config->downMatrix=Cfg.DecCfg.downMatrix;
-		config->useOldADTSFormat=Cfg.DecCfg.useOldADTSFormat;
-		config->dontUpSampleImplicitSBR=1;
-	}
-	else
-	{
-		config->defObjectType=LC;
-		config->outputFormat=FAAD_FMT_16BIT;
-		config->defSampleRate=44100;
-		config->downMatrix=0;
-		config->useOldADTSFormat=0;
-		config->dontUpSampleImplicitSBR=1;
-	}
-	faacDecSetConfiguration(hDecoder, config);
-}
-// -----------------------------------------------------------------------------------------------
-
-void Cfaad::setDefaultFaadCfg(faacDecHandle hDecoder, BOOL showDlg)
-{
-	if(showDlg && ShowDlg4RawAAC)
-		ShowDlg4RawAAC();
-
-CMyDecCfg Cfg(false);
-	setFaadCfg(hDecoder,Cfg);
-}
-// -----------------------------------------------------------------------------------------------
-
-void Cfaad::DisplayError(char *ProcName, char *str)
-{
-MYINPUT *mi;
-char buf[100]="";
-
-	GlobalUnlock(hInput); // it wasn't done in getInfos()
-	GLOBALLOCK(mi,hInput,MYINPUT,return);
-
-	if(ProcName && *ProcName)
-		sprintf(buf,"%s: ", ProcName);
-	if(str && *str)
-		strcat(buf,str);
-	if(*buf && str)
-		MessageBox(0, buf, APP_NAME " plugin", MB_OK|MB_ICONSTOP);
-
-	mi->bytes_into_buffer=-1;
-	GlobalUnlock(hInput);
-}
-// *********************************************************************************************
-
-HANDLE Cfaad::getInfos(LPSTR lpstrFilename)
-{
-MYINPUT *mi;
-
-// test tags
-//CMyDecCfg cfg;	cfg.Tag.ReadMp4Tag(lpstrFilename);
-//CMyDecCfg cfg;	cfg.Tag.ReadAacTag(lpstrFilename);
-
-	GLOBALLOCK(mi,hInput,MYINPUT,return NULL);
-
-//	mi->IsAAC=strcmpi(lpstrFilename+lstrlen(lpstrFilename)-4,".aac")==0;
-	if((mi->IsMP4=IsMP4(lpstrFilename))==-1)
-		return ERROR_getInfos("Error opening file");
-
-	if(mi->IsMP4) // MP4 file ---------------------------------------------------------------------
-	{
-	MP4Duration			length;
-	unsigned __int32	buffer_size;
-	DWORD				timeScale;
-	BYTE				sf;
-    mp4AudioSpecificConfig mp4ASC;
-
-		if(!(mi->mp4File=MP4Read(lpstrFilename, 0)))
-			return ERROR_getInfos("Error opening file");
-
-		if((mi->track=GetAACTrack(mi->mp4File))<0)
-			return ERROR_getInfos(0); //"Unable to find correct AAC sound track");
-
-		if(!(mi->hDecoder=faacDecOpen()))
-			return ERROR_getInfos("Error initializing decoder library");
-
-		MP4GetTrackESConfiguration(mi->mp4File, mi->track, (unsigned __int8 **)&mi->buffer, &buffer_size);
-		if(!mi->buffer)
-			return ERROR_getInfos("MP4GetTrackESConfiguration()");
-		AudioSpecificConfig(mi->buffer, buffer_size, &mp4ASC);
-
-        timeScale = mp4ASC.samplingFrequency;
-        mi->Channels=mp4ASC.channelsConfiguration;
-        sf = mp4ASC.samplingFrequencyIndex;
-        mi->type = mp4ASC.objectTypeIndex;
-//        mi->SBR=mp4ASC.sbr_present_flag;
-
-		if(faacDecInit2(mi->hDecoder, mi->buffer, buffer_size, &mi->Samprate, &mi->Channels) < 0)
-			return ERROR_getInfos("Error initializing decoder library");
-		FREE_ARRAY(mi->buffer);
-
-		length=MP4GetTrackDuration(mi->mp4File, mi->track);
-		mi->len_ms=(DWORD)MP4ConvertFromTrackDuration(mi->mp4File, mi->track, length, MP4_MSECS_TIME_SCALE);
-		mi->file_info.bitrate=MP4GetTrackBitRate(mi->mp4File, mi->track);
-		mi->file_info.version=MP4GetTrackAudioType(mi->mp4File, mi->track)==MP4_MPEG4_AUDIO_TYPE ? 4 : 2;
-		mi->numSamples=MP4GetTrackNumberOfSamples(mi->mp4File, mi->track);
-		mi->sampleId=1;
-
-		mi->IsSeekable=true;
-		mi->LockSeeking=!mi->IsSeekable;
-	}
-	else // AAC file ------------------------------------------------------------------------------
-	{   
-	DWORD			read,
-					tmp;
-	BYTE			Channels4Raw=0;
-
-		if(!(mi->aacFile=fopen(lpstrFilename,"rb")))
-			return ERROR_getInfos("Error opening file"); 
-
-		// use bufferized stream
-		setvbuf(mi->aacFile,NULL,_IOFBF,32767);
-
-		// get size of file
-		fseek(mi->aacFile, 0, SEEK_END);
-		mi->src_size=ftell(mi->aacFile);
-		fseek(mi->aacFile, 0, SEEK_SET);
-
-		if(!(mi->buffer=(BYTE *)malloc(FAAD_STREAMSIZE)))
-			return ERROR_getInfos("Memory allocation error: mi->buffer");
-
-		tmp=mi->src_size<FAAD_STREAMSIZE ? mi->src_size : FAAD_STREAMSIZE;
-		read=fread(mi->buffer, 1, tmp, mi->aacFile);
-		if(read==tmp)
-		{
-			mi->bytes_read=read;
-			mi->bytes_into_buffer=read;
-		}
-		else
-			return ERROR_getInfos("Read failed!");
-
-		// skip Tag
-	long tagsize;
-		if(tagsize=id3v2_TagSize(mi->buffer))
-		{
-			if(tagsize>(long)mi->src_size)
-				ERROR_getInfos("Corrupt stream!");
-			if(tagsize<mi->bytes_into_buffer)
-			{
-				mi->bytes_into_buffer-=tagsize;
-				memcpy(mi->buffer,mi->buffer+tagsize,mi->bytes_into_buffer);
-			}
-			else
-			{
-				mi->bytes_read=tagsize;
-				mi->bytes_into_buffer=0;
-				if(tagsize>mi->bytes_into_buffer)
-					fseek(mi->aacFile, tagsize, SEEK_SET);
-			}
-			if(mi->src_size<mi->bytes_read+FAAD_STREAMSIZE-mi->bytes_into_buffer)
-				tmp=mi->src_size-mi->bytes_read;
-			else
-				tmp=FAAD_STREAMSIZE-mi->bytes_into_buffer;
-			read=fread(mi->buffer+mi->bytes_into_buffer, 1, tmp, mi->aacFile);
-			if(read==tmp)
-			{
-				mi->bytes_read+=read;
-				mi->bytes_into_buffer+=read;
-			}
-			else
-				ERROR_getInfos("Read failed!");
-		}
-
-		if(get_AAC_format(lpstrFilename, &mi->file_info, &mi->seek_table, &mi->seek_table_length, 0))
-			ERROR_getInfos("get_AAC_format()");
-		mi->IsSeekable=mi->file_info.headertype==ADTS && mi->seek_table && mi->seek_table_length>0;
-		mi->LockSeeking=!mi->IsSeekable;
-/*
-	aac_buffer	b;
-	float		fLength;
-	DWORD		headertype;
-		b.infile=mi->aacFile;
-		b.buffer=mi->buffer;
-	    b.bytes_into_buffer=read;
-		b.bytes_consumed=mi->bytes_consumed;
-		b.file_offset=0;
-		b.at_eof=(read!=tmp) ? 1 : 0;
-		GetAACInfos(&b,&headertype,&fLength,&mi->file_info.bitrate,mi->src_size);
-		mi->file_info.bitrate*=1024;
-		mi->file_info.headertype=headertype;
-        mi->bytes_into_buffer=b.bytes_into_buffer;
-        mi->bytes_consumed=b.bytes_consumed;
-		IsSeekable=false; // only mp4 can be seeked
-*/
-		if(!mi->FindBitrate) // open a new instance to get info from decoder
-		{
-		MYINPUT *miTmp;
-		Cfaad	*NewInst;
-			if(!(NewInst=new Cfaad()))
-				return ERROR_getInfos("Memory allocation error: NewInst");
-
-			GLOBALLOCK(miTmp,NewInst->hInput,MYINPUT,return 0);
-			miTmp->FindBitrate=TRUE;
-			NewInst->ShowDlg4RawAAC=ShowDlg4RawAAC;
-			NewInst->pCfg=pCfg;
-			if(!NewInst->getInfos(lpstrFilename))
-				return ERROR_getInfos(0);
-			mi->Channels=miTmp->frameInfo.channels;
-			if(mi->file_info.headertype==RAW)
-				mi->file_info.bitrate=miTmp->file_info.bitrate;//*mi->Channels;
-			mi->Samprate=miTmp->Samprate;
-			mi->file_info.headertype=miTmp->file_info.headertype;
-			mi->file_info.object_type=miTmp->file_info.object_type;
-			mi->file_info.version=miTmp->file_info.version;
-			GlobalUnlock(NewInst->hInput);
-			delete NewInst;
-		}
-
-		if(!(mi->hDecoder=faacDecOpen()))
-			return ERROR_getInfos("Can't open library");
-		if(mi->file_info.headertype==RAW)
-			if(pCfg)
-				setFaadCfg(mi->hDecoder,*pCfg);
-			else
-				setDefaultFaadCfg(mi->hDecoder,mi->FindBitrate);
-	BYTE Channels; // faacDecInit doesn't report correctly the number of channels in raw aac files
-		if((mi->bytes_consumed=faacDecInit(mi->hDecoder, mi->buffer, mi->bytes_into_buffer, &mi->Samprate, &Channels))<0)
-			return ERROR_getInfos("faacDecInit()");
-		mi->bytes_into_buffer-=mi->bytes_consumed;
-
-		if(mi->FindBitrate) // get info from decoder
-		{
-		DWORD	Samples,
-				BytesConsumed;
-
-			if(!processData(hInput,0,0))
-				return ERROR_getInfos(0);
-			Samples=mi->frameInfo.samples/sizeof(short);
-			BytesConsumed=mi->frameInfo.bytesconsumed;
-			if(mi->file_info.headertype==RAW || !mi->file_info.bitrate)
-				mi->file_info.bitrate=(BytesConsumed*8*mi->Samprate)/(Samples*2);
-			if(!mi->file_info.bitrate)
-				return ERROR_getInfos("Can't determine the bitrate");
-		}
-
-		mi->len_ms=(DWORD)((mi->src_size<<3)/(mi->file_info.bitrate>>10));
-//		mi->len_ms=(DWORD)((1000*((float)mi->src_size*8))/mi->file_info.bitrate);
-	}
-
-	if(mi->len_ms)
-		mi->dst_size=(DWORD)(mi->len_ms*((float)mi->Samprate/1000)*mi->Channels*(mi->BitsPerSample/8));
-	else
-		return ERROR_getInfos("Can't determine the length");
-
-	showInfo(mi);
-
-	GlobalUnlock(hInput);
-    return hInput;
-}
-// *********************************************************************************************
-
-int Cfaad::processData(HANDLE hInput, unsigned char far *bufout, long lBytes)
-{
-BYTE	*buffer;
-DWORD	BytesDecoded=0;
-char	*sample_buffer=0;
-int		read;
-MYINPUT	*mi;
-
-	GLOBALLOCK(mi,hInput,MYINPUT,return 0);
-
-	if(mi->LockSeeking)
-	{
-		NoSeek();
-		mi->LockSeeking=false;
-	}
-
-	if(mi->IsMP4) // MP4 file --------------------------------------------------------------------------
-	{   
-	unsigned __int32 buffer_size=0;
-    int rc;
-
-		if(newpos_ms>-1)
-		{
-		MP4Duration duration=MP4ConvertToTrackDuration(mi->mp4File,mi->track,newpos_ms,MP4_MSECS_TIME_SCALE);
-		MP4SampleId sampleId=MP4GetSampleIdFromTime(mi->mp4File,mi->track,duration,0);
-			mi->bytes_read=(DWORD)(((float)newpos_ms*mi->file_info.bitrate)/(8*1000));
-			if(seek(mi->bytes_read))  // update the slider
-				return ERROR_processData(0);
-			newpos_ms=-1;
-		}
-		do
-		{
-			buffer=NULL;
-			if(mi->sampleId>=mi->numSamples)
-				return ERROR_processData(0);
-
-			rc=MP4ReadSample(mi->mp4File, mi->track, mi->sampleId++, (unsigned __int8 **)&buffer, &buffer_size, NULL, NULL, NULL, NULL);
-			if(rc==0 || buffer==NULL)
-			{
-				FREE_ARRAY(buffer);
-				return ERROR_processData("MP4ReadSample()");
-			}
-
-			sample_buffer=(char *)faacDecDecode(mi->hDecoder,&mi->frameInfo,buffer,buffer_size);
-			BytesDecoded=mi->frameInfo.samples*sizeof(short);
-			if(BytesDecoded>(DWORD)lBytes)
-				BytesDecoded=lBytes;
-			memmove(bufout,sample_buffer,BytesDecoded);
-			FREE_ARRAY(buffer);
-			// to update the slider
-			mi->bytes_read+=buffer_size;
-			if(seek(mi->bytes_read))
-				return ERROR_processData(0);
-		}while(!BytesDecoded && !mi->frameInfo.error);
-	}
-	else // AAC file --------------------------------------------------------------------------
-	{   
-		if(newpos_ms>-1)
-		{
-			if(mi->IsSeekable)
-			{
-			DWORD normalized=mi->len_ms/(mi->seek_table_length-1);
-				if(normalized<1000)
-					normalized=1000;
-				mi->bytes_read=mi->seek_table[newpos_ms/normalized];
-				fseek(mi->aacFile, mi->bytes_read, SEEK_SET);
-				if(seek(mi->bytes_read))  // update the slider
-					return ERROR_processData(0);
-				mi->bytes_into_buffer=0;
-				mi->bytes_consumed=FAAD_STREAMSIZE;
-			}
-			newpos_ms=-1;
-		}
-		buffer=mi->buffer;
-		do
-		{
-			if(mi->bytes_consumed>0)
-			{
-				if(mi->bytes_into_buffer)
-					memmove(buffer,buffer+mi->bytes_consumed,mi->bytes_into_buffer);
-
-				if(mi->bytes_read<mi->src_size)
-				{
-				int tmp;
-					if(mi->bytes_read+mi->bytes_consumed<mi->src_size)
-						tmp=mi->bytes_consumed;
-					else
-						tmp=mi->src_size-mi->bytes_read;
-					read=fread(buffer+mi->bytes_into_buffer, 1, tmp, mi->aacFile);
-					if(read==tmp)
-					{
-						mi->bytes_read+=read;
-						mi->bytes_into_buffer+=read;
-					}
-				}
-				else
-					if(mi->bytes_into_buffer)
-						memset(buffer+mi->bytes_into_buffer, 0, mi->bytes_consumed);
-
-				mi->bytes_consumed=0;
-
-				if(	(mi->bytes_into_buffer>3 && !memcmp(mi->buffer, "TAG", 3)) ||
-					(mi->bytes_into_buffer>11 && !memcmp(mi->buffer, "LYRICSBEGIN", 11)) ||
-					(mi->bytes_into_buffer>8 && !memcmp(mi->buffer, "APETAGEX", 8)))
-					return ERROR_processData(0);
-			}
-
-			if(mi->bytes_into_buffer<1)
-				if(mi->bytes_read<mi->src_size)
-					return ERROR_processData("Buffer empty!");
-				else
-					return ERROR_processData(0);
-
-			sample_buffer=(char *)faacDecDecode(mi->hDecoder,&mi->frameInfo,buffer,mi->bytes_into_buffer);
-			BytesDecoded=mi->frameInfo.samples*sizeof(short);
-			if(bufout)
-			{
-				if(BytesDecoded>(DWORD)lBytes)
-					BytesDecoded=lBytes;
-				if(sample_buffer && BytesDecoded && !mi->frameInfo.error)
-					memmove(bufout,sample_buffer,BytesDecoded);
-			}
-			else // Data needed to decode Raw files
-			{
-				mi->Channels=mi->frameInfo.channels;
-				mi->file_info.object_type=mi->frameInfo.object_type;
-			}
-		    mi->bytes_consumed+=mi->frameInfo.bytesconsumed;
-			mi->bytes_into_buffer-=mi->bytes_consumed;
-		}while(!BytesDecoded && !mi->frameInfo.error);
-	} // END AAC file --------------------------------------------------------------------------
-
-	if(mi->frameInfo.error)
-		return ERROR_processData((char *)faacDecGetErrorMessage(mi->frameInfo.error));
-
-	showProgress(mi);
-
-	GlobalUnlock(hInput);
-    return BytesDecoded;
-}
--- a/common/Cfaac/Cfaad.h
+++ /dev/null
@@ -1,200 +1,0 @@
-/*
-CFAAC - set of classes to import/export .aac/.mp4 files
-Copyright (C) 2004 Antonio Foranna
-
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation.
-	
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
-		
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-			
-The author can be contacted at:
[email protected]
-*/
-
-#ifndef _Cfaad_H
-#define _Cfaad_H
-
-#include <mp4.h>
-#include <faac.h>
-
-#ifdef MAIN
-	#undef MAIN
-#endif
-#ifdef SSR
-	#undef SSR
-#endif
-#ifdef LTP
-	#undef LTP
-#endif
-
-#include <faad.h>
-extern "C" {
-	#include <aacinfo.h>    // get_AAC_format()
-}
-#include "Defines.h"
-#include "CRegistry.h"
-#include "CTag.h"
-
-
-
-// *********************************************************************************************
-
-// make this higher to support files with more channels
-#define MAX_CHANNELS 6
-#if FAAD_MIN_STREAMSIZE<2048
-#undef FAAD_MIN_STREAMSIZE
-// 960 for LD or else 1024 (expanded to 2048 for HE-AAC)
-#define FAAD_MIN_STREAMSIZE 2048
-#endif
-
-#define	FAAD_STREAMSIZE	(FAAD_MIN_STREAMSIZE*MAX_CHANNELS)
-
-// -----------------------------------------------------------------------------------------------
-
-#define REG_DEFAULT "Default"
-#define REG_PROFILE "Profile"
-#define REG_SAMPLERATE "SampleRate"
-#define REG_BPS "Bps"
-#define REG_DOWNMATRIX "Downmatrix"
-#define REG_OLDADTS "Old ADTS"
-#define REG_DONTUPSAMPLESBR "Don\'t upsample implicit SBR"
-
-// *********************************************************************************************
-
-
-
-/* FAAD file buffering routines */
-/*typedef struct {
-    long bytes_into_buffer;
-    long bytes_consumed;
-    long file_offset;
-    unsigned char *buffer;
-    int at_eof;
-    FILE *infile;
-} aac_buffer;
-// -----------------------------------------------------------------------------------------------
-
-typedef struct {
-    int version;
-    int channels;
-    int sampling_rate;
-    int bitrate;
-    int length;
-    int object_type;
-    int headertype;
-} faadAACInfo;
-*/
-
-// *********************************************************************************************
-
-class CMyDecCfg
-{
-private:
-
-	bool SaveCfgOnDestroy;
-
-public:
-
-	CMyDecCfg(bool SaveOnDestroy=true) { getCfg(this); SaveCfgOnDestroy=SaveOnDestroy; }
-	virtual ~CMyDecCfg() { if(SaveCfgOnDestroy) setCfg(this); FreeCfg(this); }
-
-	void FreeCfg(CMyDecCfg *cfg) { cfg->Tag.FreeTag(); }
-	void FreeCfg() { this->Tag.FreeTag(); }
-	void getCfg(CMyDecCfg *cfg);
-	void getCfg() { getCfg(this); }
-	void setCfg(CMyDecCfg *cfg);
-	void setCfg() { setCfg(this); }
-
-	bool					DefaultCfg;
-	BYTE					Channels;
-	DWORD					BitRate;
-	faacDecConfiguration	DecCfg;
-	CMP4Tag					Tag;
-};
-// -----------------------------------------------------------------------------------------------
-
-typedef struct input_tag // any special vars associated with input file
-{
-//MP4
-MP4FileHandle	mp4File;
-MP4SampleId		sampleId,
-				numSamples;
-int				track;
-BYTE			type;
-
-//AAC
-FILE			*aacFile;
-DWORD			src_size;		// size of compressed file
-long			tagsize;
-DWORD			bytes_read;		// from file
-long			bytes_consumed;	// from buffer by faadDecDecode
-long			bytes_into_buffer;
-unsigned char	*buffer;
-DWORD			*seek_table;
-int				seek_table_length;
-
-// Raw AAC
-BOOL			FindBitrate;
-
-// GLOBAL
-faacDecHandle	hDecoder;
-faadAACInfo		file_info;
-faacDecFrameInfo	frameInfo;
-DWORD			len_ms;			// length of file in milliseconds
-BYTE			Channels;
-DWORD			Samprate;
-WORD			BitsPerSample;
-DWORD			dst_size;		// size of decoded file. Cooledit needs it to update its progress bar
-//char			*src_name;		// name of compressed file
-int				IsMP4;
-bool			LockSeeking,
-				IsSeekable;
-} MYINPUT;
-// -----------------------------------------------------------------------------------------------
-
-class Cfaad
-{
-private:
-	virtual int GetAACTrack(MP4FileHandle infile);
-	long id3v2_TagSize(unsigned char *buffer);
-/*	long id3v2_TagSize(aac_buffer *b);
-	int fill_buffer(aac_buffer *b);
-	void advance_buffer(aac_buffer *b, int bytes);
-	int adts_parse(aac_buffer *b, int *bitrate, float *length);
-	void GetAACInfos(aac_buffer *b, DWORD *header_type, float *song_length, int *pbitrate, long filesize);
-*/
-	virtual void DisplayError(char *ProcName, char *str);
-	virtual HANDLE ERROR_getInfos(char *str) { DisplayError("getInfos", str); return NULL; }
-	virtual int ERROR_processData(char *str) { DisplayError("processData", str); return 0; }
-	virtual void showInfo(MYINPUT *mi) {}
-	virtual void showProgress(MYINPUT *mi) {}
-	virtual void setDefaultFaadCfg(faacDecHandle hDecoder, BOOL showDlg);
-	virtual void setFaadCfg(faacDecHandle hDecoder, CMyDecCfg Cfg);
-	virtual int seek(int newpos_bytes) { return 0; } // !=0 => error
-	virtual void NoSeek() {} // put here the code to block seeking of player
-
-public:
-    Cfaad(HANDLE hInput=NULL);
-    virtual ~Cfaad();
-
-	int (*ShowDlg4RawAAC)(); // set this to show your dialog (to decode raw aac files)
-	int IsMP4(LPSTR lpstrFilename);
-	inline bool CanSeek() { MYINPUT	*mi; GLOBALLOCK(mi,hInput,MYINPUT,return 0); bool IsSeekable=mi->IsSeekable; GlobalUnlock(hInput); return IsSeekable; }
-//	virtual void GetAACInfos(char *Filename, aac_buffer *b, DWORD *header_type, float *song_length, int *pbitrate);
-    virtual HANDLE getInfos(LPSTR lpstrFilename);
-    virtual int processData(HANDLE hInput, unsigned char far *bufout, long lBytes);
-
-// GLOBAL
-	long            newpos_ms; // set this to change position
-	HANDLE			hInput;
-	CMyDecCfg		*pCfg; // set this to use your cfg (to decode raw aac files)
-};
-#endif
--- a/common/Cfaac/DecDialog.cpp
+++ /dev/null
@@ -1,214 +1,0 @@
-/*
-CFAAC - set of classes to import/export .aac/.mp4 files
-Copyright (C) 2004 Antonio Foranna
-
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation.
-	
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
-		
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-			
-The author can be contacted at:
[email protected]
-*/
-
-#include <windows.h>
-#include "resource.h"
-#include <Defines.h>	// my defines
-#include "Cfaad.h"
-#include "DecDialog.h"
-#include "EncDialog.h"
-
-// *********************************************************************************************
-
-extern HINSTANCE hInstance;
-extern HBITMAP hBmBrowse;
-
-// -----------------------------------------------------------------------------------------------
-
-#ifndef FAAD_FMT_64BIT
-#define FAAD_FMT_64BIT 5
-#endif
-
-// *********************************************************************************************
-
-int ShowDlg4RawAAC()
-{
-	return DialogBoxParam((HINSTANCE)hInstance,(LPCSTR)MAKEINTRESOURCE(IDD_DECODER),(HWND)NULL, (DLGPROC)DialogMsgProcDec, 0);
-//	return DialogBoxParam((HINSTANCE)hInstance,(LPCSTR)MAKEINTRESOURCE(IDD_DECODER),(HWND)hWnd, (DLGPROC)DialogMsgProcDec, (DWORD)&cfg);
-}
-
-// *********************************************************************************************
-
-#define INIT_CB(hWnd,nID,list,IdSelected) \
-{ \
-	for(int i=0; list[i]; i++) \
-		SendMessage(GetDlgItem(hWnd, nID), CB_ADDSTRING, 0, (LPARAM)list[i]); \
-	SendMessage(GetDlgItem(hWnd, nID), CB_SETCURSEL, IdSelected, 0); \
-}
-// -----------------------------------------------------------------------------------------------
-
-//	EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_SSR), Enabled);
-#define DISABLE_CTRLS_DEC(Enabled) \
-{ \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_MAIN), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_LOW), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_LTP), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_CHK_DOWNMATRIX), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_CHK_OLDADTS), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_CB_SAMPLERATE), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_CB_BITSPERSAMPLE), Enabled); \
-}
-// -----------------------------------------------------------------------------------------------
-
-BOOL DialogMsgProcDec(HWND hWndDlg, UINT Message, WPARAM wParam, LPARAM lParam)
-{
-	switch(Message)
-	{
-	case WM_INITDIALOG:
-		{
-/*			if(!lParam)
-			{
-				MessageBox(hWndDlg,"Pointer==NULL",0,MB_OK|MB_ICONSTOP);
-				EndDialog(hWndDlg, 0);
-				return TRUE;
-			}
-*/
-		char buf[50];
-		char	*SampleRate[]={"6000","8000","16000","22050","32000","44100","48000","64000","88200","96000","192000",0},
-				*BitsPerSample[]={"16","24","32","32 bit FLOAT","64 bit FLOAT",0};
-		CMyDecCfg cfg(false);
-
-			SetWindowPos(GetDlgItem(hWndDlg,IDC_CHK_DEFAULTCFG),GetDlgItem(hWndDlg,IDC_GRP_DEFAULT),0,0,0,0,SWP_NOMOVE | SWP_NOSIZE);
-
-			INIT_CB(hWndDlg,IDC_CB_BITSPERSAMPLE,BitsPerSample,0);
-			INIT_CB(hWndDlg,IDC_CB_SAMPLERATE,SampleRate,5);
-			sprintf(buf,"%lu",cfg.DecCfg.defSampleRate);
-			SetDlgItemText(hWndDlg, IDC_CB_SAMPLERATE, buf);
-
-			switch(cfg.DecCfg.defObjectType)
-			{
-			case MAIN:
-				CheckDlgButton(hWndDlg,IDC_RADIO_MAIN,TRUE);
-				break;
-			case LC:
-				CheckDlgButton(hWndDlg,IDC_RADIO_LOW,TRUE);
-				break;
-			case SSR:
-				CheckDlgButton(hWndDlg,IDC_RADIO_SSR,TRUE);
-				break;
-			case LTP:
-				CheckDlgButton(hWndDlg,IDC_RADIO_LTP,TRUE);
-				break;
-			case HE_AAC:
-				CheckDlgButton(hWndDlg,IDC_RADIO_HE,TRUE);
-				break;
-			}
-
-			switch(cfg.DecCfg.outputFormat)
-			{
-			case FAAD_FMT_16BIT:
-				SendMessage(GetDlgItem(hWndDlg, IDC_CB_BITSPERSAMPLE), CB_SETCURSEL, 0, 0);
-				break;
-			case FAAD_FMT_24BIT:
-				SendMessage(GetDlgItem(hWndDlg, IDC_CB_BITSPERSAMPLE), CB_SETCURSEL, 1, 0);
-				break;
-			case FAAD_FMT_32BIT:
-				SendMessage(GetDlgItem(hWndDlg, IDC_CB_BITSPERSAMPLE), CB_SETCURSEL, 2, 0);
-				break;
-			case FAAD_FMT_FLOAT:
-				SendMessage(GetDlgItem(hWndDlg, IDC_CB_BITSPERSAMPLE), CB_SETCURSEL, 3, 0);
-				break;
-			case FAAD_FMT_64BIT:
-				SendMessage(GetDlgItem(hWndDlg, IDC_CB_BITSPERSAMPLE), CB_SETCURSEL, 4, 0);
-				break;
-			}
-
-			CheckDlgButton(hWndDlg,IDC_CHK_DOWNMATRIX, cfg.DecCfg.downMatrix);
-			CheckDlgButton(hWndDlg,IDC_CHK_OLDADTS, cfg.DecCfg.useOldADTSFormat);
-
-			CheckDlgButton(hWndDlg,IDC_CHK_DEFAULTCFG, cfg.DefaultCfg);
-			DISABLE_CTRLS_DEC(!cfg.DefaultCfg);
-		}
-		break; // End of WM_INITDIALOG                                 
-
-	case WM_CLOSE:
-		// Closing the Dialog behaves the same as Cancel               
-		PostMessage(hWndDlg, WM_COMMAND, IDCANCEL, 0);
-		break; // End of WM_CLOSE                                      
-
-	case WM_COMMAND:
-		switch(LOWORD(wParam))
-		{
-		case IDC_CHK_DEFAULTCFG:
-			{
-			char Enabled=!IsDlgButtonChecked(hWndDlg,IDC_CHK_DEFAULTCFG);
-				DISABLE_CTRLS_DEC(Enabled);
-			}
-			break;
-
-		case IDOK:
-			{
-		CMyDecCfg cfg;
-				if(IsDlgButtonChecked(hWndDlg,IDC_RADIO_MAIN))
-					cfg.DecCfg.defObjectType=MAIN;
-				if(IsDlgButtonChecked(hWndDlg,IDC_RADIO_LOW))
-					cfg.DecCfg.defObjectType=LC;
-				if(IsDlgButtonChecked(hWndDlg,IDC_RADIO_SSR))
-					cfg.DecCfg.defObjectType=SSR;
-				if(IsDlgButtonChecked(hWndDlg,IDC_RADIO_LTP))
-					cfg.DecCfg.defObjectType=LTP;
-				if(IsDlgButtonChecked(hWndDlg,IDC_RADIO_HE))
-					cfg.DecCfg.defObjectType=HE_AAC;
-				switch(SendMessage(GetDlgItem(hWndDlg, IDC_CB_BITSPERSAMPLE), CB_GETCURSEL, 0, 0))
-				{
-				case 0:
-					cfg.DecCfg.outputFormat=FAAD_FMT_16BIT;
-					break;
-				case 1:
-					cfg.DecCfg.outputFormat=FAAD_FMT_24BIT;
-					break;
-				case 2:
-					cfg.DecCfg.outputFormat=FAAD_FMT_32BIT;
-					break;
-				case 3:
-					cfg.DecCfg.outputFormat=FAAD_FMT_FLOAT;
-					break;
-				case 4:
-					cfg.DecCfg.outputFormat=FAAD_FMT_64BIT;
-					break;
-				}
-
-				cfg.DecCfg.defSampleRate=GetDlgItemInt(hWndDlg, IDC_CB_SAMPLERATE, 0, FALSE);
-				cfg.DecCfg.downMatrix=IsDlgButtonChecked(hWndDlg,IDC_CHK_DOWNMATRIX) ? TRUE : FALSE;
-				cfg.DecCfg.useOldADTSFormat=IsDlgButtonChecked(hWndDlg,IDC_CHK_OLDADTS) ? TRUE : FALSE;
-				cfg.DefaultCfg=IsDlgButtonChecked(hWndDlg,IDC_CHK_DEFAULTCFG) ? TRUE : FALSE;
-
-				EndDialog(hWndDlg, (DWORD)TRUE);
-			}
-			break;
-
-        case IDCANCEL:
-			// Ignore data values entered into the controls        
-			// and dismiss the dialog window returning FALSE
-			EndDialog(hWndDlg, (DWORD)FALSE);
-			break;
-
-		case IDC_BTN_ABOUT:
-				DialogBox((HINSTANCE)hInstance,(LPCSTR)MAKEINTRESOURCE(IDD_ABOUT), (HWND)hWndDlg, (DLGPROC)DialogMsgProcAbout);
-			break;
-		}
-		break; // End of WM_COMMAND
-	default: 
-		return FALSE;
-	}
- 
-	return TRUE;
-}
--- a/common/Cfaac/DecDialog.h
+++ /dev/null
@@ -1,39 +1,0 @@
-extern BOOL DialogMsgProcDec(HWND hWndDlg, UINT Message, WPARAM wParam, LPARAM lParam);
-extern int ShowDlg4RawAAC();
-
-static const char* mpeg4AudioNames[]=
-{
-	"Raw PCM",
-	"AAC Main",
-	"AAC LC (Low Complexity)",
-	"AAC SSR",
-	"AAC LTP (Long Term Prediction)",
-	"AAC HE (High Efficiency)",
-	"AAC Scalable",
-	"TwinVQ",
-	"CELP",
-	"HVXC",
-	"Reserved",
-	"Reserved",
-	"TTSI",
-	"Main synthetic",
-	"Wavetable synthesis",
-	"General MIDI",
-	"Algorithmic Synthesis and Audio FX",
-// defined in MPEG-4 version 2
-	"ER AAC LC (Low Complexity)",
-	"Reserved",
-	"ER AAC LTP (Long Term Prediction)",
-	"ER AAC Scalable",
-	"ER TwinVQ",
-	"ER BSAC",
-	"ER AAC LD (Low Delay)",
-	"ER CELP",
-	"ER HVXC",
-	"ER HILN",
-	"ER Parametric",
-	"Reserved",
-	"Reserved",
-	"Reserved",
-	"Reserved"
-};
binary files a/common/Cfaac/Email.bmp /dev/null differ
--- a/common/Cfaac/EncDialog.cpp
+++ /dev/null
@@ -1,945 +1,0 @@
-/*
-CFAAC - set of classes to import/export .aac/.mp4 files
-Copyright (C) 2004 Antonio Foranna
-
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation.
-	
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
-		
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-			
-The author can be contacted at:
[email protected]
-*/
-
-#include <windows.h>
-#include <shlobj.h>		// Browse
-#include <shellapi.h>	// ShellExecute
-#include <Commdlg.h>
-#include "resource.h"
-#include "Defines.h"	// my defines
-#include "CTag.h"
-#include "Cfaac.h"
-#include "EncDialog.h"
-
-#include <commctrl.h>
-#include <id3v2tag.h>
-//#include <id3\globals.h> // ID3LIB_RELEASE
-
-// *********************************************************************************************
-
-#ifdef USE_OUTPUT_FOLDER
-extern char	config_AACoutdir[MAX_PATH];
-#endif
-
-extern HINSTANCE hInstance;
-extern HBITMAP hBmBrowse;
-
-// *********************************************************************************************
-
-/*
-DWORD PackCfg(MY_ENC_CFG *cfg)
-{
-DWORD dwOptions=0;
-
-	if(cfg->AutoCfg)
-		dwOptions=1<<31;
-	dwOptions|=(DWORD)cfg->EncCfg.mpegVersion<<30;
-	dwOptions|=(DWORD)cfg->EncCfg.aacObjectType<<28;
-	dwOptions|=(DWORD)cfg->EncCfg.allowMidside<<27;
-	dwOptions|=(DWORD)cfg->EncCfg.useTns<<26;
-	dwOptions|=(DWORD)cfg->EncCfg.useLfe<<25;
-	dwOptions|=(DWORD)cfg->EncCfg.outputFormat<<24;
-	if(cfg->UseQuality)
-		dwOptions|=(((DWORD)cfg->EncCfg.quantqual>>1)&0xff)<<16; // [2,512]
-	else
-		dwOptions|=(((DWORD)cfg->EncCfg.bitRate>>1)&0xff)<<16; // [2,512]
-	if(cfg->UseQuality)
-		dwOptions|=1<<15;
-	dwOptions|=((DWORD)cfg->EncCfg.bandWidth>>1)&&0x7fff; // [0,65536]
-
-	return dwOptions;
-}
-// -----------------------------------------------------------------------------------------------
-
-void UnpackCfg(MY_ENC_CFG *cfg, DWORD dwOptions)
-{
-	cfg->AutoCfg=dwOptions>>31;
-	cfg->EncCfg.mpegVersion=(dwOptions>>30)&1;
-	cfg->EncCfg.aacObjectType=(dwOptions>>28)&3;
-	cfg->EncCfg.allowMidside=(dwOptions>>27)&1;
-	cfg->EncCfg.useTns=(dwOptions>>26)&1;
-	cfg->EncCfg.useLfe=(dwOptions>>25)&1;
-	cfg->EncCfg.outputFormat=(dwOptions>>24)&1;
-	cfg->EncCfg.bitRate=((dwOptions>>16)&0xff)<<1;
-	cfg->UseQuality=(dwOptions>>15)&1;
-	cfg->EncCfg.bandWidth=(dwOptions&0x7fff)<<1;
-}*/
-// -----------------------------------------------------------------------------------------------
-
-#define INIT_CB(hWnd,nID,list,FillList,IdSelected) \
-{ \
-	if(FillList) \
-		for(int i=0; list[i]; i++) \
-			SendMessage(GetDlgItem(hWnd, nID), CB_ADDSTRING, 0, (LPARAM)list[i]); \
-	SendMessage(GetDlgItem(hWnd, nID), CB_SETCURSEL, IdSelected, 0); \
-}
-// -----------------------------------------------------------------------------------------------
-
-#define INIT_CB_GENRES(hWnd,nID,ID3Genres,IdSelected) \
-{ \
-	for(int i=0; i<(sizeof(ID3Genres)/sizeof(ID3Genres[0])); i++) \
-		SendMessage(GetDlgItem(hWnd, nID), CB_ADDSTRING, 0, (LPARAM)ID3Genres[i].name); \
-	SendMessage(GetDlgItem(hWnd, nID), CB_SETCURSEL, IdSelected, 0); \
-}
-// -----------------------------------------------------------------------------------------------
-
-#define DISABLE_LTP \
-{ \
-	if(IsDlgButtonChecked(hWndDlg,IDC_RADIO_MPEG2) && \
-	   IsDlgButtonChecked(hWndDlg,IDC_RADIO_LTP)) \
-	{ \
-		CheckDlgButton(hWndDlg,IDC_RADIO_LTP,FALSE); \
-		CheckDlgButton(hWndDlg,IDC_RADIO_MAIN,TRUE); \
-	} \
-    EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_LTP), FALSE); \
-}
-// -----------------------------------------------------------------------------------------------
-
-//        EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_SSR), Enabled);
-//        EnableWindow(GetDlgItem(hWndDlg, IDC_CHK_USELFE), Enabled);
-#define DISABLE_CTRLS_ENC(Enabled) \
-{ \
-	CheckDlgButton(hWndDlg,IDC_CHK_AUTOCFG, !Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_MPEG4), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_MPEG2), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_RAW), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_ADTS), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_CHK_ALLOWMIDSIDE), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_CHK_USETNS), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_CHK_USELFE), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_CB_QUALITY), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_CB_BITRATE), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_CB_BANDWIDTH), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_QUALITY), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_BITRATE), Enabled); \
-    EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_MAIN), Enabled); \
-    EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_LOW), Enabled); \
-    EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_LTP), Enabled); \
-	if(IsDlgButtonChecked(hWndDlg,IDC_RADIO_MPEG4)) \
-		EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_LTP), Enabled); \
-	else \
-		DISABLE_LTP \
-}
-// -----------------------------------------------------------------------------------------------
-
-#define ENABLE_TAG(Enabled) \
-{ \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_E_ARTIST), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_E_TITLE), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_E_ALBUM), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_E_YEAR), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_CB_GENRE), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_E_WRITER), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_E_COMMENT), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_E_COMPILATION), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_CHK_COMPILATION), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_E_TRACK), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_E_NTRACKS), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_E_DISK), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_E_NDISKS), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_E_ARTFILE), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_BTN_ARTFILE), Enabled); \
-}
-// -----------------------------------------------------------------------------------------------
-
-#define ENABLE_AACTAGS(Enabled) \
-{ \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_E_COMPILATION), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_CHK_COMPILATION), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_E_NTRACKS), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_E_DISK), Enabled); \
-	EnableWindow(GetDlgItem(hWndDlg, IDC_E_NDISKS), Enabled); \
-}
-// -----------------------------------------------------------------------------------------------
-
-#ifdef USE_OUTPUT_FOLDER
-static int CALLBACK BrowseCallbackProc(HWND hwnd, UINT uMsg, LPARAM lParam, LPARAM lpData)
-{
-	if (uMsg == BFFM_INITIALIZED)
-	{
-		SetWindowText(hwnd,"Select folder");
-		SendMessage(hwnd,BFFM_SETSELECTION,(WPARAM)TRUE,(LPARAM)lpData);
-	}
-	return 0;
-}
-#else
-	#ifdef USE_IMPORT_TAG
-	static int CALLBACK BrowseCallbackProc(HWND hwnd, UINT uMsg, LPARAM lParam, LPARAM lpData)
-	{
-		if (uMsg == BFFM_INITIALIZED)
-		{
-			SetWindowText(hwnd,"Select folder");
-			SendMessage(hwnd,BFFM_SETSELECTION,(WPARAM)TRUE,(LPARAM)lpData);
-		}
-		return 0;
-	}
-	#endif
-#endif
-
-// -----------------------------------------------------------------------------------------------
-
-BOOL DialogMsgProcAbout(HWND hWndDlg, UINT Message, WPARAM wParam, LPARAM lParam)
-{
-	switch(Message)
-	{
-	case WM_INITDIALOG:
-		{
-		char buf[512];
-		char *faac_id_string, *faac_copyright_string;
-
-		sprintf(buf,
-					APP_NAME " plugin " APP_VER " by Antonio Foranna\n\n"
-					"Libraries used:\n"
-					"\tlibfaac v%s\n"
-					"\tFAAD2 v" FAAD2_VERSION "\n"
-					"\t" PACKAGE " v" VERSION "\n"
-					"\tid3v2 \n\n" //"\t %s v %s \n\n"
-					"This code is given with FAAC package and does not contain executables.\n"
-					"This program is free software and can be distributed/modifyed under the terms of the GNU General Public License.\n"
-					"This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY.\n\n"
-					"Compiled on %s\n",
-				(faacEncGetVersion(&faac_id_string, &faac_copyright_string)==FAAC_CFG_VERSION) ? faac_id_string : " wrong libfaac version",
-//					ID3LIB_FULL_NAME, ID3LIB_RELEASE,
-					__DATE__
-					);
-			SetDlgItemText(hWndDlg, IDC_L_ABOUT, buf);
-		}
-		break;
-	case WM_COMMAND:
-		switch(LOWORD(wParam))
-		{
-		case IDOK:
-			EndDialog(hWndDlg, TRUE);
-			break;
-        case IDCANCEL:
-			// Ignore data values entered into the controls and dismiss the dialog window returning FALSE
-			EndDialog(hWndDlg, FALSE);
-			break;
-		case IDC_AUDIOCODING:
-			ShellExecute(hWndDlg, NULL, "http://www.audiocoding.com", NULL, NULL, SW_SHOW);
-			break;
-		case IDC_MPEG4IP:
-			ShellExecute(hWndDlg, NULL, "http://www.mpeg4ip.net", NULL, NULL, SW_SHOW);
-			break;
-		case IDC_ID3:
-			ShellExecute(hWndDlg, NULL, "http://id3lib.sourceforge.net", NULL, NULL, SW_SHOW);
-			break;
-		case IDC_EMAIL:
-			ShellExecute(hWndDlg, NULL, "mailto:[email protected]", NULL, NULL, SW_SHOW);
-			break;
-		}
-		break;
-	default: 
-		return FALSE;
-	}
-
-	return TRUE;
-}
-// -----------------------------------------------------------------------------------------------
-
-// ripped from id3v2tag.c
-ID3GENRES ID3Genres[]=
-{
-    123,    "Acapella",
-    34,     "Acid",
-    74,     "Acid Jazz",
-    73,     "Acid Punk",
-    99,     "Acoustic",
-    20,     "Alternative",
-    40,     "AlternRock",
-    26,     "Ambient",
-    90,     "Avantgarde",
-    116,    "Ballad",
-    41,     "Bass",
-    85,     "Bebob",
-    96,     "Big Band",
-    89,     "Bluegrass",
-    0,      "Blues",
-    107,    "Booty Bass",
-    65,     "Cabaret",
-    88,     "Celtic",
-    104,    "Chamber Music",
-    102,    "Chanson",
-    97,     "Chorus",
-    61,     "Christian Rap",
-    1,      "Classic Rock",
-    32,     "Classical",
-    112,    "Club",
-    57,     "Comedy",
-    2,      "Country",
-    58,     "Cult",
-    3,      "Dance",
-    125,    "Dance Hall",
-    50,     "Darkwave",
-    254,    "Data",
-    22,     "Death Metal",
-    4,      "Disco",
-    55,     "Dream",
-    122,    "Drum Solo",
-    120,    "Duet",
-    98,     "Easy Listening",
-    52,     "Electronic",
-    48,     "Ethnic",
-    124,    "Euro-House",
-    25,     "Euro-Techno",
-    54,     "Eurodance",
-    84,     "Fast Fusion",
-    80,     "Folk",
-    81,     "Folk-Rock",
-    115,    "Folklore",
-    119,    "Freestyle",
-    5,      "Funk",
-    30,     "Fusion",
-    36,     "Game",
-    59,     "Gangsta",
-    38,     "Gospel",
-    49,     "Gothic",
-    91,     "Gothic Rock",
-    6,      "Grunge",
-    79,     "Hard Rock",
-    7,      "Hip-Hop",
-    35,     "House",
-    100,    "Humour",
-    19,     "Industrial",
-    33,     "Instrumental",
-    46,     "Instrumental Pop",
-    47,     "Instrumental Rock",
-    8,      "Jazz",
-    29,     "Jazz+Funk",
-    63,     "Jungle",
-    86,     "Latin",
-    71,     "Lo-Fi",
-    45,     "Meditative",
-    9,      "Metal",
-    77,     "Musical",
-    82,     "National Folk",
-    64,     "Native American",
-    10,     "New Age",
-    66,     "New Wave",
-    39,     "Noise",
-    255,    "Not Set",
-    11,     "Oldies",
-    103,    "Opera",
-    12,     "Other",
-    75,     "Polka",
-    13,     "Pop",
-    62,     "Pop/Funk",
-    53,     "Pop-Folk",
-    109,    "Porn Groove",
-    117,    "Power Ballad",
-    23,     "Pranks",
-    108,    "Primus",
-    92,     "Progressive Rock",
-    67,     "Psychadelic",
-    93,     "Psychedelic Rock",
-    43,     "Punk",
-    121,    "Punk Rock",
-    14,     "R&B",
-    15,     "Rap",
-    68,     "Rave",
-    16,     "Reggae",
-    76,     "Retro",
-    87,     "Revival",
-    118,    "Rhythmic Soul",
-    17,     "Rock",
-    78,     "Rock & Roll",
-    114,    "Samba",
-    110,    "Satire",
-    69,     "Showtunes",
-    21,     "Ska",
-    111,    "Slow Jam",
-    95,     "Slow Rock",
-    105,    "Sonata",
-    42,     "Soul",
-    37,     "Sound Clip",
-    24,     "Soundtrack",
-    56,     "Southern Rock",
-    44,     "Space",
-    101,    "Speech",
-    83,     "Swing",
-    94,     "Symphonic Rock",
-    106,    "Symphony",
-    113,    "Tango",
-    18,     "Techno",
-    51,     "Techno-Industrial",
-    60,     "Top 40",
-    70,     "Trailer",
-    31,     "Trance",
-    72,     "Tribal",
-    27,     "Trip-Hop",
-    28,     "Vocal"
-};
-
-BOOL CALLBACK DIALOGMsgProcEnc(HWND hWndDlg, UINT Message, WPARAM wParam, LPARAM lParam)
-{
-	switch(Message)
-	{
-	case WM_INITDIALOG:
-		{
-		char buf[50];
-		char FillList=wParam||lParam ? 1 : 0;
-		char *Quality[]={"Default (100)","10","20","30","40","50","60","70","80","90","100","110","120","130","140","150","200","300","400","500",0};
-		char *BitRate[]={"Auto","8","16","18","20","24","32","40","48","56","64","80","96","112","128","160","192","224","256","320","384",0};
-		char *BandWidth[]={"Auto","Full","4000","8000","11025","16000","22050","24000","32000","44100","48000",0};
-		char *Ext[]={".aac",".mp4",".m4a",".m4b",0};
-		CMyEncCfg cfg(false);
-			
-//			sprintf(Quality[0]+8,"%3d",3);
-
-			SetWindowPos(GetDlgItem(hWndDlg,IDC_CHK_TAG),GetDlgItem(hWndDlg,IDC_GRP_TAG),0,0,0,0,SWP_NOMOVE | SWP_NOSIZE);
-
-			INIT_CB(hWndDlg,IDC_CB_QUALITY,Quality,FillList,0);
-			INIT_CB(hWndDlg,IDC_CB_BITRATE,BitRate,FillList,0);
-			INIT_CB(hWndDlg,IDC_CB_BANDWIDTH,BandWidth,FillList,0);
-			INIT_CB(hWndDlg,IDC_CB_EXT,Ext,FillList,0);
-
-			INIT_CB_GENRES(hWndDlg,IDC_CB_GENRE,ID3Genres,0);
-
-			SendMessage(GetDlgItem(hWndDlg, IDC_BTN_ARTFILE), BM_SETIMAGE, IMAGE_BITMAP, (LPARAM) hBmBrowse);
-#ifdef USE_OUTPUT_FOLDER			
-			SendMessage(GetDlgItem(hWndDlg, IDC_BTN_BROWSE), BM_SETIMAGE, IMAGE_BITMAP, (LPARAM) hBmBrowse);
-			if(!cfg.OutDir || !*cfg.OutDir)
-			{
-				GetCurrentDirectory(MAX_PATH,config_AACoutdir);
-				FREE_ARRAY(cfg.OutDir);
-				cfg.OutDir=strdup(config_AACoutdir);
-			}
-			else
-				strcpy(config_AACoutdir,cfg.OutDir);
-			SetDlgItemText(hWndDlg, IDC_E_BROWSE, cfg.OutDir);
-#else
-			ShowWindow(GetDlgItem(hWndDlg, IDC_BTN_BROWSE),SW_HIDE);
-			ShowWindow(GetDlgItem(hWndDlg, IDC_E_BROWSE),SW_HIDE);
-			ShowWindow(GetDlgItem(hWndDlg, IDC_L_BROWSE),SW_HIDE);
-#endif
-			CheckDlgButton(hWndDlg,IDC_RADIO_MPEG4,FALSE);
-			CheckDlgButton(hWndDlg,IDC_RADIO_MPEG2,FALSE);
-			if(cfg.EncCfg.mpegVersion==MPEG4)
-				CheckDlgButton(hWndDlg,IDC_RADIO_MPEG4,TRUE);
-			else
-				CheckDlgButton(hWndDlg,IDC_RADIO_MPEG2,TRUE);
-			
-			CheckDlgButton(hWndDlg,IDC_RADIO_MAIN,FALSE);
-			CheckDlgButton(hWndDlg,IDC_RADIO_LOW,FALSE);
-			CheckDlgButton(hWndDlg,IDC_RADIO_SSR,FALSE);
-			CheckDlgButton(hWndDlg,IDC_RADIO_LTP,FALSE);
-			switch(cfg.EncCfg.aacObjectType)
-			{
-			case MAIN:
-				CheckDlgButton(hWndDlg,IDC_RADIO_MAIN,TRUE);
-				break;
-			case LOW:
-				CheckDlgButton(hWndDlg,IDC_RADIO_LOW,TRUE);
-				break;
-			case SSR:
-				CheckDlgButton(hWndDlg,IDC_RADIO_SSR,TRUE);
-				break;
-			case LTP:
-				CheckDlgButton(hWndDlg,IDC_RADIO_LTP,TRUE);
-				DISABLE_LTP
-				break;
-			}
-			
-			CheckDlgButton(hWndDlg,IDC_RADIO_RAW,FALSE);
-			CheckDlgButton(hWndDlg,IDC_RADIO_ADTS,FALSE);
-			switch(cfg.EncCfg.outputFormat)
-			{
-			case RAW:
-				CheckDlgButton(hWndDlg,IDC_RADIO_RAW,TRUE);
-				break;
-			case ADTS:
-				CheckDlgButton(hWndDlg,IDC_RADIO_ADTS,TRUE);
-				break;
-			}
-			
-			CheckDlgButton(hWndDlg, IDC_CHK_ALLOWMIDSIDE, cfg.EncCfg.allowMidside);
-			CheckDlgButton(hWndDlg, IDC_CHK_USETNS, cfg.EncCfg.useTns);
-			CheckDlgButton(hWndDlg, IDC_CHK_USELFE, cfg.EncCfg.useLfe);
-
-			if(cfg.UseQuality)
-				CheckDlgButton(hWndDlg,IDC_RADIO_QUALITY,TRUE);
-			else
-				CheckDlgButton(hWndDlg,IDC_RADIO_BITRATE,TRUE);
-
-			switch(cfg.EncCfg.quantqual)
-			{
-			case 100:
-				SendMessage(GetDlgItem(hWndDlg, IDC_CB_QUALITY), CB_SETCURSEL, 0, 0);
-				break;
-			default:
-				if(cfg.EncCfg.quantqual<10)
-					cfg.EncCfg.quantqual=10;
-				if(cfg.EncCfg.quantqual>500)
-					cfg.EncCfg.quantqual=500;
-				sprintf(buf,"%lu",cfg.EncCfg.quantqual);
-				SetDlgItemText(hWndDlg, IDC_CB_QUALITY, buf);
-				break;
-			}
-			switch(cfg.EncCfg.bitRate)
-			{
-			case 0:
-				SendMessage(GetDlgItem(hWndDlg, IDC_CB_BITRATE), CB_SETCURSEL, 0, 0);
-				break;
-			default:
-				sprintf(buf,"%lu",cfg.EncCfg.bitRate);
-				SetDlgItemText(hWndDlg, IDC_CB_BITRATE, buf);
-				break;
-			}
-			switch(cfg.EncCfg.bandWidth)
-			{
-			case 0:
-				SendMessage(GetDlgItem(hWndDlg, IDC_CB_BANDWIDTH), CB_SETCURSEL, 0, 0);
-				break;
-			case 0xffffffff:
-				SendMessage(GetDlgItem(hWndDlg, IDC_CB_BANDWIDTH), CB_SETCURSEL, 1, 0);
-				break;
-			default:
-				sprintf(buf,"%lu",cfg.EncCfg.bandWidth);
-				SetDlgItemText(hWndDlg, IDC_CB_BANDWIDTH, buf);
-				break;
-			}
-			
-			SendMessage(GetDlgItem(hWndDlg, IDC_CB_EXT), CB_SETCURSEL, cfg.SaveMP4, 0);
-
-			if(wParam|lParam)
-			{
-				CheckDlgButton(hWndDlg,IDC_CHK_AUTOCFG, cfg.AutoCfg);
-				DISABLE_CTRLS_ENC(!cfg.AutoCfg);
-			}
-#ifdef USE_IMPORT_TAG
-			CheckDlgButton(hWndDlg,IDC_CHK_IMPORTTAG, cfg.TagImport);
-			cfg.TagImport=IsDlgButtonChecked(hWndDlg,IDC_CHK_IMPORTTAG) ? 1 : 0;
-			ShowWindow(GetDlgItem(hWndDlg, IDC_CHK_IMPORTTAG),SW_SHOW);
-	#ifdef USE_PATHEXT
-			SetDlgItemText(hWndDlg, IDC_E_SOURCEPATH, cfg.TagSrcPath);
-			SetDlgItemText(hWndDlg, IDC_E_SOURCEEXT, cfg.TagSrcExt);
-			SendMessage(GetDlgItem(hWndDlg, IDC_BTN_BROWSEIMPORT), BM_SETIMAGE, IMAGE_BITMAP, (LPARAM) hBmBrowse);
-			ShowWindow(GetDlgItem(hWndDlg, IDC_E_SOURCEEXT),SW_SHOW);
-			ShowWindow(GetDlgItem(hWndDlg, IDC_E_SOURCEPATH),SW_SHOW);
-			ShowWindow(GetDlgItem(hWndDlg, IDC_BTN_BROWSEIMPORT),SW_SHOW);
-	#endif
-#endif
-			CheckDlgButton(hWndDlg,IDC_CHK_TAG, cfg.TagOn);
-			ENABLE_TAG(cfg.TagOn && !cfg.TagImport);
-			ENABLE_AACTAGS(cfg.TagOn && !cfg.TagImport && cfg.SaveMP4);
-			SetDlgItemText(hWndDlg, IDC_E_ARTIST, cfg.Tag.artist);
-			SetDlgItemText(hWndDlg, IDC_E_TITLE, cfg.Tag.title);
-			SetDlgItemText(hWndDlg, IDC_E_ALBUM, cfg.Tag.album);
-			SetDlgItemText(hWndDlg, IDC_E_YEAR, cfg.Tag.year);
-			SetDlgItemText(hWndDlg, IDC_CB_GENRE, cfg.Tag.genre);
-			SetDlgItemText(hWndDlg, IDC_E_WRITER, cfg.Tag.writer);
-			SetDlgItemText(hWndDlg, IDC_E_COMMENT, cfg.Tag.comment);
-			SetDlgItemText(hWndDlg, IDC_E_ARTFILE, cfg.Tag.artFilename);
-			SetDlgItemInt(hWndDlg, IDC_E_TRACK, cfg.Tag.trackno, FALSE);
-			SetDlgItemInt(hWndDlg, IDC_E_NTRACKS, cfg.Tag.ntracks, FALSE);
-			SetDlgItemInt(hWndDlg, IDC_E_DISK, cfg.Tag.discno, FALSE);
-			SetDlgItemInt(hWndDlg, IDC_E_NDISKS, cfg.Tag.ndiscs, FALSE);
-			SetDlgItemInt(hWndDlg, IDC_E_COMPILATION, cfg.Tag.compilation, FALSE);
-			CheckDlgButton(hWndDlg, IDC_CHK_COMPILATION, cfg.Tag.compilation);
-		}
-		break; // End of WM_INITDIALOG                                 
-		
-	case WM_CLOSE:
-		// Closing the Dialog behaves the same as Cancel               
-		PostMessage(hWndDlg, WM_COMMAND, IDCANCEL, 0L);
-		break; // End of WM_CLOSE                                      
-		
-	case WM_COMMAND:
-		switch(LOWORD(wParam))
-		{
-		case IDOK:
-			{
-//			HANDLE hCfg=(HANDLE)lParam;
-			char buf[50];
-			CMyEncCfg cfg;
-
-				cfg.AutoCfg=IsDlgButtonChecked(hWndDlg,IDC_CHK_AUTOCFG) ? TRUE : FALSE;
-				if(!cfg.AutoCfg)
-				{
-					cfg.EncCfg.mpegVersion=IsDlgButtonChecked(hWndDlg,IDC_RADIO_MPEG4) ? MPEG4 : MPEG2;
-					if(IsDlgButtonChecked(hWndDlg,IDC_RADIO_MAIN))
-						cfg.EncCfg.aacObjectType=MAIN;
-					if(IsDlgButtonChecked(hWndDlg,IDC_RADIO_LOW))
-						cfg.EncCfg.aacObjectType=LOW;
-					if(IsDlgButtonChecked(hWndDlg,IDC_RADIO_SSR))
-						cfg.EncCfg.aacObjectType=SSR;
-					if(IsDlgButtonChecked(hWndDlg,IDC_RADIO_LTP))
-						cfg.EncCfg.aacObjectType=LTP;
-					cfg.EncCfg.allowMidside=IsDlgButtonChecked(hWndDlg, IDC_CHK_ALLOWMIDSIDE);
-					cfg.EncCfg.useTns=IsDlgButtonChecked(hWndDlg, IDC_CHK_USETNS);
-					cfg.EncCfg.useLfe=IsDlgButtonChecked(hWndDlg, IDC_CHK_USELFE);
-					
-					GetDlgItemText(hWndDlg, IDC_CB_BITRATE, buf, 50);
-					switch(*buf)
-					{
-					case 'A': // Auto
-						cfg.EncCfg.bitRate=0;
-						break;
-					default:
-						cfg.EncCfg.bitRate=GetDlgItemInt(hWndDlg, IDC_CB_BITRATE, 0, FALSE);
-					}
-					GetDlgItemText(hWndDlg, IDC_CB_BANDWIDTH, buf, 50);
-					switch(*buf)
-					{
-					case 'A': // Auto
-						cfg.EncCfg.bandWidth=0;
-						break;
-					case 'F': // Full
-						cfg.EncCfg.bandWidth=0xffffffff;
-						break;
-					default:
-						cfg.EncCfg.bandWidth=GetDlgItemInt(hWndDlg, IDC_CB_BANDWIDTH, 0, FALSE);
-					}
-					cfg.UseQuality=IsDlgButtonChecked(hWndDlg,IDC_RADIO_QUALITY) ? TRUE : FALSE;
-					GetDlgItemText(hWndDlg, IDC_CB_QUALITY, buf, 50);
-					switch(*buf)
-					{
-					case 'D': // Default
-						cfg.EncCfg.quantqual=100;
-						break;
-					default:
-						cfg.EncCfg.quantqual=GetDlgItemInt(hWndDlg, IDC_CB_QUALITY, 0, FALSE);
-					}
-				}
-
-				cfg.EncCfg.outputFormat=IsDlgButtonChecked(hWndDlg,IDC_RADIO_RAW) ? RAW : ADTS;
-#ifdef USE_OUTPUT_FOLDER
-				GetDlgItemText(hWndDlg, IDC_E_BROWSE, config_AACoutdir, MAX_PATH);
-				FREE_ARRAY(cfg.OutDir);
-				cfg.OutDir=strdup(config_AACoutdir);
-#endif
-				cfg.SaveMP4=(BYTE)SendMessage(GetDlgItem(hWndDlg, IDC_CB_EXT), CB_GETCURSEL, 0, 0);
-
-				cfg.TagOn=IsDlgButtonChecked(hWndDlg,IDC_CHK_TAG) ? 1 : 0;
-			char buffer[MAX_PATH];
-#ifdef USE_IMPORT_TAG
-				cfg.TagImport=IsDlgButtonChecked(hWndDlg,IDC_CHK_IMPORTTAG) ? 1 : 0;
-	#ifdef USE_PATHEXT
-				GetDlgItemText(hWndDlg, IDC_E_SOURCEPATH, buffer, MAX_PATH);
-				cfg.TagSrcPath=strdup(buffer);
-				GetDlgItemText(hWndDlg, IDC_E_SOURCEEXT, buffer, MAX_PATH);
-				cfg.TagSrcExt=strdup(buffer);
-	#endif
-#endif
-				GetDlgItemText(hWndDlg, IDC_E_ARTIST, buffer, MAX_PATH);
-				cfg.Tag.artist=strdup(buffer);
-				GetDlgItemText(hWndDlg, IDC_E_TITLE, buffer, MAX_PATH);
-				cfg.Tag.title=strdup(buffer);
-				GetDlgItemText(hWndDlg, IDC_E_ALBUM, buffer, MAX_PATH);
-				cfg.Tag.album=strdup(buffer);
-				GetDlgItemText(hWndDlg, IDC_E_YEAR, buffer, MAX_PATH);
-				cfg.Tag.year=strdup(buffer);
-				GetDlgItemText(hWndDlg, IDC_CB_GENRE, buffer, MAX_PATH);
-				cfg.Tag.genre=strdup(buffer);
-				GetDlgItemText(hWndDlg, IDC_E_WRITER, buffer, MAX_PATH);
-				cfg.Tag.writer=strdup(buffer);
-				GetDlgItemText(hWndDlg, IDC_E_COMMENT, buffer, MAX_PATH);
-				cfg.Tag.comment=strdup(buffer);
-				GetDlgItemText(hWndDlg, IDC_E_ARTFILE, buffer, MAX_PATH);
-				cfg.Tag.artFilename=strdup(buffer);
-				cfg.Tag.trackno=GetDlgItemInt(hWndDlg, IDC_E_TRACK, 0, FALSE);
-				cfg.Tag.ntracks=GetDlgItemInt(hWndDlg, IDC_E_NTRACKS, 0, FALSE);
-				cfg.Tag.discno=GetDlgItemInt(hWndDlg, IDC_E_DISK, 0, FALSE);
-				cfg.Tag.ndiscs=GetDlgItemInt(hWndDlg, IDC_E_NDISKS, 0, FALSE);
-				cfg.Tag.compilation=(BYTE)GetDlgItemInt(hWndDlg, IDC_E_COMPILATION, 0, FALSE);
-				cfg.Tag.compilation=IsDlgButtonChecked(hWndDlg, IDC_CHK_COMPILATION) ? 1 : 0;
-				EndDialog(hWndDlg, TRUE);//(DWORD)hCfg);
-			}
-			break;
-			
-        case IDCANCEL:
-			// Ignore data values entered into the controls        
-			// and dismiss the dialog window returning FALSE
-			EndDialog(hWndDlg, FALSE);
-			break;
-
-		case IDC_BTN_ABOUT:
-			DialogBox((HINSTANCE)hInstance,(LPCSTR)MAKEINTRESOURCE(IDD_ABOUT), (HWND)hWndDlg, (DLGPROC)DialogMsgProcAbout);
-			break;
-
-		case IDC_BTN_LICENSE:
-			{
-			char *license =
-				"\nPlease note that the use of this software may require the payment of patent royalties.\n"
-				"You need to consider this issue before you start building derivative works.\n"
-				"We are not warranting or indemnifying you in any way for patent royalities!\n"
-				"YOU ARE SOLELY RESPONSIBLE FOR YOUR OWN ACTIONS!\n"
-				"\n"
-				"FAAC is based on the ISO MPEG-4 reference code. For this code base the\n"
-				"following license applies:\n"
-				"\n"
-/*				"This software module was originally developed by\n"
-				"\n"
-				"FirstName LastName (CompanyName)\n"
-				"\n"
-				"and edited by\n"
-				"\n"
-				"FirstName LastName (CompanyName)\n"
-				"FirstName LastName (CompanyName)\n"
-				"\n"
-*/				"in the course of development of the MPEG-2 NBC/MPEG-4 Audio standard\n"
-				"ISO/IEC 13818-7, 14496-1,2 and 3. This software module is an\n"
-				"implementation of a part of one or more MPEG-2 NBC/MPEG-4 Audio tools\n"
-				"as specified by the MPEG-2 NBC/MPEG-4 Audio standard. ISO/IEC gives\n"
-				"users of the MPEG-2 NBC/MPEG-4 Audio standards free license to this\n"
-				"software module or modifications thereof for use in hardware or\n"
-				"software products claiming conformance to the MPEG-2 NBC/ MPEG-4 Audio\n"
-				"standards. Those intending to use this software module in hardware or\n"
-				"software products are advised that this use may infringe existing\n"
-				"patents. The original developer of this software module and his/her\n"
-				"company, the subsequent editors and their companies, and ISO/IEC have\n"
-				"no liability for use of this software module or modifications thereof\n"
-				"in an implementation. Copyright is not released for non MPEG-2\n"
-				"NBC/MPEG-4 Audio conforming products. The original developer retains\n"
-				"full right to use the code for his/her own purpose, assign or donate\n"
-				"the code to a third party and to inhibit third party from using the\n"
-				"code for non MPEG-2 NBC/MPEG-4 Audio conforming products. This\n"
-				"copyright notice must be included in all copies or derivative works.\n"
-				"\n"
-				"Copyright (c) 1997.\n"
-				"\n"
-				"For the changes made for the FAAC project the GNU Lesser General Public\n"
-				"License (LGPL), version 2 1991 applies:\n"
-				"\n"
-				"FAAC - Freeware Advanced Audio Coder\n"
-				"Copyright (C) 2001-2004 The individual contributors\n"
-				"\n"
-				"This library is free software; you can redistribute it and/or modify it under the terms of\n"
-				"the GNU Lesser General Public License as published by the Free Software Foundation;\n"
-				"either version 2.1 of the License, or (at your option) any later version.\n"
-				"\n"
-				"This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n"
-				"without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n"
-				"See the GNU Lesser General Public License for more details.\n"
-				"\n"
-				"You should have received a copy of the GNU Lesser General Public\n"
-				"License along with this library; if not, write to the Free Software\n"
-				"Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA\n";
-
-				MessageBox(hWndDlg,license,"FAAC libray License",MB_OK|MB_ICONINFORMATION);
-			}
-			break;
-
-#ifdef USE_OUTPUT_FOLDER
-		case IDC_BTN_BROWSE:
-			{
-			BROWSEINFO bi;
-			ITEMIDLIST *idlist;
-
-				GetDlgItemText(hWndDlg, IDC_E_BROWSE, config_AACoutdir, MAX_PATH);
-				bi.hwndOwner = hWndDlg;
-				bi.pidlRoot = 0;
-				bi.pszDisplayName = config_AACoutdir;
-				bi.lpszTitle = "Select a directory for aac/mp4 file output:";
-				bi.ulFlags = BIF_RETURNONLYFSDIRS;
-				bi.lpfn = BrowseCallbackProc;
-				bi.lParam = (LPARAM)config_AACoutdir;
-				
-				idlist = SHBrowseForFolder(&bi);
-				if(idlist)
-				{
-					SHGetPathFromIDList(idlist, config_AACoutdir);
-					SetDlgItemText(hWndDlg, IDC_E_BROWSE, config_AACoutdir);
-				}
-			}
-			break;
-#endif			
-		case IDC_BTN_ARTFILE:
-			{
-			OPENFILENAME ofn;
-			char ArtFilename[MAX_PATH]="";
-
-				GetDlgItemText(hWndDlg, IDC_E_ARTFILE, ArtFilename, MAX_PATH);
-				ofn.lStructSize			= sizeof(OPENFILENAME);
-				ofn.hwndOwner			= (HWND)hWndDlg;
-				ofn.lpstrFilter			= "Cover art files (*.gif,*jpg,*.png)\0*.gif;*.jpg;*.png\0";
-				ofn.lpstrCustomFilter	= NULL;
-				ofn.nFilterIndex		= 1;
-				ofn.lpstrFile			= ArtFilename;
-				ofn.nMaxFile			= MAX_PATH; //sizeof ArtFilename;
-				ofn.lpstrFileTitle		= NULL;
-				ofn.nMaxFileTitle		= 0;
-				ofn.lpstrInitialDir		= NULL;
-				ofn.lpstrTitle			= "Select cover art file";
-				ofn.Flags				= OFN_EXPLORER | OFN_PATHMUSTEXIST | OFN_FILEMUSTEXIST | OFN_HIDEREADONLY | OFN_ENABLESIZING;
-				ofn.lpstrDefExt			= NULL;//"jpg";
-				ofn.hInstance			= hInstance;
-
-				if(GetOpenFileName(&ofn))
-					SetDlgItemText(hWndDlg, IDC_E_ARTFILE, ArtFilename);
-			}
-			break;
-
-#ifdef USE_IMPORT_TAG
-		case IDC_BTN_BROWSEIMPORT:
-			{
-			char path[MAX_PATH];
-			BROWSEINFO bi;
-			ITEMIDLIST *idlist;
-
-				GetDlgItemText(hWndDlg, IDC_E_SOURCEPATH, path, MAX_PATH);
-				bi.hwndOwner = hWndDlg;
-				bi.pidlRoot = 0;
-				bi.pszDisplayName = path;
-				bi.lpszTitle = "Select the folder where source files are stored:";
-				bi.ulFlags = BIF_RETURNONLYFSDIRS;
-				bi.lpfn = BrowseCallbackProc;
-				bi.lParam = (LPARAM)path;
-				
-				idlist=SHBrowseForFolder(&bi);
-				if(idlist)
-				{
-					SHGetPathFromIDList(idlist, path);
-					SetDlgItemText(hWndDlg, IDC_E_SOURCEPATH, path);
-				}
-			}
-			break;
-#endif			
-		case IDC_RADIO_MPEG4:
-			EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_LTP), !IsDlgButtonChecked(hWndDlg,IDC_CHK_AUTOCFG));
-			break;
-			
-		case IDC_RADIO_MPEG2:
-			EnableWindow(GetDlgItem(hWndDlg, IDC_RADIO_LTP), FALSE);
-			DISABLE_LTP
-			break;
-
-		case IDC_CHK_AUTOCFG:
-			{
-			BYTE Enabled=IsDlgButtonChecked(hWndDlg,IDC_CHK_AUTOCFG);
-				DISABLE_CTRLS_ENC(!Enabled);
-				if(!Enabled)
-					SendMessage(hWndDlg, WM_INITDIALOG, 0L, 0L);
-				else
-				{
-					SetDlgItemInt(hWndDlg, IDC_CB_QUALITY, DEF_QUALITY, FALSE);
-					SetDlgItemInt(hWndDlg, IDC_CB_BITRATE, DEF_BITRATE, FALSE);
-					SetDlgItemInt(hWndDlg, IDC_CB_BANDWIDTH, DEF_BANDWIDTH, FALSE);
-
-					CheckDlgButton(hWndDlg,IDC_RADIO_MPEG4,FALSE);
-					CheckDlgButton(hWndDlg,IDC_RADIO_MPEG2,FALSE);
-					if(DEF_MPEGVER==MPEG4)
-						CheckDlgButton(hWndDlg,IDC_RADIO_MPEG4,TRUE);
-					else
-						CheckDlgButton(hWndDlg,IDC_RADIO_MPEG2,TRUE);
-					
-					CheckDlgButton(hWndDlg,IDC_RADIO_MAIN,FALSE);
-					CheckDlgButton(hWndDlg,IDC_RADIO_LOW,FALSE);
-					CheckDlgButton(hWndDlg,IDC_RADIO_SSR,FALSE);
-					CheckDlgButton(hWndDlg,IDC_RADIO_LTP,FALSE);
-					switch(DEF_PROFILE)
-					{
-					case MAIN:
-						CheckDlgButton(hWndDlg,IDC_RADIO_MAIN,TRUE);
-						break;
-					case LOW:
-						CheckDlgButton(hWndDlg,IDC_RADIO_LOW,TRUE);
-						break;
-					case SSR:
-						CheckDlgButton(hWndDlg,IDC_RADIO_SSR,TRUE);
-						break;
-					case LTP:
-						CheckDlgButton(hWndDlg,IDC_RADIO_LTP,TRUE);
-						DISABLE_LTP
-						break;
-					}
-					
-					CheckDlgButton(hWndDlg,IDC_RADIO_RAW,FALSE);
-					CheckDlgButton(hWndDlg,IDC_RADIO_ADTS,FALSE);
-					switch(DEF_HEADER)
-					{
-					case RAW:
-						CheckDlgButton(hWndDlg,IDC_RADIO_RAW,TRUE);
-						break;
-					case ADTS:
-						CheckDlgButton(hWndDlg,IDC_RADIO_ADTS,TRUE);
-						break;
-					}
-					
-					CheckDlgButton(hWndDlg, IDC_CHK_ALLOWMIDSIDE, DEF_MIDSIDE);
-					CheckDlgButton(hWndDlg, IDC_CHK_USETNS, DEF_TNS);
-					CheckDlgButton(hWndDlg, IDC_CHK_USELFE, DEF_LFE);
-
-					if(DEF_USEQUALTY)
-						CheckDlgButton(hWndDlg,IDC_RADIO_QUALITY,true);
-					else
-						CheckDlgButton(hWndDlg,IDC_RADIO_BITRATE,true);
-
-					if(DEF_QUALITY<10)
-						SetDlgItemInt(hWndDlg, IDC_CB_QUALITY, 10, FALSE);
-					else
-						if(DEF_QUALITY>500)
-							SetDlgItemInt(hWndDlg, IDC_CB_QUALITY, 500, FALSE);
-						else
-							SetDlgItemInt(hWndDlg, IDC_CB_QUALITY, DEF_QUALITY, FALSE);
-
-					switch(DEF_BITRATE)
-					{
-					case 0:
-						SendMessage(GetDlgItem(hWndDlg, IDC_CB_BITRATE), CB_SETCURSEL, 0, 0);
-//						SetDlgItemInt(hWndDlg, IDC_CB_BITRATE, 128, FALSE);
-						break;
-					default:
-						SetDlgItemInt(hWndDlg, IDC_CB_BITRATE, DEF_BITRATE, FALSE);
-						break;
-					}
-					switch(DEF_BANDWIDTH)
-					{
-					case 0:
-						SendMessage(GetDlgItem(hWndDlg, IDC_CB_BANDWIDTH), CB_SETCURSEL, 0, 0);
-						break;
-					case 0xffffffff:
-						SendMessage(GetDlgItem(hWndDlg, IDC_CB_BANDWIDTH), CB_SETCURSEL, 1, 0);
-						break;
-					default:
-						SetDlgItemInt(hWndDlg, IDC_CB_BANDWIDTH, DEF_BANDWIDTH, FALSE);
-						break;
-					}
-					
-					SendMessage(GetDlgItem(hWndDlg, IDC_CB_EXT), CB_SETCURSEL, DEF_WRITEMP4, 0);
-//					DISABLE_CTRLS_ENC(!Enabled);
-				}
-			}
-			break;
-
-		case IDC_CHK_TAG:
-		case IDC_CB_EXT:
-			{
-			char TagImport=IsDlgButtonChecked(hWndDlg,IDC_CHK_IMPORTTAG);
-			char TagEnabled=IsDlgButtonChecked(hWndDlg,IDC_CHK_TAG);
-				ENABLE_TAG(TagEnabled && !TagImport);
-			char Enabled=SendMessage(GetDlgItem(hWndDlg, IDC_CB_EXT), CB_GETCURSEL, 0, 0)!=0;
-				ENABLE_AACTAGS(TagEnabled && !TagImport && Enabled);
-			}
-			break;
-#ifdef USE_IMPORT_TAG
-		case IDC_CHK_IMPORTTAG:
-			SendMessage(hWndDlg, WM_COMMAND, IDC_CHK_TAG, 0);
-			break;
-#endif
-		}
-		break; // End of WM_COMMAND
-	default: 
-		return FALSE;
-	}
-	
-	return TRUE;
-} // End of DIALOGSMsgProc                                      
--- a/common/Cfaac/EncDialog.h
+++ /dev/null
@@ -1,2 +1,0 @@
-extern BOOL DialogMsgProcAbout(HWND hWndDlg, UINT Message, WPARAM wParam, LPARAM lParam);
-extern BOOL CALLBACK DIALOGMsgProcEnc(HWND hWndDlg, UINT Message, WPARAM wParam, LPARAM lParam);
--- a/common/Cfaac/FAAC.rc
+++ /dev/null
@@ -1,343 +1,0 @@
-// Microsoft Visual C++ generated resource script.
-//
-#include "resource.h"
-
-#define APSTUDIO_READONLY_SYMBOLS
-/////////////////////////////////////////////////////////////////////////////
-//
-// Generated from the TEXTINCLUDE 2 resource.
-//
-#include "afxres.h"
-
-/////////////////////////////////////////////////////////////////////////////
-#undef APSTUDIO_READONLY_SYMBOLS
-
-/////////////////////////////////////////////////////////////////////////////
-// English (U.S.) resources
-
-#if !defined(AFX_RESOURCE_DLL) || defined(AFX_TARG_ENU)
-#ifdef _WIN32
-LANGUAGE LANG_ENGLISH, SUBLANG_ENGLISH_US
-#pragma code_page(1252)
-#endif //_WIN32
-
-/////////////////////////////////////////////////////////////////////////////
-//
-// Dialog
-//
-
-IDD_ENCODER DIALOGEX 0, 0, 338, 219
-STYLE DS_SETFONT | DS_MODALFRAME | WS_POPUP | WS_VISIBLE | WS_CAPTION | 
-    WS_SYSMENU
-CAPTION "MPEG4-AAC options"
-FONT 8, "MS Sans Serif", 0, 0, 0x0
-BEGIN
-    DEFPUSHBUTTON   "&OK",IDOK,12,200,36,14
-    PUSHBUTTON      "&Cancel",IDCANCEL,48,200,36,14
-    PUSHBUTTON      "&About",IDC_BTN_ABOUT,84,200,36,14
-    PUSHBUTTON      "&License",IDC_BTN_LICENSE,120,200,36,14
-    CONTROL         "Automatic configuration",IDC_CHK_AUTOCFG,"Button",
-                    BS_AUTOCHECKBOX | WS_TABSTOP,4,4,90,10
-    CONTROL         "Main",IDC_RADIO_MAIN,"Button",BS_AUTORADIOBUTTON | 
-                    WS_GROUP,9,28,31,10
-    CONTROL         "LC",IDC_RADIO_LOW,"Button",BS_AUTORADIOBUTTON,9,40,25,
-                    10
-    CONTROL         "LTP",IDC_RADIO_LTP,"Button",BS_AUTORADIOBUTTON,9,52,29,
-                    10
-    CONTROL         "SSR",IDC_RADIO_SSR,"Button",BS_AUTORADIOBUTTON | NOT 
-                    WS_VISIBLE | WS_DISABLED,9,63,31,10
-    CONTROL         "MPEG4",IDC_RADIO_MPEG4,"Button",BS_AUTORADIOBUTTON | 
-                    WS_GROUP,62,27,40,10
-    CONTROL         "MPEG2",IDC_RADIO_MPEG2,"Button",BS_AUTORADIOBUTTON,62,
-                    40,40,9
-    CONTROL         "Raw",IDC_RADIO_RAW,"Button",BS_AUTORADIOBUTTON | 
-                    WS_GROUP,112,27,42,10
-    CONTROL         "ADTS",IDC_RADIO_ADTS,"Button",BS_AUTORADIOBUTTON,112,40,
-                    41,9
-    CONTROL         "Quality",IDC_RADIO_QUALITY,"Button",BS_AUTORADIOBUTTON | 
-                    WS_GROUP,9,84,37,10
-    COMBOBOX        IDC_CB_QUALITY,102,81,48,97,CBS_DROPDOWN | WS_VSCROLL | 
-                    WS_GROUP | WS_TABSTOP
-    CONTROL         "Bitrate",IDC_RADIO_BITRATE,"Button",BS_AUTORADIOBUTTON,
-                    9,100,36,10
-    COMBOBOX        IDC_CB_BITRATE,102,97,48,86,CBS_DROPDOWN | WS_VSCROLL | 
-                    WS_TABSTOP
-    LTEXT           "Cutoff",IDC_STATIC,21,121,20,8
-    COMBOBOX        IDC_CB_BANDWIDTH,102,118,48,81,CBS_DROPDOWN | WS_VSCROLL | 
-                    WS_TABSTOP
-    LTEXT           "Write",IDC_STATIC,22,138,18,8
-    COMBOBOX        IDC_CB_EXT,102,135,48,81,CBS_DROPDOWNLIST | WS_VSCROLL | 
-                    WS_TABSTOP
-    CONTROL         "Allow Mid/Side",IDC_CHK_ALLOWMIDSIDE,"Button",
-                    BS_AUTOCHECKBOX | WS_TABSTOP,9,152,63,10
-    CONTROL         "Use TNS",IDC_CHK_USETNS,"Button",BS_AUTOCHECKBOX | NOT 
-                    WS_VISIBLE | WS_DISABLED | WS_TABSTOP,9,162,45,10
-    CONTROL         "Use LFE channel",IDC_CHK_USELFE,"Button",
-                    BS_AUTOCHECKBOX | NOT WS_VISIBLE | WS_DISABLED | 
-                    WS_TABSTOP,88,152,67,10
-    EDITTEXT        IDC_E_BROWSE,50,172,83,14,ES_AUTOHSCROLL
-    PUSHBUTTON      "Browse",IDC_BTN_BROWSE,137,172,18,14,BS_BITMAP | 
-                    BS_FLAT
-    GROUPBOX        "",IDC_GRP_TAG,160,4,174,210
-    CONTROL         "Tag",IDC_CHK_TAG,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,
-                    165,3,29,10
-    CONTROL         "Import",IDC_CHK_IMPORTTAG,"Button",BS_AUTOCHECKBOX | 
-                    NOT WS_VISIBLE | WS_TABSTOP,165,15,35,10
-    EDITTEXT        IDC_E_SOURCEPATH,207,11,63,14,ES_AUTOHSCROLL | NOT 
-                    WS_VISIBLE
-    PUSHBUTTON      "Browse",IDC_BTN_BROWSEIMPORT,273,11,18,14,BS_BITMAP | 
-                    BS_FLAT | NOT WS_VISIBLE
-    EDITTEXT        IDC_E_SOURCEEXT,294,11,34,14,ES_AUTOHSCROLL | NOT 
-                    WS_VISIBLE
-    EDITTEXT        IDC_E_ARTIST,207,27,121,14,ES_AUTOHSCROLL
-    EDITTEXT        IDC_E_TITLE,207,42,121,14,ES_AUTOHSCROLL
-    EDITTEXT        IDC_E_ALBUM,207,57,121,14,ES_AUTOHSCROLL
-    EDITTEXT        IDC_E_YEAR,207,72,121,14,ES_AUTOHSCROLL
-    COMBOBOX        IDC_CB_GENRE,207,87,121,161,CBS_DROPDOWN | WS_VSCROLL | 
-                    WS_TABSTOP
-    EDITTEXT        IDC_E_WRITER,207,101,121,14,ES_AUTOHSCROLL
-    EDITTEXT        IDC_E_COMMENT,207,116,121,29,ES_MULTILINE | 
-                    ES_AUTOHSCROLL
-    EDITTEXT        IDC_E_COMPILATION,207,146,121,14,ES_AUTOHSCROLL | NOT 
-                    WS_VISIBLE
-    CONTROL         "Part of a compilation",IDC_CHK_COMPILATION,"Button",
-                    BS_AUTOCHECKBOX | WS_TABSTOP,165,148,80,10
-    EDITTEXT        IDC_E_TRACK,233,162,40,14,ES_AUTOHSCROLL
-    EDITTEXT        IDC_E_NTRACKS,288,162,40,14,ES_AUTOHSCROLL
-    EDITTEXT        IDC_E_DISK,233,177,40,14,ES_AUTOHSCROLL
-    EDITTEXT        IDC_E_NDISKS,288,177,40,14,ES_AUTOHSCROLL
-    EDITTEXT        IDC_E_ARTFILE,207,192,98,14,ES_AUTOHSCROLL
-    PUSHBUTTON      "&...",IDC_BTN_ARTFILE,311,192,17,14,BS_BITMAP | BS_FLAT
-    GROUPBOX        "AAC type",IDC_STATIC,56,16,48,52
-    GROUPBOX        "Profile",IDC_STATIC,4,16,48,52
-    GROUPBOX        "Header",IDC_STATIC,108,16,48,52
-    GROUPBOX        "Encoding mode",IDC_STATIC,4,73,152,42
-    LTEXT           "Artist",IDC_STATIC,165,29,16,8
-    LTEXT           "Title",IDC_STATIC,165,44,14,8
-    LTEXT           "Album",IDC_STATIC,165,59,20,8
-    LTEXT           "Year",IDC_STATIC,165,74,16,8
-    LTEXT           "Genre",IDC_STATIC,165,89,20,8
-    LTEXT           "Writer",IDC_STATIC,165,103,20,8
-    LTEXT           "Comment\n(ctrl-Enter\nto go down)",IDC_STATIC,165,118,
-                    37,26
-    LTEXT           "Track",IDC_STATIC,165,166,20,8
-    LTEXT           "/",IDC_STATIC,277,166,8,8
-    LTEXT           "Disk",IDC_STATIC,165,180,15,8
-    LTEXT           "/",IDC_STATIC,277,180,8,8
-    LTEXT           "Cover art file",IDC_STATIC,165,195,40,8
-    LTEXT           "Output folder",IDC_L_BROWSE,4,175,42,8
-END
-
-IDD_DECODER DIALOGEX 0, 0, 162, 153
-STYLE DS_SETFONT | DS_MODALFRAME | WS_POPUP | WS_VISIBLE | WS_CAPTION | 
-    WS_SYSMENU
-CAPTION "Raw .AAC options"
-FONT 8, "MS Sans Serif", 0, 0, 0x1
-BEGIN
-    DEFPUSHBUTTON   "&OK",IDOK,47,132,36,14
-    PUSHBUTTON      "&Cancel",IDCANCEL,83,132,36,14
-    PUSHBUTTON      "&About",IDC_BTN_ABOUT,119,132,36,14
-    CONTROL         "Main",IDC_RADIO_MAIN,"Button",BS_AUTORADIOBUTTON | 
-                    WS_GROUP,19,33,31,10
-    CONTROL         "Low",IDC_RADIO_LOW,"Button",BS_AUTORADIOBUTTON,19,44,29,
-                    10
-    CONTROL         "SSR",IDC_RADIO_SSR,"Button",BS_AUTORADIOBUTTON | 
-                    WS_DISABLED,19,56,31,10
-    CONTROL         "LTP",IDC_RADIO_LTP,"Button",BS_AUTORADIOBUTTON,19,68,29,
-                    10
-    GROUPBOX        "Profile",IDC_STATIC,13,23,48,70
-    COMBOBOX        IDC_CB_SAMPLERATE,72,74,69,87,CBS_DROPDOWN | WS_DISABLED | 
-                    WS_VSCROLL | WS_TABSTOP
-    CONTROL         "Default settings",IDC_CHK_DEFAULTCFG,"Button",
-                    BS_AUTOCHECKBOX | WS_TABSTOP,13,7,64,10
-    GROUPBOX        "Sample rate",IDC_STATIC,66,61,81,32
-    CONTROL         "HE",IDC_RADIO_HE,"Button",BS_AUTORADIOBUTTON | 
-                    WS_DISABLED,19,80,26,10
-    CONTROL         "Down matrix 5.1 to 2 channels",IDC_CHK_DOWNMATRIX,
-                    "Button",BS_AUTOCHECKBOX | WS_TABSTOP,13,98,111,10
-    CONTROL         "Assume old ADTS format",IDC_CHK_OLDADTS,"Button",
-                    BS_AUTOCHECKBOX | WS_TABSTOP,13,110,95,10
-    COMBOBOX        IDC_CB_BITSPERSAMPLE,72,35,69,87,CBS_DROPDOWNLIST | 
-                    WS_DISABLED | WS_VSCROLL | WS_TABSTOP
-    GROUPBOX        "Output bits per sample",IDC_STATIC,66,23,81,32
-    GROUPBOX        "",IDC_GRP_DEFAULT,7,8,147,118
-END
-
-
-#ifdef APSTUDIO_INVOKED
-/////////////////////////////////////////////////////////////////////////////
-//
-// TEXTINCLUDE
-//
-
-1 TEXTINCLUDE 
-BEGIN
-    "resource.h\0"
-END
-
-2 TEXTINCLUDE 
-BEGIN
-    "#include ""afxres.h""\r\n"
-    "\0"
-END
-
-3 TEXTINCLUDE 
-BEGIN
-    "\r\n"
-    "\0"
-END
-
-#endif    // APSTUDIO_INVOKED
-
-
-/////////////////////////////////////////////////////////////////////////////
-//
-// DESIGNINFO
-//
-
-#ifdef APSTUDIO_INVOKED
-GUIDELINES DESIGNINFO 
-BEGIN
-    IDD_ENCODER, DIALOG
-    BEGIN
-        LEFTMARGIN, 4
-        RIGHTMARGIN, 334
-        TOPMARGIN, 4
-        BOTTOMMARGIN, 214
-    END
-
-    IDD_DECODER, DIALOG
-    BEGIN
-        LEFTMARGIN, 7
-        RIGHTMARGIN, 154
-        TOPMARGIN, 7
-        BOTTOMMARGIN, 146
-    END
-END
-#endif    // APSTUDIO_INVOKED
-
-#endif    // English (U.S.) resources
-/////////////////////////////////////////////////////////////////////////////
-
-
-/////////////////////////////////////////////////////////////////////////////
-// Italian (Italy) resources
-
-#if !defined(AFX_RESOURCE_DLL) || defined(AFX_TARG_ITA)
-#ifdef _WIN32
-LANGUAGE LANG_ITALIAN, SUBLANG_ITALIAN
-#pragma code_page(1252)
-#endif //_WIN32
-
-/////////////////////////////////////////////////////////////////////////////
-//
-// Dialog
-//
-
-IDD_ABOUT DIALOGEX 0, 0, 191, 230
-STYLE DS_SETFONT | DS_MODALFRAME | WS_POPUP | WS_VISIBLE | WS_CAPTION
-CAPTION "About"
-FONT 8, "MS Sans Serif", 0, 0, 0x1
-BEGIN
-    DEFPUSHBUTTON   "&OK",IDOK,145,208,39,14
-    CONTROL         104,IDC_AUDIOCODING,"Static",SS_BITMAP | SS_NOTIFY | 
-                    SS_SUNKEN,7,7,178,69
-    CONTROL         107,IDC_MPEG4IP,"Static",SS_BITMAP | SS_NOTIFY | 
-                    SS_SUNKEN,7,202,59,20
-    CONTROL         106,IDC_EMAIL,"Static",SS_BITMAP | SS_NOTIFY,96,204,43,
-                    18
-    LTEXT           "Text",IDC_L_ABOUT,7,55,177,142
-    ICON            IDI_ID3,IDC_ID3,70,202,20,20,SS_NOTIFY | SS_SUNKEN
-END
-
-
-/////////////////////////////////////////////////////////////////////////////
-//
-// DESIGNINFO
-//
-
-#ifdef APSTUDIO_INVOKED
-GUIDELINES DESIGNINFO 
-BEGIN
-    IDD_ABOUT, DIALOG
-    BEGIN
-        LEFTMARGIN, 7
-        RIGHTMARGIN, 184
-        TOPMARGIN, 7
-        BOTTOMMARGIN, 222
-    END
-END
-#endif    // APSTUDIO_INVOKED
-
-
-/////////////////////////////////////////////////////////////////////////////
-//
-// Bitmap
-//
-
-IDB_AUDIOCODING         BITMAP                  "AudioCoding.bmp"
-IDB_EMAIL               BITMAP                  "Email.bmp"
-IDB_MPEG4IP             BITMAP                  "mpeg4ip-v.bmp"
-IDB_BROWSE              BITMAP                  "Open.bmp"
-
-/////////////////////////////////////////////////////////////////////////////
-//
-// Icon
-//
-
-// Icon with lowest ID value placed first to ensure application icon
-// remains consistent on all systems.
-IDI_ID3                 ICON                    "id3v2.ico"
-
-/////////////////////////////////////////////////////////////////////////////
-//
-// Version
-//
-
-VS_VERSION_INFO VERSIONINFO
- FILEVERSION 1,0,0,0
- PRODUCTVERSION 1,0,0,0
- FILEFLAGSMASK 0x17L
-#ifdef _DEBUG
- FILEFLAGS 0x1L
-#else
- FILEFLAGS 0x0L
-#endif
- FILEOS 0x4L
- FILETYPE 0x2L
- FILESUBTYPE 0x0L
-BEGIN
-    BLOCK "StringFileInfo"
-    BEGIN
-        BLOCK "041004b0"
-        BEGIN
-            VALUE "FileDescription", "FAAC plugin"
-            VALUE "FileVersion", "1, 0, 0, 0"
-            VALUE "InternalName", "FAAC"
-            VALUE "LegalCopyright", "Copyright (C) 2004"
-            VALUE "OriginalFilename", "FAAC.dll"
-            VALUE "ProductName", " FAAC Dynamic Link Library"
-            VALUE "ProductVersion", "1, 0, 0, 0"
-        END
-    END
-    BLOCK "VarFileInfo"
-    BEGIN
-        VALUE "Translation", 0x410, 1200
-    END
-END
-
-#endif    // Italian (Italy) resources
-/////////////////////////////////////////////////////////////////////////////
-
-
-
-#ifndef APSTUDIO_INVOKED
-/////////////////////////////////////////////////////////////////////////////
-//
-// Generated from the TEXTINCLUDE 3 resource.
-//
-
-
-/////////////////////////////////////////////////////////////////////////////
-#endif    // not APSTUDIO_INVOKED
-
binary files a/common/Cfaac/Open.bmp /dev/null differ
--- a/common/Cfaac/ReadMe.txt
+++ /dev/null
@@ -1,20 +1,0 @@
-+----------------------------------------------------------------+
-|                                                                |
-|                           Cfaac Readme                         |
-|                           ------------                         |
-|                                                                |
-+----------------------------------------------------------------+
-
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License.
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY.
-
-----------------------------------------------------------------------------
-
-Cfaac is a set of classes to develop plugins (to import/export .aac/.mp4 files) with ease.
-
-----------------------------------------------------------------------------
-
-For suggestions, bugs report, etc., you can contact me at
[email protected]
--- a/common/Cfaac/TypeDef.h
+++ /dev/null
@@ -1,45 +1,0 @@
-/*
-FAAC - codec plugin for Cooledit
-Copyright (C) 2002-2004 Antonio Foranna
-
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation.
-	
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
-		
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-			
-The author can be contacted at:
[email protected]
-*/
-
-//---------------------------------------------------------------------------
-#ifndef TypeDefH
-#define TypeDefH
-//---------------------------------------------------------------------------
-
-/* typedef.h */
-
-#ifndef BYTE
-typedef unsigned char    BYTE;
-#endif
-#ifndef WORD
-typedef unsigned short   WORD;
-#endif
-#ifndef DWORD
-typedef unsigned long    DWORD;
-#endif
-#ifndef QWORD
-typedef unsigned __int64 QWORD;
-#endif
-
-//---------------------------------------------------------------------------
-#endif
-//---------------------------------------------------------------------------
-
binary files a/common/Cfaac/id3v2.ico /dev/null differ
binary files a/common/Cfaac/mpeg4ip-v.bmp /dev/null differ
--- a/common/Cfaac/resource.h
+++ /dev/null
@@ -1,81 +1,0 @@
-//{{NO_DEPENDENCIES}}
-// Microsoft Visual C++ generated include file.
-// Used by FAAC.rc
-//
-#define IDD_ENCODER                     101
-#define IDD_DECODER                     102
-#define IDD_ABOUT                       103
-#define IDB_AUDIOCODING                 104
-#define IDB_EMAIL                       106
-#define IDB_MPEG4IP                     107
-#define IDB_BROWSE                      108
-#define IDI_ID3                         110
-#define IDC_CHK_DEFAULTCFG              1000
-#define IDC_CHK_DOWNMATRIX              1001
-#define IDC_CHK_OLDADTS                 1002
-#define IDC_CB_SAMPLERATE               1003
-#define IDC_AUDIOCODING                 1004
-#define IDC_CB_BITSPERSAMPLE            1004
-#define IDC_EMAIL                       1005
-#define IDC_MPEG4IP                     1006
-#define IDC_E_BROWSE                    1007
-#define IDC_BTN_BROWSE                  1008
-#define IDC_RADIO_MPEG4                 1009
-#define IDC_RADIO_MPEG2                 1010
-#define IDC_RADIO_LOW                   1011
-#define IDC_RADIO_MAIN                  1012
-#define IDC_RADIO_SSR                   1013
-#define IDC_RADIO_LTP                   1014
-#define IDC_RADIO_RAW                   1015
-#define IDC_RADIO_HE                    1016
-#define IDC_BTN_BROWSE2                 1016
-#define IDC_BTN_BROWSEIMPORT            1016
-#define IDC_RADIO_ADTS                  1017
-#define IDC_CB_BANDWIDTH                1018
-#define IDC_CB_BITRATE                  1019
-#define IDC_CHK_ALLOWMIDSIDE            1020
-#define IDC_CHK_USETNS                  1021
-#define IDC_CHK_USELFE                  1022
-#define IDC_CHK_AUTOCFG                 1023
-#define IDC_BTN_ABOUT                   1024
-#define IDC_L_ABOUT                     1025
-#define IDC_BTN_ARTFILE                 1026
-#define IDC_CHK_USETNS2                 1027
-#define IDC_CB_EXT                      1028
-#define IDC_RADIO_BITRATE               1030
-#define IDC_RADIO_QUALITY               1031
-#define IDC_CB_QUALITY                  1032
-#define IDC_E_ARTIST                    1034
-#define IDC_CHK_TAG                     1035
-#define IDC_E_TITLE                     1036
-#define IDC_E_ALBUM                     1037
-#define IDC_E_YEAR                      1038
-#define IDC_CB_GENRE                    1039
-#define IDC_E_WRITER                    1040
-#define IDC_E_COMMENT                   1041
-#define IDC_E_TRACK                     1042
-#define IDC_E_NTRACKS                   1043
-#define IDC_E_DISK                      1044
-#define IDC_E_NDISKS                    1045
-#define IDC_GRP_TAG                     1046
-#define IDC_E_COMPILATION               1047
-#define IDC_E_ARTFILE                   1048
-#define IDC_BTN_LICENSE                 1049
-#define IDC_CHK_COMPILATION             1050
-#define IDC_GRP_DEFAULT                 1051
-#define IDC_ID3                         1052
-#define IDC_L_BROWSE                    1054
-#define IDC_CHK_IMPORTTAG               1055
-#define IDC_E_SOURCEEXT                 1056
-#define IDC_E_SOURCEPATH                1057
-
-// Next default values for new objects
-// 
-#ifdef APSTUDIO_INVOKED
-#ifndef APSTUDIO_READONLY_SYMBOLS
-#define _APS_NEXT_RESOURCE_VALUE        111
-#define _APS_NEXT_COMMAND_VALUE         40001
-#define _APS_NEXT_CONTROL_VALUE         1057
-#define _APS_NEXT_SYMED_VALUE           101
-#endif
-#endif