version 1.3, 2010/02/10 08:09:29
|
version 1.14, 2010/08/06 15:26:49
|
Line 1
|
Line 1
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.0.10 |
RPL/2 (R) version 4.0.18 |
Copyright (C) 1989-2010 Dr. BERTRAND Joël |
Copyright (C) 1989-2010 Dr. BERTRAND Joël |
|
|
This file is part of RPL/2. |
This file is part of RPL/2. |
Line 20
|
Line 20
|
*/ |
*/ |
|
|
|
|
#include "rpl.conv.h" |
#include "rpl-conv.h" |
|
|
|
|
/* |
/* |
Line 265 instruction_recv(struct_processus *s_eta
|
Line 265 instruction_recv(struct_processus *s_eta
|
} |
} |
} |
} |
|
|
|
# ifndef SEMAPHORES_NOMMES |
if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0) |
if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0) |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_processus; |
(*s_etat_processus).erreur_systeme = d_es_processus; |
return; |
return; |
} |
} |
|
# else |
|
if (sem_post((*s_etat_processus).semaphore_fork) != 0) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return; |
|
} |
|
# endif |
|
|
if ((s_objet_resultat = lecture_pipe(s_etat_processus, |
if ((s_objet_resultat = lecture_pipe(s_etat_processus, |
(*(*((struct_processus_fils *) (*s_objet_argument).objet)) |
(*(*((struct_processus_fils *) (*s_objet_argument).objet)) |
.thread).pipe_objets[0])) == NULL) |
.thread).pipe_objets[0])) == NULL) |
{ |
{ |
|
# ifndef SEMAPHORES_NOMMES |
while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1) |
while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1) |
|
# else |
|
while(sem_wait((*s_etat_processus).semaphore_fork) == -1) |
|
# endif |
{ |
{ |
if (errno != EINTR) |
if (errno != EINTR) |
{ |
{ |
Line 305 instruction_recv(struct_processus *s_eta
|
Line 317 instruction_recv(struct_processus *s_eta
|
return; |
return; |
} |
} |
|
|
|
# ifndef SEMAPHORES_NOMMES |
while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1) |
while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1) |
|
# else |
|
while(sem_wait((*s_etat_processus).semaphore_fork) == -1) |
|
# endif |
{ |
{ |
if (errno != EINTR) |
if (errno != EINTR) |
{ |
{ |
Line 359 instruction_recv(struct_processus *s_eta
|
Line 375 instruction_recv(struct_processus *s_eta
|
return; |
return; |
} |
} |
|
|
|
# ifndef SEMAPHORES_NOMMES |
if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0) |
if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0) |
|
# else |
|
if (sem_post((*s_etat_processus).semaphore_fork) != 0) |
|
# endif |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_processus; |
(*s_etat_processus).erreur_systeme = d_es_processus; |
return; |
return; |
Line 377 instruction_recv(struct_processus *s_eta
|
Line 397 instruction_recv(struct_processus *s_eta
|
} |
} |
} |
} |
|
|
|
# ifndef SEMAPHORES_NOMMES |
while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1) |
while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1) |
|
# else |
|
while(sem_wait((*s_etat_processus).semaphore_fork) == -1) |
|
# endif |
{ |
{ |
if (errno != EINTR) |
if (errno != EINTR) |
{ |
{ |
Line 1190 instruction_rdgn(struct_processus *s_eta
|
Line 1214 instruction_rdgn(struct_processus *s_eta
|
struct_objet *s_objet_argument; |
struct_objet *s_objet_argument; |
struct_objet *s_objet_resultat; |
struct_objet *s_objet_resultat; |
|
|
|
unsigned char *pointeur; |
unsigned char *requete; |
unsigned char *requete; |
unsigned char **types_generateurs; |
unsigned char **types_generateurs; |
|
|
Line 1247 instruction_rdgn(struct_processus *s_eta
|
Line 1272 instruction_rdgn(struct_processus *s_eta
|
} |
} |
|
|
strcpy(types_generateurs[i], (**type_courant).name); |
strcpy(types_generateurs[i], (**type_courant).name); |
|
pointeur = types_generateurs[i]; |
|
|
|
while((*pointeur) != d_code_fin_chaine) |
|
{ |
|
if ((*pointeur) == '-') |
|
{ |
|
(*pointeur) = '_'; |
|
} |
|
|
|
pointeur++; |
|
} |
} |
} |
|
|
// Tri des types de générateurs (tri shaker) |
// Tri des types de générateurs (tri shaker) |