Linkedin

Total de visualizações de página

Mostrando postagens com marcador advpl. Mostrar todas as postagens
Mostrando postagens com marcador advpl. Mostrar todas as postagens

quinta-feira, 15 de março de 2018

Como analisar error.log protheus



  • Informações de Build;
  • Nome do usuário e do computador onde ocorreu o erro;
  • Data e Hora da geração do erro;
  • Tipo do erro;
  • Função onde aconteceu o erro;
  • Nome do Fonte onde está localizada a função que gerou o erro;
  • Data e Hora de compilação do fonte;
  • Linha do fonte onde ocorreu o erro.

Bloco 02: Informações AppServer:
  • Informações de Build;
  • Plataforma do AppServer;
  • Nome do Ambiente;
  • Número da transação do AppServer (thread);
  • Número de transação do Banco de dados (dbthread);
  • Tipo de Banco de Dados utilizado;
  • Tipo dos Local Files;
  • Código da Empresa/Filia
  • Usuário logado;
  • Nome do Módulo.
  • Objeto a qual pertence a função que está gerando o erro.
Bloco 03: Pilha de Chamada das Funções:
  • Nome da Função;
  • Nome do Fonte;
  • Data e Hora compilação;
  • Linha de execução do fonte.
Bloco 04: Variáveis em uso pelas Funções da Pilha de Chamada:
  • Parâmetros dos objetos;
  • Variáveis Públicas;
  • Variáveis Locais;
  • Variáveis Privates.
Bloco 05: Arquivos em Uso – Local Files e Tabelas:
  • Nome do Arquivo;
  • Tipo do RDD (Replaceable Database Driver);
  • Alias;
  • Filtro do Arquivo;
  • Número do Registro (Recno);
  • Total de Registros;
  • Ordem do Arquivo (Índice selecionado);
  • Campos dos registros posicionados;
  • Dados dos Registros informados.
Apenas a geração de um único error.log, pode-se gerar milhares de linhas, isto porque, o Protheus trás o maior número de informações possíveis para análise.
Para cada função executada, o Protheus trás as respectivas variáveis em uso por função, além de trazer todos os Local Files, Tabelas e seus respectivos registros em uso, no momento em que é gerada a exceção de erro. Por isso, é gerada tantas linhas no arquivo de log.
A primeira vez que temos que analisar o error.log do Protheus, podemos ficar um pouco “assustado”, devido à enorme quantidade de informações geradas. Porém com o tempo, e sabendo “ler” o arquivo de erro.log corretamente, logo nos acostumamos.
Nas imagens abaixo, fazemos uma alusão da separação das informações do log por “Blocos”, conforme descrito acima:
Bloco 01 – Informações Gerais
Bloco 01 error.log - Smart SigaImagem 01 – Bloco 01 error.log – Smart Siga

Bloco 02 – Informações AppServer
Bloco 02 error.log - Smart SigaImagem 02 – Bloco 02 error.log – Smart Siga

Bloco 03 – Pilha de Chamada das Funções
Bloco 03 error.log - Smart SigaImagem 03 – Bloco 03 error.log – Smart Siga

Bloco 04 – Variáveis em uso pelas Funções da Pilha de Chamada
Bloco 04 error.log - Smart SigaImagem 04 – Bloco 02 error.log – Smart Siga

Bloco 05 – Arquivos em Uso – Local Files e Tabelas
Bloco 05 error.log - Smart SigaImagem 05 – Bloco 05 error.log – Smart Siga
No nosso exemplo, foi executada a função MATR260 (Relatório de Estoque Analítico), a qual chamou a função REPORTPRINT, que está comparando variáveis de tipos diferentes, gerando o error.log de “type mismatch on compare”.
Analisando as imagens, podemos verificar que o erro foi na linha 259, do fonte MATR260, conforme descrito no Bloco 01.
Depois, no Bloco 02, temos as informações referentes a Build, e as configurações do AppSever.
No Bloco 03 temos a Pilha de Chamadas de funções, a partir da função REPORTPRINT.
No Bloco 04, temos todas as variáveis em uso, separadas por função, da Pilha de Execução.
E para finalizar, no Bloco 05, temos todos os Local Files, Tabelas, e seus receptivos registros, os quais a função MATR260 estava posicionado e/ou em uso, no momento que ocorre o erro.
Esse tipo de erro “type mismatch on compare”, poderia ter sido, causado por um registro e/ou parâmetro cadastrado de forma errado, por exemplo, o qual deveria ser do tipo “numérico” e estava cadastrado com o tipo “string”.
Abaixo, listamos os erros mais comuns gerados no Protheus:
Array out of Bounds
Esse tipo de erro, ocorre quando a função tenta acessar diretamente um elemento de uma variável do tipo Array, e tal elemento não existe.
Array Index out of Bounds
Similar ao erro “Array out of Bounds”, tal exceção é gerada quando tentamos acessar uma posição de uma variável do tipo Array, que não existe.
Alias Already in Use
Esse erro ocorre, quando a função tenta abrir uma Tabela ou uma Query, que já está em uso na thread atual.
Alias Does Not Exist
Quando a função faz referência a uma Alias, e esse Alias não está “aberto” no momento da chamada, é retornado tal erro.
Argument X Error, Expected Z->Y, Function XPTO
Quando a função espera um parâmetro por exemplo do tipo “string” e é passado um parâmetro do tipo “numérico”, tal exceção de erro é gerada.
Type Mismatch on Compare On XPTO
Esse erro ocorre, quando a função tenta comparar, por exemplo, uma variável do tipo “string” com uma variável do tipo “numérica”, isto é, quando se tenta comprar variáveis com tipos de dados (escopos) diferentes.
Cannot Insert Duplicate Key
Essa exceção de erro, ocorre quando se tenta, incluir um registro “duplicado”, isto é, quando a função tenta incluir um registro exatamente igual, a outro registro já existente no Banco de Dados.

