Sumario Este artigo descreve a execução de programa em modo DEBUGGER, descrevendo os passos necessários para encontrar valores de variáveis, tabelas, estruturas. Sobre o Autor: Uderson Luis Fermino, formado em Ciências da Computação pela Faculdade de Pesquisa e Ensino IPEP, atua no mercado a 2 anos como desenvolvedor Java nas plataformas: (J2SE, J2EE e J2ME), com participação em grandes projetos envolvendo estas tecnologias. É consultor ABAP com experiências em REPORT, ALV (GRID, LIST, BLOCK, OO, TREE, HIERARQUICK), IDOC, ALE, ONLINE, SAPSCRIPT, SMARTFORM, NETWEAVER (JCO, BSP, WebDynpro). Email: Uderson@gmail.com
DEBUGGER ABAP Debug é o ato de corrigir erros,dentro de um determinado artefato, onde este artefato pode ser um simples ou complexo programa. O Debug é usado para verificar e visualizar instruções códigos-a-codigo. O abap é uma linguagem puramente interpretada, todos os módulos da linguagem são interpretados, onde é a principal ferramenta de trabalho aos programadores abap, está tarefa de codificação facilita a customização do sistema em tempo real. Para chamar o debugger do SAP (R/3) basta inserir o /h como uma transação. Verifica a barra de status. A partir deste momento o mode debugger do SAP está em funcionamento, em qualquer transação, que estivermos, poderemos visualizar código-a-codigo, o que o compilador, ABAP está interpretando. Iremos DEBUGAR a partir do código abaixo: Entre na transação SE38 crie um programa executável de aplicação desconhecida. De o Nome de ZFUNCIONARIO e siga o exemplo da figura:
Copie este código para dentro do EDITOR *&---------------------------------------------------------------------* *& Report ZFUNCIONARIO * *& * *&---------------------------------------------------------------------* *& * *& * *&---------------------------------------------------------------------* REPORT ZFUNCIONARIO. TABLES: ZFUNCIONARIO. BREAK-POINT. DATA: BEGIN OF T_ZFUNCIONARIO OCCURS 0, MATRICULA LIKE ZFUNCIONARIO-MATRICULA, NOME LIKE ZFUNCIONARIO-NOME, DATANASCIMENTO LIKE ZFUNCIONARIO-DATANASCIMENTO, RG LIKE ZFUNCIONARIO-RG, CPF LIKE ZFUNCIONARIO-CPF, END OF T_ZFUNCIONARIO. SELECTION-SCREEN BEGIN OF BLOCK bl001 WITH FRAME. PARAMETER: P_MATRI LIKE ZFUNCIONARIO-MATRICULA OBLIGATORY. PARAMETER: P_NOME LIKE ZFUNCIONARIO-NOME OBLIGATORY. PARAMETER: P_DATNA LIKE ZFUNCIONARIO-DATANASCIMENTO OBLIGATORY. PARAMETER: P_RG LIKE ZFUNCIONARIO-RG OBLIGATORY. PARAMETER: P_CPF LIKE ZFUNCIONARIO-CPF OBLIGATORY. SELECTION-SCREEN END OF BLOCK bl001. T_ZFUNCIONARIO-MATRICULA = P_MATRI. T_ZFUNCIONARIO-NOME = P_NOME. T_ZFUNCIONARIO-DATANASCIMENTO = P_DATNA. T_ZFUNCIONARIO-RG = P_RG.
T_ZFUNCIONARIO-CPF APPEND T_ZFUNCIONARIO. = P_CPF. MOVE: T_ZFUNCIONARIO-MATRICULA TO ZFUNCIONARIO-MATRICULA, T_ZFUNCIONARIO-NOME TO ZFUNCIONARIO-NOME, T_ZFUNCIONARIO-DATANASCIMENTO TO ZFUNCIONARIO-DATANASCIMENTO, T_ZFUNCIONARIO-RG TO ZFUNCIONARIO-RG, T_ZFUNCIONARIO-CPF TO ZFUNCIONARIO-CPF. INSERT ZFUNCIONARIO. IF SY-SUBRC = '0'. COMMIT WORK. MESSAGE I368(00) WITH 'DADOS SALVOS COM SUCESSO'. ELSE. ROLLBACK WORK. MESSAGE I368(00) WITH 'ERRO AO SALVAR DADOS'. ENDIF. CLEAR: T_ZFUNCIONARIO, T_ZFUNCIONARIO[]. SELECT MATRICULA NOME DATANASCIMENTO RG CPF FROM ZFUNCIONARIO INTO TABLE T_ZFUNCIONARIO. LOOP AT T_ZFUNCIONARIO. WRITE: / ' ', T_ZFUNCIONARIO-MATRICULA, ' ', T_ZFUNCIONARIO-NOME, ' ', T_ZFUNCIONARIO-DATANASCIMENTO, ' ', T_ZFUNCIONARIO-RG, ' ', T_ZFUNCIONARIO-CPF, ' '. ULINE. ENDLOOP. Após ter copiado o código, clique em DIRETO ou F8. (Lembre-se de SALVAR, CHECAR e ATIVAR). Logo em seguida aparecera a seguinte tela:
Preencha os campos conforme a figura a baixo ou a tabela Matricula 123456789 Nome Teste de Debug Data de Nascimento 17.05.2007 Rg 2233445 CPF 21177889900654534322 Após ter preenchido, insira o código /N, na caixa de transações: Verifica a barra de status. Clique em executar, e siga passo a passo este HowTo.
Observe, que tem um ponteiro no primeiro código do programa, e o editor encontre-se em modo não editavel. Passo 2: Tecle uma vez F5, observe que o ponteiro irá para o comando BREAK-POINT, este comando é usado, para parar uma determinada instrução e mostrar está em modo debug,
Observe que o comando não parou na linha TABLES: ZFUNCIONARIO, pois esta é uma instrução interna do abap. Tecle F5 e observe que o ponteiro irá direto para o comando de atribuição: T_ZFUNCIONARIO-MATRICULA = P_MATRI. Observe que no modo Debug a seguinte tela: Nesta tela que poderemos EXIBIR e MODIFICAR valores das variáveis em tempo de execução do programa, Lembre-se estamos em modo debug onde cada comando segue passo a passo o que pedimos. Antes de prosseguir clique sobre os objetos: P_MATRI, P_NOME, P_DATNAS, como segue a figura.
Observe que os valores destes objetos podem ser visualizados na tela: Para limpar os campos de visualização clique na lixeira, é CAMPO será limpa, a limpeza não é feita no objeto e sim no campo de visualização, logo a frente, será mostrado como limpara ou alterar o valor do objeto. Fincado:
Observer que o ponteiro está apontado ainda para o objeto T_ZFUNCIONARIO-MATRICULA valor 0000000000123456789. = P_MATRI., onde P_MATRI contem o Clique sobre o objeto T_ZFUNCIONARIO-MATRICULA e observe que o valor de P_MATR, ainda não foi atribuído ao objeto T_ZFUNCIONARIO-MATRICULA. Tecle F5, e observe que agora o objeto T_ZFUNCIONARIO-MATRICULA contem o mesmo valor de P_MATRI. Para treinar, faça os mesmos passos, para os objetos : T_ZFUNCIONARIO-NOME = P_NOME. T_ZFUNCIONARIO-DATANASCIMENTO = P_DATNA. T_ZFUNCIONARIO-RG = P_RG. T_ZFUNCIONARIO-CPF = P_CPF.
Siga os passos até que o ponteiro fique apontado sobre o comando: APPEND T_ZFUNCIONARIO. Antes de prosseguir limpe todos os campos: Ainda com o ponteiro, apontado ao comando APPEND, clique duas vezes sobre a tabela interna T_ZFUNCIONARIO. Observe que no campo de exibição e modificação de variáveis e objetos apareceu a linha. Para ver os valores da tabela clique sobre o ícone:
Observe que os campos de exibição e modificação mudaram: Pois agora estamos em estrutura multidimensional, cujo o formato é uma estrutua de tabela, onde cada campo contem um determinado tamanho de armazenamento de dado. O ABAP trata todas as tabelas tanto tabelas internas como tabelas reais(chamadas de tabelas standard ou tabelas Z) iguais, onde todas as tabelas contem uma HEADER LINE. HEADER LINE Toda tabela manipulada, dentro do sap é criada uma HeaderLine, que é um vetor de dado do tipo de uma tupla,de uma determinada tabela, a Header Line é uma copia dos dados do registro em que o ponteiro, está posicionado no momento, uma header line pode ser visualizada claramente dentro de um loop HeaderLine da TabelaX Matnr Datnam Nome Descrição 00001 10.10.2000 Cana de Açúcar Matéria Prima LOOP AT TabelaX Matnr Datnam Nome Descrição 00001 10.10.2000 Cana de Açúcar Matéria Prima 00002 14.12.2006 Álcool Matéria Prima 00003 20.25.2000 Gasolina Matéria Prima
ENDLOOP 00004 11.09.1997 Óleo Diesel Matéria Prima 00005 13.08.2005 BioDiesel Matéria Prima HeaderLine da TabelaX Matnr Datnam Nome Descrição 00002 14.12.2006 Álcool Matéria Prima LOOP AT TabelaX ENDLOOP Matnr Datnam Nome Descrição 00001 10.10.2000 Cana de Açúcar Matéria Prima 00002 14.12.2006 Álcool Matéria Prima 00003 20.25.2000 Gasolina Matéria Prima 00004 11.09.1997 Óleo Diesel Matéria Prima 00005 13.08.2005 BioDiesel Matéria Prima HeaderLine da TabelaX Matnr Datnam Nome Descrição 00003 20.25.2000 Gasolina Matéria Prima LOOP AT TabelaX ENDLOOP Matnr Datnam Nome Descrição 00001 10.10.2000 Cana de Açúcar Matéria Prima 00002 14.12.2006 Álcool Matéria Prima 00003 20.25.2000 Gasolina Matéria Prima 00004 11.09.1997 Óleo Diesel Matéria Prima 00005 13.08.2005 BioDiesel Matéria Prima Observação: LOOP AT O Comando LOOP AT... ENDLOOP. Serve para andar em cada registro de uma tabela interna, podendo alterar, excluir, incluir dados nos campos deste registro, atual, o exemplo acima mostra o LOOP AT, em uma tabela interna, chamada de TabelaX, Cada iteração em um registro, a HeaderLine é modificado para a posição atual, do LOOP AT, a variável SY-TABIX, é a variável, que armazena o numero atual da iteração. O ícone chapéu é a indicação da tabela
Somente os dados estarão dentro da tabela interna T_ZFUNCIONARIO quando o comando APPEND for passado. Tecle F5 Veja que a tabela agora conte registros; A HEADERLINE esta com o valor e a tabela interna também.
Agora a tabela interna conte valores, neste caso apenas um registro, porem mais a frente a tabela interna terá mais de um registro. valor, O ponteiro está apontado sobre o comando MOVE, onde está movendo cada Diretamente a HeaderLine da Tabela ZFUNCIONARIO. Antes de prosseguir clique duas vezes sobre a tabela real ZFUNCIONARO. Veja que novamente mudou os campos de EXIBIÇÃO E MODIFICAÇÃO:
Observe que cada vez que o ponteiro mover dentro do comando Move será adcionado um valor dentro do campo selecionado da figura. Observe que determinados comandos não é possível verificar seu dados internos. Tecle F5, até apontar no comando: CLEAR: T_ZFUNCIONARIO, T_ZFUNCIONARIO[].
O comando clear como o próprio nome diz, serve para limpar campos de variáveis, tabelas internas e headerline, a Sintaxe é: CLEAR: TABELA_INTERNA CLEAR: TABELA_INTERNA[] = Limpa a Header Line de uma tabela Interna = Limpa a tabela interna sem limpar a Header Line Antes de prosseguir clique duas vezes sobre a tabela interna T_ZFUNCIONARIO. Observe que podemos ver os valores da HeaderLine e da Tabela Interna, tecle F5 para prosseguir o ponteiro, e observe que os valores foram excluídos da HeaderLine e da Tabela:
Estes valores com 0 (Zeros), são valores Default que os tipos de dados primitivos possuem. O ponteiro agora está sobre o comando select, onde será inserido valores na tabela interna T_ZFUNCIONARIO novamente. Antes de prossegui com o ponteiro clique duas vezes da tabela interna que está dentro do select: Observe que a tabela interna e a sua HeaderLine, não contem valores.
Tecle F5. Observe que agora a tabela interna contem diverso registros, pois todos os registros que estava na tabela real ZFUNCIONARIO, foi passado para está tabela. está. Agora muita atenção pois a parte mais cautelosa deste HowTo com certeza é Mova a tela para baixo, conforme indicado pela cor VERMELHA, até que a visualização do código fique idêntico a figura, observe que o ponteiro está apontando o comando LOOP é no fim da tela temos a finalização do comando LOOP com a instrução ENDLOOP.
Observe que a HeaderLine está vazia, mais a cada iteração um determinado registro será colocado na HeaderLine, o ponteiro de registro é interno da tabela não conseguimos visualizar ele, somente visualizamos o registro atual na HeaderLine. Tecle F5 para prosseguir e observe a HeaderLine.
Observe que a HeaderLine contem o mesmo valor do registro 1, pois é a primeira iteração, o comando write, escreve os valores da HeaderLine, A variável de controle de iteração é SY-TABIX. Tecle F5 até que o ponteiro aponte a instrução ENDLOOP, como é uma iteração o ponteiro apontará ao prosseguir, teclando F5 para o comando LOOP AT tabela_interna, internamente ele verifica será mais registros, caso contem registro ele entra dentro do loop, e assim por diante observer que sempre a HeaderLine armazena os valores do registro atual, A assim até o fim dos ultimo registro, quando não ter mais registro o ponteiro apontara para o próximo comando, caso exista mais comando depois do comando LOOP...ENDLOOP. Estes são os passos básicos do MODO DEBBUGER da linguagem ABAP, mais passos a seguir, porem serão apenas descritos a segui, sem exemplificação de seu usos. Mudar valor da variável, objetos, antes de inserir ou antes de escrever, ou antes de executar a instrução que fará a leitura deste dado: use o lápis, basta modificar o valor no campo de inserção de dado e clicar no lápis que o valor será alterado, use antes de alguma instrução usar o valor atual, pois se o valor for modificado após alguma instrução ter utilizado o valor, não fará sentido alterar o mesmo.
Watchpoint: Utilizado dentro de uma estrutura de iteração (LOOP, DO, WHILE), para fazer a parada em um determinado valor, é necessário especificar o campo ou (variavel), o valor de parada e o operador lógico que usará: Exemplo: Clique duas vezes sobre o campo da tabela interna, conforme a figura: Clique em Watchpoint
Onde Programa Nome do campo = nome do programa = Nome do campo da tabela ou variável Operador relacional =Operador lógico de condição, clique sobre o MATCHCONDE date e abrirá um lista. De dois clique sobre o campo escolhido.
Campo ou valor de comparação = o valor que o campo escolhido deverá possui para fazer a parada (lembrando do operador relacional escolhido)