IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

CICS Discussion :

Abend AEIV - Erreur de longueur


Sujet :

CICS

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    10
    Détails du profil
    Informations personnelles :
    Âge : 49
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 10
    Points : 12
    Points
    12
    Par défaut Abend AEIV - Erreur de longueur
    Bonjour,

    Je sollicite votre aide car je sèche sur un plantage cics assez étrange :
    Voici le compte rendu d'un outil d'aide au débuggage au moment de l'erreur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    TRANID: E004      CICS ABEND: AEIV              
      001686        *EXEC CICS RECEIVE INTO (ZORECEP)                              
      001687        *                  LENGTH (LONGMAP)                            
      001688        *END-EXEC.                                                     
      001689             Call 'DFHEI1' using by content x'0402c0000700000014000040 
      001690        -    '00f0f1f4f4f2404040' by reference ZORECEP by reference    
      001691             LONGMAP end-call.                                         
    The COBOL source code for data fields involved in the failure:                 
      Source                                                                       
      Line £                                                                       
      000081         77  LONGMAP             PIC S9(4)   COMP SYNC   VALUE +1000.  
      000083         77  ZORECEP             PIC X(1000).                          
    Data field values at time of abend:                                            
      LONGMAP = 302                                                                
      ZORECEP = . AE003. N  SAISIE . ^SORTIE PREPARATION     .AH11/06/13.B/TOURNEE 
                NOTE: Above value truncated after 118 bytes.
    Je plante sur un receive en AIEV, donc sur un problème de longueur. C'est logique car LONGMAP vaut 302 (!!). Pourtant cette variable n'est jamais modifiée dans le programme (!). Elle est initialisée à 1000. Ce plantage est assez rare (2 fois dans une journée sur des centaines d'utilisations du programme). Est-ce que ce problème vous évoque quelque chose ? Je vois que la variable de longueur (LONGMAP) est passée "by reference", est-ce que CICS modifie la valeur de la variable (si je passe plusieurs fois sur le receive) ?

    (Quelques heures plus tard re-plantage... cette fois LONGMAP valait 266...)

    Je vous remercie à l'avance.

  2. #2
    Membre chevronné Avatar de bernard59139
    Profil pro
    Administrateur de base de données
    Inscrit en
    Octobre 2006
    Messages
    950
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Octobre 2006
    Messages : 950
    Points : 2 064
    Points
    2 064
    Par défaut
    Dans le programme, vérifie si il n'y a pas plusieurs RECEIVE avec LENGTH (LONGMAP).

    Ca fait très longtemps que je n'ai pas fait du cobol cics...

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    10
    Détails du profil
    Informations personnelles :
    Âge : 49
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 10
    Points : 12
    Points
    12
    Par défaut
    Bonjour Bernard,

    Merci de ta réponse.
    J'ai effectivement plusieurs receive qui utilisent la variable LONGMAP dans le programme. Tu penses qu'un ordre receive est susceptible de modifier la valeur de la variable LONGMAP ? (je le soupsonne comme la variable est passée "by reference")

    Je vais simplement tenter un move 1000 to longmap juste avant le receive qui plante.

  4. #4
    Membre chevronné Avatar de bernard59139
    Profil pro
    Administrateur de base de données
    Inscrit en
    Octobre 2006
    Messages
    950
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Octobre 2006
    Messages : 950
    Points : 2 064
    Points
    2 064
    Par défaut
    la piste de plusieurs receive est à creuser.
    Extrait de la doc:
    LENGTH(data-area)
    specifies the length, as a halfword binary value, of the data transmitted.
    If you specify the INTO option, but omit the MAXLENGTH option, the argument must be a data area
    that specifies the maximum length that the program accepts. If the value specified is less than zero, zero is assumed.
    If the length of the data exceeds the value specified, but the NOTRUNCATE option is not specified, the data is truncated to that value and the LENGERR condition occurs. When the data has been received, the data area is set to the original length of the data.
    If you specify the SET option, the argument must be a data area. When the data has been received, the data area is set to the length of the data.
    Un simple suivi avec CEDF devrait confirmer cette piste.

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    10
    Détails du profil
    Informations personnelles :
    Âge : 49
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 10
    Points : 12
    Points
    12
    Par défaut
    C'est bien ça.
    Quand je reviens d'un

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    MOVE 1000 TO LONGMAP
    EXEC CICS RECEIVE INTO (ZORECEP)      
                      LENGTH (LONGMAP)
    LONGMAP est bien modifié avec la taille réelle de ce qui a été reçu. (J'ai fait un petit test et LONGMAP vaut 249 après le receive.)
    Et on plante dans le receive suivant car le developpeur pense que longmap vaut toujours 1000.

    Encore merci pour le coups de main.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Longueur des messages d'erreur
    Par joujou_le_fou dans le forum Général Dotnet
    Réponses: 5
    Dernier message: 06/10/2009, 14h32
  2. Réponses: 1
    Dernier message: 19/12/2006, 22h19
  3. Réponses: 1
    Dernier message: 16/11/2006, 11h34
  4. Erreur lors de changement de longueur de champs
    Par Bouillon dans le forum Bases de données
    Réponses: 2
    Dernier message: 09/10/2006, 09h17
  5. [Forms 6i] Erreur FRM-30187 : longueur ?
    Par macben dans le forum Forms
    Réponses: 13
    Dernier message: 08/11/2004, 15h45

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo