function ListagemRelease(objDados, objPaginacao, strArquivoJson, objCriarListaDadosItem, objCriarPaginacao, objCriarDados) {

	// -- INI --- Funções externas utilizadas -----------------------
	//Função responsável por gerar a paginação, é opcional e a a propriedade '<JSON>.configuracao.intItensPorPagina ' não pode ser definida, nesse caso.
	//noticias.criarPaginacao = function(oConfig) {}
	
	//Cria o conteúdo que será exibido quando a opção da lista for escolhida. É opcional. Se for opcional a propriedade '<JSON>.configuracao.strPaginaLink' tem que ser configurada para utilizar o método mostrarDados(intIndex)
	//noticias.criarDados = function(oConfig, oDados) {}
	
	//Função responsável por gerar cada item da lista, é obrigatorio a sua definição
	//noticias.criarListaDadosItem = function(oConfig, oDados, intIndex) {}
	// -- FIM --- Funções externas utilizadas -----------------------
	
	var bolForcarAtualizacao = false; // utilizado para verificar se foi requisitado a atualização dos dados antes do request acabar de carregar o arquivo JSON
	var objJson = null; // objeto que contém os dados capturados do arquivo json
	// -- INI --- Configuração -----------------------
	this.configuracao = {
		'strTextoFiltro': null,		  //opcional, define o texto para fazer o filtro
		'intMes': 0,				  //opcional, o valor do mes -> 1: janeiro, 2: fevereiro, ... 12 -> dezembro
		'intAno': 0,				  //opcional o valor do ano -> 2008, 2009
		'intPaginaAtual' : 1,		  //opcional quando não for utilizado a paginação
		'intTotalDePaginas' : 0,	  //variavel interna, A classe define a quantidade de total de paginas que será mostrada
		'bolAtivarPaginacao' : false, //opcional, Se vai utilizar o sistema de paginação
		'intItensPorPagina' : 0,	  //opcional, quando não for utilizado a paginação é utilizada para exibir a quantidade de itens iniciais exibidos.
		'strPaginaLink' : null		  //Caso a função criarDados não for especificada, é obrigatório, ex. colocar como: imprensa_detalhes_[ID].aspx
	};
	// -- FIM --- Configuração -----------------------
	this.objDados = objDados; //Onde vai ser inserido o HTML referente aos dados ex.: a exibição do conteudo ou exibição da listagem
	this.objPaginacao = objPaginacao; // Onde vai ser inserido o HTML da paginação
	this.criarListaDadosItem = objCriarListaDadosItem; //externo, a função que contém a estrutura para criar o HTML de cada item na listagem dos dados
	this.criarPaginacao = objCriarPaginacao; //externo (opcional), a função que contém a estrutura para criar o HTML da paginação
	this.criarDados = objCriarDados; //externo (opcional), a função que contém a estrutura para criar o HTML para a exibição do item escolhido

	//---------------------------------------------------------------------------------------------------
	//Função que vai fazer o filtro e atualizar as informações que vão ser exibidas
	this.filtrar = function (strTextoFiltro, intMes, intAno) {
		if (strTextoFiltro != null)
			this.configuracao.strTextoFiltro = strTextoFiltro.toLowerCase();
		else
			this.configuracao.strTextoFiltro = null;

		this.configuracao.intMes = intMes;
		this.configuracao.intAno = intAno;

		this.configuracao.intPaginaAtual = 1; //seta para um toda vez que o filtro for atualizado
		this.configuracao.intTotalDePaginas=0; // zera o total para que a quantidade de paginação seja atualizada de acordo com o filtro
		this.atualizar();
	};

	//---------------------------------------------------------------------------------------------------
	//Função que altera a pagina e atualiza as informações que vão ser exibidas, mantendo o filtro já escolhido
	this.irPagina = function(intPagina) {
		this.configuracao.intPaginaAtual = intPagina;
		this.atualizar();
	};

	//---------------------------------------------------------------------------------------------------
	//Função responsável por atulizar as informações que vão ser exibidas
	this.atualizar = function () {
		//Caso solicitado a atualização dos dados, verifica se o request está sendo executado ainda.
		//Se estiver a variavel bolForcarAtualizacao fica true e depois a atualização é executada quando o request pegar os dados
		if (request.running) {
			bolForcarAtualizacao = true;
			return;
		}
		this.objDados.addClass('ajaxCarregando');
		if (objJson != null)
			this.objDados.innerHTML = this.criarListaDados(this.configuracao, objJson.secao.conteudo_arquivo_link);
		if (this.objPaginacao !=null && this.criarPaginacao != null)
			this.objPaginacao.innerHTML = this.criarPaginacao(this.configuracao);
		this.objDados.removeClass('ajaxCarregando');
	};
	
	//---------------------------------------------------------------------------------------------------
	//Função Interna, Que cria a listagem dos itens, essa função chama a função externa: criarListaDadosItem, que deve ser definida fora da classe
	this.criarListaDados = function(oConfig, oDados) {
		var strHtml = '';

		if (oDados == null)
			return strHtml;

		var intInicio = oConfig.intPaginaAtual-1; //Qual o indice do primeiro item que vai ser exibido
		var intFim = oDados.length; //Qual o indice do ultimo item que vai ser exibido
		// Caso for definido a quantidade de itens por pagina, não leva em consideração o filtro
		if (oConfig.intItensPorPagina > 0) {
			intInicio = ((oConfig.intPaginaAtual-1) * oConfig.intItensPorPagina );
			intFim = ((oConfig.intPaginaAtual) * oConfig.intItensPorPagina );
			if (intFim > oDados.length)
				intFim = oDados.length;
		}
		
		var intQtdItem = 0; // Quantidade de itens selecionados, pelo filtro, necessario para ajustar a paginação
		for (i = 0; i < oDados.length; i++) {
			dtDAtaPublicacao = new Date();
			intMes = oDados[i].DATA_INCLUSAO.substr(oDados[i].DATA_INCLUSAO.indexOf('/')+1, 2)-1; //pega o mes da data
			if (isNaN(intMes))
				intMes = oDados[i].data.substr(oDados[i].data.indexOf('/')+1, 1)-1; //pega o mes da data, sempre -1 pq inicia no zero

			intAno = oDados[i].DATA_INCLUSAO.substr(oDados[i].DATA_INCLUSAO.lastIndexOf('/')+1, 4); //pega o ano da data
			dtDAtaPublicacao.setFullYear(intAno, intMes, 1);
			//Verificar se os dados batem com o solicitado
		if  (
			(	oDados[i].arquivo != null && oDados[i].arquivo != 'null' &&
				oDados[i].titulo != null && oDados[i].titulo != 'null'
			) && (
				( oConfig.strTextoFiltro != null && oConfig.strTextoFiltro.length > 0 &&
					(
					(oDados[i].arquivo.toLowerCase().indexOf(oConfig.strTextoFiltro) >= 0) ||
					(oDados[i].titulo.toLowerCase().indexOf(oConfig.strTextoFiltro) >= 0)
					)
				) || (oConfig.strTextoFiltro == null || oConfig.strTextoFiltro.length == 0)
			) && (
				(oConfig.intAno != null && oConfig.intAno > 0 && dtDAtaPublicacao.getFullYear() == oConfig.intAno) ||
				(oConfig.intAno == null || oConfig.intAno == 0)
			) && (
				(oConfig.intMes != null && oConfig.intMes > 0 && dtDAtaPublicacao.getMonth() == (oConfig.intMes-1)) ||
				(oConfig.intMes == null || oConfig.intMes == 0)
			)
			) {
					if (this.criarListaDadosItem == null) {// Avisa que não foi possivel encontrar a função para gerar o item
						alert('Fun\347\343o this.criarListaDadosItem não definida.');
						return;
					}
					intQtdItem++; // Quantidade de itens pego pelo filtro
					if (i >= intInicio && i < intFim) { // Se o item estiver nessa faixa ele mostra o conteudo
						strHtml = strHtml + this.criarListaDadosItem(oConfig, oDados[i], i);
					}
			}
			else {
				// Caso  o item não pega pelo filtro, altera os seguintes valores, para mostrar os itens certos
				intFim++; // Adiciona mais um no final para procurar mais um item
				intInicio++; //Adiciona mais um no inicio para evitar a repetição de itens já exibidos antes da pagina atual
				if (intFim > oDados.length)
					intFim = oDados.length;
			}
		}
			//Calcular a quantidade de paginas para a paginacao, caso for solicitado a paginação
			if (oConfig.bolAtivarPaginacao == true && oConfig.intItensPorPagina != null && oConfig.intItensPorPagina > 0 && oConfig.intTotalDePaginas == 0)
				oConfig.intTotalDePaginas = Math.ceil( intQtdItem / oConfig.intItensPorPagina);

		return strHtml;
	};
	//---------------------------------------------------------------------------------------------------
/*	//Função responsável por mostrar as informações que são referentes ao item escolhido
	this.mostrarDados = function(intIndex) {
		if (this.criarDados != null) {
			objDados.innerHTML = this.criarDados(this.configuracao, objJson.secao.conteudo_arquivo_link[intIndex]);
			if (objPaginacao != null)
				objPaginacao.innerHTML = "";
		} else { //Abrir link para o arquivo
			document.location.href = this.configuracao.strPaginaLink.replace('[ID]', objJson.secao.conteudo_arquivo_link[intIndex].OBJ_ID);
		}
	};
*/
	//---------------------------------------------------------------------------------------------------
	//Codigo executado quando o objeto for criado
	var me = this; // utilizado para ter referencia sobre o objeto atual
	//Requisita o arquivo no formato JSON
	var request = new Request({
		url: strArquivoJson,
		method: 'get',
		encoding: 'utf-8',
		autoCancel: true,
		onSuccess: function(jsonObj, txt) {
			objJson = JSON.decode(jsonObj);
			if (bolForcarAtualizacao) { //Se for feita uma tentativa de atualização, antes do arquivo ser carregado, atualiza agora
				me.atualizar();
			}
			me.objDados.removeClass('ajaxCarregando');
		},
		onFailure: function(instance) {
			if (instance.status == 406)
				alert('Erro de configura\347\343o no servidor para arquivos JSONs.\n' + 'Erro n\260: ' + instance.status + ".\nMensagem: " + instance.statusText + ".");
			else if (instance.status == 404)
				alert('N\343o foi poss\355vel localizar um dos arquivos.');
			else
				alert('Erro de comunica\347\343o com o servidor.\n' + 'Erro n\260: ' + instance.status + ".\nMensagem: " + instance.statusText + ".");
			me.objDados.removeClass('ajaxCarregando');
		}
	}).send();
}
