✒️ABAP Los Field Exits
ABAP Los Field Exits
Field Exits: También llamados ampliaciones de campo, son validaciones de los elementos de datos asociados a campos de pantallas o dynpros de SAP.
Los Field Exits son módulos de funciones que son llamados y ejecutados posteriormente de las validaciones del sistema estándar.
Los mismos por ser módulos de funciones, se ejecutan en instancias de memoria propias y al momento de su ejecución, sólo se dispone del valor del campo, que se importa en el parámetro INPUT y que puede ser modificado a través del parámetro OUTPUT. Para el uso de otros campos de la pantalla, se debe proceder al uso de funciones que permiten capturar dichos valores.
Un ejemplo en donde utilizaríamos un Field Exit es si se quiere insertar un valor en un campo determinado de una dynpro entonces pondríamos una validación en ese campo a nivel Field Exit para que solo permita insertar determinados valores.
Si ingresamos a la transacción SE37 (Biblioteca de Funciones), colocamos FIELD_EXIT_* y luego pulsamos F4, visualizaremos todos los Field Exit del sistema.
Las principales ventajas que presenta un Field Exit son:
Facilita la validación de campos en un programa estándar sin modificar el código original.
Puede utilizarse el mismo código para varias transacciones.
Se puede aplicar globalmente (para todos los programas) o para determinados programas y dynpros que se le asignen.
Las principales desventajas que presenta un Field Exit son:
Toma de la dynpro (Import) un solo valor, que es el del campo al cual hace referencia, por lo que no se pueden utilizar tablas internas específicas del programa estándar en el código del Field Exit.
El mismo código del Field Exit tiene que servir para todos los programas que se quieran utilizar, por lo que se tiene que especificar en el código que acción tomará de acuerdo al programa en el cual se esté ejecutando.
No es posible hacer un Debug del código del Field Exit de forma directa, a través de un Breakpoint. Para esto se utilizan mensajes de error para ir viendo que valores van tomando los diferentes objetos (variables, tablas, etc.) y por donde va pasando dentro del código del Field Exit.
AUDIO ACLARATIVO: En un Field Exit no podemos usar ninguna de las siguientes instrucciones: BreakPoint, Call Screen, Call Dialog, Call Transaction, Submit, Commit Work, RollBack Work y Message I correspondiente a los mensajes de información. Una nota importante que debemos tener en cuenta es que para poder activarlos Field Exit debemos tener el parámetro ABAP Field Exit = YES seteado en el servidor. El cual se configura a través de la transacción estándar: RZ10.
2 | Los pasos para la realizar un Field Exit
El primer paso para realizar un Field Exit es dirigirnos a la transacción CMOD (Gestión de proyectos de ampliaciones SAP).
Allí ejecutamos el comando PRFB dentro de la CMOD, sin anteponer /N.
En la pantalla siguiente se encuentran todos los Field Exits del sistema. Aquí podemos ver también si están activados a nivel Global (para todas las transacciones) o tienen algún programa y dynpro asignados.
Para crear un Field Exit, seleccionamos el menú Exit campo y la opción Crear.
En la siguiente ventana de diálogo introducimos el nombre del elemento de datos al cual se quiere realizar el Field Exit. Este elemento de datos debe ser el mismo que tiene el campo de la dynpro al cuál se quiere relacionar.
Este dato lo obtenemos presionando la tecla F1 sobre el campo de la dynpro y luego presionando el botón de Información técnica .
Ingresamos el elemento de datos y presionamos enter.
A continuación el sistema nos propone la creación del módulo de funciones en la SE37, por lo que presionaremos el botón Crear.
Luego el sistema nos solicita la asignación de un grupo de funciones, es recomendable crear uno exclusivamente para el Field Exit. También introducimos un Texto breve para el módulo de funciones.
Este módulo de función tiene la particularidad de tener un parámetro de Import o entrada y uno de Export o salida. El parámetro de entrada es INPUT y contendrá el valor del campo al cual se ha asignado el Field Exit.
El parámetro de salida OUTPUT es el valor que tomará el campo al salir del Field Exit.
En la solapa Cód fte. vamos a ingresar el código correspondiente a la validación que deseamos agregar. Por ejemplo en este caso emitimos un mensaje de error en caso de que el usuario introduzca en el campo de la pantalla el texto 'CORRIENTES 123'.
Si en la función no se quiere modificar el campo donde esta colocado el Field Exit entonces al principio de todo se debe escribir: OUTPUT = INPUT para devolver el mismo valor que se ingresó.
Dentro del módulo de función sólo se pueden trabajar con estos parámetros, pero si se quiere obtener valores de otros campos de la dynpro se puede utilizar otros Field Exits en los cuales se utilizará el comando SET PARAMETER para poder grabar en memoria al valor del campo y utilizarlo en el Field Exit anterior tomándolo de memoria con GET PARAMETER.
Otra opción es utilizar la función GET_DYNP_VALUE para obtener valores de otros campos de la dynpro.
Una vez terminada la codificación se debe asignar un programa y dynpro al Field Exit (si no se quiere hacer Global, es decir para todos los programas).
Mientras no se haya realizado la asignación de la dynpro, el Field Exit afectará a todas las pantallas donde se encuentre un campo con el elemento de datos.
Para asignar el programa y dynpro se debe ir a la pantalla de administración de Field Exit (CMOD - PRFB), seleccionar el Field Exit y presionar el botón Asignar prog./dynpro.
AUDIO ACLARATIVO: A nivel administración del sistema SAP, existe el parámetro de instancia ABAP Field Exit, el cual controla la activación o desactivación de los Field Exit en el sistema. Si pensamos en el rendimiento performance del sistema, si el parámetro que controla la activación de los Field Exit está activo el sistema consultará dos tablas estándar que son la TDDIR y TDDIRS para saber si se debe generar un Exit de campo para cada campo. El usuario no notará una ralentización del sistema, ya que la generación de la dynpro es extraordinariamente rápida. Si deseamos conocer el contenido de algún otro campo de la pantalla cuando trabajamos con Field Exit, podemos guardar el contenido de otros campos en variables globales al grupo de función o utilizar la función DIM_VALUES_REED para leer valores de otros campos de la misma pantalla. Debemos considerar que si varios campos de la pantalla tienen el mismo elemento de datos, el Field Exit aplicará para todos ellos.
 
 
 
Sobre el autor
Publicación académica de Pedro Antonio Duarte, en su ámbito de estudios para la Carrera Consultor ABAP.
Pedro Antonio Duarte
Profesión: Consultor de Sap Abap - Argentina - Legajo: JP24O
✒️Autor de: 128 Publicaciones Académicas
🎓Egresado de los módulos:
Disponibilidad Laboral: FullTime
Certificación Académica de Pedro Duarte