function emailCheck (emailStr) {
	var checkTLD=1;
	
	//Domínios conhecidos retirados da FAPESP - www.fapesp.org
	var knownDomsPat=/^(com|net|org|edu|int|mil|gov|arpa|biz|aero|name|coop|info|pro|museum|jus|can|adm|adv|arq|art|bio|tv|cnt|bio|ecn|eng|esp|etc|eti|far|fot|fst|g12|ind|inf|jor|lel|med|nom|odo|ppg|pro|psc|psi|rec|srv|tmp|tur|vet|zlg)$/;
	var emailPat=/^(.+)@(.+)$/;
	var specialChars="\\(\\)><@,;:\\\\\\\"\\.\\[\\]";
	var validChars="\[^\\s" + specialChars + "\]";
	var quotedUser="(\"[^\"]*\")";
	var ipDomainPat=/^\[(\d{1,3})\.(\d{1,3})\.(\d{1,3})\.(\d{1,3})\]$/;
	var atom=validChars + '+';
	var word="(" + atom + "|" + quotedUser + ")";
	var userPat=new RegExp("^" + word + "(\\." + word + ")*$");
	var domainPat=new RegExp("^" + atom + "(\\." + atom +")*$");
	var matchArray=emailStr.match(emailPat);
	var matchWWW=emailStr.match("www.");
	
	if (matchWWW!=null) {
		alert("O endereço de e-mail está com formato incorreto. A sequência 'www.' é desnecessária.");
		return false;
	}
	
	if (matchArray==null) {
		alert("O endereço de e-mail está em formato não reconhecido.");
		return false;
	}
	
	var user=matchArray[1];
	var domain=matchArray[2];
	
	for (i=0; i<user.length; i++) {
		if (user.charCodeAt(i)>127) {
			alert("O nome de usuário do campo e-mail contém um caracter inválido.");
			return false;
	   }
	}
	
	for (i=0; i<domain.length; i++) {
		if (domain.charCodeAt(i)>127) {
			alert("O nome do domínio no campo e-mail contém um caracter inválido.");
			return false;
	   }
	}
	
	if (user.match(userPat)==null) {
		alert("O nome de usuário do campo e-mail é inválido.");
		return false;
	}
	
	/* if the e-mail address is at an IP address (as opposed to a symbolic
	host name) make sure the IP address is valid. */
	var IPArray=domain.match(ipDomainPat);
	if (IPArray!=null) {
		// this is an IP address	
		for (var i=1;i<=4;i++) {
			if (IPArray[i]>255) {
				alert("O endereço IP de destino no e-mail é inválido!");
				return false;
		  	}
		}
		return true;
	}
	
	// Domain is symbolic name.  Check if it's valid. 
	var atomPat=new RegExp("^" + atom + "$");
	var domArr=domain.split(".");
	var len=domArr.length;
	
	for (i=0;i<len;i++) {
		if (domArr[i].search(atomPat)==-1) {
			alert("O nome do domínio no e-mail está incorreto.");
			return false;
	   	}
	}
	
	/* domain name seems valid, but now make sure that it ends in a
	known top-level domain (like com, edu, gov) or a two-letter word,
	representing country (uk, nl), and that there's a hostname preceding 
	the domain or country. */
	if (checkTLD && domArr[domArr.length-1].length!=2 && domArr[domArr.length-1].search(knownDomsPat)==-1) {
		alert("O endereço de e-mail deve ser finalizado por um domínio ou duas letras representando um país.");
		return false;
	}
	
	// Make sure there's a host name preceding the domain.
	if (len<2) {
		alert("Está faltando o nome da máquina de destino no endreço de e-mail.");
		return false;
	}
	
	// If we've gotten this far, everything's valid!
	return true;
}
