version 1.9, 2010/03/04 10:09:31
|
version 1.18, 2010/04/21 13:45:50
|
Line 1
|
Line 1
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.0.11 |
RPL/2 (R) version 4.0.15 |
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 31
|
Line 31
|
*/ |
*/ |
|
|
int |
int |
rplinit(int argc, char *argv[], unsigned char ***resultats) |
rplinit(int argc, char *argv[], unsigned char ***resultats, char *rpl_home) |
{ |
{ |
# include "copyright.conv.h" |
# include "copyright.conv.h" |
# include "licence.conv.h" |
# include "licence.conv.h" |
Line 102 rplinit(int argc, char *argv[], unsigned
|
Line 102 rplinit(int argc, char *argv[], unsigned
|
setvbuf(stdout, NULL, _IOLBF, 0); |
setvbuf(stdout, NULL, _IOLBF, 0); |
setvbuf(stderr, NULL, _IOLBF, 0); |
setvbuf(stderr, NULL, _IOLBF, 0); |
|
|
|
# ifndef SEMAPHORES_NOMMES |
sem_init(&semaphore_liste_threads, 0, 1); |
sem_init(&semaphore_liste_threads, 0, 1); |
sem_init(&semaphore_gestionnaires_signaux, 0, 0); |
sem_init(&semaphore_gestionnaires_signaux, 0, 0); |
sem_init(&semaphore_gestionnaires_signaux_atomique, 0, 1); |
sem_init(&semaphore_gestionnaires_signaux_atomique, 0, 1); |
|
# else |
|
semaphore_liste_threads = sem_init2(1, sem_liste_threads); |
|
semaphore_gestionnaires_signaux = sem_init2(0, sem_gestionnaires_signaux); |
|
semaphore_gestionnaires_signaux_atomique = sem_init2(1, |
|
sem_gestionnaires_signaux_atomique); |
|
|
|
if ((semaphore_liste_threads == SEM_FAILED) || |
|
(semaphore_gestionnaires_signaux == SEM_FAILED) || |
|
(semaphore_gestionnaires_signaux_atomique == SEM_FAILED)) |
|
{ |
|
erreur = d_es_allocation_memoire; |
|
|
|
if ((langue = getenv("LANG")) != NULL) |
|
{ |
|
if (strncmp(langue, "fr", 2) == 0) |
|
{ |
|
uprintf("+++Système : Mémoire insuffisante\n"); |
|
} |
|
else |
|
{ |
|
uprintf("+++System : Not enough memory\n"); |
|
} |
|
} |
|
else |
|
{ |
|
uprintf("+++System : Not enough memory\n"); |
|
} |
|
|
|
return(EXIT_FAILURE); |
|
} |
|
# endif |
|
|
if ((s_etat_processus = malloc(sizeof(struct_processus))) == NULL) |
if ((s_etat_processus = malloc(sizeof(struct_processus))) == NULL) |
{ |
{ |
erreur = d_es_allocation_memoire; |
erreur = d_es_allocation_memoire; |
|
|
if ((*s_etat_processus).langue == 'F') |
if ((langue = getenv("LANG")) != NULL) |
{ |
{ |
printf("+++Système : Mémoire insuffisante\n"); |
if (strncmp(langue, "fr", 2) == 0) |
|
{ |
|
uprintf("+++Système : Mémoire insuffisante\n"); |
|
} |
|
else |
|
{ |
|
uprintf("+++System : Not enough memory\n"); |
|
} |
} |
} |
else |
else |
{ |
{ |
printf("+++System : Not enough memory\n"); |
uprintf("+++System : Not enough memory\n"); |
} |
} |
|
|
return(EXIT_FAILURE); |
return(EXIT_FAILURE); |
} |
} |
|
|
|
if ((langue = getenv("LANG")) != NULL) |
|
{ |
|
(*s_etat_processus).langue = (strncmp(langue, "fr", 2) == 0) |
|
? 'F' : 'E'; |
|
} |
|
else |
|
{ |
|
(*s_etat_processus).langue = 'E'; |
|
} |
|
|
(*s_etat_processus).exception = d_ep; |
(*s_etat_processus).exception = d_ep; |
(*s_etat_processus).erreur_systeme = d_es; |
(*s_etat_processus).erreur_systeme = d_es; |
(*s_etat_processus).erreur_execution = d_ex; |
(*s_etat_processus).erreur_execution = d_ex; |
|
|
|
(*s_etat_processus).rpl_home = rpl_home; |
|
|
insertion_thread(s_etat_processus, d_vrai); |
insertion_thread(s_etat_processus, d_vrai); |
|
|
pthread_mutexattr_init(&attributs_mutex); |
pthread_mutexattr_init(&attributs_mutex); |
Line 133 rplinit(int argc, char *argv[], unsigned
|
Line 184 rplinit(int argc, char *argv[], unsigned
|
pthread_mutex_init(&((*s_etat_processus).mutex), &attributs_mutex); |
pthread_mutex_init(&((*s_etat_processus).mutex), &attributs_mutex); |
pthread_mutexattr_destroy(&attributs_mutex); |
pthread_mutexattr_destroy(&attributs_mutex); |
|
|
|
# ifndef SEMAPHORES_NOMMES |
sem_init(&((*s_etat_processus).semaphore_fork), 0, 0); |
sem_init(&((*s_etat_processus).semaphore_fork), 0, 0); |
|
# else |
|
if (((*s_etat_processus).semaphore_fork = sem_init2(0, sem_fork)) == |
|
SEM_FAILED) |
|
{ |
|
if ((*s_etat_processus).langue == 'F') |
|
{ |
|
uprintf("+++Système : Mémoire insuffisante\n"); |
|
} |
|
else |
|
{ |
|
uprintf("+++System : Not enough memory\n"); |
|
} |
|
|
|
return(EXIT_FAILURE); |
|
} |
|
# endif |
|
|
pthread_mutexattr_init(&attributs_mutex); |
pthread_mutexattr_init(&attributs_mutex); |
pthread_mutexattr_settype(&attributs_mutex, PTHREAD_MUTEX_NORMAL); |
pthread_mutexattr_settype(&attributs_mutex, PTHREAD_MUTEX_NORMAL); |
Line 153 rplinit(int argc, char *argv[], unsigned
|
Line 221 rplinit(int argc, char *argv[], unsigned
|
.mutex), &attributs_mutex); |
.mutex), &attributs_mutex); |
pthread_mutexattr_destroy(&attributs_mutex); |
pthread_mutexattr_destroy(&attributs_mutex); |
|
|
if ((langue = getenv("LANG")) != NULL) |
|
{ |
|
(*s_etat_processus).langue = (strncmp(langue, "fr", 2) == 0) |
|
? 'F' : 'E'; |
|
} |
|
else |
|
{ |
|
(*s_etat_processus).langue = 'E'; |
|
} |
|
|
|
localisation_courante(s_etat_processus); |
localisation_courante(s_etat_processus); |
|
(*s_etat_processus).erreur_systeme = d_es; |
|
|
if ((*s_etat_processus).erreur_systeme != d_es) |
if ((*s_etat_processus).localisation == NULL) |
{ |
{ |
if ((*s_etat_processus).langue == 'F') |
if (((*s_etat_processus).localisation = malloc((strlen(d_locale) + 1) * |
|
sizeof(unsigned char))) == NULL) |
{ |
{ |
uprintf("+++Système : Mémoire insuffisante\n"); |
if ((*s_etat_processus).langue == 'F') |
} |
{ |
else |
uprintf("+++Système : Mémoire insuffisante\n"); |
{ |
} |
uprintf("+++System : Not enough memory\n"); |
else |
|
{ |
|
uprintf("+++System : Not enough memory\n"); |
|
} |
|
|
|
return(EXIT_FAILURE); |
} |
} |
|
|
return(EXIT_FAILURE); |
strcpy((*s_etat_processus).localisation, d_locale); |
} |
} |
|
|
printf("+++RPL/2 (R) version %s (%s)\n", d_version_rpl, |
printf("+++RPL/2 (R) version %s (%s)\n", d_version_rpl, |
Line 229 rplinit(int argc, char *argv[], unsigned
|
Line 294 rplinit(int argc, char *argv[], unsigned
|
return(EXIT_FAILURE); |
return(EXIT_FAILURE); |
} |
} |
|
|
|
# ifndef SEMAPHORES_NOMMES |
if (pthread_setspecific(semaphore_fork_processus_courant, |
if (pthread_setspecific(semaphore_fork_processus_courant, |
&((*s_etat_processus).semaphore_fork)) != 0) |
&((*s_etat_processus).semaphore_fork)) != 0) |
|
# else |
|
if (pthread_setspecific(semaphore_fork_processus_courant, |
|
(*s_etat_processus).semaphore_fork) != 0) |
|
# endif |
{ |
{ |
if ((*s_etat_processus).langue == 'F') |
if ((*s_etat_processus).langue == 'F') |
{ |
{ |
Line 483 rplinit(int argc, char *argv[], unsigned
|
Line 553 rplinit(int argc, char *argv[], unsigned
|
(*s_etat_processus).chemin_fichiers_temporaires = |
(*s_etat_processus).chemin_fichiers_temporaires = |
recherche_chemin_fichiers_temporaires(s_etat_processus); |
recherche_chemin_fichiers_temporaires(s_etat_processus); |
|
|
erreur = d_os; |
erreur = d_absence_erreur; |
core = d_faux; |
core = d_faux; |
mode_interactif = d_faux; |
mode_interactif = d_faux; |
(*s_etat_processus).nom_fichier_source = NULL; |
(*s_etat_processus).nom_fichier_source = NULL; |
Line 504 rplinit(int argc, char *argv[], unsigned
|
Line 574 rplinit(int argc, char *argv[], unsigned
|
|
|
if (argc == 1) |
if (argc == 1) |
{ |
{ |
erreur = d_os_ligne_de_commande; |
erreur = d_erreur; |
informations(s_etat_processus); |
informations(s_etat_processus); |
} |
} |
else |
else |
Line 556 rplinit(int argc, char *argv[], unsigned
|
Line 626 rplinit(int argc, char *argv[], unsigned
|
} |
} |
|
|
option_a = d_vrai; |
option_a = d_vrai; |
printf("\n"); |
|
|
|
if ((*s_etat_processus).langue == 'F') |
|
{ |
|
printf(" Auteur: Joël BERTRAND,\n"); |
|
printf(" Email : " |
|
"joel.bertrand@systella.fr\n"); |
|
printf(" Liste de diffusion : " |
|
"rpl2@systella.fr\n"); |
|
printf(" Page : " |
|
"http://www.rpl2.fr"); |
|
printf("\n"); |
|
} |
|
else |
|
{ |
|
printf(" Author: Joël BERTRAND,\n"); |
|
printf(" Email : " |
|
"joel.bertrand@systella.fr\n"); |
|
printf(" Mailing list : " |
|
"rpl2@systella.fr\n"); |
|
printf(" Web page : " |
|
"http://www.rpl2/net"); |
|
printf("\n"); |
|
} |
|
|
|
break; |
break; |
} |
} |
|
|
Line 1295 rplinit(int argc, char *argv[], unsigned
|
Line 1340 rplinit(int argc, char *argv[], unsigned
|
return(EXIT_FAILURE); |
return(EXIT_FAILURE); |
} |
} |
|
|
|
free(type_debug); |
break; |
break; |
} |
} |
|
|
Line 1382 rplinit(int argc, char *argv[], unsigned
|
Line 1428 rplinit(int argc, char *argv[], unsigned
|
printf("+++Error : More than one definition\n"); |
printf("+++Error : More than one definition\n"); |
} |
} |
|
|
erreur = d_os_ligne_de_commande; |
erreur = d_erreur; |
} |
} |
else |
else |
{ |
{ |
Line 1584 rplinit(int argc, char *argv[], unsigned
|
Line 1630 rplinit(int argc, char *argv[], unsigned
|
(*s_etat_processus).nom_fichier_source); |
(*s_etat_processus).nom_fichier_source); |
} |
} |
|
|
erreur = d_os_fichier_introuvable; |
erreur = d_erreur; |
} |
} |
else |
else |
{ |
{ |
Line 1631 rplinit(int argc, char *argv[], unsigned
|
Line 1677 rplinit(int argc, char *argv[], unsigned
|
} |
} |
} |
} |
|
|
if ((erreur == d_os) && (presence_definition == 'O')) |
if ((erreur == d_absence_erreur) && (presence_definition == 'O')) |
{ |
{ |
(*s_etat_processus).profilage = (option_P != 0) ? d_vrai : d_faux; |
(*s_etat_processus).profilage = (option_P != 0) ? d_vrai : d_faux; |
(*s_etat_processus).niveau_profilage = option_P; |
(*s_etat_processus).niveau_profilage = option_P; |
Line 1646 rplinit(int argc, char *argv[], unsigned
|
Line 1692 rplinit(int argc, char *argv[], unsigned
|
(*s_etat_processus).affichage_arguments = 'N'; |
(*s_etat_processus).affichage_arguments = 'N'; |
(*s_etat_processus).autorisation_conversion_chaine = 'Y'; |
(*s_etat_processus).autorisation_conversion_chaine = 'Y'; |
(*s_etat_processus).autorisation_evaluation_nom = 'Y'; |
(*s_etat_processus).autorisation_evaluation_nom = 'Y'; |
|
(*s_etat_processus).autorisation_nom_implicite = 'Y'; |
(*s_etat_processus).autorisation_empilement_programme = 'N'; |
(*s_etat_processus).autorisation_empilement_programme = 'N'; |
(*s_etat_processus).requete_arret = 'N'; |
(*s_etat_processus).requete_arret = 'N'; |
(*s_etat_processus).evaluation_forcee = 'N'; |
(*s_etat_processus).evaluation_forcee = 'N'; |
Line 2545 rplinit(int argc, char *argv[], unsigned
|
Line 2592 rplinit(int argc, char *argv[], unsigned
|
free(arguments); |
free(arguments); |
} |
} |
|
|
if (option_D == d_vrai) |
if (option_a == d_vrai) |
{ |
{ |
lancement_daemon(s_etat_processus); |
fprintf(stdout, "%s\n", (*s_etat_processus) |
|
.definitions_chainees); |
} |
} |
|
else |
if (option_p == d_faux) |
|
{ |
{ |
if (setjmp(contexte_initial) == 0) |
if (option_D == d_vrai) |
{ |
{ |
erreur = sequenceur(s_etat_processus); |
lancement_daemon(s_etat_processus); |
} |
} |
} |
|
else |
if (option_p == d_faux) |
{ |
|
if (setjmp(contexte_initial) == 0) |
|
{ |
{ |
erreur = sequenceur_optimise(s_etat_processus); |
if (setjmp(contexte_initial) == 0) |
|
{ |
|
erreur = sequenceur(s_etat_processus); |
|
} |
|
} |
|
else |
|
{ |
|
if (setjmp(contexte_initial) == 0) |
|
{ |
|
erreur = sequenceur_optimise(s_etat_processus); |
|
} |
} |
} |
} |
} |
|
|
Line 3188 rplinit(int argc, char *argv[], unsigned
|
Line 3243 rplinit(int argc, char *argv[], unsigned
|
fclose((*((struct_descripteur_fichier *) |
fclose((*((struct_descripteur_fichier *) |
(*((struct_liste_chainee *) |
(*((struct_liste_chainee *) |
l_element_courant)).donnee)) |
l_element_courant)).donnee)) |
.descripteur); |
.descripteur_c); |
|
|
|
if ((*((struct_descripteur_fichier *) |
|
(*((struct_liste_chainee *) |
|
l_element_courant)).donnee)).type != 'C') |
|
{ |
|
sqlite3_close((*((struct_descripteur_fichier *) |
|
(*((struct_liste_chainee *) |
|
l_element_courant)).donnee)) |
|
.descripteur_sqlite); |
|
} |
|
|
if ((*((struct_descripteur_fichier *) |
if ((*((struct_descripteur_fichier *) |
(*((struct_liste_chainee *) |
(*((struct_liste_chainee *) |
Line 3335 rplinit(int argc, char *argv[], unsigned
|
Line 3400 rplinit(int argc, char *argv[], unsigned
|
retrait_thread(s_etat_processus); |
retrait_thread(s_etat_processus); |
|
|
pthread_mutex_destroy(&((*s_etat_processus).mutex)); |
pthread_mutex_destroy(&((*s_etat_processus).mutex)); |
|
# ifndef SEMAPHORES_NOMMES |
sem_post(&((*s_etat_processus).semaphore_fork)); |
sem_post(&((*s_etat_processus).semaphore_fork)); |
sem_destroy(&((*s_etat_processus).semaphore_fork)); |
sem_destroy(&((*s_etat_processus).semaphore_fork)); |
|
# else |
|
sem_post((*s_etat_processus).semaphore_fork); |
|
sem_destroy2((*s_etat_processus).semaphore_fork, sem_fork); |
|
# endif |
|
|
free((*s_etat_processus).localisation); |
free((*s_etat_processus).localisation); |
free(s_etat_processus); |
free(s_etat_processus); |
|
|
|
# ifndef SEMAPHORES_NOMMES |
sem_destroy(&semaphore_liste_threads); |
sem_destroy(&semaphore_liste_threads); |
|
# else |
|
sem_destroy2(semaphore_liste_threads, sem_liste_threads); |
|
# endif |
|
# ifndef SEMAPHORES_NOMMES |
sem_post(&semaphore_gestionnaires_signaux); |
sem_post(&semaphore_gestionnaires_signaux); |
sem_destroy(&semaphore_gestionnaires_signaux); |
sem_destroy(&semaphore_gestionnaires_signaux); |
sem_destroy(&semaphore_gestionnaires_signaux_atomique); |
sem_destroy(&semaphore_gestionnaires_signaux_atomique); |
|
# else |
|
sem_post(semaphore_gestionnaires_signaux); |
|
sem_destroy2(semaphore_gestionnaires_signaux, sem_gestionnaires_signaux); |
|
sem_destroy2(semaphore_gestionnaires_signaux_atomique, |
|
sem_gestionnaires_signaux_atomique); |
|
# endif |
|
|
# ifdef DEBUG_MEMOIRE |
# ifdef DEBUG_MEMOIRE |
debug_memoire_verification(s_etat_processus); |
debug_memoire_verification(s_etat_processus); |
# endif |
# endif |
|
|
return((erreur == d_os) ? EXIT_SUCCESS : EXIT_FAILURE); |
return((erreur == d_absence_erreur) ? EXIT_SUCCESS : EXIT_FAILURE); |
} |
} |
|
|
|
|
Line 3362 informations(struct_processus *s_etat_pr
|
Line 3443 informations(struct_processus *s_etat_pr
|
if ((*s_etat_processus).langue == 'F') |
if ((*s_etat_processus).langue == 'F') |
{ |
{ |
printf(" rpl [-options] [programme]\n"); |
printf(" rpl [-options] [programme]\n"); |
printf(" -a : informations sur l'auteur\n"); |
printf(" -a : analyse du code\n"); |
printf(" -A : paramètres passés au programme principal\n"); |
printf(" -A : paramètres passés au programme principal\n"); |
printf(" -c : génération de fichier de débogage (rpl-core)\n"); |
printf(" -c : génération de fichier de débogage (rpl-core)\n"); |
printf(" -d : option de déverminage interne\n"); |
printf(" -d : option de déverminage interne\n"); |
Line 3381 informations(struct_processus *s_etat_pr
|
Line 3462 informations(struct_processus *s_etat_pr
|
else |
else |
{ |
{ |
printf(" rpl [-options] [program]\n"); |
printf(" rpl [-options] [program]\n"); |
printf(" -a : displays informations about the author\n"); |
printf(" -a : analyzes program\n"); |
printf(" -A : sends parameters to main program\n"); |
printf(" -A : sends parameters to main program\n"); |
printf(" -c : allows creation of a rpl-core file, providing a way" |
printf(" -c : allows creation of a rpl-core file, providing a way" |
"\n" |
"\n" |