Télécharger fimots.eso

Retour à la liste

Numérotation des lignes :

fimots
  1. C FIMOTS SOURCE CB215821 20/11/04 21:17:26 10766
  2. SUBROUTINE FIMOTS(MYMOT,MYLMOT,
  3. $ INDMOT,
  4. $ IMPR,IRET)
  5. IMPLICIT INTEGER(I-N)
  6. IMPLICIT REAL*8 (A-H,O-Z)
  7. C***********************************************************************
  8. C NOM : FIMOTS
  9. C PROJET : Noyau linéaire NLIN
  10. C DESCRIPTION : Cherche le mot MYMOT dans la liste de mots MYLMOT.
  11. C Si on le trouve, on renvoie son indice dans la liste
  12. C sinon erreur...
  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 APPELE PAR : PRASEM
  18. C***********************************************************************
  19. C ENTREES : MYMOT(CH*), MYLMOT(seg. MLMOTS)
  20. C SORTIES : INDMOT
  21. C CODE RETOUR (IRET) : = 0 si tout s'est bien passé
  22. C***********************************************************************
  23. C VERSION : v1, 12/08/99, version initiale
  24. C HISTORIQUE : v1, 12/08/99, création
  25. C HISTORIQUE :
  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 SMLMOTS
  36. POINTEUR MYLMOT.MLMOTS
  37. CHARACTER*(*) MYMOT
  38. INTEGER INDMOT
  39. *
  40. INTEGER IMPR,IRET
  41. *
  42. INTEGER MLMETA
  43. INTEGER INBM
  44. INTEGER NBMOTS
  45. LOGICAL LFOUND
  46. *
  47. * Executable statements
  48. *
  49. IF (IMPR.GT.5) WRITE(IOIMP,*) 'Entrée dans fimots'
  50. CALL OOOETA(MYLMOT,MLMETA,IMOD)
  51. IF (MLMETA.NE.1) SEGACT MYLMOT
  52. NBMOTS=MYLMOT.MOTS(/2)
  53. INBM=0
  54. LFOUND=.FALSE.
  55. 1 CONTINUE
  56. IF (.NOT.LFOUND.AND.INBM.LT.NBMOTS) THEN
  57. INBM=INBM+1
  58. LFOUND=MYMOT.EQ.MYLMOT.MOTS(INBM)
  59. GOTO 1
  60. ENDIF
  61. IF (.NOT.LFOUND) THEN
  62. WRITE(IOIMP,*) 'On n''a pas trouvé le mot ',MYMOT
  63. WRITE(IOIMP,*) 'dans la liste de mots ',MYLMOT
  64. GOTO 9999
  65. ENDIF
  66. INDMOT=INBM
  67. IF (MLMETA.NE.1) SEGDES MYLMOT
  68. *
  69. * Normal termination
  70. *
  71. IRET=0
  72. RETURN
  73. *
  74. * Format handling
  75. *
  76. *
  77. * Error handling
  78. *
  79. 9999 CONTINUE
  80. IRET=1
  81. WRITE(IOIMP,*) 'An error was detected in subroutine fimots'
  82. RETURN
  83. *
  84. * End of subroutine FIMOTS
  85. *
  86. END
  87.  
  88.  
  89.  
  90.  
  91.  
  92.  

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