excoc2
C EXCOC2 SOURCE CB215821 20/11/04 21:16:53 10766 C----------------------------------------------------------------------- C EXTRACTION D UNE LISTE DE COMPOSANTES D UN MCHAML C C ENTREE C IPCH1= POINTEUR SUR UN MCHAML C LMOT1= LISTE DES NOMS DES COMPOSANTES A EXTRAIRE C LMOT2= LISTE DES NOUVEAUX NOMS UNE FOIS EXTRAITS C IVID = 1 SI ON A LU LE MOT 'NOID', 0 SINON C C SORTIE C IPCH2= POINTEUR SUR LE MCHAML CONTENANT LES COMPOSANTES EXTRAITES C----------------------------------------------------------------------- IMPLICIT INTEGER(I-N) IMPLICIT REAL*8(A-H,O-Z) -INC SMCHAML -INC PPARAM -INC CCOPTIO -INC SMLMOTS CHARACTER*(LOCOMP) LEMOT,MOLIST MLMOTS=LMOT1 MLMOT2=LMOT2 MCHELM=IPCH1 SEGINI,MCHEL1=MCHELM IPCH2 =MCHEL1 N1ori =MCHEL1.ICHAML(/1) N3 =MCHEL1.INFCHE(/2) C BOUCLE SUR MCHAML N1loc=0 DO 100 IN1=1,N1ori MCHAML=MCHEL1.ICHAML(IN1) SEGINI,MCHAM1=MCHAML N2ori =MCHAM1.IELVAL(/1) C BOUCLE SUR MELVAL N2loc=0 C BOUCLE SUR MLMOTS DO 150 IMO=1,JGM IF (MOLIST.EQ.LEMOT) THEN N2loc = N2loc + 1 GOTO 110 ENDIF 150 CONTINUE 110 CONTINUE IF (N2loc .EQ. 0) THEN SEGSUP,MCHAM1 GOTO 100 ELSE N1loc = N1loc + 1 MCHEL1.ICHAML(N1loc)=MCHAM1 MCHEL1.CONCHE(N1loc)=MCHELM.CONCHE(IN1) MCHEL1.IMACHE(N1loc)=MCHELM.IMACHE(IN1) DO IN3=1,N3 MCHEL1.INFCHE(N1loc,IN3)=MCHELM.INFCHE(IN1,IN3) ENDDO IF (N2loc .NE. N2ori) THEN N2=N2loc SEGADJ,MCHAM1 ENDIF ENDIF 100 CONTINUE IF (N1loc.EQ.0 .AND. IVID.NE.1) THEN RETURN ELSEIF(N1loc .NE. N1ori) THEN N1 = N1loc L1 = MCHEL1.TITCHE(/1) SEGADJ,MCHEL1 ENDIF END
© Cast3M 2003 - Tous droits réservés.
Mentions légales