version 1.78, 2015/11/26 11:44:31
|
version 1.102, 2025/04/15 10:17:50
|
Line 1
|
Line 1
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.1.24 |
RPL/2 (R) version 4.1.36 |
Copyright (C) 1989-2015 Dr. BERTRAND Joël |
Copyright (C) 1989-2025 Dr. BERTRAND Joël |
|
|
This file is part of RPL/2. |
This file is part of RPL/2. |
|
|
Line 42 formateur(struct_processus *s_etat_proce
|
Line 42 formateur(struct_processus *s_etat_proce
|
int parentheses_groupe_gauche; |
int parentheses_groupe_gauche; |
int parentheses_groupe_droit; |
int parentheses_groupe_droit; |
|
|
|
integer8 (*__type_disp)(struct_processus *, void **); |
|
|
logical1 registre45; |
logical1 registre45; |
|
|
logical4 autorisation_parenthese; |
logical4 autorisation_parenthese; |
Line 3296 formateur(struct_processus *s_etat_proce
|
Line 3298 formateur(struct_processus *s_etat_proce
|
|
|
if (chaine == NULL) |
if (chaine == NULL) |
{ |
{ |
|
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
|
return(NULL); |
|
} |
|
|
|
strcpy(chaine, chaine_sauvegarde); |
|
free(chaine_sauvegarde); |
|
strcat(chaine, " ]"); |
|
} |
|
} |
|
else if ((*s_objet).type == REC) |
|
{ |
|
chaine = (unsigned char *) malloc(4 * sizeof(unsigned char)); |
|
|
|
if (chaine == NULL) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
|
return(NULL); |
|
} |
|
|
|
strcpy(chaine, "|[ "); |
|
offset = ((integer8) strlen(chaine)) + offset_initial; |
|
|
|
// L'objet se compose de deux tables à une dimension de |
|
// mêmes tailles. |
|
|
|
chaine_sauvegarde = chaine; |
|
|
|
if ((chaine_formatee = formateur(s_etat_processus, (long) offset, |
|
(*((struct_record *) (*s_objet).objet)).noms)) == NULL) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
|
return(NULL); |
|
} |
|
|
|
if ((chaine = (unsigned char *) malloc((strlen(chaine_formatee) |
|
+ strlen(chaine_sauvegarde) + 1) |
|
* sizeof(unsigned char))) == NULL) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
|
return(NULL); |
|
} |
|
|
|
sprintf(chaine, "%s%s", chaine_sauvegarde, chaine_formatee); |
|
free(chaine_sauvegarde); |
|
free(chaine_formatee); |
|
|
|
if (test_cfsf(s_etat_processus, 45) == d_vrai) |
|
{ |
|
chaine_sauvegarde = chaine; |
|
|
|
if ((chaine = (unsigned char *) malloc( |
|
(strlen(chaine_sauvegarde) + 2) * sizeof(unsigned char))) |
|
== NULL) |
|
{ |
(*s_etat_processus).erreur_systeme = |
(*s_etat_processus).erreur_systeme = |
d_es_allocation_memoire; |
d_es_allocation_memoire; |
return(NULL); |
return(NULL); |
Line 3303 formateur(struct_processus *s_etat_proce
|
Line 3359 formateur(struct_processus *s_etat_proce
|
|
|
strcpy(chaine, chaine_sauvegarde); |
strcpy(chaine, chaine_sauvegarde); |
free(chaine_sauvegarde); |
free(chaine_sauvegarde); |
strcat(chaine, " ]"); |
strcat(chaine, "\n"); |
|
|
|
chaine_sauvegarde = chaine; |
|
|
|
chaine = (unsigned char *) malloc( |
|
(strlen(chaine_sauvegarde) + 1 + ((size_t) offset)) |
|
* sizeof(unsigned char)); |
|
|
|
if (chaine == NULL) |
|
{ |
|
(*s_etat_processus).erreur_systeme = |
|
d_es_allocation_memoire; |
|
return(NULL); |
|
} |
|
|
|
strcpy(chaine, chaine_sauvegarde); |
|
free(chaine_sauvegarde); |
|
ptre = &(chaine[strlen(chaine)]); |
|
|
|
for(k = 0; k < offset; k++, *(ptre++) = ' '); |
|
|
|
(*ptre) = d_code_fin_chaine; |
} |
} |
|
else |
|
{ |
|
chaine_sauvegarde = chaine; |
|
|
|
if ((chaine = (unsigned char *) malloc( |
|
(strlen(chaine_sauvegarde) + 2) |
|
* sizeof(unsigned char))) == NULL) |
|
{ |
|
(*s_etat_processus).erreur_systeme = |
|
d_es_allocation_memoire; |
|
return(NULL); |
|
} |
|
|
|
strcpy(chaine, chaine_sauvegarde); |
|
free(chaine_sauvegarde); |
|
strcat(chaine, " "); |
|
} |
|
|
|
chaine_sauvegarde = chaine; |
|
|
|
if ((chaine_formatee = formateur(s_etat_processus, (long) offset, |
|
(*((struct_record *) (*s_objet).objet)).donnees)) == NULL) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
|
return(NULL); |
|
} |
|
|
|
if ((chaine = (unsigned char *) malloc((strlen(chaine_formatee) |
|
+ strlen(chaine_sauvegarde) + 1) |
|
* sizeof(unsigned char))) == NULL) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
|
return(NULL); |
|
} |
|
|
|
sprintf(chaine, "%s%s", chaine_sauvegarde, chaine_formatee); |
|
free(chaine_sauvegarde); |
|
free(chaine_formatee); |
|
|
|
chaine_sauvegarde = chaine; |
|
chaine = (unsigned char *) malloc((strlen(chaine_sauvegarde) + 4) |
|
* sizeof(unsigned char)); |
|
|
|
if (chaine == NULL) |
|
{ |
|
(*s_etat_processus).erreur_systeme = |
|
d_es_allocation_memoire; |
|
return(NULL); |
|
} |
|
|
|
strcpy(chaine, chaine_sauvegarde); |
|
free(chaine_sauvegarde); |
|
strcat(chaine, " ]|"); |
|
} |
|
else if ((*s_objet).type == NON) |
|
{ |
|
if ((chaine = malloc((strlen("System object") + 1) |
|
* sizeof(unsigned char))) == NULL) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
|
return(NULL); |
|
} |
|
|
|
strcpy(chaine, "System object"); |
|
} |
|
else if ((*s_objet).type == EXT) |
|
{ |
|
l_element_courant = (*s_etat_processus).s_bibliotheques; |
|
|
|
while(l_element_courant != NULL) |
|
{ |
|
if ((*((struct_bibliotheque *) (*l_element_courant).donnee)) |
|
.descripteur == (*s_objet).descripteur_bibliotheque) |
|
{ |
|
if ((__type_disp = dlsym((*s_objet).descripteur_bibliotheque, |
|
"__type_disp")) == NULL) |
|
{ |
|
// Symbole externe non affichable |
|
|
|
if ((chaine = malloc((strlen( |
|
"External symbol (disp function not found)") + 1) |
|
* sizeof(unsigned char))) == NULL) |
|
{ |
|
(*s_etat_processus).erreur_systeme = |
|
d_es_allocation_memoire; |
|
return(NULL); |
|
} |
|
|
|
strcpy(chaine, "External symbol (disp function not found)"); |
|
} |
|
else |
|
{ |
|
// Symbole externe affichable |
|
void **arg; |
|
|
|
arg = (void **) &s_objet; |
|
__type_disp(s_etat_processus, arg); |
|
chaine = (unsigned char *) (*arg); |
|
} |
|
|
|
break; |
|
} |
|
|
|
l_element_courant = (*l_element_courant).suivant; |
|
} |
|
|
|
if (l_element_courant == NULL) |
|
{ |
|
// Symbole externe non affichable |
|
|
|
if ((chaine = malloc((strlen("External symbol") + 1) |
|
* sizeof(unsigned char))) == NULL) |
|
{ |
|
(*s_etat_processus).erreur_systeme = |
|
d_es_allocation_memoire; |
|
return(NULL); |
|
} |
|
|
|
strcpy(chaine, "External symbol"); |
|
} |
|
} |
|
else |
|
{ |
|
BUG(1, uprintf("Unknown symbol type\n")); |
} |
} |
|
|
return(chaine); |
return(chaine); |