chauss
C CHAUSS SOURCE PV090527 25/01/16 21:15:01 12128 SUBROUTINE CHAUSS IMPLICIT INTEGER(I-N) IMPLICIT REAL*8(A-H,O-Z) C_______________________________________________________________________ C C ENT1=CHAU 'SERVEUR' ('ATTENTE' ENT4); C ENT1=CHAU 'CLIENT' MOT1; C ENT1=CHAU 'ECRITURE' LREE1 ('ECHO') ('ATTENTE' ENT4); C ENT1=CHAU 'ECRITURE' MOT2 ('ECHO') ('ATTENTE' ENT4); C ENT1 LREE2=CHAU 'LECTLIST' ENT2 ('ECHO') ('ATTENTE' ENT4); C ENT1 MOT3=CHAU 'LECTUMOT' ENT3 ('ECHO') ('ATTENTE' ENT4); C ENT1=CHAU 'FERMETURE' ('COMPLETE'); C C_______________________________________________________________________ C C WARNING: il doit etre possible de dialoguer avec des programmes C. C ----> tout les objets transferes sont codes en ASCII ... C ----> ... sont completer par le caractere NULL ... C ----> ... et les flottants ont un exposant sur 3 digits C_______________________________________________________________________ C P.PEGON 10-12/3/93 7/9/93 C----------------------------------------------------------------------- C -INC SMLREEL -INC PPARAM -INC CCOPTIO LOGICAL LDUMM SEGMENT BUFFER CHARACTER*(L1) LBUFF=' ' ENDSEGMENT POINTEUR BUFFE1.BUFFER C CHARACTER NULL,CCC*3 CHARACTER*(LOCHAI) BUFF1 C PARAMETER(NCLE=6) CHARACTER MCLE(NCLE)*8,NOM*72,MMCLE(1)*8,macnam*20 DATA MCLE/'SERVEUR ','CLIENT ','ECRITURE','LECTLIST','LECTUMOT', > 'FERMETUR'/ DATA MMCLE(1)/'COMPLETE'/ DATA LDUMM/.FALSE./ C NULL=CHAR(0) IF(ICLE.EQ.0)RETURN C GOTO(10,20,30,40,50,60),ICLE C C OUVERTURE SERVEUR C IF(IENT.EQ.0) GOTO 100 C CALL initserver(IWAIT,IENT,macnam) IF(IENT.NE.1)THEN WRITE(IOIMP,*)'Chauss: Erreur en "OUVERTURE SERVEUR"',IENT ENDIF GOTO 100 C C OUVERTURE CLIENT C IF(IENT.GT.0)THEN IENT=IENT+1 NOM(IENT:IENT)=NULL CALL initclient(NOM(1:IENT),IENT) IF(IENT.NE.1)THEN WRITE(IOIMP,*)'Chauss: Erreur en "OUVERTURE CLIENT"' ENDIF ENDIF GOTO 100 C C ECRITURE C C C 1) CAS DU LISTREEL C IF(IENT.NE.0)THEN C IF(IERR .NE. 0) RETURN IF(IENT.EQ.0) GOTO 100 C SEGINI,BUFFER WRITE(LBUFF((IE1-1)*23+1:IE1*23-1),'(1PE21.14,A1)') C LBUFF((IE1-1)*23+21:IE1*23)=LBUFF((IE1-1)*23+20:IE1*23-1) CCC=LBUFF((IE1-1)*23+20:IE1*23-1) LBUFF((IE1-1)*23+21:IE1*23)=CCC LBUFF((IE1-1)*23+20:(IE1-1)*23+20)='0' LBUFF((IE1-1)*23+1:(IE1-1)*23+1)='+' ENDIF ENDDO IF(IIMPI.EQ.1789)THEN WRITE(IOIMP,*)'Echo transmission' WRITE(IOIMP,*)IE1,':',LBUFF((IE1-1)*23+1:IE1*23) ENDDO ENDIF C C 2) CAS DU MOT C ELSE C IF(IENT.EQ.0) GOTO 100 C IF(IENT.EQ.0) GOTO 100 C L1=IENT+1 SEGINI,BUFFER LBUFF = NOM LBUFF(L1:L1)= NULL IF(IIMPI.EQ.1789)THEN WRITE(IOIMP,*)'Echo transmission' WRITE(IOIMP,*)LBUFF(1:L1) ENDIF ENDIF C IF(JECHO.EQ.0)L1=1 SEGINI,BUFFE1 BUFFE1.LBUFF(L1:L1)=NULL C CALL writesocket(JECHO,IWAIT,IENT,LBUFF(/1),LBUFF,BUFFE1.LBUFF) IF(IENT.NE.1)THEN WRITE(IOIMP,*)'Chauss: Erreur en "ECRITURE"' ENDIF SEGSUP,BUFFER,BUFFE1 C GOTO 100 C C LECTURE D'UN LISTREEL C IF(IENT.EQ.0)GOTO 100 C IF(IENT.EQ.0) GOTO 100 C L1=JG*23 SEGINI,BUFFER CALL readsocket(LBUFF,JECHO,IWAIT,IENT,LBUFF(/1)) IF(IENT.NE.1)THEN WRITE(IOIMP,*)'Chauss: Erreur en "LECTURE LISTREEL"' GOTO 99 ENDIF C IF(IIMPI.EQ.1789)THEN WRITE(IOIMP,*)'Echo reception' DO IE1=1,JG WRITE(IOIMP,*)IE1,':',LBUFF((IE1-1)*23+1:IE1*23) ENDDO ENDIF C SEGINI,MLREEL DO IE1=1,JG C LBUFF((IE1-1)*23+20:IE1*23-2)=LBUFF((IE1-1)*23+21:IE1*23-1) CCC=LBUFF((IE1-1)*23+21:IE1*23) LBUFF((IE1-1)*23+20:IE1*23-1)=CCC ENDDO C Ecriture des resultats SEGSUP,BUFFER C GOTO 100 C C LECTURE D'UN MOT C IF(IENT.EQ.0)GOTO 100 C IF(IENT.EQ.0) GOTO 100 C L1=L1+1 SEGINI,BUFFER LBUFF(L1:L1)=NULL CALL readsocket(LBUFF,JECHO,IWAIT,IENT,L1) IF(IENT.NE.1)THEN WRITE(IOIMP,*)'Chauss: Erreur en "LECTURE MOT"' GOTO 99 ENDIF C IF(IIMPI.EQ.1789)THEN WRITE(IOIMP,*)'Echo reception' WRITE(IOIMP,*)LBUFF(1:L1) ENDIF C BUFF1(1:L1-1)=LBUFF(1:L1-1) SEGSUP,BUFFER C GOTO 100 C C FERMETURE DU PORT C CALL closesocket(ICOMPL,IENT) IF(IENT.NE.1)THEN WRITE(IOIMP,*)'Chauss: Erreur en "FERMETURE"' ENDIF C GOTO 100 C C ERREUR LECTURE (TIME OUT ET AUTRES) C C C ON SORT C RETURN END
© Cast3M 2003 - Tous droits réservés.
Mentions légales