nomc3
C NOMC3 SOURCE PV090527 25/01/07 14:42:51 12115 *----------------------------------------------------------------------- * Renommer certaines composantes d'un MCHAML * * IPCH1 (e) pointeur sur un champ par element (type MCHAML) * IPLM1 (e) liste des composantes a remplacer (type LISTMOTS) * IPLM2 (e) liste des nouvelles composantes (type LISTMOTS) * IPCH2 (s) objet resultat (type MCHAML) * MOT nouveau nom de composante * * kich 01/99 * nouveau paradigme sans segdes SG 2019/12/10 *----------------------------------------------------------------------- IMPLICIT INTEGER(I-N) IMPLICIT REAL*8(A-H,O-Z) -INC PPARAM -INC CCOPTIO -INC SMCOORD -INC SMCHAML -INC SMLMOTS CHARACTER*(*) MOT IPCH2 = 0 mchel1 = IPCH1 SEGINI,mchelm = mchel1 n1 = mchelm.ichaml(/1) * Le MCHAML ne doit avoir qu un constituant * n3 = mchelm.infche(/2) * do icha = 2, n1 * if (mchelm.conche(icha).ne.mchelm.conche(1)) then * call erreur(716) * return * endif * enddo * 1 - Cas MOT : MCHAML a une composante IF (IPLM1.EQ.-1) THEN DO icha = 1, n1 mcham1 = mchelm.ichaml(icha) segini,mchaml = mcham1 mchelm.ichaml(icha) = mchaml n2 = mchaml.ielval(/1) if (n2.ne.1) then moterr(1: 8) = mot moterr(9:16) = 'MCHAML ' return endif mchaml.nomche(1) = mot *new-paradigm segdes mchaml ENDDO * 2 - Cas Liste de composantes a renommer : * ELSE IF (IPLM1.NE.-1) THEN ELSE * Verification des listes des composantes si fournies MLMOT1 = IPLM1 MLMOT2 = IPLM2 SEGACT MLMOT1,MLMOT2 IF (JGM1.NE.JGM2) THEN *new-paradigm SEGDES MLMOT1,MLMOT2 RETURN ENDIF DO icha = 1, n1 mcham1 = mchelm.ichaml(icha) segini,mchaml = mcham1 mchelm.ichaml(icha) = mchaml n2 = mchaml.ielval(/1) DO k = 1, n2 IF (IMO.NE.0) THEN ELSE C Deja fait par le segini,mchaml = mcham1 ENDIF ENDDO *new-paradigm segdes mchaml ENDDO ENDIF *new-paradigm segdes mchelm IPCH2 = MCHELM c RETURN END
© Cast3M 2003 - Tous droits réservés.
Mentions légales