sexta-feira, 2 de março de 2018

rodapé MV_LJFISMS

MV_LJFISMS , neste parâmetro é possível customizar o rodapé incluindo informações. Segue abaixo um exemplo do preenchimento do parâmetro:

Segue abaixo uma dica de como usar o parâmetro MV_LJFISMS sem criar um rdmake a ser compilado.

&("Filial: "+SL1->L1_FILIAL+CHR(10)+SA3->A3_COD+" - "+SA3->A3_NOME+CHR(10)+SA6->A6_COD+" - "+SA6->A6_NOME+CHR(10)+PADC("Obrigado! Volte Sempre!",40))

No código acima é impresso no rodapé do cupom fiscal:
Filial: (código da filial)
Código do Vendedor – Nome Vendedor
Código do Caixa – Nome do Caixa
Obrigado! Volte Sempre!

quinta-feira, 1 de março de 2018

MV_LJALTAP - Características do Parâmetro


Linha de Produto:
Microsiga Protheus
Segmento:
Varejo
Módulos:
SIGALOJA
Definição 
Parâmetro que permite a alteração do aPgtos após escolha da condição de pagamento na finalização da venda.

Procedimento para Configuração

No Configurador (SIGACFG), acesse Ambientes/Cadastros/Parâmetros (CFGX017). Crie/configure o parâmetro a seguir:

Nome da Variável
MV_LJALTAP
Tipo
Lógico 
Descrição
Permite a alteração do aPgtos após escolha da condição de pagamento na finalização da venda.;
Quando estiver como .F. o aPgtos estará bloqueado.
Valor Padrão
.F.

terça-feira, 1 de agosto de 2017

StrZero

Ir para o final dos metadados
Ir para o início dos metadados


A partir de um numérico esta função retorna uma string formatada, inserindo zeros à esquerda e/ou o símbolo decimal (".") em suas casas, de acordo com as informações do parâmetro.
Sintaxe
StrZero( < nValor >, < nTamanho >, [ nDecimal ] )
Parâmetros
Nome
Tipo
Descrição
Obrigatório
Referência
nValor
numérico
Indica o valor numérico que será convertido para string.
X

nTamanho
numérico
Indica o tamanho da string será gerada.
X

nDecimal
numérico
Indica o número de casas após o símbolo decimal.


Retorno
Nome
Tipo
Descrição
cRet
caractere
Retorna uma string a partir do valor numérico e do tamanho informado no parâmetro.


Observações


Observe que <nTamanho> indica o número de caracteres que serão utilizados para representar o valor passado através de <nValor>.


Sempre que o número de caracteres passados em <nTamanho> não for suficiente para representar <nValor> juntamente de seu símbolo e casas decimais, a função retornará um conjunto de caracteres ("*") com o <nTamanho> definido.


Exemplos
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
#DEFINE CRLF Chr(13)+Chr(10)
User Function Exemplo()
  Local cMensagem := ""
  //+----------------------------------------------------------------------------+
  //|Exemplifica o uso da função StrZero                                         |
  //+----------------------------------------------------------------------------+
  cMensagem += "StrZero(98765432.1, 1, 8) = "  + StrZero(98765432.1, 1, 8)  + CRLF
  cMensagem += "StrZero(9876543.21)       = "  + StrZero(9876543.21)        + CRLF
  cMensagem += "StrZero(987654.321, 3, 6) = "  + StrZero(987654.321, 3, 6)  + CRLF
  cMensagem += "StrZero(98765.4321) = "        + StrZero(98765.4321)        + CRLF
  cMensagem += "StrZero(9876.54321, 5, 4) = "  + StrZero(9876.54321, 5, 4)  + CRLF
  cMensagem += "StrZero(987.654321, 6 ,3) = "  + StrZero(987.654321, 6, 3)  + CRLF
  cMensagem += "StrZero(98.7654321, 7, 2) = "  + StrZero(98.7654321, 7, 2)  + CRLF
  cMensagem += "StrZero(9.87654321, 8, 1) = "  + StrZero(9.87654321, 8, 1)  + CRLF
  cMensagem += "StrZero(0) = "                 + StrZero(0)                 + CRLF
  cMensagem += "StrZero(-9.87654321, 5, 2) = " + StrZero(-9.87654321, 5, 2) + CRLF
  cMensagem += "StrZero(-98.7654321, 4, 1) = " + StrZero(-98.7654321, 4, 1) + CRLF
  cMensagem += "StrZero(-987.654321) = "       + StrZero(-987.654321)       + CRLF
  cMensagem += "StrZero(-9876.54321, 2, 6) = " + StrZero(-9876.54321, 2, 6) + CRLF
  cMensagem += "StrZero(-98765.4321, 1, 5) = " + StrZero(-98765.4321, 1, 5) + CRLF
  cMensagem += "StrZero(-987654.321, 0, 0) = " + StrZero(-987654.321, 0, 0) + CRLF
  cMensagem += "StrZero(-9876543.21, 5, 1) = " + StrZero(-9876543.21, 5, 1) + CRLF
  cMensagem += "StrZero(-98765432.1, 4, 2) = " + StrZero(-98765432.1, 4, 2) + CRLF
  //+----------------------------------------------------------------------------+
  //|Apresenta uma mensagem com os resultados obtidos                            |
  //+----------------------------------------------------------------------------+
Return MsgInfo(cMensagem, "Exemplo do StrZero")

Preview