Télécharger ficomp.eso

Retour à la liste

Numérotation des lignes :

ficomp
  1. C FICOMP SOURCE GOUNAND 21/06/02 21:15:53 11022
  2. SUBROUTINE FICOMP(CNOM,MYCOMS,
  3. $ MYCOM,
  4. $ IMPR,IRET)
  5. IMPLICIT REAL*8 (A-H,O-Z)
  6. IMPLICIT INTEGER (I-N)
  7. C***********************************************************************
  8. C NOM : FICOMP
  9. C PROJET : Noyau linéaire NLIN
  10. C DESCRIPTION : Cherche les infos sur une loi de comportement par son
  11. C nom.
  12. C
  13. C LANGAGE : ESOPE
  14. C AUTEUR : Stéphane GOUNAND (CEA/DRN/DMT/SEMT/LTMF)
  15. C mél : gounand@semt2.smts.cea.fr
  16. C***********************************************************************
  17. C APPELES : OOOETA (état d'un segment)
  18. C APPELE PAR :
  19. C***********************************************************************
  20. C ENTREES :
  21. C
  22. C SORTIES :
  23. C***********************************************************************
  24. C VERSION : v1, 10/05/04, version initiale
  25. C HISTORIQUE : v1, 10/05/04, création
  26. C HISTORIQUE :
  27. C***********************************************************************
  28. C Prière de PRENDRE LE TEMPS de compléter les commentaires
  29. C en cas de modification de ce sous-programme afin de faciliter
  30. C la maintenance !
  31. C***********************************************************************
  32.  
  33. -INC PPARAM
  34. -INC CCOPTIO
  35. -INC TNLIN
  36. *-INC SLCOMP
  37. POINTEUR MYCOMS.COMPS
  38. POINTEUR COCOUR.COMP
  39. POINTEUR MYCOM.COMP
  40. *
  41. INTEGER IMPR,IRET
  42. *
  43. CHARACTER*(*) CNOM
  44. INTEGER LCNOM
  45. INTEGER MCSETA
  46. INTEGER ICOMPS,NCOMPS
  47. LOGICAL LFOUND
  48. *
  49. * Executable statements
  50. *
  51. IF (IMPR.GT.6) WRITE(IOIMP,*) 'Entrée dans ficomp'
  52. LFOUND=.FALSE.
  53. LCNOM=LEN(CNOM)
  54. * On veut laisser MYCOMS dans le même état (actif, inactif) qu'avant
  55. * l'appel à FICOMP.
  56. CALL OOOETA(MYCOMS,MCSETA,IMOD)
  57. IF (MCSETA.NE.1) SEGACT MYCOMS
  58. NCOMPS=MYCOMS.LISCOM(/1)
  59. ICOMPS=0
  60. * Boucle 1 : repeat...until
  61. 1 CONTINUE
  62. ICOMPS=ICOMPS+1
  63. COCOUR=MYCOMS.LISCOM(ICOMPS)
  64. SEGACT COCOUR
  65. IF (COCOUR.NOMCOM(/1).EQ.LCNOM) THEN
  66. IF (COCOUR.NOMCOM.EQ.CNOM) THEN
  67. LFOUND=.TRUE.
  68. ENDIF
  69. ENDIF
  70. SEGDES COCOUR
  71. IF (.NOT.LFOUND.AND.ICOMPS.LT.NCOMPS) GOTO 1
  72. IF (LFOUND) THEN
  73. MYCOM=COCOUR
  74. ELSE
  75. WRITE(IOIMP,*) 'On n''a pas trouvé ',CNOM,
  76. $ 'dans les lois de comportement'
  77. GOTO 9999
  78. ENDIF
  79. IF (MCSETA.NE.1) SEGDES MYCOMS
  80. *
  81. * Normal termination
  82. *
  83. IRET=0
  84. RETURN
  85. *
  86. * Format handling
  87. *
  88. *
  89. * Error handling
  90. *
  91. 9999 CONTINUE
  92. IRET=1
  93. WRITE(IOIMP,*) 'An error was detected in subroutine ficomp'
  94. RETURN
  95. *
  96. * End of subroutine ficomp
  97. *
  98. END
  99.  
  100.  
  101.  
  102.  
  103.  

© Cast3M 2003 - Tous droits réservés.
Mentions légales